Как я могу использовать последнюю бета-версию 302-версии драйвера nvidia (который наконец-то поддерживает расширение RandR!) С ядром реального времени в Precise?
Этот вопрос содержит информацию о включении текущей версии 295 для ядра 3.4 с исправлением RT. Но я ищу ответ, который устанавливает драйвер nvidia с помощью диспетчера пакетов, а не установщика nvidia (чьи установки иногда прерываются из-за перезаписи файлов системы управления пакетами).
Патч в этом вопросе для ядра 3.4 и так является тем ниже; исправленное в реальном времени ядро 3.4 требуется.
Новый драйвер nvidia 302 требует видео ABI, который обеспечивает сервер Xorg 1.12, и к сожалению Точный прибывает с сервером Xorg 1.11. Следующие инструкции включают добавление обрезных станков Xorg PPA как источник программного обеспечения для обеспечения сервера Xorg 1.12, и это представляет определенную угрозу поломки. Инструкции по удалению внизу, но прочитывают их для возможных отклонений там.
Создайте временный каталог и изменение в него с:
mkdir -p ~/tmp/nvidia_302_fixrt && cd ~/tmp/nvidia_302_fixrt
Загрузите nvidia-current_302*.deb с обрезных станков Xorg PPA путем просмотра пакетов для Точного под nvidia-graphics-driver_302* здесь. Во время этой записи прямая загрузка может быть выполнена с:
wget https://launchpad.net/~xorg-edgers/+archive/ppa/+files/nvidia-current_302.17-0ubuntu1~xedgers~precise1_amd64.deb
Извлеките .deb с:
dpkg-deb -x nvidia-current_*.deb deb_contents && dpkg-deb --control nvidia-current_*.deb deb_contents/DEBIAN
Добавьте патч к deb_contents/usr/src/nvidia-current*/patches
каталог путем вставки следующего в терминале:
d=$(echo deb_contents/usr/src/nvidia-current*/patches) ; cat > $d/buildfix_kernel_rt_3.4.patch <<'EOF'
diff -u a/conftest.sh b/conftest.sh
--- a/conftest.sh 2012-05-03 09:49:19.582854050 +0100
+++ b/conftest.sh 2012-05-03 09:52:58.524101586 +0100
@@ -95,7 +95,7 @@
fi
fi
- CFLAGS="$CFLAGS $OUTPUT_CFLAGS -I$HEADERS $AUTOCONF_CFLAGS"
+ CFLAGS="$CFLAGS $OUTPUT_CFLAGS -I$HEADERS -I$OUTPUT/arch/x86/include/generated $AUTOCONF_CFLAGS"
test_xen
@@ -965,11 +965,12 @@
#
echo "$CONFTEST_PREAMBLE
#include <linux/acpi.h>
+ #include <acpi/acpixf.h>
void conftest_acpi_walk_namespace(void) {
acpi_walk_namespace();
}" > conftest$$.c
- $CC $CFLAGS -c conftest$$.c > /dev/null 2>&1
+ #CC $CFLAGS -c conftest$$.c > /dev/null 2>&1
rm -f conftest$$.c
if [ -f conftest$$.o ]; then
@@ -980,6 +981,7 @@
echo "$CONFTEST_PREAMBLE
#include <linux/acpi.h>
+ #include <acpi/acpixf.h>
void conftest_acpi_walk_namespace(void) {
acpi_walk_namespace(0, NULL, 0, NULL, NULL, NULL, NULL);
}" > conftest$$.c
@@ -1604,6 +1606,9 @@
fi
fi
+ RET=0
+ SELECTED_MAKEFILE=Makefile.kbuild
+
if [ "$RET" = "0" ]; then
ln -s $SELECTED_MAKEFILE Makefile
exit 0
diff -u a/nv-linux.h b/nv-linux.h
--- a/nv-linux.h 2012-05-03 09:49:19.622853547 +0100
+++ b/nv-linux.h 2012-05-03 09:56:12.045668690 +0100
@@ -291,7 +291,18 @@
#endif
#endif
-#if defined(CONFIG_PREEMPT_RT)
+#if defined(CONFIG_PREEMPT_RT_FULL)
+typedef raw_spinlock_t nv_spinlock_t;
+#define NV_SPIN_LOCK_INIT(lock) raw_spin_lock_init(lock)
+#define NV_SPIN_LOCK_IRQ(lock) raw_spin_lock_irq(lock)
+#define NV_SPIN_UNLOCK_IRQ(lock) raw_spin_unlock_irq(lock)
+#define NV_SPIN_LOCK_IRQSAVE(lock,flags) raw_spin_lock_irqsave(lock,flags)
+#define NV_SPIN_UNLOCK_IRQRESTORE(lock,flags) \
+ raw_spin_unlock_irqrestore(lock,flags)
+#define NV_SPIN_LOCK(lock) raw_spin_lock(lock)
+#define NV_SPIN_UNLOCK(lock) raw_spin_unlock(lock)
+#define NV_SPIN_UNLOCK_WAIT(lock) raw_spin_unlock_wait(lock)
+#elif defined(CONFIG_PREEMPT_RT)
typedef atomic_spinlock_t nv_spinlock_t;
#define NV_SPIN_LOCK_INIT(lock) atomic_spin_lock_init(lock)
#define NV_SPIN_LOCK_IRQ(lock) atomic_spin_lock_irq(lock)
@@ -954,7 +965,9 @@
return ret;
}
-#if defined(CONFIG_PREEMPT_RT)
+#if defined(CONFIG_PREEMPT_RT_FULL)
+#define NV_INIT_MUTEX(mutex) sema_init(mutex,1)
+#elif defined(CONFIG_PREEMPT_RT)
#define NV_INIT_MUTEX(mutex) semaphore_init(mutex)
#else
#if !defined(__SEMAPHORE_INITIALIZER) && defined(__COMPAT_SEMAPHORE_INITIALIZER)
EOF
Добавьте патч к dkms.conf путем вставки этого в терминале:
d=$(echo deb_contents/usr/src/nvidia-current*) ; cat >> $d/dkms.conf <<'EOF'
PATCH_MATCH[1]="^3\.4.*(rt|realtime)"
PATCH[1]="buildfix_kernel_rt_3.4.patch"
EOF
Измените номер версии в deb_contents/DEBIAN/control путем издания:
sed -i 's/^\(Version: .*\)$/\1+rtfix/' deb_contents/DEBIAN/control
Повторно упакуйте драйвер с:
dpkg -b deb_contents nvidia-current_$(sed -n 's/^\(Version: *\)//p' deb_contents/DEBIAN/control)_amd64.deb
Добавьте обрезные станки Xorg PPA:
sudo add-apt-repository ppa:xorg-edgers/ppa && sudo apt-get update && sudo apt-get dist-upgrade
Установите локально измененный .deb с:
sudo dpkg -i nvidia-current_*+rtfix_*.deb
Обрезные станки Xorg, которые PPA обновит с более новыми версиями драйвера Nvidia, поскольку они выходят; необходимо будет повторить переупаковочные инструкции выше с каждым новым выпуском.
Необходимо смочь вернуться к nouveau
драйвер со следующим:
sudo apt-get remove nvidia-current
sudo apt-get install ppa-purge
sudo ppa-purge ppa:xorg-edgers/ppa
В моем случае этот процесс включил удаление wine
наряду с некоторыми i386 пакетами (который должен был быть понижен вместо этого). Опасаться ppa-purge
если Вы находитесь на amd64, так как он не в хороших отношениях с мультидугой (как обозначено в предупреждениях PPA); в моем случае результатом был надуманный вопрос (я просто переустановил wine
), но другие люди могли бы закончить с плохо поврежденными зависимостями в зависимости от того, что они установили.