valentyn@alsa-project.org
Questo è l'ALSA Sound driver mini-HOWTO. Vi fornisce informazioni sull'installazione e l'utilizzo dei driver audio ALSA per la vostra scheda audio. I driver ALSA sono driver audio completamente modulari che supportano kerneld o kmod. Sono compatibili con le API OSS e ne superano le possibilità. In altre parole: compatibili, ma migliori.
Questo documento contiene delle informazioni che ho preso dalle pagine del driver ALSA. La struttura è stata presa dal SB-mini-HOWTO, semplicemente perché assomigliava molto a quella che stavo cercando. Grazie al pacchetto SGML Tools, questo HOWTO è disponibile in diversi formati, tutti generati da un solo file sorgente. Grazie a Erik Warmelink per la rilettura, grazie a Alfred Munnikes per le sue domande ed i suoi suggerimenti sempre d'aiuto. Grazie a Yamahata Isaku per la traduzione Giapponese, Miodrag Vallat per la traduzione in Francese. Steve Crowder ha fatto un ottimo lavoro nella lettura e nella composizione dell'intero testo. Grazie a Marc-Aurele Darche, Piotr Ingling, Juergen Kahrs, Tim Pearce Patrick Stoddard, Rutger de Graaf, Shuly Wintner, Jyrki Saarela, Jonas Lofwander, Kumar Sankaran per i loro suggerimenti ed i loro contributi.
Versione 1.7 - Luglio 29, 1999. Qualche correzione.
Versione 1.6 - Luglio 26, 1999. Aggiunta una sezione sulle versioni di ALSA.
Versione 1.5 - Maggio 21, 1999. Modificata la sezione sul mixer, aggiunta una sezione di installazione rapida.
Versione 1.4 - Maggio 18, 1999. Inclusa la URL della versione Francese, cambiate altre URL.
Versione 1.3 - Maggio 16, 1999. Grazie a Jaroslav questo HOWTO ha trovato casa nel sito web del progetto ALSA. A causa di questo avvenimento sono stati modificati indirizzi web e di email.
Versione 1.2 - Maggio 11, 1999. Diversi aggiornamenti.
Versione 1.1 - Marzo 11, 1999. Aggiunte molte schede audio della nuova versione 0.3 dei driver, scritto qualcosa sul kernel versione 2.2.
Versione 1.0 - Febbraio 8, 1999. Aggiunte diverse cosa alla sezione di risoluzione dei problemi, ma sembra quasi completo.
Versione 0.3 beta - Gennaio 20, 1999. Link sulla homepage ALSA. Ah, siamo ufficiali!
Versione 0.2 alfa - Metà Gennaio 1999, prima versione .sgml.
Versione 0.1 alfa - Gennaio 1999, prima versione, più che altro HTML.
Ancora: vi prego di inviare qualsiasi patch in Inglese, you native speakers!
L'ultima versione può essere trovata su http://www.alsa-project.org./~valentyn
Altri formati (html, sgml, txt) sono nella directory other-formats. Sfortunatamente non sono riuscito a compilare una versione Postscript poiché lo script sgml2latex esce con un sacco di errori.
Yamahata Isaku ha tradotto in Giapponese questo documento che sarà disponibile sul sito giapponese del progetto ALSA http://plaza21.mbn.or.jp/~momokuri/alsa/index.html
Miodrag Vallat ha tradotto in Francese questo documento, traduzione che è disponibile su http://www.freenix.fr/unix/linux/HOWTO/mini/Alsa.html.
Se effettuate una traduzione di questo documento fatemelo sapere e includerò qui un riferimento alla traduzione.
Mi affido a te, lettore, per rendere utile questo HOWTO. Se avete suggerimenti, correzioni o commenti inviatemeli ( alsa-howto@alsa-project.org), e cercherò di inglobarli nella prossima revisione.
Nota bene: non ricevo molte mail riguardo i driver ALSA e quindi ogni cosa è benvenuta. anche un ``grazie per'' sarà apprezzato - magari non vi sarà di troppa fatica aggiungere una sezione ``mi è piaciuto di più'' o ``questo o quello non erano molto chiari''.
Se pubblicate questo documento su un CDROM o su altro supporto, una copia di cortesia sarebbe apprezzata. Scrivetemi per l'indirizzo postale. Considerate anche l'opportunità di effettuare una donazione per il Linux Documentation Project per aiutare la documentazione libera per Linux. Contattare il coordinatore dei Linux HOWTO, Tim Bynum linux-howto@metalab.unc.edu, per maggiori informazioni.
Copyright 1998/1999 Valentijn Sessink
This HOWTO is free documentation; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This document is distributed in the hope that it will be useful, but without any warranty; without even the implied warranty of merchantability or fitness for a particular purpose. See the GNU General Public License for more details.
You can obtain a copy of the GNU General Public License by writing to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
Se volete l'audio e lo volete ADESSO! e non dopo aver letto questo HOWTO, questa piccola panoramica dei driver ALSA potrebbe esservi di aiuto.
Le versioni 0.3.0, 0.3.1 e 0.3.2 dei driver ALSA hanno diversi problemi dovuti alla ristrutturazione dell'interfaccia mixer. Utilizzatene una versione differente (leggete la nota sulle versioni). Probabilmente vorrete utilizzare la versione 0.3.0-pre4.
È la solita roba ``./configure - make - make install''. Ripeterla per driver, librerie e programmi di utilità. Avrete bisogno di tutte e tre le cose, poiché le utilità vi aiuteranno a togliere il muting alla vostra scheda audio. I kernel 2.2.x devono avere compilato il supporto generico per il suono (senza specificare per quale scheda audio), mentre i kernel 2.0.x devono avere il supporto per il suono disabilitato.
I driver ALSA utilizzano i loro dispositivi, potete crearli con lo script ./snddevices.
Dovrete caricare il modulo per la vostra scheda audio (o utilizzare kmod) e se volete che il supporto per l'audio sia compatibile con i driver audio del kernel di Linux (sì che lo volete) avrete bisogno di un altro modulo che si chiama snd-pcm1-oss. Si veda la sezione Quale modulo per quale scheda per sapere quale modulo caricare. Dopo il caricamento potete dare un'occhiata in /proc/asound per avere diverse informazioni sui driver ALSA.
Qualche nota: ALSA utilizza i suoi dispositivi in /dev/snd, per esempio /dev/snd/pcmC0D1 è la scheda 0, dispositivo 1. Potrete usare i vecchi dispositivi /dev/pcmXY solo se avete caricato il modulo di compatibilità snd-pcm1-oss. Prima di poter riprodurre qualsiasi suono dovrete togliere il "mute" alla scheda con "amixer". Digitate "amixer", quindi provate qualcosa tipo:
amixer pcm 100 unmute
Generalmente potete utilizzare le opzioni ``mute'' o ``unmute'', ``rec'' o ``norec'', valori numerici o left:right.
Ecco fatto! Adesso, se funziona, bene. Altrimenti avrete veramente bisogno di leggere questo HOWTO...
Lo scopo di questo documento è quello di rendere più semplice l'installazione dei driver audio ALSA nel vostro sistema Linux. Il sistema di riferimento è quello formato dalla distribuzione Slackware 4.0 di Linux su un computer AMD/K6 (compatibile x86), ma dovrebbe funzionare con qualsiasi altra distribuzione di Linux. Non so se i driver ALSA funzionano anche su altre piattaforme ma, come dice la documentazione, sono stati testati con successo su Alpha. Io qui dispongo solo di PC x86, quindi ogni altra informazione aggiuntiva è bene accetta.
Potrebbe tornare utile la lettura del Linux Sound HOWTO (si veda la sezione Altri HOWTO), sebbene questo HOWTO sià focalizzato sui driver sonori distribuiti assieme al kernel.
Il driver audio ALSA è stato originariamente scritto come sostituzione del driver audio del kernel per le schede audio Gravis Ultrasound (GUS). Visto che questo driver di sostituzione per la GUS si è rivelato un successo, l'autore ha cominciato il progetto ALSA per un driver generico per diversi chip audio, con impostazione completamente modulare.
È compatibile con i driver audio OSS/Free e OSS/Linux (i driver del kernel), ma ha la sua propria interfaccia che è anche migliore di quella dei driver OSS. Un elenco delle funzioni presenti è disponibile su http://www.alsa-project.org/intro.html
Si noti che i driver ALSA sono ancora in fase di sviluppo. Le cose potrebbero cambiare nel tempo i programmi che si affidano ai driver ALSA funzionano solo con specifiche versioni dei driver. Al di là di questo, io credo che siano grandi! Li sto utilizzando da circa 10 mesi e non tornerò all'oscurantismo dei driver audio "closed source" (suggerimento) ;)
La pagina principale del progetto ALSA è http://www.alsa-project.org/
I driver ALSA supportano solo un sottoinsieme delle schede audio esistenti. Al momento in cui scrivo le schede audio seguenti sono supportate: (si noti che qualcuna fra queste può non essere disponibile nella versione 0.3.0-pre4, in questo caso dovrete usarel a 0.3.2 o successive).
Questo ALSA-sound-mini-HOWTO è solo un mini. Vi sono altri HOWTO che possono aiutarvi nel caso che questo sia troppo blando. Vi sono diversi aspetti che potreste incontrare durante l'installazione dei driver ALSA. Gli HOWTO possono generalmente essere trovati sui mirror di Metalab (il vecchio Sunsite). Date un'occhiata su http://metalab.unc.edu/LDP/mirrors.html e cercate il sito mirror a voi più vicino. Potrete trovare gli HOWTO nella directory LDP/HOWTO/. Nota bene: i collegamenti in questo documento saranno tutti relativi a /LDP/HOWTO/mini. Se avete trovato questo documento in un discreto sito mirror vi troverete anche gli HOWTO.
Adesso una nota per i kernel della serie 2.2.x. Per i kernel 2.2.x il supporto dell'audio è uguale ad ogni altro tipo di supporto: funziona, ma è differente da ciò che eravate abituati a fare. Questo HOWTO (come ogni altro HOWTO) si concentrerà sui kernel della serie 2.0, anche se cercherò di rimarcare le differenze. Sarò felice di aggiungere qualsiasi cosa posso aiutare questo HOWTO ad essere aggiornato con i kernel della serie 2.2.
Forse avete già comprato una scheda audio o forse è da tempo installata nel vostro computer. E adesso state per utilizzarla! Date un'occhiata al Sound-HOWTO per vedere se avrete dei problemi (potreste prima volere comprare la nuova Mega-Rumble-Blaster, poi provare i driver ALSA).
Molte moderne schede audio per la piattaforma Intel sono schede ISA PnP, che è l'abbreviazione di ''Plug and Play''. Questo significa che la scheda deve essere configurata dal sistema operativo. Ciò deve essere fatto attraverso una routine di inizializzazione al boot. Probabilmente avrete bisogno di configurare le vostre schede con il pacchetto PnP-utils. Ogni distribuzione di Linux recente include questi tool. Per l'utilizzo date un'occhiata al Plug-and-Play-HOWTO
Sembra che i driver ALSA abbiano un loro supporto interno per diverse schede ISA-PnP. Sfortunatamente non avendo trovato documentazione su questo aspetto, non posso dirvi come funziona. Se qualcuno vuole provare ad usare ALSA senza il tool ISA-PnP me lo faccia sapere.
I driver ALSA sono compilati come moduli. Qui potrete trovare maggiori informazioni sui moduli: Kernel-HOWTO. Vi è anche un Module-HOWTO ma al momento è senza un curatore; date un'occhiata alla sezione 'unmaintained' del Howto-HOWTO. Vi è un Modules-mini-HOWTO che comunque potrebbe essere utile.
Un altro HOWTO che potrebbe essere utile a qualcuno è il Kerneld-mini-HOWTO. Kerneld è un demone che installa e rimuove i moduli del kernel a seconda delle necessità. (Ho zero esperienza con questa cosa quindi ogni informazione aggiuntiva al riguardo è la benvenuta. La documentazione del driver ALSA contiene qualche informazione sulla configurazione di kerneld, queste sono state incluse nel presente mini-HOWTO.)
Se avete una scheda PnP, avrete anche bisogno di:
Si noti che non devono esserci driver audio attivi se volete usare i driver ALSA. Se avete un kernel che ha i driver audio compilati monoliticamente, dovrete ricompilarlo. Se avete il vecchio modulo "sound.o" attivo, dovrete disattivarlo. Se utilizzate kerneld, questo significa cancellare sound.o dalla directory /lib/modules/<kernel_version>/misc. I nuovi sistemi RedHat hanno un approccio al suono differente, che comporta l'attività contemporanea di diversi moduli audio. Dovrete disattivarli tutti.
I kernel della serie 2.2 hanno un nuovo approccio all'audio. Dovrete compilarli includendo il supporto sonoro! Sì, è così: aggiungete il supporto per l'audio al kernel ma non aggiungete supporto per alcuna scheda audio. Quindi compilate ed installate il kernel e, fatto questo, compilate i driver ALSA.
I driver ALSA sono disponibili su ftp://ftp.alsa-project.org/pub/ e sul sito mirror ftp://linux.a2000.nl/alsa. Per una installazione di ALSA completa avrete bisogno del driver, delle librerie e dei programmi di utilità; ad es. se scegliete il sito mirror dovrete prendere ftp://linux.a2000.nl/alsa/driver/alsa-driver-0.3.0-pre4.tar.gz, ftp://linux.a2000.nl/alsa/lib/alsa-lib-0.3.0pre4.tar.gz e ftp://linux.a2000.nl/alsa/utils/alsa-utils-0.3.0-pre4.tar.gz (NO, questi collegamenti non sono assoluti, meglio che diate un'occhiata sul sito principale per sapere quali versioni sono disponibili. Leggete la prossima sezione).
I driver ALSA hanno percorso un lungo cammino. Lo sviluppo è cominciato durante la versione 2.0 del kernel, poi sono arrivati i kernel 2.2 (con il loro kernel audio).
La versione attuale di ALSA sta subendo una ampia riscrittura dell'interfaccia mixer. Il vecchio mixer era la solita roba volume-in, bass/treble, volume-out mentre la nuova interfaccia consente di controllare l'entrata e l'uscita di ogni singolo elemento. In altre parole un programma dispone di un metodo per sapere se "l'uscita del CD è collegata all'entrata di registrazione". Il mixer è pronto, ma i vari programmi che lo supportano sono ancora in fase di costruzione.
Se volete utilizzare subito ALSA probabilmente vi conviene scegliere alsa-driver-0.3.0-pre4, alsa-lib-0.3.0-pre4 ed alsa-utils-0.3.0-pre3.
Le vecchie versioni, 0.2.0-pre10p3 e precedenti funzionano sotto 2.0.x, ma non sono riuscito a farle funzionare sotto 2.2.x (probabilmente a causa della mancanza di interfacciamento con il modulo soundcore del kernel).
La nuova versione (3.2.0) funziona e si compila sotto 2.0.x e 2.2.x. Si noti che questa sarà l'ultima versione che includerà il supporto per la serie 2.0 del kernel, quindi se vorrete usare una prossima versione dovrete fare il salto verso il 2.2.
Potete utilizzare la 0.3.2 se volete l'ultima e la più aggiornata ma potrebbe non essere la scelta migliore a causa della riscrittura dell'interfaccia mixer. Ho ravvisato dei problemi con il mixer OSS ed amixer ha una interfaccia completamente nuova che lo rende difficile da utilizzare.
I driver possono essere decompattati con comandi standard, tipo il solito tar -zxf <file>. Per i novellini e per chi soffre di amnesia:
cd /usr/src
tar -zxf ~/alsa-driver-0.3.0-pre4.tar.gz
(se questo comando ha funzionato siete collegati come utente root, che non è cosa buona, fermatevi qui e leggete il DOS/Win95-to-Linux-HOWTO, o avrete già pensato che questa è una cosa di amministrazione per la quale avrete bisogno dei privilegi di root. Quindi: vi servono i privilegi di root, date "su" e la password).
tar -zxf ~/alsa-lib-0.3.0pre4.tar.gz
tar -zxf ~/alsa-utils-0.3.0-pre4.tar.gz
Ugualmente funzionante e più divertente: find ~ -name alsa* -exec tar -zxf {} \;
(bambini, non fate questo a casa, è solo un esempio). Si noti che se si sono
scaricati i driver con Netscape, avreste potuto accidentalmente avere il file
dei driver decompressi con l'estensione ".tgz". Se tar si lamenta del formato
del file, forse avrete maggior fortuna togliendo la "z" dalle opzioni di tar.
Avrete bisogno dei driver prima di poter compilare ed utilizzare le librerie. Avrete bisogno delle librerie prima che possiate compilare o usare i programmi di utilità. Quindi andiamo a cominciare:
cd alsa-driver-0.3.0-pre4
(e per coloro senza molta esperienza: provate a premere <tab> (il tasto "tab") dopo "alsa-d". È la cosa chiamata command line completion). ("completamento della riga di comando", ndt.). Se volete utilizzare l'interfaccia PnP interna dovrete dare il comando
./configure --with-isapnp=yes
./configure
make
Adesso dovete essere 'root' per installare il tutto (probabilmente siete
già "root")
make install
Se questo comando vi dice qualcosa del tipo ``version.h'' cannot be found,
probabilmente i sorgenti del vostro kernel non sono del tutto a posto.
Avrete bisogno di diversi file sorgenti del kernel per compilare i driver
ALSA. Decompattate il vostro linux-2.x.y.tar.gz preferito in /usr/src e date
il comando make menuconfig
(in effetti potrebbe bastare
make symlinks
). Adesso compilate le librerie:
cd ../alsa-lib-0.3.0-pre4
./configure
make
make install
OK, adesso passiamo ai programmi di utilità:
cd ../alsa-utils-0.3.0-pre4
./configure
make
make install
Nota: potete anche non dare "make install" per i programmi di
utilità dapprima. Potreste anche tralasciare l'intero processo di
compilazione per le librerie e per i programmi di utilità per
controllare se i driver funzionano.
Vi è uno script nella directory dei driver che installerà i dispositivi sonori ALSA nella vostra directory /dev. Si dia il comando
./snddevices
nella directory dei driver. Vi dovrebbe essere una sottodirectory /dev/snd
adesso (si controlli se esiste. Se non avete familiarità nemmeno con il
comando "ls", prima prendete in considerazione la lettura degli altri
HOWTO. Dovreste avere una qualche conoscenza di Linux per installare questi
driver).
Adesso siete pronti a caricare il driver, quindi passate pure al prossimo paragrafo.
Vi sono due metodi per utilizzare i moduli sonori ALSA. Io personalmente preferisco adottare la soluzione manuale, nel senso che carico i moduli all'avvio. I driver ALSA sono stati progettati come moduli caricabili/scaricabili - non effettuano un reset del mixer dopo essere stati caricati - quindi si può facilmente utilizzare un approccio basato su kerneld.
Si legga la sezione Compatibilità all'indietro. Ne avrete bisogno per avere il supporto sonoro ``alla vecchia maniera''.
Nota: se avete una scheda audio PnP, dovrete prima impostarla sui giusti (o almeno conosciuti) IO/IRQ/DMA. Si consulti il Plug-and-Play-HOWTO. Avete configurato la vostra scheda audio Plug-and-Play ? Ok, allora continuate a leggere. La cosa principale è dare il comando "modprobe snd-<soundcard>". Questo dovrebbe mettere le cose a posto. Si noti che non tutte le distribuzioni includono /sbin nel vostro path. Se il comando restituisce "bash: modprobe: command not found", questo molto probabilmente significa che modprobe non è nel vostro path. Provate "/sbin/modprobe snd-sb16", o provate a cercare modprobe da qualche altra parte.
Le maggiori difficoltà risiedono nella configurazione dei chipset Crystal, per i quali i driver ALSA non prevedono l'impostazione automatica. Informazioni più attuali possono essere trovate nel file INSTALL nella directory dei driver. Due esempi ed una lista: Gravis UltraSound (GUS) e compatibili:
/sbin/modprobe snd-gusclassic
Per tutte le schede audio SoundBlaster a 16 bit (SoundBlaster 16 (PnP), SoundBlaster
AWE 32 (PnP), SoundBlaster AWE 64 (PnP):
/sbin/modprobe snd-sb16
modprobe snd-gusextreme
modprobe snd-gusmax
Schede audio ESS AudioDrive ES-1688 e ES-688
modprobe snd-audiodrive1688
ESS AudioDrive ES-18xx
modprobe snd-audiodrive18xx
Gravis UltraSound PnP, Dynasonic 3-D/Pro, STB Sound Rage 32, ExpertColor MED3201 altre schede audio basate sul chip AMD InterWave (R)
modprobe snd-interwave
UltraSound 32-Pro (scheda audio della STB usata da Compaq) ed altre schede basate sul chip AMD InterWave (tm) con il circuito TEA6330T per il controllo dei bassi, alti e del volume.
modprobe snd-interwave-stb
Schede Soundblaster a 8 bit (SoundBlaster 1.0, SoundBlaster 2.0, SoundBlaster Pro)
modprobe snd-sb8
Schede SoundBlaster a 16 bit (SoundBlaster 16 (PnP), SoundBlaster AWE 32 (PnP), SoundBlaster AWE 64 (PnP). Nota bene: questo modulo non supporta la scheda audio SoundBlaster VibraX16.
modprobe snd-sb16
modprobe snd-mozart
Diverse schede che utilizzano il chipset OPTi 82C9xx.
modprobe snd-opti9xx
modprobe snd-card-ad1848
Il solo "modprobe snd-opl3sa" non funzionerà, questo driver non effettua impostazioni automatiche. Si guardi più avanti.
Schede audio PCI S3 SonicVibes. (PINE Schubert 32 PCI)
modprobe snd-sonicvibes
Schede audio PCI Ensoniq AudioPCI ES1370/1371. (SoundBlaster PCI 64)
modprobe snd-audiopci
Il solo ``modprobe snd-card-cs4231'' non funzionerà, questo driver non effettua impostazioni automatiche. Si guardi più avanti.
Tutte le schede audio basate sui chip CS4232/CS4232A. Il solo "modprobe snd-card-cs4232" non funzionerà, a causa della mancanza dell'impostazione automatica. Si guardi più avanti.
Tutte le schede audio basate sui chip CS4235/CS4236/CS4236B/CS4237B/CS4238B/CS4239. Il solo "modprobe snd-card-cs4236" non funzionerà, a causa della mancanza dell'impostazione automatica. Si guardi più avanti.
modprobe snd-card-cs461x
Scheda ESS Solo-1, 128iPCI (es1938, ESS-SOLO-1). Questa non è nel file
INSTALL presente nella directory dei driver. Jonas Lofwander mi ha inviato la
locazione di un documento che vi aiuterà ad installare questa scheda che è,
alla fine, nulla più di una modprobe snd-esssolo1
... ma
http://195.163.39.4/~dice/alsa-solo1.txt potrà essere di aiuto
nell'utilizzo della versione 0.3.2 di amixer. Se avete un Thinkpad della IBM
potete anche consultare
http://www.geocities.com/SiliconValley/Peaks/3649/1412.html, grazie a
Kumar Sankaran.
Best Union Miss Melody 4DWave PCI, HIS 4DWave PCI, Warpspeed ONSpeed 4DWave PCI, AzTech PCI 64-Q3D, Addonics SV 750, CHIC True Sound 4Dwave, Shark Predator4D-PCI, Jaton SonicWave 4D. Questa scheda è supportata nella versione 0.3.2.
modprobe snd-trid4dwave
Queste sono le scheda audio basate sul chip FM801.
modprobe snd-card-fm801
Se utilizzate un driver senza impostazione automatica, dovrete fornire delle indicazioni aggiuntive al lancio del driver per permettergli di funzionare. Altre informazioni possono essere trovate nel file INSTALL presente nella directory dei driver.
Come dice il file INSTALL dovrete fornire tutte le indicazioni per permettere a questo driver di funzionare. Se la scheda è stata inizializzata con i tool isapnp, probabilmente potrete ottenere dal file /etc/isanp.conf maggiori informazioni sui seguenti valori:
snd_port - porta di controllo per il chip OPL3-SA
snd_wss_port - porta WSS per il chip OPL3-SA
(0x530,0xe80,0xf40,0x604)
snd_midi_port - porta per MPU-401 UART (0x300,0x330), -1 =
disabilitata
snd_fm_port -porta FM del chip OPL3-SA (0x388),-1 = disabilitata
snd_irq - IRQ del chip OPL3-SA (5,7,9,10)
snd_dma1 - primo DMA del chip Yamaha OPL3-SA (0,1,3)
snd_dma1_size - dimensione max primo DMA in kB (4-64kB)
snd_dma2 - secondo DMA del chip Yamaha OPL3-SA (0,1,3), -1
=disabilitato snd_dma2_size - dimensione max secondo DMA in
kB(4-64kB)
Potreste dare il comando "modprobe snd-opl3sa
snd_port=0xNNN snd_wss_port=0x530
snd_midi_port=-1 snd_fm_port=0x388
snd_irq=5 snd_dma1=0 snd_dma1_size=NN
snd_dma2=1 snd_dma2_size=NN" per caricare questo driver
(senza supporto per il midi. Sono ancora convinto del fatto che il supporto
per il midi vi serva solo quando avete dei sintetizzatori e altra roba e li
volete collegare al vostro sistema Linux. Non mi è mai servito il supporto per
il midi neanche quando riproduco dei file midi).
Si noti che il valore "NN" deve essere fornito, solo che non so quale potrebbe essere un valore ragionevole. Non so se il valore della dimensione del DMA sia assolutamente richiesto.
Se possedete un Thinkpad della IBM con questo chipset allora http://www.cirs.org/patrick/index.html potrebbe esservi di aiuto.
In accordo con il file INSTALL avrete bisogno di inserire la porta principale per questa scheda. Si noti che con il driver per le schede 3235/6/7/8/9, quello descritto qui sotto, ho finito con il fornire tutte le informazioni (tranne la dimensione del DMA), altrimenti il driver non avrebbe funzionato. Quindi potreste provare ad utilizzare l'intera linea di comando per caricare il driver. Se avete inizializzato la scheda con il tool isapnp probabilmente potrete avere maggiori informazioni dal file /etc/isapnp.conf sui valori delle seguenti impostazioni:
snd_port - porta del chip CS4232 (PnP setup - 0x534)
snd_mpu_port - porta dell'UART MPU-401 (PnP setup - 0x300),
-1 = disable snd_irq - IRQ del chip CS4232 (5,7,9,11,12,15)
snd_mpu_irq - IRQ dell'UART MPU-401 (9,11,12,15)
snd_dma1 - primo DMA del chip CS4232 (0,1,3)
snd_dma1_size - dimensione max. primo DMA in kB (4-64kB)
snd_dma2 - secondo DMA per chip Yamaha CS4232 (0,1,3), -1 = disabilita
snd_dma2_size - dimensione max. secondo DMA in kB (4-64kB)
Potete dare il comando "modprobe snd-card-cs4231
snd_port=0x534 snd_mpu_port=-1 snd_irq=5
snd_dma1=0 snd_dma1_size=NN snd_dma2=1
snd_dma2_size=NN" per caricare il driver in configurazione
standard. (Senza supporto per il MIDI, si veda la nota al chip Yamaha OPL-3).
Se avete utilizzato valori differenti in /etc/isapnp.conf dovrete usarli anche
qui) Nota: è saggio comunque usare il proprio cervello ;)
Si noti che il valore NN deve essere impostato, solamente che non so quali possano essere dei valori ragionevoli. Non so se serve specificare la dimensione del dma.
Secondo quello che dice il file INSTALL dovrete indicare la porta principale usata da questa scheda per farla funzionare. Si noti che con il driver per le schede 3235/6/7/8/9, quello sotto, ho finito con il fornire tutte le impostazioni (tranne il DMA-size), altrimenti il driver non ne voleva sapere di funzionare. Perciò si può usare l'intera linea di comando per caricare il driver. Se la scheda è stata inizializzata con il tool isapnp, potrete probabilmente ottenere maggiori informazioni dal file /etc/isapnp.conf sui seguenti valori:
snd_port - porta del chip CS4232 (PnP setup - 0x534)
snd_cport - porta di controllo del chip CS4232 (PnP setup - 0x120)
snd_mpu_port - porta UART MPU-401 (PnP setup - 0x300),-1 =
disabilitata
snd_fm_port - porta FM del chip CS4232 (PnP setup - 0x388), -1
= disabilitata
snd_jport - porta joystick del chip CS4232 (PnP setup - 0x200), -1 =
disabilitata
snd_irq - IRQ chip CS4232 (5,7,9,11,12,15)
snd_mpu_irq - IRQ MPU-401 UART (9,11,12,15)
snd_dma1 - primo DMA chip CS4232 (0,1,3)
snd_dma1_size - dim. max primo DMA in kB (4-64kB)
snd_dma2 - secondo DMA chip Yamaha CS4232 (0,1,3), -1 =
disable snd_dma2_size - dim. max secondo DMA in kB(4-64kB)
Potreste dare il comando "modprobe snd-card-cs4232
snd_port=0x534 snd_cport=0x120 snd_mpu_port=-1
snd_fm_port=0x388 snd_jport=-1 snd_irq=5
snd_dma1=0 snd_dma1_size=NN snd_dma2=1
snd_dma2_size=NN" per caricare il driver per una
scheda audio in "configurazione standard" (senza supporto per il MIDI,
si veda la nota al driver Yamaha OPL-3 e senza supporto per il joystick).
Se avete utilizzato valori differenti nel file /etc/isapnp.conf, potreste
anche utilizzare queste impostazioni (nota: la cosa più saggia da fare è
utilizzare il cervello ;).
Si noti che il valore "NN" deve essere specificato, solo che non so quali valori possono essere ragionevoli. Non so se è obbligatorio specificare la dimensione del dma.
In accordo con quanto asserisce il file INSTALL dovrete impostare il valore della porta principale e di quella di controllo di questa scheda. Si noti che con una scheda CS4237B ho finito con il fornire tutte le impostazioni necessarie (tranne la dimensione del DMA), altrimenti il driver si rifiutava di funzionare. Perciò dovreste utilizzare l'intera linea di comando per caricare il driver, e non specificare solamente la porta principale e quella di controllo. Se la scheda è stata inizializzata con i tool isapnp probabilmente si possono ottenere maggiori informazioni dal file /etc/isapnp.conf riguardo le seguenti impostazioni:
snd_port - porta del chip CS4232 (PnP setup - 0x534)
snd_cport - porta di controllo del chip CS4232 (PnP setup - 0x120)
snd_mpu_port - porta; della UART MPU-401 (PnP setup - 0x300),
-1 = disabilitata
snd_fm_port - porta FM del chip CS4232 (PnP setup - 0x388),
-1 = disabilitata
snd_jport - porta joystick del chip CS4232 (PnP setup - 0x200),
-1 = disabilitata
snd_irq - IRQ chip CS4232 (5,7,9,11,12,15)
snd_mpu_irq - IRQ della UART MPU-401 (9,11,12,15)
snd_dma1 - primo DMA del chip CS4232 (0,1,3)
snd_dma1_size - dim. max primo DMA in kB (4-64kB)
snd_dma2 - secondo DMA del chip Yamaha CS4232 (0,1,3),
-1 = disabilitato
snd_dma2_size - dim. max secondo DMA in kB (4-64kB)
Potreste usare il comando "modprobe snd-card-cs4236
snd_port=0x534 snd_cport=0x120 snd_mpu_port=-1
snd_fm_port=0x388 snd_jport=-1 snd_irq=5
snd_dma1=0 snd_dma1_size=NN snd_dma2=1
snd_dma2_size=NN" per caricare il driver (senza supporto per
il MIDI, se vedano le note al driver per Yamaha OPL-3, e senza supporto per
il joystick). Note:
kerneld
è un demone (daemon) che provvede al caricamento dei moduli su
richiesta, e al loro scaricamento dalla memoria quando essi non vengono
utilizzati. Poiché non ho alcuna esperienza sull'uso di kerneld, non so
se le informazioni che riporto sono accurate. Le informazioni provengono
dal file INSTALL del pacchetto ALSA-drivers. Informazioni eccellenti sul
kerneld possono essere trovate nel kerneld-mini-HOWTO.
Seguite questi passi:
Esempio di file /etc/conf.modules per una scheda audio Gravis UltraSound PnP:
alias char-major-14 snd
alias snd-minor-oss-0 snd-interwave
alias snd-minor-oss-3 snd-pcm1-oss
alias snd-minor-oss-4 snd-pcm1-oss
alias snd-minor-oss-5 snd-pcm1-oss
alias snd-minor-oss-12 snd-pcm1-oss
alias snd-card-0 snd-interwave
options snd snd_major=14 snd_cards_limit=1
options snd-interwave snd_index=1 snd_id="guspnp" snd_port=0x220 snd_irq=5
snd_dma1=5 snd_dma2=6
Esempio per l'utilizzo di più schede audio nella stessa macchina (la configurazione che segue è pensata per una Sound Blaster 16 e per una Gravis Ultrasound Classic):
alias char-major-14 snd
alias snd-minor-oss-0 snd-mixer
alias snd-minor-oss-3 snd-pcm1-oss
alias snd-minor-oss-4 snd-pcm1-oss
alias snd-minor-oss-5 snd-pcm1-oss
alias snd-minor-oss-12 snd-pcm1-oss
alias snd-card-0 snd-sb16
alias snd-card-1 snd-gusclassic
options snd snd_major=14 snd_cards_limit=2
options snd-sb16 snd_index=1 snd_port=0x220 snd_irq=5 snd_dma8=1 snd_dma16=5
options snd-gusclassic snd_index=2 snd_irq=11 snd_dma1=6 snd_dma2=7
Esempio per l'utilizzo di due schede Gravis UltraSound Classic:
alias char-major-14 snd
alias snd-minor-oss-0 snd-mixer
alias snd-minor-oss-3 snd-pcm1-oss
alias snd-minor-oss-4 snd-pcm1-oss
alias snd-minor-oss-5 snd-pcm1-oss
alias snd-minor-oss-12 snd-pcm1-oss
alias snd-card-0 snd-gusclassic
alias snd-card-1 snd-gusclassic
options snd snd_major=14 snd_cards_limit=2
options snd-gusclassic snd_index=1,2 snd_port=0x220,0x260 snd_irq=5,11
snd_dma1=5,6 snd_dma2=7,3
Se volete assicurarvi la compatibilità con OSS/Free e OSS/Linux dovrete caricare un ulteriore driver: il driver snd-pcm1-oss per la compatibilità con OSS. Date il comando
modprobe snd-pcm1-oss
Questo vi darà /dev/audio e /dev/dsp-support, come i driver OSS/Free (kernel)
e OSS/Linux (quello da $25). Si noti che questa è solo un'emulazione.
Adesso dovrete verificare su il driver audio è stato realmente caricato e quindi provare ad utilizzarlo.
Potete trovare molte informazioni utili sul vostro sistema nella sottodirectory /proc. /proc è un filesystem "virtuale", ciò significa che non esiste veramente, ma si riferisce solo ai vari processi e task del vostro computer. Affinché /proc funzioni dovrete aver compilato il supporto per esso nel kernel. Molte distribuzioni di Linux lo fanno in maniera predefinita, ma se avete compilato un kernel e lasciato fuori il supporto per /proc, ovviamente non vi sarà nulla in /proc.
/proc/modules vi fornisce informazioni su moduli in memoria. Una volta che i driver audio ALSA sono stati caricati, se date il comando cat /proc/modules dovreste vedere qualcosa tipo questo:
snd-pcm1-oss 4 0
snd-sb16 1 1
snd-sb-dsp 4 [snd-sb16] 0
snd-pcm1 4 [snd-pcm1-oss snd-sb-dsp] 0
snd-pcm 3 [snd-pcm1-oss snd-sb16 snd-sb-dsp snd-pcm1] 0
snd-mixer 3 [snd-pcm1-oss snd-sb16 snd-sb-dsp] 1
snd-mpu401-uart 1 [snd-sb16] 0
snd-midi 4 [snd-sb16 snd-sb-dsp snd-mpu401-uart] 0
snd-opl3 1 [snd-sb16] 0
snd-synth 1 [snd-sb16 snd-opl3] 0
snd-timer 1 [snd-opl3] 0
snd 8 [snd-pcm1-oss snd-sb16 snd-sb-dsp snd-pcm1 snd-pcm snd-mixer snd-mpu401-uart snd-midi snd-opl3 snd-synth snd-timer] 0
Se qualcosa è andata male durante l'installazione del driver, vedrete
un sacco di dispositivi "snd", ma il supporto per l'audio non sarà attivo.
Per esempio (Nota: non dovrete dare questo comando così come viene posto adesso, il driver cs4236 abbisogna delle opzioni):
win3:~# modprobe
snd-card-cs4236 /lib/modules/2.0.35/misc/snd-card-cs4236.o:
init_module: Device or resource busy snd-mixer: Device or resource busy
win3:~# cat /proc/modules
snd-cs4236 2 0
snd-cs4231 3 [snd-cs4236] 0
snd-timer 1 [snd-cs4231] 0
snd-pcm1 4 [snd-cs4236 snd-cs4231] 0
snd-mixer 3 [snd-cs4236 snd-cs4231] 0
snd-pcm 3 [snd-cs4236 snd-cs4231 snd-pcm1] 0
snd-mpu401-uart 1 0
snd-midi 4 [snd-mpu401-uart] 0
snd-opl3 1 0
snd-synth 1 [snd-opl3] 0
snd-timer 1 [snd-cs4231 snd-opl3] 0
snd 8 [snd-cs4231 snd-timer snd-pcm1 snd-mixer snd-pcm] 0
Potrete assicurarvi dell'esistenza di una scheda audio controllando /proc/asound/cards. Per esempio:
bash$ cat /proc/asound/cards
0 [card1 : SB16 - Sound Blaster 16
Sound Blaster 16 at 0x220, irq 5, dma 1&5
Nell'esempio precedente (dove ho dimenticato le opzioni) l'output sarebbe
dovuto essere:
win3:~# cat /proc/asound/cards
--- no soundcards ---
Una scheda CS4236 funzionante produrrebbe
0 [card1 ]: CS4236 - CS4237B
CS4237B at 0x534, irq 7, dma 1&0
Se avete controllato e ricontrollato le vostre impostazioni ed ancora non
vedete nessuna scheda, date un'occhiata alla sezione Risoluzione dei problemi.
La directory virtuale /proc/asound
fornisce molte altre informazioni
sul driver. Si noti che /proc/asound esiste solo dopo aver caricato il primo
modulo ALSA. Se non vi è una /proc/asound questo significa semplicemente che
il modulo "snd" non è stato correttamente caricato. Potrete identificare le
schede installate in /proc/asound/cards, e trovare le informazioni sulla
scheda0 in /proc/asound/0, /proc/asound/1 per la scheda1 ecc.
Se cat /proc/asound/card1/pcm0
mostra qualcosa del tipo
ES1370 DAC2/ADC
Playback isn't active.
Record isn't active.
questo significa che il vostro
driver è pronto a funzionare, ma in questo momento non sta facendo nulla
(quindi è andato tutto bene).
Per coloro che usano un kernel 2.0 vi è un terzo metodo per raccogliere informazioni sui dispositivi audio, più precisamente se avete caricato il driver OSS compatibile vi sarà un dispositivo /dev/sndstat. Il driver ALSA vi chiede gentilmente di non fare affidamento su queste informazioni poiché il dispositivo è presente solo per compatibilità con i driver OSS e informazioni più attendibili possono essere ottenute da /proc/asound/. Nei kernel 2.2.x ALSA utilizza il soundcore del kernel e quindi non può emulare il /dev/sndstat, poiché potrebbe interferire con i driver OSS.
Una volta che i driver per la vostra scheda audio sono stati installati e il vostro filesystem /proc vi assicura che tutto è andato a buon fine, potete provare a produrre qualche suono. Prima di tutto si installi il pacchetto dei programmi di utilità, o almeno si metta il comando "amixer" in qualche posto accettabile (tipo /usr/local/bin). Si dia un'occhiata alle impostazioni del mixer digitando "amixer". Questo comando mostra le impostazioni del mixer o, come vengono normalmente chiamate, i livelli di volume delle diverse parti della scheda audio. Per la mia Soundblaster 16 dice:
Master 0 % (-14.00dB) : 0 % (-14.00dB)
Bass 0 % (-14.00dB) : 0 % (-14.00dB)
Treble 0 % (-14.00dB) : 0 % (-14.00dB)
Synth 0 % (-62.00dB) : 0 % (-62.00dB)
PCM 0 % (-62.00dB) : 0 % (-62.00dB)
Line-In 0 % (-62.00dB) : 0 % (-62.00dB) Mute
MIC 0 % (-62.00dB) : 0 % (-62.00dB) Mute
CD 0 % (-62.00dB) : 0 % (-62.00dB) Mute
In-Gain 0 % (-18.00dB) : 0 % (-18.00dB)
Out-Gain 0 % (-18.00dB) : 0 % (-18.00dB)
PC Speaker 0 % (-18.00dB) : 0 % (-18.00dB)
La mia scheda basata sul Crystal 4237B ha molte altre opzioni:
Master D 0 % (-22.00dB) : 0 %
(-22.00dB) Mute 3D Center 0 % (-22.50dB) : 0 % (-22.50dB)
3D Space 0 % (-22.50dB) : 0 % (-22.50dB) Mute
Synth 0 % (-94.50dB) : 0 % (-94.50dB) Mute
FM 0 % (-94.50dB) : 0 % (-94.50dB) Mute
DSP 0 % (-94.50dB) : 0 % (-94.50dB) Mute
PCM 0 % (-94.50dB) : 0 % (-94.50dB) Mute
Line-In 0 % (-34.50dB) : 0 % (-34.50dB) Mute
MIC 0 % (-22.50dB) : 0 % (-22.50dB) Mute
CD 0 % (-34.50dB) : 0 % (-34.50dB) Mute
Record-Gain 0 % ( 0.00dB) : 0 % ( 0.00dB)
In-Gain 0 % (-18.00dB) : 0 % (-18.00dB)
Loopback 0 % (-94.50dB) : 0 % (-94.50dB) Mute
Mono 0 % (-45.00dB) : 0 % (-45.00dB) Mute
Aux A 0 % (-34.50dB) : 0 % (-34.50dB) Mute
Se tutto ciò che vedete è un messaggio del tipo ``amixer: Specify command...'' state utilizzando i nuovi programmi di utilità di ALSA 3.2. Vi serve questa versione per le versioni 0.3.0+ dei driver ma la loro documentazione è incompleta e l'interfaccia del mixer è ancora pesantemente beta; il mio suggerimento è di ritornare ad utilizzare la versione 0.3.0-pre4. Il nuovo amixer non ha ancora una pagina di manuale da consultare, quindi dovrete continuare da soli.
Avrete notato la voce "Mute" su qualche dispositivo. Questa significa che quel particolare dispositivo sarà escluso, qualunque sia il suo livello di volume. Il CS4237B la mette anche sul canale principale. Nel caso del CS4237B dovrei digitare
amixer "master d" unmute
per riuscire anche solo ad udire qualche suono. La Soundblaster non ha il mute sul canale di output ma
amixer master 100 unmute
porterà al 100% il volume e toglierà il "mute" dal canale principale. Potete utilizzare un numero o una parola come "mute" o "unmute" o tutti e due. Digitate
amixer "master d" 100; amixer pcm 100 unmute
per impostare il volume della scheda CS4237B al massimo volume del canale principale ed attivare il canale PCM e portarlo al massimo volume. Per separare le impostazioni L/R (Left/Right, Destra/Sinistra. ndt) utilizzate i due punti, per esempio
amixer CD 25:50
(No, non so quale dei due numeri corrisponda a destra e quale a sinistra ma lasciatemi dire che questo dipende pesantemente anche dalla posizione dei vostri speaker).
I vari componenti del mixer possono confondervi se non avete grosse conoscenze sulla produzione di audio digitale. Il Sound-HOWTO potrebbe aiutarvi e qui troverete una introduzione veramente minima.
Probabilmente avrete bisogno di pochi elementi del mixer: uno di questi è ``CD'' (regola il suono analogico proveniente dal vostro lettore di CD, diversi lettori di CD sono connessi con un cavo rosso/bianco/nero a 3 o 4 fili).
``PCM'' è utilizzato per molte applicazioni. I programmi come mpg123, xmms, speakfreely, realplayer ed altri utilizzano il canale PCM.
``MIC'' sta per microfono e ``line-in'' è un entrata (opzionale) extra della vostra scheda audio.
I vari ``gain'' ("guadagno" ndt) permettono di avere una ulteriore amplificazione per diversi utilizzi e si capiscono facilmente. (record-gain è una amplificazione extra del canale di registrazione, che può tornare utile se si utilizza un microfono).
Potete impostare il canale CD per la registrazione digitando
amixer cd rec
e toglierli questa opzione con
amixer cd norec
.
Se volete registrare qualcosa dal microfono potrete probabilmente digitare
amixer record-gain 100; amixer mic 100 rec mute
(l'utilizzo dell'input microfonico potrebbe generare del rumore ad alta frequenze se il suono rientrasse dagli speaker). Molti microfoni dispongono di una regolazione di ``gain'' per amplificarne il volume; probabilmente dovrete agire su questa per riuscire ad udire i suoni provenienti dal microfono.
Sfortunatamente non sono riuscito a modificare il volume delle impostazioni "3d center" e "3d space" con amixer. Se qualcuno ci riuscisse è pregato di farmelo sapere. A questo scopo può essere utilizzato alsamixer.
Le FAQ di ALSA dicono che è possibile ristabilire le impostazioni del mixer con
cat <file> > /proc/asound/#/mixerC0D0
, dove <file> è
l'output di /proc/asound/#/mixerC0D0. Non sono riuscito a far funzionare
questo metodo perché il mio sistema si lamenta riguardo a dei dispositivi
inesistenti.
I driver alsa dispongono di specifici dispositivi nella directory /dev/snd. Se disponete di una scheda potrete vedere seguenti dispositivi:
/dev/snd/pcmC0D0 - il dispositivo raw audio della scheda
/dev/snd/mixerC0D0 - il mixer della scheda 0
/dev/snd/controlC0D0 - il dispositivo di controllo della scheda 0
Il primo numero indica il numero della scheda audio, il secondo numero (se
c'è) è il numero del dispositivo. Una scheda audio con due dispositivi PCM
dovrebbe avere un dispositivo pcmC0D0 e pcmC0D1. Nota bene: i dispositivi ALSA
sono cambiati dalle precedenti versioni. I vecchi dispositivi ALSA
utilizzavano /dev/snd/pcm00 (il primo numero è la scheda, il secondo il
dispositivo). Se questo HOWTO usa la vecchia notazione, scrivetemi, così posso
correggerlo.
Adesso siete pronti a mettere un file audio nel dispositivo PCM della prima
scheda. Provate quindi a fare un cat di un qualsiasi file di testo (un file
qualunque) in /dev/snd/pcmC0D0, tipo: cat <nomefile> > /dev/snd/pcmC0D0
.
<nomefile> può essere un file qualsiasi, purché sia abbastanza lungo. Se avete
un file audio da qualche parte potete provare con quello. Potete anche
prendere il file che trovate su
http://www.ldp.org/sounds/english.au, è Linus Torvalds che dice come
si pronuncia Linux.
L'impostazione predefinita del vostro dispositivo audio è 8000 Hz, 8 bit. Questo significa che il file "english.au" di cui sopra riprodurrà il parlato e gli altri file di testo semplicemente del rumore. Se non riuscite a sentire nulla controllate i vostri speaker, provate di nuovo con "amixer" o consultate un medico (più avanti potrete facilmente utilizzare la vostra scheda a 48 Khz e 16 bit con il vostro player preferito, tipo sox o mpg123).
Se avete caricato il modulo "snd-pcm1-oss" potete anche usare la compatibilità con OSS per accedere alla vostra scheda. Sono utilizzati i seguenti mapping:
/dev/snd/pcmC0D0 -> /dev/audio0 (/dev/audio) -> minor 4
/dev/snd/pcmC0D0 -> /dev/dsp0 (/dev/dsp) -> minor 3
/dev/snd/pcmC0D1 -> /dev/adsp0 (/dev/adsp) -> minor 12
/dev/snd/pcmC1D0 -> /dev/audio1 -> minor 4+16 = 20
/dev/snd/pcmC1D0 -> /dev/dsp1 -> minor 3+16 = 19
/dev/snd/pcmC1D1 -> /dev/adsp1 -> minor 12+16 = 28
/dev/snd/pcmC2D0 -> /dev/audio2 -> minor 4+32 = 36
/dev/snd/pcmC2D0 -> /dev/dsp2 -> minor 3+32 = 35
/dev/snd/pcmC2D1 -> /dev/adsp2 -> minor 12+32 = 44
Il file INSTALL nella directory del driver ALSA contiene alcuni accorgimenti per far capire le impostazioni al driver. L'avere o meno bisogno di questi comandi dipenderà dall'applicazione che userete per riprodurre l'audio. Le normali applicazioni di riproduzione audio, come mpg123, sox (frequentemente associato al comando ``play''), o le applicazioni per X11 come RealPlayer probabilmente funzioneranno correttamente comunque. In ogni caso io non li ho mai utilizzati.
"Playback erase" - cancella tutte le informazioni aggiuntive
sulle applicazioni OSS
"Playback <app_name> <fragments> <fragment_size> [<options>]"
"Record erase" - cancella tutte le informazioni aggiuntive sulle applicazioni OSS
"Record <app_name> <fragments> <fragment_size> [<options>]"
<app_name>
- nome dell'applicazione con (a priorità più
alta) o senza percorso
<fragments>
- numero dei frammenti o zero per modalità automatica
<fragment_size>
- dimensione dei frammenti in byte o zero
per modalità automatica
<options>
- parametri opzionali
WR_ONLY
- se l'applicazione prova ad accedere al dispositivo
pcm con O_RDWR il driver lo cambia in O_WRONLY (riproduzione)
ottimo per Quake ecc.
Esempi:
echo "Playback x11amp 128 16384" > /proc/asound/0/pcm0o
echo "Playback squake 0 0 WR_ONLY" > /proc/asound/0/pcm0o
"Playback 8" -> il driver utilizzerà sempre il canale DMA a
8-bit per la riproduzione.
"Playback 16" -> il driver utilizzerà sempre il canale DMA a 16 bit per la
riproduzione.
"Playback auto" (predefinito) -> il driver utilizzerà l'impostazione
automatica (il primo canale aperto utilizzerà il canale DMA a 16 bit).
"Record 8" -> il driver utilizzerà sempre il canale DMA a 8 bit per la
registrazione.
"Record 16" -> il driver utilizzerà sempre il canale DMA a 16 bit per la
registrazione.
"Record auto" (predefinito) -> il driver utilizzerà l'impostazione automatica
(il primo canale aperto utilizzerà il canale DMA a 16 bit).
Esempio: echo "Record 16" > /proc/asound/0/sb16
Per altre informazioni si consulti il file INSTALL.
Si dia un'occhiata al file FAQ nella directory del driver audio. Questa sezione è ancora in lavorazione.
Se i vostri driver ALSA non si compilano correttamente e vi dicono delle cose
su ``version.h'' o altri file header che non riescono a trovare questo
potrebbe significare che non disponete dei file header del kernel. Date
un'occhiata al Kernel HOWTO, scompattate un kernel recente in /usr/src e date
il comando make config
.
Si controllino le seguenti cose..
Siete sicuri al 100% che la vostra scheda audio SIA supportata? Controllate di nuovo. A volte una X123 non è uguale ad una X123b e voi potreste solo perdere del tempo. D'altra parte anche una scheda supportata può darvi problemi - mi sono servite due ore per immaginarmi l'installazione di una CS4237B che, dopo tutto, si è dimostrata solo un esempio di RTFM (Acronimo di "Read The Fine Manual" (leggi il bel manuale) ndt).
Potreste avere un kernel 2.0.x con supporto per l'audio compilato nel kernel,
o il driver OSS/Lite (del kernel) potrebbero essere caricati (controllate con
il comando cat /proc/modules
). Rimuovete i driver o ricompilate il
kernel (date un'occhiata al Kernel-HOWTO).
Il modulo audio nella serie 2.0 del kernel si chiama ``sound.o'' e non dovrebbe essere attivo (il driver ALSA ``snd.o'' è comunque OK).
Se avete un kernel della serie 2.2.x senza driver audio compilato nel kernel, il driver ALSA comunque non funzionerà.
So che non è molto chiaro, quindi permettetemi di spiegarlo una volta ancora. Se avete un kernel della serie 2.0.x (il comando ``uname -a'' vi dice qualcosa del tipo ``Linux penguin 2.0.35 #6 Wed Sep 23 10:19:16 CEST 1998 i686 unknown'') dovete lasciare fuori i driver dal kernel.
Se avete un kernel della serie 2.2.x avrete bisogno dei driver audio. Un kernel della serie 2.2 dovrà essere compilato con il supporto per il suono ma senza il driver della scheda audio. Quindi selezionate il supporto per l'audio ma assicuratevi che nessuno specifico driver di scheda audio sarà compilato.
Un'altra ragione per la quale i driver potrebbero lamentarsi del fatto che il dispositivo sia occupato è che il file /etc/conf.modules contenga ancora dei riferimenti ai driver della scheda audio. Dovrete cancellarli e lasciare solo tutto ciò che si riferisce ai driver ALSA (sarebbe bene lasciare come sono i riferimenti a driver che non siano di dispositivi audio).
Un'altra sorgente di messaggi ``unresolved symbols'' potrebbe essere un nuovo kernel con i vecchi driver. Siete pregati di ricompilare i driver ALSA dopo aver ricompilato un nuovo kernel. Questo assicurerà la compatibilità tra i driver ed il nuovo kernel.
Siete sicuri che la vostra scheda audio sia attiva? Date un'ulteriore occhiata al PnP-HOWTO e controllate di aver attivato correttamente la vostra scheda audio.
Controllate e ricontrollate i parametri della vostra scheda audio. Nota bene: 534 non è come 543 e neppure 0x534 è uguale a 534.
Oltretutto qualche scheda audio potrebbe richiedere un driver diverso da quello che vi aspettereste. Fate una pausa, prendetevi una birra o qualchecos'altro e date ancora un'occhiata al comando ``modprobe''. Per esempio il driver per la Crystal 4232 dovrebbe essere caricato da modprobe snd-card-cs4232, e non ``snd-cs4231'', e la SoundBlaster PCI 64 deve essere caricata con ``snd-audiopci'', non con snd-es1370 (è tutto scritto nella documentazione ed anche se io ho scritto un HOWTO, mi è successo una volta di perdere un intero pomeriggio cercando di persuadere snd-cs4231 a produrre del suono).
I driver ALSA possono sfruttare la funzione di ``muting'' di cui molte schede audio dispongono. Se avete caricato i driver audio e tutto è andato bene ma non sentite altro che silenzio, probabilmente avete dimenticato di togliere il mute alla scheda. Avrete bisogno di ``amixer'' o ``alsamixer'' per farlo, potete trovarli tutti e due nel pacchetto ALSA-utilities. Digitate solamente
amixer -c 1 master 70:70 unmute
amixer -c 1 pcm 70:70 unmute
amixer -c 1 cd 70:70 unmute
dovrebbe funzionare per la maggior parte delle applicazioni.
Molte schede audio dispongono di un componente del mixer a parte per l'amplificazione delle entrate/uscite aggiuntive. Questo componente è spesso chiamato ``gain'', ``in-gain'' per le entrate ed ``out-gain'' per le uscite. L'impostazione di questo componente ad un livello adeguato vi permetterà di ottenere il massimo dai vostri speaker (pensate comunque ai vostri genitori/vicini/orecchie). Quindi un comando come
amixer out-gain 100 unmute
probabilmente vi sarà di aiuto.
Se questa è la prima volta che utilizzate i driver ALSA e prima usavate i
driver audio del kernel, probabilmente vorrete avere un driver audio che sia
compatibile con quello precedente (ad es. che utilizzi i dispositivi
/dev/pcmX). Dovrete caricare il ``driver di compatibilità OSS'' per ottenere
questo risultato. Date il comando modprobe snd-pcm1-oss
(date
un'occhiata alla sezione dove si parla di caricare il driver). Nota bene:
snd-pcm1-oss non è la stessa cosa di snd-pcm1, avete bisogno di
snd-pcm1-oss per avere un supporto audio vecchio stile.
Se avete provato ad installare diverse versioni differenti di ALSA a volte il mixer resta inaccessibile. Questo accade se avete provato la 0.3.2 e volete ritornare alla 0.3.0-pre4 (IIRC). Dovrete cancellare tutti i file libasound ed i link ad essi da /usr/lib e quindi ricompilare librerie e programmi di utilità:
rm /usr/lib/libasound.*
Solo per stare sicuri, cancellate tutti i driver ALSA quindi ricompilate,
installate e caricare i driver.
È sempre utile partire con il comando "insmod" invece che con kerneld. Avrete così modo di vedere i possibili errori sullo schermo.
Un sacco di informazioni potete trovarle nel file INSTALL presente nella directory dei driver. Se il vostro driver si rifiuta di funzionare dateci un'occhiata per vedere se ci sono informazioni aggiuntive.
Come ultima spiaggia potete ricompilare il driver impostandolo in modo tale da
inviare le informazioni di debug su /var/log/messages. Andate nella directory
del driver con cd /usr/src/alsa-driver-....
e digitate:
./configure --with-debug=detect; make clean; make
Rimuovete il driver (se esso è attivo si cerchi più avanti un comando per la rimozione). Si usi il comando di "modprobe" che avete dato prima per caricare il driver appena compilato. Date un'occhiata in /var/log/messages per vedere se vi sono messaggi.
Se questi messaggi non vi sono di aiuto, mandate un messaggio alla mailing list degli utenti di ALSA, alsa-user@alsa-project.org.
Accludete le seguenti informazioni:
Se trovate un bug gli sviluppatori di ALSA vorrebbero sapere (minimo) le seguenti cose:
Se utilizzare kmod/kerneld ed i driver ALSA per riprodurre i CD, probabilmente kmod/kerneld non carica i driver come dovrebbe. Questo è dovuto al fatto che un player di CD dice solo al CD di cominciare a riprodurre senza utilizzare alcuno dei dispositivi che avvisano kmod/kerneld della necessità del suono. L'utilizzo di modprobe potrebbe essere l'unica soluzione al vostro problema.
Normalmente la porta di IO del dispositivo seriale è di proprietà del driver del dispositivo seriale. Quindi prima di dare il comando ``modprobe snd-serial'' dovremmo dire al driver di rilasciare il dispositivo seriale.
Ecco la procedura.
setserial /dev/ttyS0 uart none
modprobe snd-serial
(Sostituire /dev/ttyS0 con il giusto dispositivo /dev/ttySx se il vostro MIDI utilizza un diverso dispositivo seriale).
Dopo aver aggiornato il vostro kernel probabilmente avrete bisogno di
ricompilare il driver ALSA. Se sono ancora nella directory originaria
/usr/src, non dimenticatevi di dare un make clean
prima di
./configure, make, make install.
Ah, vi è una anomalia nella numerazione dei kernel: lo script di configurazione dicd che un kernel ``2.2.0ac1'' è un ``not a number'' (non un numero, ndt). Penso che questo sia stato risolto nei nuovi script di configurazione altrimenti dovreste cambiare la versione del kernel nei sorgenti.
Supponete di avere KDE funzionante e di non riuscire però a far funzionare i suoni di sistema, come aprire le finestre, cambiare desktop ecc. L'audio funziona in generale. Se il vostro player cd e mp3 ed il mixer funzionano normalmente probabilmente quello che non funziona è solo "kwmsound".
Quindi: assicuratevi che "kwmsound" sia nello script di avvio ($KDEDIR/bin/startkde)
Se avevate già precedentemente il supporto per il suono nel vostro sistema Linux è probabile che tutte le vostre applicazioni puntino a /dev/pcm0, /dev/audio e /dev/mixer. Questo va bene, se utilizzate il modulo di compatibilità con OSS, snd-pcm1-oss. Potrebbe essere meglio utilizzare i dispositivi ALSA veri, quelli che trovate in /dev/snd/.
La rimozione di 10 o più moduli uno ad uno non è cosa buona. Fortunatamente tutti i moduli iniziano con il prefisso "snd-", quindi un po' di programmazione da riga di comando potrebbe fare al nostro caso. Potete facilmente rimuovere i driver ALSA con un comando di questo tipo:
cat /proc/modules|gawk '/^snd-/{print $1}|xargs -i rmmod {}
Juergen Kahrs scritto: ``Ho uno script che rimuove anche soundcore, soundlow e sound se sono presenti e se non sono utilizzati. Lo script processa /proc/modules tre volte quindi non dovrebbero esserci troppi moduli dopo la sua esecuzione''. Ecco la sua soluzione:
awk '/^snd/||/^sound/&&($3==0){system("rmmod " $1)}' /proc/modules /proc/modules /proc/modules
Nota bene: se qualche modulo dipende da qualche altro modulo non si può semplicemente rimuovere il modulo più "in alto". Questo significa che potreste aver bisogno di una seconda esecuzione del comando di rimozione (comunque non ho mai incontrato questa situazione, sembra quindi che i moduli ALSA possano essere rimossi nell'ordine in cui appaiono nel file /proc/modules).