Slackware: ATI SlackBuild (ITA): Difference between revisions
(Inserite le patch di Slacky.eu e fatte alcune correzioni) |
m (Protected "Slackware: ATI SlackBuild (ITA)": Excessive vandalism ([edit=autoconfirmed] (expires 14:05, 10 January 2013 (UTC)) [move=autoconfirmed] (expires 14:05, 10 January 2013 (UTC)))) |
||
(36 intermediate revisions by 16 users not shown) | |||
Line 1: | Line 1: | ||
<!-- Per http://wiki.cchtml.com --> | <!-- Per http://wiki.cchtml.com/index.php/Slackware:_ATI_SlackBuild_(ITA) --> | ||
= Introduzione = | = Introduzione = | ||
Questo wiki spiega come installare i driver propritari ATI con la distribuzione linux Slackware, creando, grazie ad uno SlackBuild, dei | Questo wiki spiega come installare i driver propritari ATI con la distribuzione linux Slackware, creando, grazie ad uno SlackBuild, dei pacchetti che possono essere installati tramite il comando '''installpkg'''. | ||
pacchetti che possono essere installati tramite il comando '''installpkg'''. | |||
Il wiki NON spiega come migliorare le prestazioni. In particolare fornisce solo una descrizione minimale di come impostare il server X.Org | Il wiki NON spiega come migliorare le prestazioni. In particolare fornisce solo una descrizione minimale di come impostare il server X.Org con l'unico scopo di far funzionare i driver proprietari (una descrizione su come configurare il server X.Org per ottenere prestazioni più elevate la potete trovare [http://www.slacky.eu/wikislack/index.php?title=Installazione_driver_ATI_su_Slackware_GNU/Linux qui]). | ||
con l'unico scopo di far funzionare i driver proprietari (una descrizione su come configurare il server X.Org per ottenere prestazioni | |||
più elevate la potete trovare [http://www.slacky.eu/wikislack/index.php?title=Installazione_driver_ATI_su_Slackware_GNU/Linux qui]). | |||
Tutti i comandi che iniziano con un '#>' devono essere eseguiti con i diritti dell'utente root, mentre quello che iniziano con '$>' possono | Tutti i comandi che iniziano con un '#>' devono essere eseguiti con i diritti dell'utente root, mentre quello che iniziano con '$>' possono essere eseguiti anche da un utente senza tali diritti. | ||
essere eseguiti anche da un utente senza tali diritti. | |||
= ATI Proprietary Driver e ATI Catalyst = | = ATI Proprietary Driver e ATI Catalyst = | ||
A partire dal 21 Novembre 2007 i driver ATI hanno cambiato nome e numero di versione. I nuovi driver, che prima venivano | A partire dal 21 Novembre 2007 i driver ATI hanno cambiato nome e numero di versione. I nuovi driver, che prima venivano indicati solo come '''ATI Proprietary Driver''', ora si chiamano '''ATI Catalyst'''. Non solo, il numero di versione è passato da '''8.XX.X''' a '''7.XX'''. | ||
indicati solo come '''ATI Proprietary Driver''', ora si chiamano '''ATI Catalyst'''. Non solo, il numero di versione | |||
è passato da '''8.XX.X''' a '''7.XX'''. | |||
Quando in questo articolo si parlerà dei driver ''versione < 8.37.6'', ci si riferirà implicitamente ai | Quando in questo articolo si parlerà dei driver ''versione < 8.37.6'', ci si riferirà implicitamente ai vecchi driver, ovvero agli ATI Proprietary Driver, i nuovi ATI Catalyst sono da considerarsi ''versione >= 8.37.6'', anche se, ad esempio, hanno come numero di release 7.11. | ||
vecchi driver, ovvero agli ATI Proprietary Driver, i nuovi ATI Catalyst sono da considerarsi ''versione >= 8.37.6'', | |||
anche se, ad esempio, hanno come numero di release 7.11. | |||
= Come ottenere tutto il software necessario = | = Come ottenere tutto il software necessario = | ||
L'installer può essere scaricato direttamente dal [http://support.amd.com/us/gpudownload/Pages/index.aspx sito ufficiale]. | |||
{{Warning|Attenzione|Se la versione dei driver che si è scaricata è minore della 8.37.6 allora dovete sapere fin d'ora che non funzioneranno con il server X.Org 7.2 (o 1.3) o successivi.}} | |||
{{Helpful Hint|Nota|I driver per le architetture x86 e x86_64 sono equivalenti. L'installer infatti contiene i file per entrambe le architetture, sarà poi il processo di compilazione e creazione dei pacchetti che sceglierà i file adeguati. | |||
Questo vuol dire che lo SlackBuild andrà bene sia per la Slackware sia la Slackware64, sia per le varie versioni porting a 64 bit (Slamd64, Bluewhite64, etc...).}} | |||
Dato che i driver contengono anche un modulo del kernel che verrà compilato direttamente sul vostro sistema, è necessario avere anche i sorgenti del kernel attualmente in uso. | |||
= Come creare i pacchetti per la Slackware = | = Come creare i pacchetti per la Slackware = | ||
== ATI Proprietary Driver o ATI Catalyst < 11.3 == | |||
Per questi driver lo SlackBuild produce due pacchetti (vedere [[#Cosa contengono i pacchetti creati?]]). | |||
=== Versione dei driver < 8.37.6 (SlackBuild esterno) === | |||
== Versione dei driver < 8.37.6 (SlackBuild esterno) == | |||
Per questi tipi di driver ho creato uno '''SlackBuild esterno''' per la Slackware di cui ho fatto [http://www.slacky.eu/~spina/fglrx/ati-slack-packager-1.1.9-noarch-1.tgz questo pacchetto]. | Per questi tipi di driver ho creato uno '''SlackBuild esterno''' per la Slackware di cui ho fatto [http://www.slacky.eu/~spina/fglrx/ati-slack-packager-1.1.9-noarch-1.tgz questo pacchetto]. | ||
Per creare i pacchetti Slackware basta eseguire: | Per creare i pacchetti Slackware basta eseguire: | ||
#> installpkg ati-slack-packager- | #> installpkg ati-slack-packager-1.1.9-noarch-1.tgz | ||
#> sh installer.run --buildpkg custom-package/Slackware | #> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg custom-package/Slackware | ||
== Versione dei driver >= 8.37.6 o nuovi ATI Catalyst (SlackBuild interno) == | === Versione dei driver >= 8.37.6 o nuovi ATI Catalyst (SlackBuild interno) === | ||
Per questi driver lo SlackBuild l'ho inviato direttamente alla ATI che ha provveduto ad inserirlo all'interno dell'installer, quindi basta | Per questi driver lo SlackBuild l'ho inviato direttamente alla ATI che ha provveduto ad inserirlo all'interno dell'installer, quindi basta eseguire: | ||
eseguire: | #> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg Slackware/All | ||
#> sh installer.run --buildpkg Slackware/All | o, se i driver sono abbastanza recenti, basta un semplice: | ||
o, se i driver sono abbastanza recenti | #> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg | ||
#> sh installer.run --buildpkg | Oppure, per creare ed installare direttamente i pacchetti, si può usare (sempre con versioni recenti dei driver): | ||
Oppure, per creare ed installare direttamente i pacchetti, si | |||
#> sh intaller.run --buildandinstallpkg | #> sh intaller.run --buildandinstallpkg | ||
= Cosa contengono i pacchetti creati? = | === Cosa contengono i pacchetti creati? === | ||
I due pacchetti creati dallo SlackBuild, che chiameremo ''fglrx-module'' e ''fglrx-x'', contengono, rispettivamente, il modulo per il | I due pacchetti creati dallo SlackBuild, che chiameremo ''fglrx-module'' e ''fglrx-x'', contengono, rispettivamente, il modulo per il kernel attualmente installato sul sistema, e i driver per la versione del server X.Org installata. In questo modo, se si aggiorna il kernel oppure il server X.Org si può creare solo il relativo pacchetto. | ||
kernel attualmente installato sul sistema, e i driver per la versione del server X.Org installata. | |||
In questo modo, se si aggiorna il kernel oppure il server X.Org si può creare solo il relativo pacchetto. | |||
== Creare solo il pacchetto fglrx-module == | ==== Creare solo il pacchetto fglrx-module ==== | ||
Per creare solo il pacchetto contenente il modulo per il kernel attualmente installato, basta lanciare l'installer con l'opzione | Per creare solo il pacchetto contenente il modulo per il kernel attualmente installato, basta lanciare l'installer con l'opzione ''Only_Module ''. | ||
''Only_Module ''. | |||
Quindi, con lo '''SlackBuild esterno''': | Quindi, con lo '''SlackBuild esterno''': | ||
#> sh installer.run --buildpkg custom-package/Only_Module | #> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg custom-package/Only_Module | ||
Con lo '''SlackBuild interno''': | Con lo '''SlackBuild interno''': | ||
#> sh installer.run --buildpkg Slackware/Only_Module | #> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg Slackware/Only_Module | ||
== Creare solo il pacchetto fglrx-x == | ==== Creare solo il pacchetto fglrx-x ==== | ||
Per creare solo il pacchetto contenente i driver per il server X.Org attualmente installato sul sistema, basta lanciare l'installer con | Per creare solo il pacchetto contenente i driver per il server X.Org attualmente installato sul sistema, basta lanciare l'installer con l'opzione ''Only_X''. | ||
l'opzione ''Only_X''. | |||
Con lo '''SlackBuild esterno''': | Con lo '''SlackBuild esterno''': | ||
#> sh installer.run --buildpkg custom-package/Only_X | #> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg custom-package/Only_X | ||
Con lo '''SlackBuild interno''': | Con lo '''SlackBuild interno''': | ||
#> sh installer.run --buildpkg Slackware/Only_X | #> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg Slackware/Only_X | ||
== ATI Catalyst >= 11.3 == | |||
A partire da questi driver lo '''SlackBuild interno''' produce un solo pacchetto, chiamato ''fglrx-<versione>-<architettura>-<release>.tgz'', che può essere creato con: | |||
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg | |||
Si può anche creare ed installare direttamente il pacchetto con: | |||
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildandinstallpkg | |||
= Configurazione minimale del server X.Org = | = Configurazione minimale del server X.Org = | ||
Una volta installati i due pacchetti bisogna segnalare al server X.Org di usare i driver proprietari ATI, per fare questo bisogna | Una volta installati i due pacchetti bisogna segnalare al server X.Org di usare i driver proprietari ATI, per fare questo bisogna controllare che il file xorg.conf, che generalmente è situato nella directory /etc/X11/, contenga le seguenti voci: | ||
controllare che il file xorg.conf, che generalmente è situato nella directory /etc/X11/, contenga le seguenti voci: | |||
Section "Module" | Section "Module" | ||
Line 108: | Line 84: | ||
Mode 0666 | Mode 0666 | ||
EndSection | EndSection | ||
{{Useful Information|Nota|Il comando: | |||
#> aticonfig --initial | |||
può essere di aiuto. Eseguire '''aticonfig''' senza opzioni per maggiori informazioni}} | |||
= Verifica = | = Verifica = | ||
Line 119: | Line 99: | ||
= Rimuovere i pacchetti installati = | = Rimuovere i pacchetti installati = | ||
Per rimuovere i pacchetti installati si può tranquillamente usare l' | == ATI Proprietary Driver o ATI Catalyst < 11.3 == | ||
considerati: | Per rimuovere i pacchetti installati si può tranquillamente usare l'utility '''removepkg'''. Ci sono però aspetti che vanno considerati: | ||
* La rimozione dei pacchetti non elimina i file di configurazione del driver fglrx, questi file sono situati nella directory ''/etc/ati'' | * La rimozione dei pacchetti non elimina i file di configurazione del driver fglrx, questi file sono situati nella directory ''/etc/ati'' | ||
{{Be Careful|Occhio|La directory ''/etc/ati/custom-package'' se esiste, contiene lo '''SlackBuild esterno''' e quindi non va cancellata.}} | |||
*Il pacchetto ''fglrx-x'' contiene le librerie OpenGL della ATI, e queste librerie sono posizionate nella stessa directory di quelle Mesa, indi per cui quando si installa il pacchetto ''fglrx-x'' vengono sovrascritte le OpenGL Mesa. Per ripristinare la situazione si deve semplicemente reinstallare il pacchetto contenente queste librerie, ovvero il pacchetto: | *Il pacchetto ''fglrx-x'' contiene le librerie OpenGL della ATI, e queste librerie sono posizionate nella stessa directory di quelle Mesa, indi per cui quando si installa il pacchetto ''fglrx-x'' vengono sovrascritte le OpenGL Mesa. Per ripristinare la situazione si deve semplicemente reinstallare il pacchetto contenente queste librerie, ovvero il pacchetto: | ||
::x11 | ::x11 | ||
Line 128: | Line 108: | ||
::mesa | ::mesa | ||
:se si usa la Slackware 12. | :se si usa la Slackware 12. | ||
== ATI Catalyst >= 11.3 == | |||
Durante l'installazione del pacchetto ''fglrx-<versione>-<architettura>-<release>.tgz'' alcune librerie che sarebbero sovrascritte vengono rinominate in FGL.renamed.nome_libreria. Per disinstallare il pacchetto in maniera "pulita" si dovrebbe eseguire il comando: | |||
#> aticonfig --uninstall | |||
oppure direttamente lo script: | |||
#> /usr/share/ati/amd-uninstall.sh | |||
o, ancora, con un qualsiasi installer >= 11.3, con: | |||
#> ati-driver-installer-<versione>-x86.x86_64.run --uninstall | |||
Dopo di ciò rimarrà solo la directory ''/etc/ati'' con i file di configurazione dei driver. | |||
= Patchare i driver = | = Patchare i driver = | ||
I driver ATI sono noti per essere sempre in ritardo rispetto all'aggiornamento del kernel linux. Spesso occorre quindi patchare i driver in modo tale che la creazione del modulo per il kernel abbia successo. A partire dagli ATI Catalist > 8.11 | I driver ATI sono noti per essere sempre in ritardo rispetto all'aggiornamento del kernel linux. Spesso occorre quindi patchare i driver in modo tale che la creazione del modulo per il kernel abbia successo. A partire dagli ATI Catalist > 8.11 ho inserito nello '''SlackBuild interno''' la possibilità di patchare i driver ATI prima che lo SlackBuild stesso esegua la compilazione del modulo per il kernel. | ||
Per fare questo basta creare (o scaricare da internet) una patch e dargli questo path: | Per fare questo basta creare (o scaricare da internet) una patch e dargli questo path: | ||
Line 139: | Line 128: | ||
ATI_DRIVER_VERSION deve essere uguale al risultato del comando: | ATI_DRIVER_VERSION deve essere uguale al risultato del comando: | ||
$> sh installer.run -i | head -n1 | cut -d'-' -f2 | $> sh ati-driver-installer-<versione>-x86.x86_64.run -i | head -n1 | cut -d'-' -f2 | ||
KERNEL_VERSION deve essere uguale al risultato del comando: | KERNEL_VERSION deve essere uguale al risultato del comando: | ||
$> uname -r | $> uname -r | ||
Line 145: | Line 134: | ||
se la directory ''/et/ati/patch'' non esiste, va ovviamente creata. | se la directory ''/et/ati/patch'' non esiste, va ovviamente creata. | ||
Quindi, ad esempio, se si il primo dei due comandi da come risultato '''8.56''' e il secondo '''2.6.27.6''', la patch va chiamata: ''/etc/ati/patch/patch-8.56-2.6.27.6'' | Quindi, ad esempio, se si il primo dei due comandi da come risultato '''8.56''' e il secondo '''2.6.27.6''', la patch va chiamata: ''/etc/ati/patch/patch-8.56-2.6.27.6''. | ||
Lo '''SlackBuild interno''' automaticamente noterà la patch, e, se si è in possesso del programma '''patch''', eseguirà: | Lo '''SlackBuild interno''' automaticamente noterà la patch, e, se si è in possesso del programma '''patch''', eseguirà: | ||
Line 179: | Line 168: | ||
#> sh ati-driver-installer-10-4-x86.x86_64.run --buildpkg | #> sh ati-driver-installer-10-4-x86.x86_64.run --buildpkg | ||
=== ATI Catalyst 10.9 e Slackware64 13.1 | === ATI Catalyst 10.9 e Slackware64 13.1 o current === | ||
Scaricate la [http://www.slacky.eu/~spina/fglrx/patch/fglrx_10.9_with_Slackware64-13.1.diff patch] nella directory ''/tmp'', quindi fate: | Scaricate la [http://www.slacky.eu/~spina/fglrx/patch/fglrx_10.9_with_Slackware64-13.1.diff patch] nella directory ''/tmp'', quindi fate: | ||
#> mkdir -p /etc/ati/patch/ | #> mkdir -p /etc/ati/patch/ | ||
Line 198: | Line 187: | ||
quindi inserire: | quindi inserire: | ||
./2.6.x/Makefile | ./2.6.x/Makefile | ||
=== ATI Catalyst 10.10, 10.11 e kernel == 2.6.36.x === | |||
Scaricate la [http://www.slacky.eu/~spina/fglrx/patch/fglrx_10.10-11_with_2.6.36.x.diff patch] nella directory ''/tmp'', quindi: | |||
* Per i '''Catalyst 10.10''' fate: | |||
#> mkdir -p /etc/ati/patch/ | |||
#> mv /tmp/fglrx_10.10-11_with_2.6.36.x.diff /etc/ati/patch/patch-8.783-$(uname -r) | |||
#> sh ati-driver-installer-10-10-x86.x86_64.run --buildpkg | |||
* Per i '''Catalyst 10.11''' fate: | |||
#> mkdir -p /etc/ati/patch/ | |||
#> mv /tmp/fglrx_10.10-11_with_2.6.36.x.diff /etc/ati/patch/patch-8.791-$(uname -r) | |||
#> sh ati-driver-installer-10-11-x86.x86_64.run --buildpkg | |||
=== ATI Catalyst 10.10, 10.11 e 10.12 e kernel == 2.6.37.x === | |||
Scaricate la [http://www.slacky.eu/~spina/fglrx/patch/fglrx_10.10-12_with_2.6.37.x.diff patch] nella directory ''/tmp'', quindi: | |||
* Per i '''Catalyst 10.10''' fate: | |||
#> mkdir -p /etc/ati/patch/ | |||
#> mv /tmp/fglrx_10.10-12_with_2.6.37.x.diff /etc/ati/patch/patch-8.783-$(uname -r) | |||
#> sh ati-driver-installer-10-10-x86.x86_64.run --buildpkg | |||
* Per i '''Catalyst 10.11''' fate: | |||
#> mkdir -p /etc/ati/patch/ | |||
#> mv /tmp/fglrx_10.10-12_with_2.6.37.x.diff /etc/ati/patch/patch-8.791-$(uname -r) | |||
#> sh ati-driver-installer-10-11-x86.x86_64.run --buildpkg | |||
* Per i '''Catalyst 10.12''' fate: | |||
#> mkdir -p /etc/ati/patch/ | |||
#> mv /tmp/fglrx_10.10-12_with_2.6.37.x.diff /etc/ati/patch/patch-8.801-$(uname -r) | |||
#> sh ati-driver-installer-10-12-x86.x86_64.run --buildpkg | |||
= Problemi noti = | = Problemi noti = | ||
== error: implicit declaration of function 'lock_kernel' and error: implicit declaration of function 'unlock_kernel' == | |||
Dovete abilitare l'opzione '''Big Kernel Lock''' nella vostra configurazione del kernel. La voce si trova nel menù '''Kernel hacking'''. Per controllare se questa opzione è abilitata potete fare: | |||
$> zcat /proc/config.gz | grep BKL | |||
CONFIG_BKL=y | |||
== FATAL: modpost: GPL-incompatible module fglrx.ko uses GPL-only symbol 'paravirt_ops' == | == FATAL: modpost: GPL-incompatible module fglrx.ko uses GPL-only symbol 'paravirt_ops' == | ||
L'errore accade in fase di compilazione del modulo ed è dovuto al fatto che il kernel è stato compilato con l'opzione di | L'errore accade in fase di compilazione del modulo ed è dovuto al fatto che il kernel è stato compilato con l'opzione di paravirtualizzazione attiva. Questa opzione tra le altre cose, impedisce di caricare, e quindi di compilare, moduli che non hanno la licenza GPL. Visto che i driver ATI non hanno questo tipo di licenza, non vengono compilati. | ||
paravirtualizzazione attiva. Questa opzione tra le altre cose, impedisce di caricare, e quindi di compilare, moduli che non hanno la | |||
licenza GPL. Visto che i driver ATI non hanno questo tipo di licenza, non vengono compilati. | |||
Per ovviare al problema si può: | Per ovviare al problema si può: | ||
Line 222: | Line 243: | ||
* Copiare la patch nella directory ''/etc/ati/patch'' (se non esiste, va creata) | * Copiare la patch nella directory ''/etc/ati/patch'' (se non esiste, va creata) | ||
Lo SlackBuild noterà la presenza della patch e la applicherà. Per disinstallare la patch | Lo SlackBuild noterà la presenza della patch e la applicherà. Per disinstallare la patch basterà quindi cancellarla. | ||
== Using GLX_SGIX_pbuffer FGLTexMgr: open of shared memory object failed (Permission denied) __FGLTexMgrCreateObject: __FGLTexMgrSHMmalloc failed!!! == | == Using GLX_SGIX_pbuffer FGLTexMgr: open of shared memory object failed (Permission denied) __FGLTexMgrCreateObject: __FGLTexMgrSHMmalloc failed!!! == | ||
Questo problema è dovuto alla mancanza nel sistema del filesystem SHM (oggi chiamato tmpfs), ovvero il virtual memory filesystem. | Questo problema è dovuto alla mancanza nel sistema del filesystem SHM (oggi chiamato tmpfs), ovvero il virtual memory filesystem. Per ovviare al problema si deve: | ||
Per ovviare al problema si deve: | |||
* Aggiungere al file ''/etc/fstab'' la seguente riga: | * Aggiungere al file ''/etc/fstab'' la seguente riga: | ||
shm | shm /dev/shm tmpfs defaults 0 0 | ||
* Quindi montare il filesystem tramite: | * Quindi montare il filesystem tramite: | ||
#> mount /dev/shm | #> mount /dev/shm | ||
Ovviamente il kernel deve essero predisposto al "montaggio" di questo filesystem, in particolare l'opzione del kernel che deve essere | Ovviamente il kernel deve essero predisposto al "montaggio" di questo filesystem, in particolare l'opzione del kernel che deve essere abilitata è '''CONFIG_TMPFS''' che generalmente è sistuata nel sottomenù del kernel '''File systems --> Pseudo filesystems'''. C'è da dire però che tutti i kernel precompilati hanno generalmente questa opzione abilitata. | ||
abilitata è '''CONFIG_TMPFS''' che generalmente è sistuata nel sottomenù del kernel '''File systems --> Pseudo filesystems'''. C'è da dire però che tutti i kernel precompilati hanno generalmente questa opzione abilitata. | |||
== kernel includes at /lib/modules/`uname -r`/build/include do not match current kernel == | == kernel includes at /lib/modules/`uname -r`/build/include do not match current kernel == | ||
Line 250: | Line 269: | ||
non puntano alla directory in cui sono inseriti i sorgenti del kernel attuale (che generalmente è /usr/src/linux-`uname -r`). Accade a coloro che usano uno dei kernel contenuto nella Slackware, per cui cercherò di spiegarlo in termini di "pacchetti" Slackware. Questo può succedere: | non puntano alla directory in cui sono inseriti i sorgenti del kernel attuale (che generalmente è /usr/src/linux-`uname -r`). Accade a coloro che usano uno dei kernel contenuto nella Slackware, per cui cercherò di spiegarlo in termini di "pacchetti" Slackware. Questo può succedere: | ||
* O perchè i sorgenti del kernel effettivamente non sono stati installati. In questo caso dovrebbe bastare installare il pacchetto dei sorgenti che si trova nella directory k/ della Slackware. Non è detto però che il problema venga risolto, si veda il secondo motivo per cui sussiste l'errore. | * O perchè i sorgenti del kernel effettivamente non sono stati installati. In questo caso dovrebbe bastare installare il pacchetto dei sorgenti che si trova nella directory k/ della Slackware. Non è detto però che il problema venga risolto, si veda il secondo motivo per cui sussiste l'errore. | ||
* O perchè i sorgenti (se pur installati) non rispecchiano le impostazioni dell'attuale kernel. La nuova Slackware 12 ha al suo interno un pò di kernel precompilati (che vuol dire impostazioni differenti) mentre un solo pacchetto per i sorgenti (a meno di vedere nel ramo extra/). In particolare i sorgenti sono per un kernel SMP e quindi se si utilizza un kernel precompilato non SMP può | * O perchè i sorgenti (se pur installati) non rispecchiano le impostazioni dell'attuale kernel. La nuova Slackware 12 ha al suo interno un pò di kernel precompilati (che vuol dire impostazioni differenti) mentre un solo pacchetto per i sorgenti (a meno di vedere nel ramo extra/). In particolare i sorgenti sono per un kernel SMP e quindi se si utilizza un kernel precompilato non SMP può accadere che si verifichi l'errore suddetto. Per ovviare basta fare quanto segue, dopo essersi assicurati che il pacchetto dei sorgenti è stato installato: | ||
#> cd /usr/src/linux | #> cd /usr/src/linux | ||
#> cp /boot/config .config | #> cp /boot/config .config | ||
#> make | #> make | ||
:eseguendo il make, oltre a compilare il kernel e relativi moduli (che poi non useremo), si rigenerano alcuni file headers che rispecchiano la configurazione del kernel (per come impostata nel file .config). | :eseguendo il make, oltre a compilare il kernel e relativi moduli (che poi non useremo), si rigenerano alcuni file headers che rispecchiano la configurazione del kernel (per come impostata nel file .config). | ||
<<edit by 414N>>: Questo problema può presentarsi anche in caso di kernel ricompilati manualmente ai quali si è aggiunta una qualche tag in fase di configurazione. | |||
Per risolvere è sufficiente un make prepare nella directory dei sorgenti del kernel in uso, in modo da avere gli header necessari allo script (make andrebbe a compilare tutto il kernel). | |||
== Logo nei driver 8.39.4 == | == Logo nei driver 8.39.4 == | ||
Line 269: | Line 291: | ||
Un alternativa ai driver ufficiali ATI: | Un alternativa ai driver ufficiali ATI: | ||
http://www. | http://www.x.org/wiki/radeon | ||
Una guida su come installare e configurare i driver (open source e proprietary) ATI: | Una guida su come installare e configurare i driver (open source e proprietary) ATI: | ||
http://www.slacky.eu/wikislack/index.php?title=Installazione_driver_ATI_su_Slackware_GNU/Linux | http://www.slacky.eu/wikislack/index.php?title=Installazione_driver_ATI_su_Slackware_GNU/Linux | ||
= | = Ringraziamenti = | ||
Ringrazio Ezio Ghibaudo e Federico Rota per aver iniziato questo wiki e per l'aiuto che mi hanno dato con lo SlackBuild. Vorrei anche ringraziare tutti gli utenti della community [http://www.slacky.eu Slacky] per i feedback e consigli. | |||
[[User:Spina|Spina]] |
Latest revision as of 14:05, 10 December 2012
Introduzione
Questo wiki spiega come installare i driver propritari ATI con la distribuzione linux Slackware, creando, grazie ad uno SlackBuild, dei pacchetti che possono essere installati tramite il comando installpkg.
Il wiki NON spiega come migliorare le prestazioni. In particolare fornisce solo una descrizione minimale di come impostare il server X.Org con l'unico scopo di far funzionare i driver proprietari (una descrizione su come configurare il server X.Org per ottenere prestazioni più elevate la potete trovare qui).
Tutti i comandi che iniziano con un '#>' devono essere eseguiti con i diritti dell'utente root, mentre quello che iniziano con '$>' possono essere eseguiti anche da un utente senza tali diritti.
ATI Proprietary Driver e ATI Catalyst
A partire dal 21 Novembre 2007 i driver ATI hanno cambiato nome e numero di versione. I nuovi driver, che prima venivano indicati solo come ATI Proprietary Driver, ora si chiamano ATI Catalyst. Non solo, il numero di versione è passato da 8.XX.X a 7.XX.
Quando in questo articolo si parlerà dei driver versione < 8.37.6, ci si riferirà implicitamente ai vecchi driver, ovvero agli ATI Proprietary Driver, i nuovi ATI Catalyst sono da considerarsi versione >= 8.37.6, anche se, ad esempio, hanno come numero di release 7.11.
Come ottenere tutto il software necessario
L'installer può essere scaricato direttamente dal sito ufficiale.
Attenzione: |
Se la versione dei driver che si è scaricata è minore della 8.37.6 allora dovete sapere fin d'ora che non funzioneranno con il server X.Org 7.2 (o 1.3) o successivi. |
Nota: |
I driver per le architetture x86 e x86_64 sono equivalenti. L'installer infatti contiene i file per entrambe le architetture, sarà poi il processo di compilazione e creazione dei pacchetti che sceglierà i file adeguati.
Questo vuol dire che lo SlackBuild andrà bene sia per la Slackware sia la Slackware64, sia per le varie versioni porting a 64 bit (Slamd64, Bluewhite64, etc...). |
Dato che i driver contengono anche un modulo del kernel che verrà compilato direttamente sul vostro sistema, è necessario avere anche i sorgenti del kernel attualmente in uso.
Come creare i pacchetti per la Slackware
ATI Proprietary Driver o ATI Catalyst < 11.3
Per questi driver lo SlackBuild produce due pacchetti (vedere #Cosa contengono i pacchetti creati?).
Versione dei driver < 8.37.6 (SlackBuild esterno)
Per questi tipi di driver ho creato uno SlackBuild esterno per la Slackware di cui ho fatto questo pacchetto.
Per creare i pacchetti Slackware basta eseguire:
#> installpkg ati-slack-packager-1.1.9-noarch-1.tgz #> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg custom-package/Slackware
Versione dei driver >= 8.37.6 o nuovi ATI Catalyst (SlackBuild interno)
Per questi driver lo SlackBuild l'ho inviato direttamente alla ATI che ha provveduto ad inserirlo all'interno dell'installer, quindi basta eseguire:
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg Slackware/All
o, se i driver sono abbastanza recenti, basta un semplice:
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg
Oppure, per creare ed installare direttamente i pacchetti, si può usare (sempre con versioni recenti dei driver):
#> sh intaller.run --buildandinstallpkg
Cosa contengono i pacchetti creati?
I due pacchetti creati dallo SlackBuild, che chiameremo fglrx-module e fglrx-x, contengono, rispettivamente, il modulo per il kernel attualmente installato sul sistema, e i driver per la versione del server X.Org installata. In questo modo, se si aggiorna il kernel oppure il server X.Org si può creare solo il relativo pacchetto.
Creare solo il pacchetto fglrx-module
Per creare solo il pacchetto contenente il modulo per il kernel attualmente installato, basta lanciare l'installer con l'opzione Only_Module .
Quindi, con lo SlackBuild esterno:
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg custom-package/Only_Module
Con lo SlackBuild interno:
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg Slackware/Only_Module
Creare solo il pacchetto fglrx-x
Per creare solo il pacchetto contenente i driver per il server X.Org attualmente installato sul sistema, basta lanciare l'installer con l'opzione Only_X.
Con lo SlackBuild esterno:
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg custom-package/Only_X
Con lo SlackBuild interno:
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg Slackware/Only_X
ATI Catalyst >= 11.3
A partire da questi driver lo SlackBuild interno produce un solo pacchetto, chiamato fglrx-<versione>-<architettura>-<release>.tgz, che può essere creato con:
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildpkg
Si può anche creare ed installare direttamente il pacchetto con:
#> sh ati-driver-installer-<versione>-x86.x86_64.run --buildandinstallpkg
Configurazione minimale del server X.Org
Una volta installati i due pacchetti bisogna segnalare al server X.Org di usare i driver proprietari ATI, per fare questo bisogna controllare che il file xorg.conf, che generalmente è situato nella directory /etc/X11/, contenga le seguenti voci:
Section "Module" .... Load "dri" Load "glx" .... EndSection
Section "Device" .... Driver "fglrx" .... EndSection
Section "DRI" Group 0 Mode 0666 EndSection
Invite You to Test Hosting Service
Hi, I'm Terra from the American Hosting Association.
I’m reaching out to you because we are looking for bloggers/site owners like you to test the Bluehost hosting service.
Bluehost is an excellent hosting service recommended by WordPress.org
Fr.ee WordPress Migration|30-Day Hosting Money-back Guarantee
You can visit https://www.myloginsecurity.com/hosting/ if you are interested.
Thank you for your time,
Terra Michealson
^^^^^^^^ Unsubscribe: https://www.myloginsecurity.com/unsubscribe
Verifica
Per verificare se i driver proprietari ATI sono stati correttamente installati si può eseguire il comando:
$> fglrxinfo
Sulla mia macchina l'output è:
display: :0.0 screen: 0 OpenGL vendor string: ATI Technologies Inc. OpenGL renderer string: ATI Mobility Radeon X1400 OpenGL version string: 2.0.6650 (8.39.4)
Rimuovere i pacchetti installati
ATI Proprietary Driver o ATI Catalyst < 11.3
Per rimuovere i pacchetti installati si può tranquillamente usare l'utility removepkg. Ci sono però aspetti che vanno considerati:
- La rimozione dei pacchetti non elimina i file di configurazione del driver fglrx, questi file sono situati nella directory /etc/ati
Occhio: |
La directory /etc/ati/custom-package se esiste, contiene lo SlackBuild esterno e quindi non va cancellata. |
- Il pacchetto fglrx-x contiene le librerie OpenGL della ATI, e queste librerie sono posizionate nella stessa directory di quelle Mesa, indi per cui quando si installa il pacchetto fglrx-x vengono sovrascritte le OpenGL Mesa. Per ripristinare la situazione si deve semplicemente reinstallare il pacchetto contenente queste librerie, ovvero il pacchetto:
- x11
- si usa la Slackware 11, oppure:
- mesa
- se si usa la Slackware 12.
ATI Catalyst >= 11.3
Durante l'installazione del pacchetto fglrx-<versione>-<architettura>-<release>.tgz alcune librerie che sarebbero sovrascritte vengono rinominate in FGL.renamed.nome_libreria. Per disinstallare il pacchetto in maniera "pulita" si dovrebbe eseguire il comando:
#> aticonfig --uninstall
oppure direttamente lo script:
#> /usr/share/ati/amd-uninstall.sh
o, ancora, con un qualsiasi installer >= 11.3, con:
#> ati-driver-installer-<versione>-x86.x86_64.run --uninstall
Dopo di ciò rimarrà solo la directory /etc/ati con i file di configurazione dei driver.
Patchare i driver
I driver ATI sono noti per essere sempre in ritardo rispetto all'aggiornamento del kernel linux. Spesso occorre quindi patchare i driver in modo tale che la creazione del modulo per il kernel abbia successo. A partire dagli ATI Catalist > 8.11 ho inserito nello SlackBuild interno la possibilità di patchare i driver ATI prima che lo SlackBuild stesso esegua la compilazione del modulo per il kernel.
Per fare questo basta creare (o scaricare da internet) una patch e dargli questo path:
/etc/ati/patch/patch-ATI_DRIVER_VERSION-KERNEL_VERSION
dove:
ATI_DRIVER_VERSION deve essere uguale al risultato del comando:
$> sh ati-driver-installer-<versione>-x86.x86_64.run -i | head -n1 | cut -d'-' -f2
KERNEL_VERSION deve essere uguale al risultato del comando:
$> uname -r
se la directory /et/ati/patch non esiste, va ovviamente creata.
Quindi, ad esempio, se si il primo dei due comandi da come risultato 8.56 e il secondo 2.6.27.6, la patch va chiamata: /etc/ati/patch/patch-8.56-2.6.27.6.
Lo SlackBuild interno automaticamente noterà la patch, e, se si è in possesso del programma patch, eseguirà:
#> patch -p0 < /etc/ati/patch/patch-8.56-2.6.27.6
Alcune patch
Di seguito alcune patch note e come usarle:
ATI Catalyst 10.3, 10.4 e kernel == 2.6.33.x
Scaricate la patch nella directory /tmp, quindi:
- Per i Catalyst 10.3 fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.3-4_with_2.6.33.x.diff /etc/ati/patch/patch-8.712-$(uname -r) #> sh ati-driver-installer-10-3-x86.x86_64.run --buildpkg
- Per i Catalyst 10.4 fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.3-4_with_2.6.33.x.diff /etc/ati/patch/patch-8.723-$(uname -r) #> sh ati-driver-installer-10-4-x86.x86_64.run --buildpkg
ATI Catalyst 10.4, 10.5 e kernel == 2.6.34
Scaricate la patch nella directory /tmp, quindi:
- Per i Catalyst 10.4 fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.4-5_with_2.6.34.diff /etc/ati/patch/patch-8.723-$(uname -r) #> sh ati-driver-installer-10-4-x86.x86_64.run --buildpkg
- Per i Catalyst 10.5 fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.4-5_with_2.6.34.diff /etc/ati/patch/patch-8.732-$(uname -r) #> sh ati-driver-installer-10-4-x86.x86_64.run --buildpkg
ATI Catalyst 10.9 e Slackware64 13.1 o current
Scaricate la patch nella directory /tmp, quindi fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.9_with_Slackware64-13.1.diff /etc/ati/patch/patch-8.771-$(uname -r) #> sh ati-driver-installer-10-9-x86.x86_64.run --buildpkg
ad un certo punto l'installazione chiede:
can't find file to patch at input line 4 Perhaps you should have used the -p or --strip option? The text leading up to this was: -------------------------- |diff -ru ./2.6.x/Makefile ../../../../../../fglrx-install.uZLF8t/common/lib/modules/fglrx/build_mod//2.6.x/Makefile |--- ./2.6.x/Makefile 2010-09-01 16:05:31.000000000 +0200 |+++ ../../../../../../fglrx-install.uZLF8t/common/lib/modules/fglrx/build_mod//2.6.x/Makefile 2010-09-23 08:47:24.000000000 +0200 -------------------------- File to patch:
quindi inserire:
./2.6.x/Makefile
ATI Catalyst 10.10, 10.11 e kernel == 2.6.36.x
Scaricate la patch nella directory /tmp, quindi:
- Per i Catalyst 10.10 fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.10-11_with_2.6.36.x.diff /etc/ati/patch/patch-8.783-$(uname -r) #> sh ati-driver-installer-10-10-x86.x86_64.run --buildpkg
- Per i Catalyst 10.11 fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.10-11_with_2.6.36.x.diff /etc/ati/patch/patch-8.791-$(uname -r) #> sh ati-driver-installer-10-11-x86.x86_64.run --buildpkg
ATI Catalyst 10.10, 10.11 e 10.12 e kernel == 2.6.37.x
Scaricate la patch nella directory /tmp, quindi:
- Per i Catalyst 10.10 fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.10-12_with_2.6.37.x.diff /etc/ati/patch/patch-8.783-$(uname -r) #> sh ati-driver-installer-10-10-x86.x86_64.run --buildpkg
- Per i Catalyst 10.11 fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.10-12_with_2.6.37.x.diff /etc/ati/patch/patch-8.791-$(uname -r) #> sh ati-driver-installer-10-11-x86.x86_64.run --buildpkg
- Per i Catalyst 10.12 fate:
#> mkdir -p /etc/ati/patch/ #> mv /tmp/fglrx_10.10-12_with_2.6.37.x.diff /etc/ati/patch/patch-8.801-$(uname -r) #> sh ati-driver-installer-10-12-x86.x86_64.run --buildpkg
Problemi noti
error: implicit declaration of function 'lock_kernel' and error: implicit declaration of function 'unlock_kernel'
Dovete abilitare l'opzione Big Kernel Lock nella vostra configurazione del kernel. La voce si trova nel menù Kernel hacking. Per controllare se questa opzione è abilitata potete fare:
$> zcat /proc/config.gz | grep BKL CONFIG_BKL=y
FATAL: modpost: GPL-incompatible module fglrx.ko uses GPL-only symbol 'paravirt_ops'
L'errore accade in fase di compilazione del modulo ed è dovuto al fatto che il kernel è stato compilato con l'opzione di paravirtualizzazione attiva. Questa opzione tra le altre cose, impedisce di caricare, e quindi di compilare, moduli che non hanno la licenza GPL. Visto che i driver ATI non hanno questo tipo di licenza, non vengono compilati.
Per ovviare al problema si può:
Disabilitare la paravirtualizzazione nel kernel
L'opzione di paravirtualizzazione si chiama CONFIG_PARAVIRT e generalmente si trova nel sottomenù Processor type and features del kernel.
Patchare i driver ATI
Questa operazione è illegale poichè si deve modificare il tipo di licenza rilasciata dalla ATI in GPL. Ho scritto la patch:
ati_to_gpl.patch (md5sum: 4207f41a71035dc2eed3ea9346b881bb)
di cui non mi prendo nessuna responsabilità, io non la uso e ne sconsiglio l'uso preferendo l'alternativa di disabilitare la paravirtualizzazione del kernel. Per usare questa patch bisogna:
SlackBuild esterno:
- Copiare la patch nella directory /etc/ati/custom-package/patch
SlackBuild interno (solo con ATI Catalist > 8.11):
- Copiare la patch nella directory /etc/ati/patch (se non esiste, va creata)
Lo SlackBuild noterà la presenza della patch e la applicherà. Per disinstallare la patch basterà quindi cancellarla.
Questo problema è dovuto alla mancanza nel sistema del filesystem SHM (oggi chiamato tmpfs), ovvero il virtual memory filesystem. Per ovviare al problema si deve:
- Aggiungere al file /etc/fstab la seguente riga:
shm /dev/shm tmpfs defaults 0 0
- Quindi montare il filesystem tramite:
#> mount /dev/shm
Ovviamente il kernel deve essero predisposto al "montaggio" di questo filesystem, in particolare l'opzione del kernel che deve essere abilitata è CONFIG_TMPFS che generalmente è sistuata nel sottomenù del kernel File systems --> Pseudo filesystems. C'è da dire però che tutti i kernel precompilati hanno generalmente questa opzione abilitata.
kernel includes at /lib/modules/`uname -r`/build/include do not match current kernel
L'errore completo è qualcosa del genere:
Error: kernel includes at /lib/modules/`uname -r`/build/include do not match current kernel. they are versioned as "" instead of "`uname -r`". you might need to adjust your symlinks: - /usr/include - /usr/src/linux
L'errore, se pur spiegato può non essere chiaro. In pratica deriva dal fatto che i link simbolici:
/lib/modules/`uname -r`/source /lib/modules/`uname -r`/build
non puntano alla directory in cui sono inseriti i sorgenti del kernel attuale (che generalmente è /usr/src/linux-`uname -r`). Accade a coloro che usano uno dei kernel contenuto nella Slackware, per cui cercherò di spiegarlo in termini di "pacchetti" Slackware. Questo può succedere:
- O perchè i sorgenti del kernel effettivamente non sono stati installati. In questo caso dovrebbe bastare installare il pacchetto dei sorgenti che si trova nella directory k/ della Slackware. Non è detto però che il problema venga risolto, si veda il secondo motivo per cui sussiste l'errore.
- O perchè i sorgenti (se pur installati) non rispecchiano le impostazioni dell'attuale kernel. La nuova Slackware 12 ha al suo interno un pò di kernel precompilati (che vuol dire impostazioni differenti) mentre un solo pacchetto per i sorgenti (a meno di vedere nel ramo extra/). In particolare i sorgenti sono per un kernel SMP e quindi se si utilizza un kernel precompilato non SMP può accadere che si verifichi l'errore suddetto. Per ovviare basta fare quanto segue, dopo essersi assicurati che il pacchetto dei sorgenti è stato installato:
#> cd /usr/src/linux #> cp /boot/config .config #> make
- eseguendo il make, oltre a compilare il kernel e relativi moduli (che poi non useremo), si rigenerano alcuni file headers che rispecchiano la configurazione del kernel (per come impostata nel file .config).
<<edit by 414N>>: Questo problema può presentarsi anche in caso di kernel ricompilati manualmente ai quali si è aggiunta una qualche tag in fase di configurazione. Per risolvere è sufficiente un make prepare nella directory dei sorgenti del kernel in uso, in modo da avere gli header necessari allo script (make andrebbe a compilare tutto il kernel).
Logo nei driver 8.39.4
Questo "bug" nei driver 8.39.4 deriva dal fatto che gli sviluppatori ATI non aggiornano i packager mantainer prima della release ufficiale. Sarebbe carino se facessero testare prima a noi le release ufficiali, in modo da certificare il corretto funzionamento degli script per creare i pacchetti. Per risolvere il problema si deve usare lo SlackBuild esterno come descritto qui.
amdcccle non parte con la Slackware 12
Molti utenti che utilizzano la versione del server X.Org 7.2 (o 1.3) non riescono a lanciare correttamente il Catalyst. Il comando per eseguire il Catalyst è:
#> amdcccle
Per questo problema sembra non esserci ancora soluzione, ma stiamo lavorando per risolverlo.
Link utili
Il thread di discussione da cui è stato tratto questo articolo: http://www.slacky.eu/forum/viewtopic.php?t=18134&highlight=
Un alternativa ai driver ufficiali ATI: http://www.x.org/wiki/radeon
Una guida su come installare e configurare i driver (open source e proprietary) ATI: http://www.slacky.eu/wikislack/index.php?title=Installazione_driver_ATI_su_Slackware_GNU/Linux
Ringraziamenti
Ringrazio Ezio Ghibaudo e Federico Rota per aver iniziato questo wiki e per l'aiuto che mi hanno dato con lo SlackBuild. Vorrei anche ringraziare tutti gli utenti della community Slacky per i feedback e consigli.