
Como posso usar o beta recente da versão 302 do driver nvidia (que finalmente suporta a extensão RandR!) com um kernel em tempo real no Precise?
Essa questãocontém informações sobre como habilitar a versão 295 atual para o kernel 3.4 com o patch RT. Mas estou procurando uma resposta que instale o driver da nvidia usando o gerenciador de pacotes em vez do instalador da nvidia (cujas instalações são interrompidas de vez em quando devido à substituição de arquivos pelo sistema de gerenciamento de pacotes).
Responder1
Aviso
O patch emessa questãoé para o kernel 3.4, assim como o abaixo; é necessário um kernel 3.4 com patch em tempo real.
O novo driver nvidia 302 requer a ABI de vídeo fornecida pelo xorg-server 1.12 e, infelizmente, o Precise vem com o xorg-server 1.11. As instruções a seguir envolvem adicionar oPPA xorg-edgerscomo 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 problemas.
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
Baixe nvidia-current_302*.deb do PPA xorg-edgers navegando nos pacotes do Precise em nvidia-graphics-driver_302*aqui. No momento em que este artigo 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
deb_contents/usr/src/nvidia-current*/patches
diretório 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 isto 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: .*\)$/\1+rtfix/' deb_contents/DEBIAN/control
Reempacote 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 versões mais recentes do driver nvidia à medida que forem lançadas; você precisará repetir as instruções de reembalagem acima a cada novo lançamento.
Desinstalando
Vocêdeveser capaz de reverter para o nouveau
driver 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, esse processo envolveu a desinstalação wine
junto com alguns pacotes i386 (que deveriam ter sido rebaixados). Tenha cuidado ppa-purge
se você estiver no AMD64, poisnão se dá bem com multiarch(conforme indicado nos avisos do PPA); no meu caso, o resultado não foi um problema (simplesmente reinstalei wine
), mas outras pessoas podem acabar com dependências muito quebradas, dependendo do que instalaram.