Использование бета-драйвера nvidia 302.xx с поддержкой RandR в 12.04 с ядром реального времени
Как я могу использовать последнюю бета-версию 302-версии драйвера nvidia (который наконец-то поддерживает расширение RandR!) С ядром реального времени в Precise?
Этот вопрос содержит информацию о включении текущей версии 295 для ядра 3.4 с исправлением RT. Но я ищу ответ, который устанавливает драйвер nvidia с помощью менеджера пакетов, а не установщика nvidia (чьи установки ломаются время от времени из-за перезаписи файлов системы управления пакетами).
1 ответ
Предупреждение
Патч в этом вопросе для ядра 3.4, как и приведенный ниже; требуется исправленное ядро 3.4.
Новый драйвер nvidia 302 требует видео ABI, которое предоставляет xorg-server 1.12, и, к сожалению, Precise поставляется с xorg-server 1.11. Следующие инструкции включают в себя добавление xorg-edgers PPA в качестве программного источника для обеспечения xorg-server 1.12, и это создает определенный риск поломки. Инструкции по удалению находятся внизу, но прочитайте их на предмет возможных ошибок.
инструкции
Модификация упакованного драйвера nvidia
Создайте временный каталог и перейдите в него:
mkdir -p ~/tmp/nvidia_302_fixrt && cd ~/tmp/nvidia_302_fixrt
Загрузите nvidia-current_302*.deb из PPA-пакета xorg-edgers, просмотрев пакеты для Precise в разделе 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
Установка PPA и модифицированного драйвера
Добавьте xorg-edgers 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
В ногу со временем
PPA xorg-edgers будет обновляться новыми версиями драйвера 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, поскольку он не очень хорошо ладит с multiarch (как указано в предупреждениях PPA); в моем случае результат был не проблема (я просто переустанавливал wine
), но другие люди могут столкнуться с сильно нарушенными зависимостями в зависимости от того, что они установили.