Aviso
O patch em esta questão é para o kernel 3.4, e assim é o abaixo; um kernel 3.4 atualizado em tempo real é necessário.
O novo driver nvidia 302 requer o vídeo ABI que o xorg-server 1.12 fornece e, infelizmente, o Precise vem com o xorg-server 1.11. As instruções a seguir envolvem adicionar o PPAs xorg-edgers como uma fonte de software para fornecer o xorg-server 1.12, e isso representa um certo risco de quebra. As instruções de desinstalação estão na parte inferior, mas leia-as para possíveis falhas aqui.
Instruções
Modificando o driver nvidia empacotado
-
Crie um diretório temporário e mude para ele com:
mkdir -p ~/tmp/nvidia_302_fixrt && cd ~/tmp/nvidia_302_fixrt
-
Faça o download do nvidia-current_302 * .deb do PPA do xorg-edgers navegando nos pacotes do Precise em nvidia-graphics-driver_302 * aqui . No momento em que este texto foi escrito, um download direto pode ser realizado com:
wget https://launchpad.net/~xorg-edgers/+archive/ppa/+files/nvidia-current_302.17-0ubuntu1~xedgers~precise1_amd64.deb
-
Extraia o .deb com:
dpkg-deb -x nvidia-current_*.deb deb_contents && dpkg-deb --control nvidia-current_*.deb deb_contents/DEBIAN
-
Adicione o patch ao diretório
deb_contents/usr/src/nvidia-current*/patches
colando o seguinte em um terminal: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
-
Adicione o patch ao dkms.conf colando-o em um terminal:
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
-
Modifique o número da versão em deb_contents / DEBIAN / control emitindo:
sed -i 's/^\(Version: .*\)$/+rtfix/' deb_contents/DEBIAN/control
-
Reembale o driver com:
dpkg -b deb_contents nvidia-current_$(sed -n 's/^\(Version: *\)//p' deb_contents/DEBIAN/control)_amd64.deb
Instalando o PPA e o driver modificado
-
Adicione o PPA xorg-edgers:
sudo add-apt-repository ppa:xorg-edgers/ppa && sudo apt-get update && sudo apt-get dist-upgrade
-
Instale o .deb modificado localmente com:
sudo dpkg -i nvidia-current_*+rtfix_*.deb
Manter-se atualizado
O PPA xorg-edgers será atualizado com as versões mais recentes do driver da nvidia quando elas forem lançadas; você precisará repetir as instruções de reempacotamento acima a cada nova versão.
Desinstalando
Você deve ser capaz de reverter para o driver nouveau
com o seguinte:
sudo apt-get remove nvidia-current
sudo apt-get install ppa-purge
sudo ppa-purge ppa:xorg-edgers/ppa
No meu caso, este processo envolveu a desinstalação de wine
juntamente com alguns pacotes i386 (que deveriam ter sido rebaixados). Desconfie de ppa-purge
se você estiver em amd64, pois não se dá bem com multiarch (conforme indicado nos avisos do PPA); no meu caso, o resultado foi um não-problema (eu simplesmente reinstalei o wine
), mas outras pessoas podem acabar com dependências gravemente quebradas, dependendo do que elas instalaram.