blob: 95c5443eff38b9853f2633302b174a038e85312a [file] [log] [blame]
Takashi Iwai7ddedeb2016-09-29 18:21:46 +02001======================
2Writing an ALSA Driver
3======================
4
5:Author: Takashi Iwai <tiwai@suse.de>
6:Date: Oct 15, 2007
7:Edition: 0.3.7
8
9Preface
10=======
11
12This document describes how to write an `ALSA (Advanced Linux Sound
13Architecture) <http://www.alsa-project.org/>`__ driver. The document
14focuses mainly on PCI soundcards. In the case of other device types, the
15API might be different, too. However, at least the ALSA kernel API is
16consistent, and therefore it would be still a bit help for writing them.
17
18This document targets people who already have enough C language skills
19and have basic linux kernel programming knowledge. This document doesn't
20explain the general topic of linux kernel coding and doesn't cover
21low-level driver implementation details. It only describes the standard
22way to write a PCI sound driver on ALSA.
23
24If you are already familiar with the older ALSA ver.0.5.x API, you can
25check the drivers such as ``sound/pci/es1938.c`` or
26``sound/pci/maestro3.c`` which have also almost the same code-base in
27the ALSA 0.5.x tree, so you can compare the differences.
28
29This document is still a draft version. Any feedback and corrections,
30please!!
31
32File Tree Structure
33===================
34
35General
36-------
37
38The ALSA drivers are provided in two ways.
39
40One is the trees provided as a tarball or via cvs from the ALSA's ftp
41site, and another is the 2.6 (or later) Linux kernel tree. To
42synchronize both, the ALSA driver tree is split into two different
43trees: alsa-kernel and alsa-driver. The former contains purely the
44source code for the Linux 2.6 (or later) tree. This tree is designed
45only for compilation on 2.6 or later environment. The latter,
46alsa-driver, contains many subtle files for compiling ALSA drivers
47outside of the Linux kernel tree, wrapper functions for older 2.2 and
482.4 kernels, to adapt the latest kernel API, and additional drivers
49which are still in development or in tests. The drivers in alsa-driver
50tree will be moved to alsa-kernel (and eventually to the 2.6 kernel
51tree) when they are finished and confirmed to work fine.
52
53The file tree structure of ALSA driver is depicted below. Both
54alsa-kernel and alsa-driver have almost the same file structure, except
55for “core” directory. It's named as “acore” in alsa-driver tree.
56
57::
58
59 sound
60 /core
61 /oss
62 /seq
63 /oss
64 /instr
65 /ioctl32
66 /include
67 /drivers
68 /mpu401
69 /opl3
70 /i2c
71 /l3
72 /synth
73 /emux
74 /pci
75 /(cards)
76 /isa
77 /(cards)
78 /arm
79 /ppc
80 /sparc
81 /usb
82 /pcmcia /(cards)
83 /oss
84
85
86core directory
87--------------
88
89This directory contains the middle layer which is the heart of ALSA
90drivers. In this directory, the native ALSA modules are stored. The
91sub-directories contain different modules and are dependent upon the
92kernel config.
93
94core/oss
95~~~~~~~~
96
97The codes for PCM and mixer OSS emulation modules are stored in this
98directory. The rawmidi OSS emulation is included in the ALSA rawmidi
99code since it's quite small. The sequencer code is stored in
100``core/seq/oss`` directory (see `below <#core-seq-oss>`__).
101
102core/ioctl32
103~~~~~~~~~~~~
104
105This directory contains the 32bit-ioctl wrappers for 64bit architectures
106such like x86-64, ppc64 and sparc64. For 32bit and alpha architectures,
107these are not compiled.
108
109core/seq
110~~~~~~~~
111
112This directory and its sub-directories are for the ALSA sequencer. This
113directory contains the sequencer core and primary sequencer modules such
114like snd-seq-midi, snd-seq-virmidi, etc. They are compiled only when
115``CONFIG_SND_SEQUENCER`` is set in the kernel config.
116
117core/seq/oss
118~~~~~~~~~~~~
119
120This contains the OSS sequencer emulation codes.
121
122core/seq/instr
123~~~~~~~~~~~~~~
124
125This directory contains the modules for the sequencer instrument layer.
126
127include directory
128-----------------
129
130This is the place for the public header files of ALSA drivers, which are
131to be exported to user-space, or included by several files at different
132directories. Basically, the private header files should not be placed in
133this directory, but you may still find files there, due to historical
134reasons :)
135
136drivers directory
137-----------------
138
139This directory contains code shared among different drivers on different
140architectures. They are hence supposed not to be architecture-specific.
141For example, the dummy pcm driver and the serial MIDI driver are found
142in this directory. In the sub-directories, there is code for components
143which are independent from bus and cpu architectures.
144
145drivers/mpu401
146~~~~~~~~~~~~~~
147
148The MPU401 and MPU401-UART modules are stored here.
149
150drivers/opl3 and opl4
151~~~~~~~~~~~~~~~~~~~~~
152
153The OPL3 and OPL4 FM-synth stuff is found here.
154
155i2c directory
156-------------
157
158This contains the ALSA i2c components.
159
160Although there is a standard i2c layer on Linux, ALSA has its own i2c
161code for some cards, because the soundcard needs only a simple operation
162and the standard i2c API is too complicated for such a purpose.
163
164i2c/l3
165~~~~~~
166
167This is a sub-directory for ARM L3 i2c.
168
169synth directory
170---------------
171
172This contains the synth middle-level modules.
173
174So far, there is only Emu8000/Emu10k1 synth driver under the
175``synth/emux`` sub-directory.
176
177pci directory
178-------------
179
180This directory and its sub-directories hold the top-level card modules
181for PCI soundcards and the code specific to the PCI BUS.
182
183The drivers compiled from a single file are stored directly in the pci
184directory, while the drivers with several source files are stored on
185their own sub-directory (e.g. emu10k1, ice1712).
186
187isa directory
188-------------
189
190This directory and its sub-directories hold the top-level card modules
191for ISA soundcards.
192
193arm, ppc, and sparc directories
194-------------------------------
195
196They are used for top-level card modules which are specific to one of
197these architectures.
198
199usb directory
200-------------
201
202This directory contains the USB-audio driver. In the latest version, the
203USB MIDI driver is integrated in the usb-audio driver.
204
205pcmcia directory
206----------------
207
208The PCMCIA, especially PCCard drivers will go here. CardBus drivers will
209be in the pci directory, because their API is identical to that of
210standard PCI cards.
211
212oss directory
213-------------
214
215The OSS/Lite source files are stored here in Linux 2.6 (or later) tree.
216In the ALSA driver tarball, this directory is empty, of course :)
217
218Basic Flow for PCI Drivers
219==========================
220
221Outline
222-------
223
224The minimum flow for PCI soundcards is as follows:
225
226- define the PCI ID table (see the section `PCI Entries`_).
227
228- create ``probe`` callback.
229
230- create ``remove`` callback.
231
232- create a :c:type:`struct pci_driver <pci_driver>` structure
233 containing the three pointers above.
234
235- create an ``init`` function just calling the
236 :c:func:`pci_register_driver()` to register the pci_driver
237 table defined above.
238
239- create an ``exit`` function to call the
240 :c:func:`pci_unregister_driver()` function.
241
242Full Code Example
243-----------------
244
245The code example is shown below. Some parts are kept unimplemented at
246this moment but will be filled in the next sections. The numbers in the
247comment lines of the :c:func:`snd_mychip_probe()` function refer
248to details explained in the following section.
249
250::
251
252 #include <linux/init.h>
253 #include <linux/pci.h>
254 #include <linux/slab.h>
255 #include <sound/core.h>
256 #include <sound/initval.h>
257
258 /* module parameters (see "Module Parameters") */
259 /* SNDRV_CARDS: maximum number of cards supported by this module */
260 static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;
261 static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR;
262 static bool enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP;
263
264 /* definition of the chip-specific record */
265 struct mychip {
266 struct snd_card *card;
267 /* the rest of the implementation will be in section
268 * "PCI Resource Management"
269 */
270 };
271
272 /* chip-specific destructor
273 * (see "PCI Resource Management")
274 */
275 static int snd_mychip_free(struct mychip *chip)
276 {
277 .... /* will be implemented later... */
278 }
279
280 /* component-destructor
281 * (see "Management of Cards and Components")
282 */
283 static int snd_mychip_dev_free(struct snd_device *device)
284 {
285 return snd_mychip_free(device->device_data);
286 }
287
288 /* chip-specific constructor
289 * (see "Management of Cards and Components")
290 */
291 static int snd_mychip_create(struct snd_card *card,
292 struct pci_dev *pci,
293 struct mychip **rchip)
294 {
295 struct mychip *chip;
296 int err;
297 static struct snd_device_ops ops = {
298 .dev_free = snd_mychip_dev_free,
299 };
300
301 *rchip = NULL;
302
303 /* check PCI availability here
304 * (see "PCI Resource Management")
305 */
306 ....
307
308 /* allocate a chip-specific data with zero filled */
309 chip = kzalloc(sizeof(*chip), GFP_KERNEL);
310 if (chip == NULL)
311 return -ENOMEM;
312
313 chip->card = card;
314
315 /* rest of initialization here; will be implemented
316 * later, see "PCI Resource Management"
317 */
318 ....
319
320 err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops);
321 if (err < 0) {
322 snd_mychip_free(chip);
323 return err;
324 }
325
326 *rchip = chip;
327 return 0;
328 }
329
330 /* constructor -- see "Driver Constructor" sub-section */
331 static int snd_mychip_probe(struct pci_dev *pci,
332 const struct pci_device_id *pci_id)
333 {
334 static int dev;
335 struct snd_card *card;
336 struct mychip *chip;
337 int err;
338
339 /* (1) */
340 if (dev >= SNDRV_CARDS)
341 return -ENODEV;
342 if (!enable[dev]) {
343 dev++;
344 return -ENOENT;
345 }
346
347 /* (2) */
348 err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
349 0, &card);
350 if (err < 0)
351 return err;
352
353 /* (3) */
354 err = snd_mychip_create(card, pci, &chip);
355 if (err < 0) {
356 snd_card_free(card);
357 return err;
358 }
359
360 /* (4) */
361 strcpy(card->driver, "My Chip");
362 strcpy(card->shortname, "My Own Chip 123");
363 sprintf(card->longname, "%s at 0x%lx irq %i",
364 card->shortname, chip->ioport, chip->irq);
365
366 /* (5) */
367 .... /* implemented later */
368
369 /* (6) */
370 err = snd_card_register(card);
371 if (err < 0) {
372 snd_card_free(card);
373 return err;
374 }
375
376 /* (7) */
377 pci_set_drvdata(pci, card);
378 dev++;
379 return 0;
380 }
381
382 /* destructor -- see the "Destructor" sub-section */
383 static void snd_mychip_remove(struct pci_dev *pci)
384 {
385 snd_card_free(pci_get_drvdata(pci));
386 pci_set_drvdata(pci, NULL);
387 }
388
389
390
391Driver Constructor
392------------------
393
394The real constructor of PCI drivers is the ``probe`` callback. The
395``probe`` callback and other component-constructors which are called
396from the ``probe`` callback cannot be used with the ``__init`` prefix
397because any PCI device could be a hotplug device.
398
399In the ``probe`` callback, the following scheme is often used.
400
4011) Check and increment the device index.
402~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
403
404::
405
406 static int dev;
407 ....
408 if (dev >= SNDRV_CARDS)
409 return -ENODEV;
410 if (!enable[dev]) {
411 dev++;
412 return -ENOENT;
413 }
414
415
416where ``enable[dev]`` is the module option.
417
418Each time the ``probe`` callback is called, check the availability of
419the device. If not available, simply increment the device index and
420returns. dev will be incremented also later (`step 7
421<#set-the-pci-driver-data-and-return-zero>`__).
422
4232) Create a card instance
424~~~~~~~~~~~~~~~~~~~~~~~~~
425
426::
427
428 struct snd_card *card;
429 int err;
430 ....
431 err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
432 0, &card);
433
434
435The details will be explained in the section `Management of Cards and
436Components`_.
437
4383) Create a main component
439~~~~~~~~~~~~~~~~~~~~~~~~~~
440
441In this part, the PCI resources are allocated.
442
443::
444
445 struct mychip *chip;
446 ....
447 err = snd_mychip_create(card, pci, &chip);
448 if (err < 0) {
449 snd_card_free(card);
450 return err;
451 }
452
453The details will be explained in the section `PCI Resource
454Management`_.
455
4564) Set the driver ID and name strings.
457~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
458
459::
460
461 strcpy(card->driver, "My Chip");
462 strcpy(card->shortname, "My Own Chip 123");
463 sprintf(card->longname, "%s at 0x%lx irq %i",
464 card->shortname, chip->ioport, chip->irq);
465
466The driver field holds the minimal ID string of the chip. This is used
467by alsa-lib's configurator, so keep it simple but unique. Even the
468same driver can have different driver IDs to distinguish the
469functionality of each chip type.
470
471The shortname field is a string shown as more verbose name. The longname
472field contains the information shown in ``/proc/asound/cards``.
473
4745) Create other components, such as mixer, MIDI, etc.
475~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
476
477Here you define the basic components such as `PCM <#PCM-Interface>`__,
478mixer (e.g. `AC97 <#API-for-AC97-Codec>`__), MIDI (e.g.
479`MPU-401 <#MIDI-MPU401-UART-Interface>`__), and other interfaces.
480Also, if you want a `proc file <#Proc-Interface>`__, define it here,
481too.
482
4836) Register the card instance.
484~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
485
486::
487
488 err = snd_card_register(card);
489 if (err < 0) {
490 snd_card_free(card);
491 return err;
492 }
493
494Will be explained in the section `Management of Cards and
495Components`_, too.
496
4977) Set the PCI driver data and return zero.
498~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
499
500::
501
502 pci_set_drvdata(pci, card);
503 dev++;
504 return 0;
505
506In the above, the card record is stored. This pointer is used in the
507remove callback and power-management callbacks, too.
508
509Destructor
510----------
511
512The destructor, remove callback, simply releases the card instance. Then
513the ALSA middle layer will release all the attached components
514automatically.
515
516It would be typically like the following:
517
518::
519
520 static void snd_mychip_remove(struct pci_dev *pci)
521 {
522 snd_card_free(pci_get_drvdata(pci));
523 pci_set_drvdata(pci, NULL);
524 }
525
526
527The above code assumes that the card pointer is set to the PCI driver
528data.
529
530Header Files
531------------
532
533For the above example, at least the following include files are
534necessary.
535
536::
537
538 #include <linux/init.h>
539 #include <linux/pci.h>
540 #include <linux/slab.h>
541 #include <sound/core.h>
542 #include <sound/initval.h>
543
544where the last one is necessary only when module options are defined
545in the source file. If the code is split into several files, the files
546without module options don't need them.
547
548In addition to these headers, you'll need ``<linux/interrupt.h>`` for
549interrupt handling, and ``<asm/io.h>`` for I/O access. If you use the
550:c:func:`mdelay()` or :c:func:`udelay()` functions, you'll need
551to include ``<linux/delay.h>`` too.
552
553The ALSA interfaces like the PCM and control APIs are defined in other
554``<sound/xxx.h>`` header files. They have to be included after
555``<sound/core.h>``.
556
557Management of Cards and Components
558==================================
559
560Card Instance
561-------------
562
563For each soundcard, a “card” record must be allocated.
564
565A card record is the headquarters of the soundcard. It manages the whole
566list of devices (components) on the soundcard, such as PCM, mixers,
567MIDI, synthesizer, and so on. Also, the card record holds the ID and the
568name strings of the card, manages the root of proc files, and controls
569the power-management states and hotplug disconnections. The component
570list on the card record is used to manage the correct release of
571resources at destruction.
572
573As mentioned above, to create a card instance, call
574:c:func:`snd_card_new()`.
575
576::
577
578 struct snd_card *card;
579 int err;
580 err = snd_card_new(&pci->dev, index, id, module, extra_size, &card);
581
582
583The function takes six arguments: the parent device pointer, the
584card-index number, the id string, the module pointer (usually
585``THIS_MODULE``), the size of extra-data space, and the pointer to
586return the card instance. The extra_size argument is used to allocate
587card->private_data for the chip-specific data. Note that these data are
588allocated by :c:func:`snd_card_new()`.
589
590The first argument, the pointer of struct :c:type:`struct device
591<device>`, specifies the parent device. For PCI devices, typically
592``&pci->`` is passed there.
593
594Components
595----------
596
597After the card is created, you can attach the components (devices) to
598the card instance. In an ALSA driver, a component is represented as a
599:c:type:`struct snd_device <snd_device>` object. A component
600can be a PCM instance, a control interface, a raw MIDI interface, etc.
601Each such instance has one component entry.
602
603A component can be created via :c:func:`snd_device_new()`
604function.
605
606::
607
608 snd_device_new(card, SNDRV_DEV_XXX, chip, &ops);
609
610This takes the card pointer, the device-level (``SNDRV_DEV_XXX``), the
611data pointer, and the callback pointers (``&ops``). The device-level
612defines the type of components and the order of registration and
613de-registration. For most components, the device-level is already
614defined. For a user-defined component, you can use
615``SNDRV_DEV_LOWLEVEL``.
616
617This function itself doesn't allocate the data space. The data must be
618allocated manually beforehand, and its pointer is passed as the
619argument. This pointer (``chip`` in the above example) is used as the
620identifier for the instance.
621
622Each pre-defined ALSA component such as ac97 and pcm calls
623:c:func:`snd_device_new()` inside its constructor. The destructor
624for each component is defined in the callback pointers. Hence, you don't
625need to take care of calling a destructor for such a component.
626
627If you wish to create your own component, you need to set the destructor
628function to the dev_free callback in the ``ops``, so that it can be
629released automatically via :c:func:`snd_card_free()`. The next
630example will show an implementation of chip-specific data.
631
632Chip-Specific Data
633------------------
634
635Chip-specific information, e.g. the I/O port address, its resource
636pointer, or the irq number, is stored in the chip-specific record.
637
638::
639
640 struct mychip {
641 ....
642 };
643
644
645In general, there are two ways of allocating the chip record.
646
6471. Allocating via :c:func:`snd_card_new()`.
648~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
649
650As mentioned above, you can pass the extra-data-length to the 5th
651argument of :c:func:`snd_card_new()`, i.e.
652
653::
654
655 err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
656 sizeof(struct mychip), &card);
657
658:c:type:`struct mychip <mychip>` is the type of the chip record.
659
660In return, the allocated record can be accessed as
661
662::
663
664 struct mychip *chip = card->private_data;
665
666With this method, you don't have to allocate twice. The record is
667released together with the card instance.
668
6692. Allocating an extra device.
670~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
671
672After allocating a card instance via :c:func:`snd_card_new()`
673(with ``0`` on the 4th arg), call :c:func:`kzalloc()`.
674
675::
676
677 struct snd_card *card;
678 struct mychip *chip;
679 err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
680 0, &card);
681 .....
682 chip = kzalloc(sizeof(*chip), GFP_KERNEL);
683
684The chip record should have the field to hold the card pointer at least,
685
686::
687
688 struct mychip {
689 struct snd_card *card;
690 ....
691 };
692
693
694Then, set the card pointer in the returned chip instance.
695
696::
697
698 chip->card = card;
699
700Next, initialize the fields, and register this chip record as a
701low-level device with a specified ``ops``,
702
703::
704
705 static struct snd_device_ops ops = {
706 .dev_free = snd_mychip_dev_free,
707 };
708 ....
709 snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops);
710
711:c:func:`snd_mychip_dev_free()` is the device-destructor
712function, which will call the real destructor.
713
714::
715
716 static int snd_mychip_dev_free(struct snd_device *device)
717 {
718 return snd_mychip_free(device->device_data);
719 }
720
721where :c:func:`snd_mychip_free()` is the real destructor.
722
723Registration and Release
724------------------------
725
726After all components are assigned, register the card instance by calling
727:c:func:`snd_card_register()`. Access to the device files is
728enabled at this point. That is, before
729:c:func:`snd_card_register()` is called, the components are safely
730inaccessible from external side. If this call fails, exit the probe
731function after releasing the card via :c:func:`snd_card_free()`.
732
733For releasing the card instance, you can call simply
734:c:func:`snd_card_free()`. As mentioned earlier, all components
735are released automatically by this call.
736
737For a device which allows hotplugging, you can use
738:c:func:`snd_card_free_when_closed()`. This one will postpone
739the destruction until all devices are closed.
740
741PCI Resource Management
742=======================
743
744Full Code Example
745-----------------
746
747In this section, we'll complete the chip-specific constructor,
748destructor and PCI entries. Example code is shown first, below.
749
750::
751
752 struct mychip {
753 struct snd_card *card;
754 struct pci_dev *pci;
755
756 unsigned long port;
757 int irq;
758 };
759
760 static int snd_mychip_free(struct mychip *chip)
761 {
762 /* disable hardware here if any */
763 .... /* (not implemented in this document) */
764
765 /* release the irq */
766 if (chip->irq >= 0)
767 free_irq(chip->irq, chip);
768 /* release the I/O ports & memory */
769 pci_release_regions(chip->pci);
770 /* disable the PCI entry */
771 pci_disable_device(chip->pci);
772 /* release the data */
773 kfree(chip);
774 return 0;
775 }
776
777 /* chip-specific constructor */
778 static int snd_mychip_create(struct snd_card *card,
779 struct pci_dev *pci,
780 struct mychip **rchip)
781 {
782 struct mychip *chip;
783 int err;
784 static struct snd_device_ops ops = {
785 .dev_free = snd_mychip_dev_free,
786 };
787
788 *rchip = NULL;
789
790 /* initialize the PCI entry */
791 err = pci_enable_device(pci);
792 if (err < 0)
793 return err;
794 /* check PCI availability (28bit DMA) */
795 if (pci_set_dma_mask(pci, DMA_BIT_MASK(28)) < 0 ||
796 pci_set_consistent_dma_mask(pci, DMA_BIT_MASK(28)) < 0) {
797 printk(KERN_ERR "error to set 28bit mask DMA\n");
798 pci_disable_device(pci);
799 return -ENXIO;
800 }
801
802 chip = kzalloc(sizeof(*chip), GFP_KERNEL);
803 if (chip == NULL) {
804 pci_disable_device(pci);
805 return -ENOMEM;
806 }
807
808 /* initialize the stuff */
809 chip->card = card;
810 chip->pci = pci;
811 chip->irq = -1;
812
813 /* (1) PCI resource allocation */
814 err = pci_request_regions(pci, "My Chip");
815 if (err < 0) {
816 kfree(chip);
817 pci_disable_device(pci);
818 return err;
819 }
820 chip->port = pci_resource_start(pci, 0);
821 if (request_irq(pci->irq, snd_mychip_interrupt,
822 IRQF_SHARED, KBUILD_MODNAME, chip)) {
823 printk(KERN_ERR "cannot grab irq %d\n", pci->irq);
824 snd_mychip_free(chip);
825 return -EBUSY;
826 }
827 chip->irq = pci->irq;
828
829 /* (2) initialization of the chip hardware */
830 .... /* (not implemented in this document) */
831
832 err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops);
833 if (err < 0) {
834 snd_mychip_free(chip);
835 return err;
836 }
837
838 *rchip = chip;
839 return 0;
840 }
841
842 /* PCI IDs */
843 static struct pci_device_id snd_mychip_ids[] = {
844 { PCI_VENDOR_ID_FOO, PCI_DEVICE_ID_BAR,
845 PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0, },
846 ....
847 { 0, }
848 };
849 MODULE_DEVICE_TABLE(pci, snd_mychip_ids);
850
851 /* pci_driver definition */
852 static struct pci_driver driver = {
853 .name = KBUILD_MODNAME,
854 .id_table = snd_mychip_ids,
855 .probe = snd_mychip_probe,
856 .remove = snd_mychip_remove,
857 };
858
859 /* module initialization */
860 static int __init alsa_card_mychip_init(void)
861 {
862 return pci_register_driver(&driver);
863 }
864
865 /* module clean up */
866 static void __exit alsa_card_mychip_exit(void)
867 {
868 pci_unregister_driver(&driver);
869 }
870
871 module_init(alsa_card_mychip_init)
872 module_exit(alsa_card_mychip_exit)
873
874 EXPORT_NO_SYMBOLS; /* for old kernels only */
875
876Some Hafta's
877------------
878
879The allocation of PCI resources is done in the ``probe`` function, and
880usually an extra :c:func:`xxx_create()` function is written for this
881purpose.
882
883In the case of PCI devices, you first have to call the
884:c:func:`pci_enable_device()` function before allocating
885resources. Also, you need to set the proper PCI DMA mask to limit the
886accessed I/O range. In some cases, you might need to call
887:c:func:`pci_set_master()` function, too.
888
889Suppose the 28bit mask, and the code to be added would be like:
890
891::
892
893 err = pci_enable_device(pci);
894 if (err < 0)
895 return err;
896 if (pci_set_dma_mask(pci, DMA_BIT_MASK(28)) < 0 ||
897 pci_set_consistent_dma_mask(pci, DMA_BIT_MASK(28)) < 0) {
898 printk(KERN_ERR "error to set 28bit mask DMA\n");
899 pci_disable_device(pci);
900 return -ENXIO;
901 }
902
903
904Resource Allocation
905-------------------
906
907The allocation of I/O ports and irqs is done via standard kernel
908functions. Unlike ALSA ver.0.5.x., there are no helpers for that. And
909these resources must be released in the destructor function (see below).
910Also, on ALSA 0.9.x, you don't need to allocate (pseudo-)DMA for PCI
911like in ALSA 0.5.x.
912
913Now assume that the PCI device has an I/O port with 8 bytes and an
914interrupt. Then :c:type:`struct mychip <mychip>` will have the
915following fields:
916
917::
918
919 struct mychip {
920 struct snd_card *card;
921
922 unsigned long port;
923 int irq;
924 };
925
926
927For an I/O port (and also a memory region), you need to have the
928resource pointer for the standard resource management. For an irq, you
929have to keep only the irq number (integer). But you need to initialize
930this number as -1 before actual allocation, since irq 0 is valid. The
931port address and its resource pointer can be initialized as null by
932:c:func:`kzalloc()` automatically, so you don't have to take care of
933resetting them.
934
935The allocation of an I/O port is done like this:
936
937::
938
939 err = pci_request_regions(pci, "My Chip");
940 if (err < 0) {
941 kfree(chip);
942 pci_disable_device(pci);
943 return err;
944 }
945 chip->port = pci_resource_start(pci, 0);
946
947It will reserve the I/O port region of 8 bytes of the given PCI device.
948The returned value, ``chip->res_port``, is allocated via
949:c:func:`kmalloc()` by :c:func:`request_region()`. The pointer
950must be released via :c:func:`kfree()`, but there is a problem with
951this. This issue will be explained later.
952
953The allocation of an interrupt source is done like this:
954
955::
956
957 if (request_irq(pci->irq, snd_mychip_interrupt,
958 IRQF_SHARED, KBUILD_MODNAME, chip)) {
959 printk(KERN_ERR "cannot grab irq %d\n", pci->irq);
960 snd_mychip_free(chip);
961 return -EBUSY;
962 }
963 chip->irq = pci->irq;
964
965where :c:func:`snd_mychip_interrupt()` is the interrupt handler
966defined `later <#pcm-interface-interrupt-handler>`__. Note that
967``chip->irq`` should be defined only when :c:func:`request_irq()`
968succeeded.
969
970On the PCI bus, interrupts can be shared. Thus, ``IRQF_SHARED`` is used
971as the interrupt flag of :c:func:`request_irq()`.
972
973The last argument of :c:func:`request_irq()` is the data pointer
974passed to the interrupt handler. Usually, the chip-specific record is
975used for that, but you can use what you like, too.
976
977I won't give details about the interrupt handler at this point, but at
978least its appearance can be explained now. The interrupt handler looks
979usually like the following:
980
981::
982
983 static irqreturn_t snd_mychip_interrupt(int irq, void *dev_id)
984 {
985 struct mychip *chip = dev_id;
986 ....
987 return IRQ_HANDLED;
988 }
989
990
991Now let's write the corresponding destructor for the resources above.
992The role of destructor is simple: disable the hardware (if already
993activated) and release the resources. So far, we have no hardware part,
994so the disabling code is not written here.
995
996To release the resources, the “check-and-release” method is a safer way.
997For the interrupt, do like this:
998
999::
1000
1001 if (chip->irq >= 0)
1002 free_irq(chip->irq, chip);
1003
1004Since the irq number can start from 0, you should initialize
1005``chip->irq`` with a negative value (e.g. -1), so that you can check
1006the validity of the irq number as above.
1007
1008When you requested I/O ports or memory regions via
1009:c:func:`pci_request_region()` or
1010:c:func:`pci_request_regions()` like in this example, release the
1011resource(s) using the corresponding function,
1012:c:func:`pci_release_region()` or
1013:c:func:`pci_release_regions()`.
1014
1015::
1016
1017 pci_release_regions(chip->pci);
1018
1019When you requested manually via :c:func:`request_region()` or
1020:c:func:`request_mem_region()`, you can release it via
1021:c:func:`release_resource()`. Suppose that you keep the resource
1022pointer returned from :c:func:`request_region()` in
1023chip->res_port, the release procedure looks like:
1024
1025::
1026
1027 release_and_free_resource(chip->res_port);
1028
1029Don't forget to call :c:func:`pci_disable_device()` before the
1030end.
1031
1032And finally, release the chip-specific record.
1033
1034::
1035
1036 kfree(chip);
1037
1038We didn't implement the hardware disabling part in the above. If you
1039need to do this, please note that the destructor may be called even
1040before the initialization of the chip is completed. It would be better
1041to have a flag to skip hardware disabling if the hardware was not
1042initialized yet.
1043
1044When the chip-data is assigned to the card using
1045:c:func:`snd_device_new()` with ``SNDRV_DEV_LOWLELVEL`` , its
1046destructor is called at the last. That is, it is assured that all other
1047components like PCMs and controls have already been released. You don't
1048have to stop PCMs, etc. explicitly, but just call low-level hardware
1049stopping.
1050
1051The management of a memory-mapped region is almost as same as the
1052management of an I/O port. You'll need three fields like the
1053following:
1054
1055::
1056
1057 struct mychip {
1058 ....
1059 unsigned long iobase_phys;
1060 void __iomem *iobase_virt;
1061 };
1062
1063and the allocation would be like below:
1064
1065::
1066
1067 if ((err = pci_request_regions(pci, "My Chip")) < 0) {
1068 kfree(chip);
1069 return err;
1070 }
1071 chip->iobase_phys = pci_resource_start(pci, 0);
1072 chip->iobase_virt = ioremap_nocache(chip->iobase_phys,
1073 pci_resource_len(pci, 0));
1074
1075and the corresponding destructor would be:
1076
1077::
1078
1079 static int snd_mychip_free(struct mychip *chip)
1080 {
1081 ....
1082 if (chip->iobase_virt)
1083 iounmap(chip->iobase_virt);
1084 ....
1085 pci_release_regions(chip->pci);
1086 ....
1087 }
1088
1089PCI Entries
1090-----------
1091
1092So far, so good. Let's finish the missing PCI stuff. At first, we need a
1093:c:type:`struct pci_device_id <pci_device_id>` table for
1094this chipset. It's a table of PCI vendor/device ID number, and some
1095masks.
1096
1097For example,
1098
1099::
1100
1101 static struct pci_device_id snd_mychip_ids[] = {
1102 { PCI_VENDOR_ID_FOO, PCI_DEVICE_ID_BAR,
1103 PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0, },
1104 ....
1105 { 0, }
1106 };
1107 MODULE_DEVICE_TABLE(pci, snd_mychip_ids);
1108
1109The first and second fields of the :c:type:`struct pci_device_id
1110<pci_device_id>` structure are the vendor and device IDs. If you
1111have no reason to filter the matching devices, you can leave the
1112remaining fields as above. The last field of the :c:type:`struct
1113pci_device_id <pci_device_id>` struct contains private data
1114for this entry. You can specify any value here, for example, to define
1115specific operations for supported device IDs. Such an example is found
1116in the intel8x0 driver.
1117
1118The last entry of this list is the terminator. You must specify this
1119all-zero entry.
1120
1121Then, prepare the :c:type:`struct pci_driver <pci_driver>`
1122record:
1123
1124::
1125
1126 static struct pci_driver driver = {
1127 .name = KBUILD_MODNAME,
1128 .id_table = snd_mychip_ids,
1129 .probe = snd_mychip_probe,
1130 .remove = snd_mychip_remove,
1131 };
1132
1133The ``probe`` and ``remove`` functions have already been defined in
1134the previous sections. The ``name`` field is the name string of this
1135device. Note that you must not use a slash “/” in this string.
1136
1137And at last, the module entries:
1138
1139::
1140
1141 static int __init alsa_card_mychip_init(void)
1142 {
1143 return pci_register_driver(&driver);
1144 }
1145
1146 static void __exit alsa_card_mychip_exit(void)
1147 {
1148 pci_unregister_driver(&driver);
1149 }
1150
1151 module_init(alsa_card_mychip_init)
1152 module_exit(alsa_card_mychip_exit)
1153
1154Note that these module entries are tagged with ``__init`` and ``__exit``
1155prefixes.
1156
1157Oh, one thing was forgotten. If you have no exported symbols, you need
1158to declare it in 2.2 or 2.4 kernels (it's not necessary in 2.6 kernels).
1159
1160::
1161
1162 EXPORT_NO_SYMBOLS;
1163
1164That's all!
1165
1166PCM Interface
1167=============
1168
1169General
1170-------
1171
1172The PCM middle layer of ALSA is quite powerful and it is only necessary
1173for each driver to implement the low-level functions to access its
1174hardware.
1175
1176For accessing to the PCM layer, you need to include ``<sound/pcm.h>``
1177first. In addition, ``<sound/pcm_params.h>`` might be needed if you
1178access to some functions related with hw_param.
1179
1180Each card device can have up to four pcm instances. A pcm instance
1181corresponds to a pcm device file. The limitation of number of instances
1182comes only from the available bit size of the Linux's device numbers.
1183Once when 64bit device number is used, we'll have more pcm instances
1184available.
1185
1186A pcm instance consists of pcm playback and capture streams, and each
1187pcm stream consists of one or more pcm substreams. Some soundcards
1188support multiple playback functions. For example, emu10k1 has a PCM
1189playback of 32 stereo substreams. In this case, at each open, a free
1190substream is (usually) automatically chosen and opened. Meanwhile, when
1191only one substream exists and it was already opened, the successful open
1192will either block or error with ``EAGAIN`` according to the file open
1193mode. But you don't have to care about such details in your driver. The
1194PCM middle layer will take care of such work.
1195
1196Full Code Example
1197-----------------
1198
1199The example code below does not include any hardware access routines but
1200shows only the skeleton, how to build up the PCM interfaces.
1201
1202::
1203
1204 #include <sound/pcm.h>
1205 ....
1206
1207 /* hardware definition */
1208 static struct snd_pcm_hardware snd_mychip_playback_hw = {
1209 .info = (SNDRV_PCM_INFO_MMAP |
1210 SNDRV_PCM_INFO_INTERLEAVED |
1211 SNDRV_PCM_INFO_BLOCK_TRANSFER |
1212 SNDRV_PCM_INFO_MMAP_VALID),
1213 .formats = SNDRV_PCM_FMTBIT_S16_LE,
1214 .rates = SNDRV_PCM_RATE_8000_48000,
1215 .rate_min = 8000,
1216 .rate_max = 48000,
1217 .channels_min = 2,
1218 .channels_max = 2,
1219 .buffer_bytes_max = 32768,
1220 .period_bytes_min = 4096,
1221 .period_bytes_max = 32768,
1222 .periods_min = 1,
1223 .periods_max = 1024,
1224 };
1225
1226 /* hardware definition */
1227 static struct snd_pcm_hardware snd_mychip_capture_hw = {
1228 .info = (SNDRV_PCM_INFO_MMAP |
1229 SNDRV_PCM_INFO_INTERLEAVED |
1230 SNDRV_PCM_INFO_BLOCK_TRANSFER |
1231 SNDRV_PCM_INFO_MMAP_VALID),
1232 .formats = SNDRV_PCM_FMTBIT_S16_LE,
1233 .rates = SNDRV_PCM_RATE_8000_48000,
1234 .rate_min = 8000,
1235 .rate_max = 48000,
1236 .channels_min = 2,
1237 .channels_max = 2,
1238 .buffer_bytes_max = 32768,
1239 .period_bytes_min = 4096,
1240 .period_bytes_max = 32768,
1241 .periods_min = 1,
1242 .periods_max = 1024,
1243 };
1244
1245 /* open callback */
1246 static int snd_mychip_playback_open(struct snd_pcm_substream *substream)
1247 {
1248 struct mychip *chip = snd_pcm_substream_chip(substream);
1249 struct snd_pcm_runtime *runtime = substream->runtime;
1250
1251 runtime->hw = snd_mychip_playback_hw;
1252 /* more hardware-initialization will be done here */
1253 ....
1254 return 0;
1255 }
1256
1257 /* close callback */
1258 static int snd_mychip_playback_close(struct snd_pcm_substream *substream)
1259 {
1260 struct mychip *chip = snd_pcm_substream_chip(substream);
1261 /* the hardware-specific codes will be here */
1262 ....
1263 return 0;
1264
1265 }
1266
1267 /* open callback */
1268 static int snd_mychip_capture_open(struct snd_pcm_substream *substream)
1269 {
1270 struct mychip *chip = snd_pcm_substream_chip(substream);
1271 struct snd_pcm_runtime *runtime = substream->runtime;
1272
1273 runtime->hw = snd_mychip_capture_hw;
1274 /* more hardware-initialization will be done here */
1275 ....
1276 return 0;
1277 }
1278
1279 /* close callback */
1280 static int snd_mychip_capture_close(struct snd_pcm_substream *substream)
1281 {
1282 struct mychip *chip = snd_pcm_substream_chip(substream);
1283 /* the hardware-specific codes will be here */
1284 ....
1285 return 0;
1286
1287 }
1288
1289 /* hw_params callback */
1290 static int snd_mychip_pcm_hw_params(struct snd_pcm_substream *substream,
1291 struct snd_pcm_hw_params *hw_params)
1292 {
1293 return snd_pcm_lib_malloc_pages(substream,
1294 params_buffer_bytes(hw_params));
1295 }
1296
1297 /* hw_free callback */
1298 static int snd_mychip_pcm_hw_free(struct snd_pcm_substream *substream)
1299 {
1300 return snd_pcm_lib_free_pages(substream);
1301 }
1302
1303 /* prepare callback */
1304 static int snd_mychip_pcm_prepare(struct snd_pcm_substream *substream)
1305 {
1306 struct mychip *chip = snd_pcm_substream_chip(substream);
1307 struct snd_pcm_runtime *runtime = substream->runtime;
1308
1309 /* set up the hardware with the current configuration
1310 * for example...
1311 */
1312 mychip_set_sample_format(chip, runtime->format);
1313 mychip_set_sample_rate(chip, runtime->rate);
1314 mychip_set_channels(chip, runtime->channels);
1315 mychip_set_dma_setup(chip, runtime->dma_addr,
1316 chip->buffer_size,
1317 chip->period_size);
1318 return 0;
1319 }
1320
1321 /* trigger callback */
1322 static int snd_mychip_pcm_trigger(struct snd_pcm_substream *substream,
1323 int cmd)
1324 {
1325 switch (cmd) {
1326 case SNDRV_PCM_TRIGGER_START:
1327 /* do something to start the PCM engine */
1328 ....
1329 break;
1330 case SNDRV_PCM_TRIGGER_STOP:
1331 /* do something to stop the PCM engine */
1332 ....
1333 break;
1334 default:
1335 return -EINVAL;
1336 }
1337 }
1338
1339 /* pointer callback */
1340 static snd_pcm_uframes_t
1341 snd_mychip_pcm_pointer(struct snd_pcm_substream *substream)
1342 {
1343 struct mychip *chip = snd_pcm_substream_chip(substream);
1344 unsigned int current_ptr;
1345
1346 /* get the current hardware pointer */
1347 current_ptr = mychip_get_hw_pointer(chip);
1348 return current_ptr;
1349 }
1350
1351 /* operators */
1352 static struct snd_pcm_ops snd_mychip_playback_ops = {
1353 .open = snd_mychip_playback_open,
1354 .close = snd_mychip_playback_close,
1355 .ioctl = snd_pcm_lib_ioctl,
1356 .hw_params = snd_mychip_pcm_hw_params,
1357 .hw_free = snd_mychip_pcm_hw_free,
1358 .prepare = snd_mychip_pcm_prepare,
1359 .trigger = snd_mychip_pcm_trigger,
1360 .pointer = snd_mychip_pcm_pointer,
1361 };
1362
1363 /* operators */
1364 static struct snd_pcm_ops snd_mychip_capture_ops = {
1365 .open = snd_mychip_capture_open,
1366 .close = snd_mychip_capture_close,
1367 .ioctl = snd_pcm_lib_ioctl,
1368 .hw_params = snd_mychip_pcm_hw_params,
1369 .hw_free = snd_mychip_pcm_hw_free,
1370 .prepare = snd_mychip_pcm_prepare,
1371 .trigger = snd_mychip_pcm_trigger,
1372 .pointer = snd_mychip_pcm_pointer,
1373 };
1374
1375 /*
1376 * definitions of capture are omitted here...
1377 */
1378
1379 /* create a pcm device */
1380 static int snd_mychip_new_pcm(struct mychip *chip)
1381 {
1382 struct snd_pcm *pcm;
1383 int err;
1384
1385 err = snd_pcm_new(chip->card, "My Chip", 0, 1, 1, &pcm);
1386 if (err < 0)
1387 return err;
1388 pcm->private_data = chip;
1389 strcpy(pcm->name, "My Chip");
1390 chip->pcm = pcm;
1391 /* set operators */
1392 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK,
1393 &snd_mychip_playback_ops);
1394 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE,
1395 &snd_mychip_capture_ops);
1396 /* pre-allocation of buffers */
1397 /* NOTE: this may fail */
1398 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV,
1399 snd_dma_pci_data(chip->pci),
1400 64*1024, 64*1024);
1401 return 0;
1402 }
1403
1404
1405PCM Constructor
1406---------------
1407
1408A pcm instance is allocated by the :c:func:`snd_pcm_new()`
1409function. It would be better to create a constructor for pcm, namely,
1410
1411::
1412
1413 static int snd_mychip_new_pcm(struct mychip *chip)
1414 {
1415 struct snd_pcm *pcm;
1416 int err;
1417
1418 err = snd_pcm_new(chip->card, "My Chip", 0, 1, 1, &pcm);
1419 if (err < 0)
1420 return err;
1421 pcm->private_data = chip;
1422 strcpy(pcm->name, "My Chip");
1423 chip->pcm = pcm;
1424 ....
1425 return 0;
1426 }
1427
1428The :c:func:`snd_pcm_new()` function takes four arguments. The
1429first argument is the card pointer to which this pcm is assigned, and
1430the second is the ID string.
1431
1432The third argument (``index``, 0 in the above) is the index of this new
1433pcm. It begins from zero. If you create more than one pcm instances,
1434specify the different numbers in this argument. For example, ``index =
14351`` for the second PCM device.
1436
1437The fourth and fifth arguments are the number of substreams for playback
1438and capture, respectively. Here 1 is used for both arguments. When no
1439playback or capture substreams are available, pass 0 to the
1440corresponding argument.
1441
1442If a chip supports multiple playbacks or captures, you can specify more
1443numbers, but they must be handled properly in open/close, etc.
1444callbacks. When you need to know which substream you are referring to,
1445then it can be obtained from :c:type:`struct snd_pcm_substream
1446<snd_pcm_substream>` data passed to each callback as follows:
1447
1448::
1449
1450 struct snd_pcm_substream *substream;
1451 int index = substream->number;
1452
1453
1454After the pcm is created, you need to set operators for each pcm stream.
1455
1456::
1457
1458 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK,
1459 &snd_mychip_playback_ops);
1460 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE,
1461 &snd_mychip_capture_ops);
1462
1463The operators are defined typically like this:
1464
1465::
1466
1467 static struct snd_pcm_ops snd_mychip_playback_ops = {
1468 .open = snd_mychip_pcm_open,
1469 .close = snd_mychip_pcm_close,
1470 .ioctl = snd_pcm_lib_ioctl,
1471 .hw_params = snd_mychip_pcm_hw_params,
1472 .hw_free = snd_mychip_pcm_hw_free,
1473 .prepare = snd_mychip_pcm_prepare,
1474 .trigger = snd_mychip_pcm_trigger,
1475 .pointer = snd_mychip_pcm_pointer,
1476 };
1477
1478All the callbacks are described in the Operators_ subsection.
1479
1480After setting the operators, you probably will want to pre-allocate the
1481buffer. For the pre-allocation, simply call the following:
1482
1483::
1484
1485 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV,
1486 snd_dma_pci_data(chip->pci),
1487 64*1024, 64*1024);
1488
1489It will allocate a buffer up to 64kB as default. Buffer management
1490details will be described in the later section `Buffer and Memory
1491Management`_.
1492
1493Additionally, you can set some extra information for this pcm in
1494``pcm->info_flags``. The available values are defined as
1495``SNDRV_PCM_INFO_XXX`` in ``<sound/asound.h>``, which is used for the
1496hardware definition (described later). When your soundchip supports only
1497half-duplex, specify like this:
1498
1499::
1500
1501 pcm->info_flags = SNDRV_PCM_INFO_HALF_DUPLEX;
1502
1503
1504... And the Destructor?
1505-----------------------
1506
1507The destructor for a pcm instance is not always necessary. Since the pcm
1508device will be released by the middle layer code automatically, you
1509don't have to call the destructor explicitly.
1510
1511The destructor would be necessary if you created special records
1512internally and needed to release them. In such a case, set the
1513destructor function to ``pcm->private_free``:
1514
1515::
1516
1517 static void mychip_pcm_free(struct snd_pcm *pcm)
1518 {
1519 struct mychip *chip = snd_pcm_chip(pcm);
1520 /* free your own data */
1521 kfree(chip->my_private_pcm_data);
1522 /* do what you like else */
1523 ....
1524 }
1525
1526 static int snd_mychip_new_pcm(struct mychip *chip)
1527 {
1528 struct snd_pcm *pcm;
1529 ....
1530 /* allocate your own data */
1531 chip->my_private_pcm_data = kmalloc(...);
1532 /* set the destructor */
1533 pcm->private_data = chip;
1534 pcm->private_free = mychip_pcm_free;
1535 ....
1536 }
1537
1538
1539
1540Runtime Pointer - The Chest of PCM Information
1541----------------------------------------------
1542
1543When the PCM substream is opened, a PCM runtime instance is allocated
1544and assigned to the substream. This pointer is accessible via
1545``substream->runtime``. This runtime pointer holds most information you
1546need to control the PCM: the copy of hw_params and sw_params
1547configurations, the buffer pointers, mmap records, spinlocks, etc.
1548
1549The definition of runtime instance is found in ``<sound/pcm.h>``. Here
1550are the contents of this file:
1551
1552::
1553
1554 struct _snd_pcm_runtime {
1555 /* -- Status -- */
1556 struct snd_pcm_substream *trigger_master;
1557 snd_timestamp_t trigger_tstamp; /* trigger timestamp */
1558 int overrange;
1559 snd_pcm_uframes_t avail_max;
1560 snd_pcm_uframes_t hw_ptr_base; /* Position at buffer restart */
1561 snd_pcm_uframes_t hw_ptr_interrupt; /* Position at interrupt time*/
1562
1563 /* -- HW params -- */
1564 snd_pcm_access_t access; /* access mode */
1565 snd_pcm_format_t format; /* SNDRV_PCM_FORMAT_* */
1566 snd_pcm_subformat_t subformat; /* subformat */
1567 unsigned int rate; /* rate in Hz */
1568 unsigned int channels; /* channels */
1569 snd_pcm_uframes_t period_size; /* period size */
1570 unsigned int periods; /* periods */
1571 snd_pcm_uframes_t buffer_size; /* buffer size */
1572 unsigned int tick_time; /* tick time */
1573 snd_pcm_uframes_t min_align; /* Min alignment for the format */
1574 size_t byte_align;
1575 unsigned int frame_bits;
1576 unsigned int sample_bits;
1577 unsigned int info;
1578 unsigned int rate_num;
1579 unsigned int rate_den;
1580
1581 /* -- SW params -- */
1582 struct timespec tstamp_mode; /* mmap timestamp is updated */
1583 unsigned int period_step;
1584 unsigned int sleep_min; /* min ticks to sleep */
1585 snd_pcm_uframes_t start_threshold;
1586 snd_pcm_uframes_t stop_threshold;
1587 snd_pcm_uframes_t silence_threshold; /* Silence filling happens when
1588 noise is nearest than this */
1589 snd_pcm_uframes_t silence_size; /* Silence filling size */
1590 snd_pcm_uframes_t boundary; /* pointers wrap point */
1591
1592 snd_pcm_uframes_t silenced_start;
1593 snd_pcm_uframes_t silenced_size;
1594
1595 snd_pcm_sync_id_t sync; /* hardware synchronization ID */
1596
1597 /* -- mmap -- */
1598 volatile struct snd_pcm_mmap_status *status;
1599 volatile struct snd_pcm_mmap_control *control;
1600 atomic_t mmap_count;
1601
1602 /* -- locking / scheduling -- */
1603 spinlock_t lock;
1604 wait_queue_head_t sleep;
1605 struct timer_list tick_timer;
1606 struct fasync_struct *fasync;
1607
1608 /* -- private section -- */
1609 void *private_data;
1610 void (*private_free)(struct snd_pcm_runtime *runtime);
1611
1612 /* -- hardware description -- */
1613 struct snd_pcm_hardware hw;
1614 struct snd_pcm_hw_constraints hw_constraints;
1615
1616 /* -- timer -- */
1617 unsigned int timer_resolution; /* timer resolution */
1618
1619 /* -- DMA -- */
1620 unsigned char *dma_area; /* DMA area */
1621 dma_addr_t dma_addr; /* physical bus address (not accessible from main CPU) */
1622 size_t dma_bytes; /* size of DMA area */
1623
1624 struct snd_dma_buffer *dma_buffer_p; /* allocated buffer */
1625
1626 #if defined(CONFIG_SND_PCM_OSS) || defined(CONFIG_SND_PCM_OSS_MODULE)
1627 /* -- OSS things -- */
1628 struct snd_pcm_oss_runtime oss;
1629 #endif
1630 };
1631
1632
1633For the operators (callbacks) of each sound driver, most of these
1634records are supposed to be read-only. Only the PCM middle-layer changes
1635/ updates them. The exceptions are the hardware description (hw) DMA
1636buffer information and the private data. Besides, if you use the
1637standard buffer allocation method via
1638:c:func:`snd_pcm_lib_malloc_pages()`, you don't need to set the
1639DMA buffer information by yourself.
1640
1641In the sections below, important records are explained.
1642
1643Hardware Description
1644~~~~~~~~~~~~~~~~~~~~
1645
1646The hardware descriptor (:c:type:`struct snd_pcm_hardware
1647<snd_pcm_hardware>`) contains the definitions of the fundamental
1648hardware configuration. Above all, you'll need to define this in the
1649`PCM open callback`_. Note that the runtime instance holds the copy of
1650the descriptor, not the pointer to the existing descriptor. That is,
1651in the open callback, you can modify the copied descriptor
1652(``runtime->hw``) as you need. For example, if the maximum number of
1653channels is 1 only on some chip models, you can still use the same
1654hardware descriptor and change the channels_max later:
1655
1656::
1657
1658 struct snd_pcm_runtime *runtime = substream->runtime;
1659 ...
1660 runtime->hw = snd_mychip_playback_hw; /* common definition */
1661 if (chip->model == VERY_OLD_ONE)
1662 runtime->hw.channels_max = 1;
1663
1664Typically, you'll have a hardware descriptor as below:
1665
1666::
1667
1668 static struct snd_pcm_hardware snd_mychip_playback_hw = {
1669 .info = (SNDRV_PCM_INFO_MMAP |
1670 SNDRV_PCM_INFO_INTERLEAVED |
1671 SNDRV_PCM_INFO_BLOCK_TRANSFER |
1672 SNDRV_PCM_INFO_MMAP_VALID),
1673 .formats = SNDRV_PCM_FMTBIT_S16_LE,
1674 .rates = SNDRV_PCM_RATE_8000_48000,
1675 .rate_min = 8000,
1676 .rate_max = 48000,
1677 .channels_min = 2,
1678 .channels_max = 2,
1679 .buffer_bytes_max = 32768,
1680 .period_bytes_min = 4096,
1681 .period_bytes_max = 32768,
1682 .periods_min = 1,
1683 .periods_max = 1024,
1684 };
1685
1686- The ``info`` field contains the type and capabilities of this
1687 pcm. The bit flags are defined in ``<sound/asound.h>`` as
1688 ``SNDRV_PCM_INFO_XXX``. Here, at least, you have to specify whether
1689 the mmap is supported and which interleaved format is
1690 supported. When the hardware supports mmap, add the
1691 ``SNDRV_PCM_INFO_MMAP`` flag here. When the hardware supports the
1692 interleaved or the non-interleaved formats,
1693 ``SNDRV_PCM_INFO_INTERLEAVED`` or ``SNDRV_PCM_INFO_NONINTERLEAVED``
1694 flag must be set, respectively. If both are supported, you can set
1695 both, too.
1696
1697 In the above example, ``MMAP_VALID`` and ``BLOCK_TRANSFER`` are
1698 specified for the OSS mmap mode. Usually both are set. Of course,
1699 ``MMAP_VALID`` is set only if the mmap is really supported.
1700
1701 The other possible flags are ``SNDRV_PCM_INFO_PAUSE`` and
1702 ``SNDRV_PCM_INFO_RESUME``. The ``PAUSE`` bit means that the pcm
1703 supports the “pause” operation, while the ``RESUME`` bit means that
1704 the pcm supports the full “suspend/resume” operation. If the
1705 ``PAUSE`` flag is set, the ``trigger`` callback below must handle
1706 the corresponding (pause push/release) commands. The suspend/resume
1707 trigger commands can be defined even without the ``RESUME``
1708 flag. See `Power Management`_ section for details.
1709
1710 When the PCM substreams can be synchronized (typically,
1711 synchronized start/stop of a playback and a capture streams), you
1712 can give ``SNDRV_PCM_INFO_SYNC_START``, too. In this case, you'll
1713 need to check the linked-list of PCM substreams in the trigger
1714 callback. This will be described in the later section.
1715
1716- ``formats`` field contains the bit-flags of supported formats
1717 (``SNDRV_PCM_FMTBIT_XXX``). If the hardware supports more than one
1718 format, give all or'ed bits. In the example above, the signed 16bit
1719 little-endian format is specified.
1720
1721- ``rates`` field contains the bit-flags of supported rates
1722 (``SNDRV_PCM_RATE_XXX``). When the chip supports continuous rates,
1723 pass ``CONTINUOUS`` bit additionally. The pre-defined rate bits are
1724 provided only for typical rates. If your chip supports
1725 unconventional rates, you need to add the ``KNOT`` bit and set up
1726 the hardware constraint manually (explained later).
1727
1728- ``rate_min`` and ``rate_max`` define the minimum and maximum sample
1729 rate. This should correspond somehow to ``rates`` bits.
1730
1731- ``channel_min`` and ``channel_max`` define, as you might already
1732 expected, the minimum and maximum number of channels.
1733
1734- ``buffer_bytes_max`` defines the maximum buffer size in
1735 bytes. There is no ``buffer_bytes_min`` field, since it can be
1736 calculated from the minimum period size and the minimum number of
1737 periods. Meanwhile, ``period_bytes_min`` and define the minimum and
1738 maximum size of the period in bytes. ``periods_max`` and
1739 ``periods_min`` define the maximum and minimum number of periods in
1740 the buffer.
1741
1742 The “period” is a term that corresponds to a fragment in the OSS
1743 world. The period defines the size at which a PCM interrupt is
1744 generated. This size strongly depends on the hardware. Generally,
1745 the smaller period size will give you more interrupts, that is,
1746 more controls. In the case of capture, this size defines the input
1747 latency. On the other hand, the whole buffer size defines the
1748 output latency for the playback direction.
1749
1750- There is also a field ``fifo_size``. This specifies the size of the
1751 hardware FIFO, but currently it is neither used in the driver nor
1752 in the alsa-lib. So, you can ignore this field.
1753
1754PCM Configurations
1755~~~~~~~~~~~~~~~~~~
1756
1757Ok, let's go back again to the PCM runtime records. The most
1758frequently referred records in the runtime instance are the PCM
1759configurations. The PCM configurations are stored in the runtime
1760instance after the application sends ``hw_params`` data via
1761alsa-lib. There are many fields copied from hw_params and sw_params
1762structs. For example, ``format`` holds the format type chosen by the
1763application. This field contains the enum value
1764``SNDRV_PCM_FORMAT_XXX``.
1765
1766One thing to be noted is that the configured buffer and period sizes
1767are stored in “frames” in the runtime. In the ALSA world, ``1 frame =
1768channels \* samples-size``. For conversion between frames and bytes,
1769you can use the :c:func:`frames_to_bytes()` and
1770:c:func:`bytes_to_frames()` helper functions.
1771
1772::
1773
1774 period_bytes = frames_to_bytes(runtime, runtime->period_size);
1775
1776Also, many software parameters (sw_params) are stored in frames, too.
1777Please check the type of the field. ``snd_pcm_uframes_t`` is for the
1778frames as unsigned integer while ``snd_pcm_sframes_t`` is for the
1779frames as signed integer.
1780
1781DMA Buffer Information
1782~~~~~~~~~~~~~~~~~~~~~~
1783
1784The DMA buffer is defined by the following four fields, ``dma_area``,
1785``dma_addr``, ``dma_bytes`` and ``dma_private``. The ``dma_area``
1786holds the buffer pointer (the logical address). You can call
1787:c:func:`memcpy()` from/to this pointer. Meanwhile, ``dma_addr`` holds
1788the physical address of the buffer. This field is specified only when
1789the buffer is a linear buffer. ``dma_bytes`` holds the size of buffer
1790in bytes. ``dma_private`` is used for the ALSA DMA allocator.
1791
1792If you use a standard ALSA function,
1793:c:func:`snd_pcm_lib_malloc_pages()`, for allocating the buffer,
1794these fields are set by the ALSA middle layer, and you should *not*
1795change them by yourself. You can read them but not write them. On the
1796other hand, if you want to allocate the buffer by yourself, you'll
1797need to manage it in hw_params callback. At least, ``dma_bytes`` is
1798mandatory. ``dma_area`` is necessary when the buffer is mmapped. If
1799your driver doesn't support mmap, this field is not
1800necessary. ``dma_addr`` is also optional. You can use dma_private as
1801you like, too.
1802
1803Running Status
1804~~~~~~~~~~~~~~
1805
1806The running status can be referred via ``runtime->status``. This is
1807the pointer to the :c:type:`struct snd_pcm_mmap_status
1808<snd_pcm_mmap_status>` record. For example, you can get the current
1809DMA hardware pointer via ``runtime->status->hw_ptr``.
1810
1811The DMA application pointer can be referred via ``runtime->control``,
1812which points to the :c:type:`struct snd_pcm_mmap_control
1813<snd_pcm_mmap_control>` record. However, accessing directly to
1814this value is not recommended.
1815
1816Private Data
1817~~~~~~~~~~~~
1818
1819You can allocate a record for the substream and store it in
1820``runtime->private_data``. Usually, this is done in the `PCM open
1821callback`_. Don't mix this with ``pcm->private_data``. The
1822``pcm->private_data`` usually points to the chip instance assigned
1823statically at the creation of PCM, while the ``runtime->private_data``
1824points to a dynamic data structure created at the PCM open
1825callback.
1826
1827::
1828
1829 static int snd_xxx_open(struct snd_pcm_substream *substream)
1830 {
1831 struct my_pcm_data *data;
1832 ....
1833 data = kmalloc(sizeof(*data), GFP_KERNEL);
1834 substream->runtime->private_data = data;
1835 ....
1836 }
1837
1838
1839The allocated object must be released in the `close callback`_.
1840
1841Operators
1842---------
1843
1844OK, now let me give details about each pcm callback (``ops``). In
1845general, every callback must return 0 if successful, or a negative
1846error number such as ``-EINVAL``. To choose an appropriate error
1847number, it is advised to check what value other parts of the kernel
1848return when the same kind of request fails.
1849
1850The callback function takes at least the argument with :c:type:`struct
1851snd_pcm_substream <snd_pcm_substream>` pointer. To retrieve the chip
1852record from the given substream instance, you can use the following
1853macro.
1854
1855::
1856
1857 int xxx() {
1858 struct mychip *chip = snd_pcm_substream_chip(substream);
1859 ....
1860 }
1861
1862The macro reads ``substream->private_data``, which is a copy of
1863``pcm->private_data``. You can override the former if you need to
1864assign different data records per PCM substream. For example, the
1865cmi8330 driver assigns different ``private_data`` for playback and
1866capture directions, because it uses two different codecs (SB- and
1867AD-compatible) for different directions.
1868
1869PCM open callback
1870~~~~~~~~~~~~~~~~~
1871
1872::
1873
1874 static int snd_xxx_open(struct snd_pcm_substream *substream);
1875
1876This is called when a pcm substream is opened.
1877
1878At least, here you have to initialize the ``runtime->hw``
1879record. Typically, this is done by like this:
1880
1881::
1882
1883 static int snd_xxx_open(struct snd_pcm_substream *substream)
1884 {
1885 struct mychip *chip = snd_pcm_substream_chip(substream);
1886 struct snd_pcm_runtime *runtime = substream->runtime;
1887
1888 runtime->hw = snd_mychip_playback_hw;
1889 return 0;
1890 }
1891
1892where ``snd_mychip_playback_hw`` is the pre-defined hardware
1893description.
1894
1895You can allocate a private data in this callback, as described in
1896`Private Data`_ section.
1897
1898If the hardware configuration needs more constraints, set the hardware
1899constraints here, too. See Constraints_ for more details.
1900
1901close callback
1902~~~~~~~~~~~~~~
1903
1904::
1905
1906 static int snd_xxx_close(struct snd_pcm_substream *substream);
1907
1908
1909Obviously, this is called when a pcm substream is closed.
1910
1911Any private instance for a pcm substream allocated in the ``open``
1912callback will be released here.
1913
1914::
1915
1916 static int snd_xxx_close(struct snd_pcm_substream *substream)
1917 {
1918 ....
1919 kfree(substream->runtime->private_data);
1920 ....
1921 }
1922
1923ioctl callback
1924~~~~~~~~~~~~~~
1925
1926This is used for any special call to pcm ioctls. But usually you can
1927pass a generic ioctl callback, :c:func:`snd_pcm_lib_ioctl()`.
1928
1929hw_params callback
1930~~~~~~~~~~~~~~~~~~~
1931
1932::
1933
1934 static int snd_xxx_hw_params(struct snd_pcm_substream *substream,
1935 struct snd_pcm_hw_params *hw_params);
1936
1937This is called when the hardware parameter (``hw_params``) is set up
1938by the application, that is, once when the buffer size, the period
1939size, the format, etc. are defined for the pcm substream.
1940
1941Many hardware setups should be done in this callback, including the
1942allocation of buffers.
1943
1944Parameters to be initialized are retrieved by
1945:c:func:`params_xxx()` macros. To allocate buffer, you can call a
1946helper function,
1947
1948::
1949
1950 snd_pcm_lib_malloc_pages(substream, params_buffer_bytes(hw_params));
1951
1952:c:func:`snd_pcm_lib_malloc_pages()` is available only when the
1953DMA buffers have been pre-allocated. See the section `Buffer Types`_
1954for more details.
1955
1956Note that this and ``prepare`` callbacks may be called multiple times
1957per initialization. For example, the OSS emulation may call these
1958callbacks at each change via its ioctl.
1959
1960Thus, you need to be careful not to allocate the same buffers many
1961times, which will lead to memory leaks! Calling the helper function
1962above many times is OK. It will release the previous buffer
1963automatically when it was already allocated.
1964
1965Another note is that this callback is non-atomic (schedulable) as
1966default, i.e. when no ``nonatomic`` flag set. This is important,
1967because the ``trigger`` callback is atomic (non-schedulable). That is,
1968mutexes or any schedule-related functions are not available in
1969``trigger`` callback. Please see the subsection Atomicity_ for
1970details.
1971
1972hw_free callback
1973~~~~~~~~~~~~~~~~~
1974
1975::
1976
1977 static int snd_xxx_hw_free(struct snd_pcm_substream *substream);
1978
1979This is called to release the resources allocated via
1980``hw_params``. For example, releasing the buffer via
1981:c:func:`snd_pcm_lib_malloc_pages()` is done by calling the
1982following:
1983
1984::
1985
1986 snd_pcm_lib_free_pages(substream);
1987
1988This function is always called before the close callback is called.
1989Also, the callback may be called multiple times, too. Keep track
1990whether the resource was already released.
1991
1992prepare callback
1993~~~~~~~~~~~~~~~~
1994
1995::
1996
1997 static int snd_xxx_prepare(struct snd_pcm_substream *substream);
1998
1999This callback is called when the pcm is “prepared”. You can set the
2000format type, sample rate, etc. here. The difference from ``hw_params``
2001is that the ``prepare`` callback will be called each time
2002:c:func:`snd_pcm_prepare()` is called, i.e. when recovering after
2003underruns, etc.
2004
2005Note that this callback is now non-atomic. You can use
2006schedule-related functions safely in this callback.
2007
2008In this and the following callbacks, you can refer to the values via
2009the runtime record, ``substream->runtime``. For example, to get the
2010current rate, format or channels, access to ``runtime->rate``,
2011``runtime->format`` or ``runtime->channels``, respectively. The
2012physical address of the allocated buffer is set to
2013``runtime->dma_area``. The buffer and period sizes are in
2014``runtime->buffer_size`` and ``runtime->period_size``, respectively.
2015
2016Be careful that this callback will be called many times at each setup,
2017too.
2018
2019trigger callback
2020~~~~~~~~~~~~~~~~
2021
2022::
2023
2024 static int snd_xxx_trigger(struct snd_pcm_substream *substream, int cmd);
2025
2026This is called when the pcm is started, stopped or paused.
2027
2028Which action is specified in the second argument,
2029``SNDRV_PCM_TRIGGER_XXX`` in ``<sound/pcm.h>``. At least, the ``START``
2030and ``STOP`` commands must be defined in this callback.
2031
2032::
2033
2034 switch (cmd) {
2035 case SNDRV_PCM_TRIGGER_START:
2036 /* do something to start the PCM engine */
2037 break;
2038 case SNDRV_PCM_TRIGGER_STOP:
2039 /* do something to stop the PCM engine */
2040 break;
2041 default:
2042 return -EINVAL;
2043 }
2044
2045When the pcm supports the pause operation (given in the info field of
2046the hardware table), the ``PAUSE_PUSH`` and ``PAUSE_RELEASE`` commands
2047must be handled here, too. The former is the command to pause the pcm,
2048and the latter to restart the pcm again.
2049
2050When the pcm supports the suspend/resume operation, regardless of full
2051or partial suspend/resume support, the ``SUSPEND`` and ``RESUME``
2052commands must be handled, too. These commands are issued when the
2053power-management status is changed. Obviously, the ``SUSPEND`` and
2054``RESUME`` commands suspend and resume the pcm substream, and usually,
2055they are identical to the ``STOP`` and ``START`` commands, respectively.
2056See the `Power Management`_ section for details.
2057
2058As mentioned, this callback is atomic as default unless ``nonatomic``
2059flag set, and you cannot call functions which may sleep. The
2060``trigger`` callback should be as minimal as possible, just really
2061triggering the DMA. The other stuff should be initialized
2062``hw_params`` and ``prepare`` callbacks properly beforehand.
2063
2064pointer callback
2065~~~~~~~~~~~~~~~~
2066
2067::
2068
2069 static snd_pcm_uframes_t snd_xxx_pointer(struct snd_pcm_substream *substream)
2070
2071This callback is called when the PCM middle layer inquires the current
2072hardware position on the buffer. The position must be returned in
2073frames, ranging from 0 to ``buffer_size - 1``.
2074
2075This is called usually from the buffer-update routine in the pcm
2076middle layer, which is invoked when :c:func:`snd_pcm_period_elapsed()`
2077is called in the interrupt routine. Then the pcm middle layer updates
2078the position and calculates the available space, and wakes up the
2079sleeping poll threads, etc.
2080
2081This callback is also atomic as default.
2082
2083copy and silence callbacks
2084~~~~~~~~~~~~~~~~~~~~~~~~~~
2085
2086These callbacks are not mandatory, and can be omitted in most cases.
2087These callbacks are used when the hardware buffer cannot be in the
2088normal memory space. Some chips have their own buffer on the hardware
2089which is not mappable. In such a case, you have to transfer the data
2090manually from the memory buffer to the hardware buffer. Or, if the
2091buffer is non-contiguous on both physical and virtual memory spaces,
2092these callbacks must be defined, too.
2093
2094If these two callbacks are defined, copy and set-silence operations
2095are done by them. The detailed will be described in the later section
2096`Buffer and Memory Management`_.
2097
2098ack callback
2099~~~~~~~~~~~~
2100
2101This callback is also not mandatory. This callback is called when the
2102``appl_ptr`` is updated in read or write operations. Some drivers like
2103emu10k1-fx and cs46xx need to track the current ``appl_ptr`` for the
2104internal buffer, and this callback is useful only for such a purpose.
2105
2106This callback is atomic as default.
2107
2108page callback
2109~~~~~~~~~~~~~
2110
2111This callback is optional too. This callback is used mainly for
2112non-contiguous buffers. The mmap calls this callback to get the page
2113address. Some examples will be explained in the later section `Buffer
2114and Memory Management`_, too.
2115
2116PCM Interrupt Handler
2117---------------------
2118
2119The rest of pcm stuff is the PCM interrupt handler. The role of PCM
2120interrupt handler in the sound driver is to update the buffer position
2121and to tell the PCM middle layer when the buffer position goes across
2122the prescribed period size. To inform this, call the
2123:c:func:`snd_pcm_period_elapsed()` function.
2124
2125There are several types of sound chips to generate the interrupts.
2126
2127Interrupts at the period (fragment) boundary
2128~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2129
2130This is the most frequently found type: the hardware generates an
2131interrupt at each period boundary. In this case, you can call
2132:c:func:`snd_pcm_period_elapsed()` at each interrupt.
2133
2134:c:func:`snd_pcm_period_elapsed()` takes the substream pointer as
2135its argument. Thus, you need to keep the substream pointer accessible
2136from the chip instance. For example, define ``substream`` field in the
2137chip record to hold the current running substream pointer, and set the
2138pointer value at ``open`` callback (and reset at ``close`` callback).
2139
2140If you acquire a spinlock in the interrupt handler, and the lock is used
2141in other pcm callbacks, too, then you have to release the lock before
2142calling :c:func:`snd_pcm_period_elapsed()`, because
2143:c:func:`snd_pcm_period_elapsed()` calls other pcm callbacks
2144inside.
2145
2146Typical code would be like:
2147
2148::
2149
2150
2151 static irqreturn_t snd_mychip_interrupt(int irq, void *dev_id)
2152 {
2153 struct mychip *chip = dev_id;
2154 spin_lock(&chip->lock);
2155 ....
2156 if (pcm_irq_invoked(chip)) {
2157 /* call updater, unlock before it */
2158 spin_unlock(&chip->lock);
2159 snd_pcm_period_elapsed(chip->substream);
2160 spin_lock(&chip->lock);
2161 /* acknowledge the interrupt if necessary */
2162 }
2163 ....
2164 spin_unlock(&chip->lock);
2165 return IRQ_HANDLED;
2166 }
2167
2168
2169
2170High frequency timer interrupts
2171~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2172
2173This happens when the hardware doesn't generate interrupts at the period
2174boundary but issues timer interrupts at a fixed timer rate (e.g. es1968
2175or ymfpci drivers). In this case, you need to check the current hardware
2176position and accumulate the processed sample length at each interrupt.
2177When the accumulated size exceeds the period size, call
2178:c:func:`snd_pcm_period_elapsed()` and reset the accumulator.
2179
2180Typical code would be like the following.
2181
2182::
2183
2184
2185 static irqreturn_t snd_mychip_interrupt(int irq, void *dev_id)
2186 {
2187 struct mychip *chip = dev_id;
2188 spin_lock(&chip->lock);
2189 ....
2190 if (pcm_irq_invoked(chip)) {
2191 unsigned int last_ptr, size;
2192 /* get the current hardware pointer (in frames) */
2193 last_ptr = get_hw_ptr(chip);
2194 /* calculate the processed frames since the
2195 * last update
2196 */
2197 if (last_ptr < chip->last_ptr)
2198 size = runtime->buffer_size + last_ptr
2199 - chip->last_ptr;
2200 else
2201 size = last_ptr - chip->last_ptr;
2202 /* remember the last updated point */
2203 chip->last_ptr = last_ptr;
2204 /* accumulate the size */
2205 chip->size += size;
2206 /* over the period boundary? */
2207 if (chip->size >= runtime->period_size) {
2208 /* reset the accumulator */
2209 chip->size %= runtime->period_size;
2210 /* call updater */
2211 spin_unlock(&chip->lock);
2212 snd_pcm_period_elapsed(substream);
2213 spin_lock(&chip->lock);
2214 }
2215 /* acknowledge the interrupt if necessary */
2216 }
2217 ....
2218 spin_unlock(&chip->lock);
2219 return IRQ_HANDLED;
2220 }
2221
2222
2223
2224On calling :c:func:`snd_pcm_period_elapsed()`
2225~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2226
2227In both cases, even if more than one period are elapsed, you don't have
2228to call :c:func:`snd_pcm_period_elapsed()` many times. Call only
2229once. And the pcm layer will check the current hardware pointer and
2230update to the latest status.
2231
2232Atomicity
2233---------
2234
2235One of the most important (and thus difficult to debug) problems in
2236kernel programming are race conditions. In the Linux kernel, they are
2237usually avoided via spin-locks, mutexes or semaphores. In general, if a
2238race condition can happen in an interrupt handler, it has to be managed
2239atomically, and you have to use a spinlock to protect the critical
2240session. If the critical section is not in interrupt handler code and if
2241taking a relatively long time to execute is acceptable, you should use
2242mutexes or semaphores instead.
2243
2244As already seen, some pcm callbacks are atomic and some are not. For
2245example, the ``hw_params`` callback is non-atomic, while ``trigger``
2246callback is atomic. This means, the latter is called already in a
2247spinlock held by the PCM middle layer. Please take this atomicity into
2248account when you choose a locking scheme in the callbacks.
2249
2250In the atomic callbacks, you cannot use functions which may call
2251:c:func:`schedule()` or go to :c:func:`sleep()`. Semaphores and
2252mutexes can sleep, and hence they cannot be used inside the atomic
2253callbacks (e.g. ``trigger`` callback). To implement some delay in such a
2254callback, please use :c:func:`udelay()` or :c:func:`mdelay()`.
2255
2256All three atomic callbacks (trigger, pointer, and ack) are called with
2257local interrupts disabled.
2258
2259The recent changes in PCM core code, however, allow all PCM operations
2260to be non-atomic. This assumes that the all caller sides are in
2261non-atomic contexts. For example, the function
2262:c:func:`snd_pcm_period_elapsed()` is called typically from the
2263interrupt handler. But, if you set up the driver to use a threaded
2264interrupt handler, this call can be in non-atomic context, too. In such
2265a case, you can set ``nonatomic`` filed of :c:type:`struct snd_pcm
2266<snd_pcm>` object after creating it. When this flag is set, mutex
2267and rwsem are used internally in the PCM core instead of spin and
2268rwlocks, so that you can call all PCM functions safely in a non-atomic
2269context.
2270
2271Constraints
2272-----------
2273
2274If your chip supports unconventional sample rates, or only the limited
2275samples, you need to set a constraint for the condition.
2276
2277For example, in order to restrict the sample rates in the some supported
2278values, use :c:func:`snd_pcm_hw_constraint_list()`. You need to
2279call this function in the open callback.
2280
2281::
2282
2283 static unsigned int rates[] =
2284 {4000, 10000, 22050, 44100};
2285 static struct snd_pcm_hw_constraint_list constraints_rates = {
2286 .count = ARRAY_SIZE(rates),
2287 .list = rates,
2288 .mask = 0,
2289 };
2290
2291 static int snd_mychip_pcm_open(struct snd_pcm_substream *substream)
2292 {
2293 int err;
2294 ....
2295 err = snd_pcm_hw_constraint_list(substream->runtime, 0,
2296 SNDRV_PCM_HW_PARAM_RATE,
2297 &constraints_rates);
2298 if (err < 0)
2299 return err;
2300 ....
2301 }
2302
2303
2304
2305There are many different constraints. Look at ``sound/pcm.h`` for a
2306complete list. You can even define your own constraint rules. For
2307example, let's suppose my_chip can manage a substream of 1 channel if
2308and only if the format is ``S16_LE``, otherwise it supports any format
2309specified in the :c:type:`struct snd_pcm_hardware
2310<snd_pcm_hardware>` structure (or in any other
2311constraint_list). You can build a rule like this:
2312
2313::
2314
2315 static int hw_rule_channels_by_format(struct snd_pcm_hw_params *params,
2316 struct snd_pcm_hw_rule *rule)
2317 {
2318 struct snd_interval *c = hw_param_interval(params,
2319 SNDRV_PCM_HW_PARAM_CHANNELS);
2320 struct snd_mask *f = hw_param_mask(params, SNDRV_PCM_HW_PARAM_FORMAT);
2321 struct snd_interval ch;
2322
2323 snd_interval_any(&ch);
2324 if (f->bits[0] == SNDRV_PCM_FMTBIT_S16_LE) {
2325 ch.min = ch.max = 1;
2326 ch.integer = 1;
2327 return snd_interval_refine(c, &ch);
2328 }
2329 return 0;
2330 }
2331
2332
2333Then you need to call this function to add your rule:
2334
2335::
2336
2337 snd_pcm_hw_rule_add(substream->runtime, 0, SNDRV_PCM_HW_PARAM_CHANNELS,
2338 hw_rule_channels_by_format, NULL,
2339 SNDRV_PCM_HW_PARAM_FORMAT, -1);
2340
2341The rule function is called when an application sets the PCM format, and
2342it refines the number of channels accordingly. But an application may
2343set the number of channels before setting the format. Thus you also need
2344to define the inverse rule:
2345
2346::
2347
2348 static int hw_rule_format_by_channels(struct snd_pcm_hw_params *params,
2349 struct snd_pcm_hw_rule *rule)
2350 {
2351 struct snd_interval *c = hw_param_interval(params,
2352 SNDRV_PCM_HW_PARAM_CHANNELS);
2353 struct snd_mask *f = hw_param_mask(params, SNDRV_PCM_HW_PARAM_FORMAT);
2354 struct snd_mask fmt;
2355
2356 snd_mask_any(&fmt); /* Init the struct */
2357 if (c->min < 2) {
2358 fmt.bits[0] &= SNDRV_PCM_FMTBIT_S16_LE;
2359 return snd_mask_refine(f, &fmt);
2360 }
2361 return 0;
2362 }
2363
2364
2365... and in the open callback:
2366
2367::
2368
2369 snd_pcm_hw_rule_add(substream->runtime, 0, SNDRV_PCM_HW_PARAM_FORMAT,
2370 hw_rule_format_by_channels, NULL,
2371 SNDRV_PCM_HW_PARAM_CHANNELS, -1);
2372
2373I won't give more details here, rather I would like to say, “Luke, use
2374the source.”
2375
2376Control Interface
2377=================
2378
2379General
2380-------
2381
2382The control interface is used widely for many switches, sliders, etc.
2383which are accessed from user-space. Its most important use is the mixer
2384interface. In other words, since ALSA 0.9.x, all the mixer stuff is
2385implemented on the control kernel API.
2386
2387ALSA has a well-defined AC97 control module. If your chip supports only
2388the AC97 and nothing else, you can skip this section.
2389
2390The control API is defined in ``<sound/control.h>``. Include this file
2391if you want to add your own controls.
2392
2393Definition of Controls
2394----------------------
2395
2396To create a new control, you need to define the following three
2397callbacks: ``info``, ``get`` and ``put``. Then, define a
2398:c:type:`struct snd_kcontrol_new <snd_kcontrol_new>` record, such as:
2399
2400::
2401
2402
2403 static struct snd_kcontrol_new my_control = {
2404 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
2405 .name = "PCM Playback Switch",
2406 .index = 0,
2407 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE,
2408 .private_value = 0xffff,
2409 .info = my_control_info,
2410 .get = my_control_get,
2411 .put = my_control_put
2412 };
2413
2414
2415The ``iface`` field specifies the control type,
2416``SNDRV_CTL_ELEM_IFACE_XXX``, which is usually ``MIXER``. Use ``CARD``
2417for global controls that are not logically part of the mixer. If the
2418control is closely associated with some specific device on the sound
2419card, use ``HWDEP``, ``PCM``, ``RAWMIDI``, ``TIMER``, or ``SEQUENCER``,
2420and specify the device number with the ``device`` and ``subdevice``
2421fields.
2422
2423The ``name`` is the name identifier string. Since ALSA 0.9.x, the
2424control name is very important, because its role is classified from
2425its name. There are pre-defined standard control names. The details
2426are described in the `Control Names`_ subsection.
2427
2428The ``index`` field holds the index number of this control. If there
2429are several different controls with the same name, they can be
2430distinguished by the index number. This is the case when several
2431codecs exist on the card. If the index is zero, you can omit the
2432definition above.
2433
2434The ``access`` field contains the access type of this control. Give
2435the combination of bit masks, ``SNDRV_CTL_ELEM_ACCESS_XXX``,
2436there. The details will be explained in the `Access Flags`_
2437subsection.
2438
2439The ``private_value`` field contains an arbitrary long integer value
2440for this record. When using the generic ``info``, ``get`` and ``put``
2441callbacks, you can pass a value through this field. If several small
2442numbers are necessary, you can combine them in bitwise. Or, it's
2443possible to give a pointer (casted to unsigned long) of some record to
2444this field, too.
2445
2446The ``tlv`` field can be used to provide metadata about the control;
2447see the `Metadata`_ subsection.
2448
2449The other three are `Control Callbacks`_.
2450
2451Control Names
2452-------------
2453
2454There are some standards to define the control names. A control is
2455usually defined from the three parts as “SOURCE DIRECTION FUNCTION”.
2456
2457The first, ``SOURCE``, specifies the source of the control, and is a
2458string such as “Master”, “PCM”, “CD” and “Line”. There are many
2459pre-defined sources.
2460
2461The second, ``DIRECTION``, is one of the following strings according to
2462the direction of the control: “Playback”, “Capture”, “Bypass Playback”
2463and “Bypass Capture”. Or, it can be omitted, meaning both playback and
2464capture directions.
2465
2466The third, ``FUNCTION``, is one of the following strings according to
2467the function of the control: “Switch”, “Volume” and “Route”.
2468
2469The example of control names are, thus, “Master Capture Switch” or “PCM
2470Playback Volume”.
2471
2472There are some exceptions:
2473
2474Global capture and playback
2475~~~~~~~~~~~~~~~~~~~~~~~~~~~
2476
2477“Capture Source”, “Capture Switch” and “Capture Volume” are used for the
2478global capture (input) source, switch and volume. Similarly, “Playback
2479Switch” and “Playback Volume” are used for the global output gain switch
2480and volume.
2481
2482Tone-controls
2483~~~~~~~~~~~~~
2484
2485tone-control switch and volumes are specified like “Tone Control - XXX”,
2486e.g. “Tone Control - Switch”, “Tone Control - Bass”, “Tone Control -
2487Center”.
2488
24893D controls
2490~~~~~~~~~~~
2491
24923D-control switches and volumes are specified like “3D Control - XXX”,
2493e.g. “3D Control - Switch”, “3D Control - Center”, “3D Control - Space”.
2494
2495Mic boost
2496~~~~~~~~~
2497
2498Mic-boost switch is set as “Mic Boost” or “Mic Boost (6dB)”.
2499
2500More precise information can be found in
2501``Documentation/sound/alsa/ControlNames.txt``.
2502
2503Access Flags
2504------------
2505
2506The access flag is the bitmask which specifies the access type of the
2507given control. The default access type is
2508``SNDRV_CTL_ELEM_ACCESS_READWRITE``, which means both read and write are
2509allowed to this control. When the access flag is omitted (i.e. = 0), it
2510is considered as ``READWRITE`` access as default.
2511
2512When the control is read-only, pass ``SNDRV_CTL_ELEM_ACCESS_READ``
2513instead. In this case, you don't have to define the ``put`` callback.
2514Similarly, when the control is write-only (although it's a rare case),
2515you can use the ``WRITE`` flag instead, and you don't need the ``get``
2516callback.
2517
2518If the control value changes frequently (e.g. the VU meter),
2519``VOLATILE`` flag should be given. This means that the control may be
2520changed without `Change notification`_. Applications should poll such
2521a control constantly.
2522
2523When the control is inactive, set the ``INACTIVE`` flag, too. There are
2524``LOCK`` and ``OWNER`` flags to change the write permissions.
2525
2526Control Callbacks
2527-----------------
2528
2529info callback
2530~~~~~~~~~~~~~
2531
2532The ``info`` callback is used to get detailed information on this
2533control. This must store the values of the given :c:type:`struct
2534snd_ctl_elem_info <snd_ctl_elem_info>` object. For example,
2535for a boolean control with a single element:
2536
2537::
2538
2539
2540 static int snd_myctl_mono_info(struct snd_kcontrol *kcontrol,
2541 struct snd_ctl_elem_info *uinfo)
2542 {
2543 uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
2544 uinfo->count = 1;
2545 uinfo->value.integer.min = 0;
2546 uinfo->value.integer.max = 1;
2547 return 0;
2548 }
2549
2550
2551
2552The ``type`` field specifies the type of the control. There are
2553``BOOLEAN``, ``INTEGER``, ``ENUMERATED``, ``BYTES``, ``IEC958`` and
2554``INTEGER64``. The ``count`` field specifies the number of elements in
2555this control. For example, a stereo volume would have count = 2. The
2556``value`` field is a union, and the values stored are depending on the
2557type. The boolean and integer types are identical.
2558
2559The enumerated type is a bit different from others. You'll need to set
2560the string for the currently given item index.
2561
2562::
2563
2564 static int snd_myctl_enum_info(struct snd_kcontrol *kcontrol,
2565 struct snd_ctl_elem_info *uinfo)
2566 {
2567 static char *texts[4] = {
2568 "First", "Second", "Third", "Fourth"
2569 };
2570 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2571 uinfo->count = 1;
2572 uinfo->value.enumerated.items = 4;
2573 if (uinfo->value.enumerated.item > 3)
2574 uinfo->value.enumerated.item = 3;
2575 strcpy(uinfo->value.enumerated.name,
2576 texts[uinfo->value.enumerated.item]);
2577 return 0;
2578 }
2579
2580The above callback can be simplified with a helper function,
2581:c:func:`snd_ctl_enum_info()`. The final code looks like below.
2582(You can pass ``ARRAY_SIZE(texts)`` instead of 4 in the third argument;
2583it's a matter of taste.)
2584
2585::
2586
2587 static int snd_myctl_enum_info(struct snd_kcontrol *kcontrol,
2588 struct snd_ctl_elem_info *uinfo)
2589 {
2590 static char *texts[4] = {
2591 "First", "Second", "Third", "Fourth"
2592 };
2593 return snd_ctl_enum_info(uinfo, 1, 4, texts);
2594 }
2595
2596
2597Some common info callbacks are available for your convenience:
2598:c:func:`snd_ctl_boolean_mono_info()` and
2599:c:func:`snd_ctl_boolean_stereo_info()`. Obviously, the former
2600is an info callback for a mono channel boolean item, just like
2601:c:func:`snd_myctl_mono_info()` above, and the latter is for a
2602stereo channel boolean item.
2603
2604get callback
2605~~~~~~~~~~~~
2606
2607This callback is used to read the current value of the control and to
2608return to user-space.
2609
2610For example,
2611
2612::
2613
2614
2615 static int snd_myctl_get(struct snd_kcontrol *kcontrol,
2616 struct snd_ctl_elem_value *ucontrol)
2617 {
2618 struct mychip *chip = snd_kcontrol_chip(kcontrol);
2619 ucontrol->value.integer.value[0] = get_some_value(chip);
2620 return 0;
2621 }
2622
2623
2624
2625The ``value`` field depends on the type of control as well as on the
2626info callback. For example, the sb driver uses this field to store the
2627register offset, the bit-shift and the bit-mask. The ``private_value``
2628field is set as follows:
2629
2630::
2631
2632 .private_value = reg | (shift << 16) | (mask << 24)
2633
2634and is retrieved in callbacks like
2635
2636::
2637
2638 static int snd_sbmixer_get_single(struct snd_kcontrol *kcontrol,
2639 struct snd_ctl_elem_value *ucontrol)
2640 {
2641 int reg = kcontrol->private_value & 0xff;
2642 int shift = (kcontrol->private_value >> 16) & 0xff;
2643 int mask = (kcontrol->private_value >> 24) & 0xff;
2644 ....
2645 }
2646
2647In the ``get`` callback, you have to fill all the elements if the
2648control has more than one elements, i.e. ``count > 1``. In the example
2649above, we filled only one element (``value.integer.value[0]``) since
2650it's assumed as ``count = 1``.
2651
2652put callback
2653~~~~~~~~~~~~
2654
2655This callback is used to write a value from user-space.
2656
2657For example,
2658
2659::
2660
2661
2662 static int snd_myctl_put(struct snd_kcontrol *kcontrol,
2663 struct snd_ctl_elem_value *ucontrol)
2664 {
2665 struct mychip *chip = snd_kcontrol_chip(kcontrol);
2666 int changed = 0;
2667 if (chip->current_value !=
2668 ucontrol->value.integer.value[0]) {
2669 change_current_value(chip,
2670 ucontrol->value.integer.value[0]);
2671 changed = 1;
2672 }
2673 return changed;
2674 }
2675
2676
2677
2678As seen above, you have to return 1 if the value is changed. If the
2679value is not changed, return 0 instead. If any fatal error happens,
2680return a negative error code as usual.
2681
2682As in the ``get`` callback, when the control has more than one
2683elements, all elements must be evaluated in this callback, too.
2684
2685Callbacks are not atomic
2686~~~~~~~~~~~~~~~~~~~~~~~~
2687
2688All these three callbacks are basically not atomic.
2689
2690Control Constructor
2691-------------------
2692
2693When everything is ready, finally we can create a new control. To create
2694a control, there are two functions to be called,
2695:c:func:`snd_ctl_new1()` and :c:func:`snd_ctl_add()`.
2696
2697In the simplest way, you can do like this:
2698
2699::
2700
2701 err = snd_ctl_add(card, snd_ctl_new1(&my_control, chip));
2702 if (err < 0)
2703 return err;
2704
2705where ``my_control`` is the :c:type:`struct snd_kcontrol_new
2706<snd_kcontrol_new>` object defined above, and chip is the object
2707pointer to be passed to kcontrol->private_data which can be referred
2708to in callbacks.
2709
2710:c:func:`snd_ctl_new1()` allocates a new :c:type:`struct
2711snd_kcontrol <snd_kcontrol>` instance, and
2712:c:func:`snd_ctl_add()` assigns the given control component to the
2713card.
2714
2715Change Notification
2716-------------------
2717
2718If you need to change and update a control in the interrupt routine, you
2719can call :c:func:`snd_ctl_notify()`. For example,
2720
2721::
2722
2723 snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_VALUE, id_pointer);
2724
2725This function takes the card pointer, the event-mask, and the control id
2726pointer for the notification. The event-mask specifies the types of
2727notification, for example, in the above example, the change of control
2728values is notified. The id pointer is the pointer of :c:type:`struct
2729snd_ctl_elem_id <snd_ctl_elem_id>` to be notified. You can
2730find some examples in ``es1938.c`` or ``es1968.c`` for hardware volume
2731interrupts.
2732
2733Metadata
2734--------
2735
2736To provide information about the dB values of a mixer control, use on of
2737the ``DECLARE_TLV_xxx`` macros from ``<sound/tlv.h>`` to define a
2738variable containing this information, set the ``tlv.p`` field to point to
2739this variable, and include the ``SNDRV_CTL_ELEM_ACCESS_TLV_READ`` flag
2740in the ``access`` field; like this:
2741
2742::
2743
2744 static DECLARE_TLV_DB_SCALE(db_scale_my_control, -4050, 150, 0);
2745
2746 static struct snd_kcontrol_new my_control = {
2747 ...
2748 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE |
2749 SNDRV_CTL_ELEM_ACCESS_TLV_READ,
2750 ...
2751 .tlv.p = db_scale_my_control,
2752 };
2753
2754
2755The :c:func:`DECLARE_TLV_DB_SCALE()` macro defines information
2756about a mixer control where each step in the control's value changes the
2757dB value by a constant dB amount. The first parameter is the name of the
2758variable to be defined. The second parameter is the minimum value, in
2759units of 0.01 dB. The third parameter is the step size, in units of 0.01
2760dB. Set the fourth parameter to 1 if the minimum value actually mutes
2761the control.
2762
2763The :c:func:`DECLARE_TLV_DB_LINEAR()` macro defines information
2764about a mixer control where the control's value affects the output
2765linearly. The first parameter is the name of the variable to be defined.
2766The second parameter is the minimum value, in units of 0.01 dB. The
2767third parameter is the maximum value, in units of 0.01 dB. If the
2768minimum value mutes the control, set the second parameter to
2769``TLV_DB_GAIN_MUTE``.
2770
2771API for AC97 Codec
2772==================
2773
2774General
2775-------
2776
2777The ALSA AC97 codec layer is a well-defined one, and you don't have to
2778write much code to control it. Only low-level control routines are
2779necessary. The AC97 codec API is defined in ``<sound/ac97_codec.h>``.
2780
2781Full Code Example
2782-----------------
2783
2784::
2785
2786 struct mychip {
2787 ....
2788 struct snd_ac97 *ac97;
2789 ....
2790 };
2791
2792 static unsigned short snd_mychip_ac97_read(struct snd_ac97 *ac97,
2793 unsigned short reg)
2794 {
2795 struct mychip *chip = ac97->private_data;
2796 ....
2797 /* read a register value here from the codec */
2798 return the_register_value;
2799 }
2800
2801 static void snd_mychip_ac97_write(struct snd_ac97 *ac97,
2802 unsigned short reg, unsigned short val)
2803 {
2804 struct mychip *chip = ac97->private_data;
2805 ....
2806 /* write the given register value to the codec */
2807 }
2808
2809 static int snd_mychip_ac97(struct mychip *chip)
2810 {
2811 struct snd_ac97_bus *bus;
2812 struct snd_ac97_template ac97;
2813 int err;
2814 static struct snd_ac97_bus_ops ops = {
2815 .write = snd_mychip_ac97_write,
2816 .read = snd_mychip_ac97_read,
2817 };
2818
2819 err = snd_ac97_bus(chip->card, 0, &ops, NULL, &bus);
2820 if (err < 0)
2821 return err;
2822 memset(&ac97, 0, sizeof(ac97));
2823 ac97.private_data = chip;
2824 return snd_ac97_mixer(bus, &ac97, &chip->ac97);
2825 }
2826
2827
2828AC97 Constructor
2829----------------
2830
2831To create an ac97 instance, first call :c:func:`snd_ac97_bus()`
2832with an ``ac97_bus_ops_t`` record with callback functions.
2833
2834::
2835
2836 struct snd_ac97_bus *bus;
2837 static struct snd_ac97_bus_ops ops = {
2838 .write = snd_mychip_ac97_write,
2839 .read = snd_mychip_ac97_read,
2840 };
2841
2842 snd_ac97_bus(card, 0, &ops, NULL, &pbus);
2843
2844The bus record is shared among all belonging ac97 instances.
2845
2846And then call :c:func:`snd_ac97_mixer()` with an :c:type:`struct
2847snd_ac97_template <snd_ac97_template>` record together with
2848the bus pointer created above.
2849
2850::
2851
2852 struct snd_ac97_template ac97;
2853 int err;
2854
2855 memset(&ac97, 0, sizeof(ac97));
2856 ac97.private_data = chip;
2857 snd_ac97_mixer(bus, &ac97, &chip->ac97);
2858
2859where chip->ac97 is a pointer to a newly created ``ac97_t``
2860instance. In this case, the chip pointer is set as the private data,
2861so that the read/write callback functions can refer to this chip
2862instance. This instance is not necessarily stored in the chip
2863record. If you need to change the register values from the driver, or
2864need the suspend/resume of ac97 codecs, keep this pointer to pass to
2865the corresponding functions.
2866
2867AC97 Callbacks
2868--------------
2869
2870The standard callbacks are ``read`` and ``write``. Obviously they
2871correspond to the functions for read and write accesses to the
2872hardware low-level codes.
2873
2874The ``read`` callback returns the register value specified in the
2875argument.
2876
2877::
2878
2879 static unsigned short snd_mychip_ac97_read(struct snd_ac97 *ac97,
2880 unsigned short reg)
2881 {
2882 struct mychip *chip = ac97->private_data;
2883 ....
2884 return the_register_value;
2885 }
2886
2887Here, the chip can be cast from ``ac97->private_data``.
2888
2889Meanwhile, the ``write`` callback is used to set the register
2890value
2891
2892::
2893
2894 static void snd_mychip_ac97_write(struct snd_ac97 *ac97,
2895 unsigned short reg, unsigned short val)
2896
2897
2898These callbacks are non-atomic like the control API callbacks.
2899
2900There are also other callbacks: ``reset``, ``wait`` and ``init``.
2901
2902The ``reset`` callback is used to reset the codec. If the chip
2903requires a special kind of reset, you can define this callback.
2904
2905The ``wait`` callback is used to add some waiting time in the standard
2906initialization of the codec. If the chip requires the extra waiting
2907time, define this callback.
2908
2909The ``init`` callback is used for additional initialization of the
2910codec.
2911
2912Updating Registers in The Driver
2913--------------------------------
2914
2915If you need to access to the codec from the driver, you can call the
2916following functions: :c:func:`snd_ac97_write()`,
2917:c:func:`snd_ac97_read()`, :c:func:`snd_ac97_update()` and
2918:c:func:`snd_ac97_update_bits()`.
2919
2920Both :c:func:`snd_ac97_write()` and
2921:c:func:`snd_ac97_update()` functions are used to set a value to
2922the given register (``AC97_XXX``). The difference between them is that
2923:c:func:`snd_ac97_update()` doesn't write a value if the given
2924value has been already set, while :c:func:`snd_ac97_write()`
2925always rewrites the value.
2926
2927::
2928
2929 snd_ac97_write(ac97, AC97_MASTER, 0x8080);
2930 snd_ac97_update(ac97, AC97_MASTER, 0x8080);
2931
2932:c:func:`snd_ac97_read()` is used to read the value of the given
2933register. For example,
2934
2935::
2936
2937 value = snd_ac97_read(ac97, AC97_MASTER);
2938
2939:c:func:`snd_ac97_update_bits()` is used to update some bits in
2940the given register.
2941
2942::
2943
2944 snd_ac97_update_bits(ac97, reg, mask, value);
2945
2946Also, there is a function to change the sample rate (of a given register
2947such as ``AC97_PCM_FRONT_DAC_RATE``) when VRA or DRA is supported by the
2948codec: :c:func:`snd_ac97_set_rate()`.
2949
2950::
2951
2952 snd_ac97_set_rate(ac97, AC97_PCM_FRONT_DAC_RATE, 44100);
2953
2954
2955The following registers are available to set the rate:
2956``AC97_PCM_MIC_ADC_RATE``, ``AC97_PCM_FRONT_DAC_RATE``,
2957``AC97_PCM_LR_ADC_RATE``, ``AC97_SPDIF``. When ``AC97_SPDIF`` is
2958specified, the register is not really changed but the corresponding
2959IEC958 status bits will be updated.
2960
2961Clock Adjustment
2962----------------
2963
2964In some chips, the clock of the codec isn't 48000 but using a PCI clock
2965(to save a quartz!). In this case, change the field ``bus->clock`` to
2966the corresponding value. For example, intel8x0 and es1968 drivers have
2967their own function to read from the clock.
2968
2969Proc Files
2970----------
2971
2972The ALSA AC97 interface will create a proc file such as
2973``/proc/asound/card0/codec97#0/ac97#0-0`` and ``ac97#0-0+regs``. You
2974can refer to these files to see the current status and registers of
2975the codec.
2976
2977Multiple Codecs
2978---------------
2979
2980When there are several codecs on the same card, you need to call
2981:c:func:`snd_ac97_mixer()` multiple times with ``ac97.num=1`` or
2982greater. The ``num`` field specifies the codec number.
2983
2984If you set up multiple codecs, you either need to write different
2985callbacks for each codec or check ``ac97->num`` in the callback
2986routines.
2987
2988MIDI (MPU401-UART) Interface
2989============================
2990
2991General
2992-------
2993
2994Many soundcards have built-in MIDI (MPU401-UART) interfaces. When the
2995soundcard supports the standard MPU401-UART interface, most likely you
2996can use the ALSA MPU401-UART API. The MPU401-UART API is defined in
2997``<sound/mpu401.h>``.
2998
2999Some soundchips have a similar but slightly different implementation of
3000mpu401 stuff. For example, emu10k1 has its own mpu401 routines.
3001
3002MIDI Constructor
3003----------------
3004
3005To create a rawmidi object, call :c:func:`snd_mpu401_uart_new()`.
3006
3007::
3008
3009 struct snd_rawmidi *rmidi;
3010 snd_mpu401_uart_new(card, 0, MPU401_HW_MPU401, port, info_flags,
3011 irq, &rmidi);
3012
3013
3014The first argument is the card pointer, and the second is the index of
3015this component. You can create up to 8 rawmidi devices.
3016
3017The third argument is the type of the hardware, ``MPU401_HW_XXX``. If
3018it's not a special one, you can use ``MPU401_HW_MPU401``.
3019
3020The 4th argument is the I/O port address. Many backward-compatible
3021MPU401 have an I/O port such as 0x330. Or, it might be a part of its own
3022PCI I/O region. It depends on the chip design.
3023
3024The 5th argument is a bitflag for additional information. When the I/O
3025port address above is part of the PCI I/O region, the MPU401 I/O port
3026might have been already allocated (reserved) by the driver itself. In
3027such a case, pass a bit flag ``MPU401_INFO_INTEGRATED``, and the
3028mpu401-uart layer will allocate the I/O ports by itself.
3029
3030When the controller supports only the input or output MIDI stream, pass
3031the ``MPU401_INFO_INPUT`` or ``MPU401_INFO_OUTPUT`` bitflag,
3032respectively. Then the rawmidi instance is created as a single stream.
3033
3034``MPU401_INFO_MMIO`` bitflag is used to change the access method to MMIO
3035(via readb and writeb) instead of iob and outb. In this case, you have
3036to pass the iomapped address to :c:func:`snd_mpu401_uart_new()`.
3037
3038When ``MPU401_INFO_TX_IRQ`` is set, the output stream isn't checked in
3039the default interrupt handler. The driver needs to call
3040:c:func:`snd_mpu401_uart_interrupt_tx()` by itself to start
3041processing the output stream in the irq handler.
3042
3043If the MPU-401 interface shares its interrupt with the other logical
3044devices on the card, set ``MPU401_INFO_IRQ_HOOK`` (see
3045`below <#MIDI-Interrupt-Handler>`__).
3046
3047Usually, the port address corresponds to the command port and port + 1
3048corresponds to the data port. If not, you may change the ``cport``
3049field of :c:type:`struct snd_mpu401 <snd_mpu401>` manually afterward.
3050However, :c:type:`struct snd_mpu401 <snd_mpu401>` pointer is
3051not returned explicitly by :c:func:`snd_mpu401_uart_new()`. You
3052need to cast ``rmidi->private_data`` to :c:type:`struct snd_mpu401
3053<snd_mpu401>` explicitly,
3054
3055::
3056
3057 struct snd_mpu401 *mpu;
3058 mpu = rmidi->private_data;
3059
3060and reset the ``cport`` as you like:
3061
3062::
3063
3064 mpu->cport = my_own_control_port;
3065
3066The 6th argument specifies the ISA irq number that will be allocated. If
3067no interrupt is to be allocated (because your code is already allocating
3068a shared interrupt, or because the device does not use interrupts), pass
3069-1 instead. For a MPU-401 device without an interrupt, a polling timer
3070will be used instead.
3071
3072MIDI Interrupt Handler
3073----------------------
3074
3075When the interrupt is allocated in
3076:c:func:`snd_mpu401_uart_new()`, an exclusive ISA interrupt
3077handler is automatically used, hence you don't have anything else to do
3078than creating the mpu401 stuff. Otherwise, you have to set
3079``MPU401_INFO_IRQ_HOOK``, and call
3080:c:func:`snd_mpu401_uart_interrupt()` explicitly from your own
3081interrupt handler when it has determined that a UART interrupt has
3082occurred.
3083
3084In this case, you need to pass the private_data of the returned rawmidi
3085object from :c:func:`snd_mpu401_uart_new()` as the second
3086argument of :c:func:`snd_mpu401_uart_interrupt()`.
3087
3088::
3089
3090 snd_mpu401_uart_interrupt(irq, rmidi->private_data, regs);
3091
3092
3093RawMIDI Interface
3094=================
3095
3096Overview
3097--------
3098
3099The raw MIDI interface is used for hardware MIDI ports that can be
3100accessed as a byte stream. It is not used for synthesizer chips that do
3101not directly understand MIDI.
3102
3103ALSA handles file and buffer management. All you have to do is to write
3104some code to move data between the buffer and the hardware.
3105
3106The rawmidi API is defined in ``<sound/rawmidi.h>``.
3107
3108RawMIDI Constructor
3109-------------------
3110
3111To create a rawmidi device, call the :c:func:`snd_rawmidi_new()`
3112function:
3113
3114::
3115
3116 struct snd_rawmidi *rmidi;
3117 err = snd_rawmidi_new(chip->card, "MyMIDI", 0, outs, ins, &rmidi);
3118 if (err < 0)
3119 return err;
3120 rmidi->private_data = chip;
3121 strcpy(rmidi->name, "My MIDI");
3122 rmidi->info_flags = SNDRV_RAWMIDI_INFO_OUTPUT |
3123 SNDRV_RAWMIDI_INFO_INPUT |
3124 SNDRV_RAWMIDI_INFO_DUPLEX;
3125
3126The first argument is the card pointer, the second argument is the ID
3127string.
3128
3129The third argument is the index of this component. You can create up to
31308 rawmidi devices.
3131
3132The fourth and fifth arguments are the number of output and input
3133substreams, respectively, of this device (a substream is the equivalent
3134of a MIDI port).
3135
3136Set the ``info_flags`` field to specify the capabilities of the
3137device. Set ``SNDRV_RAWMIDI_INFO_OUTPUT`` if there is at least one
3138output port, ``SNDRV_RAWMIDI_INFO_INPUT`` if there is at least one
3139input port, and ``SNDRV_RAWMIDI_INFO_DUPLEX`` if the device can handle
3140output and input at the same time.
3141
3142After the rawmidi device is created, you need to set the operators
3143(callbacks) for each substream. There are helper functions to set the
3144operators for all the substreams of a device:
3145
3146::
3147
3148 snd_rawmidi_set_ops(rmidi, SNDRV_RAWMIDI_STREAM_OUTPUT, &snd_mymidi_output_ops);
3149 snd_rawmidi_set_ops(rmidi, SNDRV_RAWMIDI_STREAM_INPUT, &snd_mymidi_input_ops);
3150
3151The operators are usually defined like this:
3152
3153::
3154
3155 static struct snd_rawmidi_ops snd_mymidi_output_ops = {
3156 .open = snd_mymidi_output_open,
3157 .close = snd_mymidi_output_close,
3158 .trigger = snd_mymidi_output_trigger,
3159 };
3160
3161These callbacks are explained in the `RawMIDI Callbacks`_ section.
3162
3163If there are more than one substream, you should give a unique name to
3164each of them:
3165
3166::
3167
3168 struct snd_rawmidi_substream *substream;
3169 list_for_each_entry(substream,
3170 &rmidi->streams[SNDRV_RAWMIDI_STREAM_OUTPUT].substreams,
3171 list {
3172 sprintf(substream->name, "My MIDI Port %d", substream->number + 1);
3173 }
3174 /* same for SNDRV_RAWMIDI_STREAM_INPUT */
3175
3176RawMIDI Callbacks
3177-----------------
3178
3179In all the callbacks, the private data that you've set for the rawmidi
3180device can be accessed as ``substream->rmidi->private_data``.
3181
3182If there is more than one port, your callbacks can determine the port
3183index from the struct snd_rawmidi_substream data passed to each
3184callback:
3185
3186::
3187
3188 struct snd_rawmidi_substream *substream;
3189 int index = substream->number;
3190
3191RawMIDI open callback
3192~~~~~~~~~~~~~~~~~~~~~
3193
3194::
3195
3196 static int snd_xxx_open(struct snd_rawmidi_substream *substream);
3197
3198
3199This is called when a substream is opened. You can initialize the
3200hardware here, but you shouldn't start transmitting/receiving data yet.
3201
3202RawMIDI close callback
3203~~~~~~~~~~~~~~~~~~~~~~
3204
3205::
3206
3207 static int snd_xxx_close(struct snd_rawmidi_substream *substream);
3208
3209Guess what.
3210
3211The ``open`` and ``close`` callbacks of a rawmidi device are
3212serialized with a mutex, and can sleep.
3213
3214Rawmidi trigger callback for output substreams
3215~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
3216
3217::
3218
3219 static void snd_xxx_output_trigger(struct snd_rawmidi_substream *substream, int up);
3220
3221
3222This is called with a nonzero ``up`` parameter when there is some data
3223in the substream buffer that must be transmitted.
3224
3225To read data from the buffer, call
3226:c:func:`snd_rawmidi_transmit_peek()`. It will return the number
3227of bytes that have been read; this will be less than the number of bytes
3228requested when there are no more data in the buffer. After the data have
3229been transmitted successfully, call
3230:c:func:`snd_rawmidi_transmit_ack()` to remove the data from the
3231substream buffer:
3232
3233::
3234
3235 unsigned char data;
3236 while (snd_rawmidi_transmit_peek(substream, &data, 1) == 1) {
3237 if (snd_mychip_try_to_transmit(data))
3238 snd_rawmidi_transmit_ack(substream, 1);
3239 else
3240 break; /* hardware FIFO full */
3241 }
3242
3243If you know beforehand that the hardware will accept data, you can use
3244the :c:func:`snd_rawmidi_transmit()` function which reads some
3245data and removes them from the buffer at once:
3246
3247::
3248
3249 while (snd_mychip_transmit_possible()) {
3250 unsigned char data;
3251 if (snd_rawmidi_transmit(substream, &data, 1) != 1)
3252 break; /* no more data */
3253 snd_mychip_transmit(data);
3254 }
3255
3256If you know beforehand how many bytes you can accept, you can use a
3257buffer size greater than one with the
3258:c:func:`snd_rawmidi_transmit\*()` functions.
3259
3260The ``trigger`` callback must not sleep. If the hardware FIFO is full
3261before the substream buffer has been emptied, you have to continue
3262transmitting data later, either in an interrupt handler, or with a
3263timer if the hardware doesn't have a MIDI transmit interrupt.
3264
3265The ``trigger`` callback is called with a zero ``up`` parameter when
3266the transmission of data should be aborted.
3267
3268RawMIDI trigger callback for input substreams
3269~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
3270
3271::
3272
3273 static void snd_xxx_input_trigger(struct snd_rawmidi_substream *substream, int up);
3274
3275
3276This is called with a nonzero ``up`` parameter to enable receiving data,
3277or with a zero ``up`` parameter do disable receiving data.
3278
3279The ``trigger`` callback must not sleep; the actual reading of data
3280from the device is usually done in an interrupt handler.
3281
3282When data reception is enabled, your interrupt handler should call
3283:c:func:`snd_rawmidi_receive()` for all received data:
3284
3285::
3286
3287 void snd_mychip_midi_interrupt(...)
3288 {
3289 while (mychip_midi_available()) {
3290 unsigned char data;
3291 data = mychip_midi_read();
3292 snd_rawmidi_receive(substream, &data, 1);
3293 }
3294 }
3295
3296
3297drain callback
3298~~~~~~~~~~~~~~
3299
3300::
3301
3302 static void snd_xxx_drain(struct snd_rawmidi_substream *substream);
3303
3304
3305This is only used with output substreams. This function should wait
3306until all data read from the substream buffer have been transmitted.
3307This ensures that the device can be closed and the driver unloaded
3308without losing data.
3309
3310This callback is optional. If you do not set ``drain`` in the struct
3311snd_rawmidi_ops structure, ALSA will simply wait for 50 milliseconds
3312instead.
3313
3314Miscellaneous Devices
3315=====================
3316
3317FM OPL3
3318-------
3319
3320The FM OPL3 is still used in many chips (mainly for backward
3321compatibility). ALSA has a nice OPL3 FM control layer, too. The OPL3 API
3322is defined in ``<sound/opl3.h>``.
3323
3324FM registers can be directly accessed through the direct-FM API, defined
3325in ``<sound/asound_fm.h>``. In ALSA native mode, FM registers are
3326accessed through the Hardware-Dependent Device direct-FM extension API,
3327whereas in OSS compatible mode, FM registers can be accessed with the
3328OSS direct-FM compatible API in ``/dev/dmfmX`` device.
3329
3330To create the OPL3 component, you have two functions to call. The first
3331one is a constructor for the ``opl3_t`` instance.
3332
3333::
3334
3335 struct snd_opl3 *opl3;
3336 snd_opl3_create(card, lport, rport, OPL3_HW_OPL3_XXX,
3337 integrated, &opl3);
3338
3339The first argument is the card pointer, the second one is the left port
3340address, and the third is the right port address. In most cases, the
3341right port is placed at the left port + 2.
3342
3343The fourth argument is the hardware type.
3344
3345When the left and right ports have been already allocated by the card
3346driver, pass non-zero to the fifth argument (``integrated``). Otherwise,
3347the opl3 module will allocate the specified ports by itself.
3348
3349When the accessing the hardware requires special method instead of the
3350standard I/O access, you can create opl3 instance separately with
3351:c:func:`snd_opl3_new()`.
3352
3353::
3354
3355 struct snd_opl3 *opl3;
3356 snd_opl3_new(card, OPL3_HW_OPL3_XXX, &opl3);
3357
3358Then set ``command``, ``private_data`` and ``private_free`` for the
3359private access function, the private data and the destructor. The
3360``l_port`` and ``r_port`` are not necessarily set. Only the command
3361must be set properly. You can retrieve the data from the
3362``opl3->private_data`` field.
3363
3364After creating the opl3 instance via :c:func:`snd_opl3_new()`,
3365call :c:func:`snd_opl3_init()` to initialize the chip to the
3366proper state. Note that :c:func:`snd_opl3_create()` always calls
3367it internally.
3368
3369If the opl3 instance is created successfully, then create a hwdep device
3370for this opl3.
3371
3372::
3373
3374 struct snd_hwdep *opl3hwdep;
3375 snd_opl3_hwdep_new(opl3, 0, 1, &opl3hwdep);
3376
3377The first argument is the ``opl3_t`` instance you created, and the
3378second is the index number, usually 0.
3379
3380The third argument is the index-offset for the sequencer client assigned
3381to the OPL3 port. When there is an MPU401-UART, give 1 for here (UART
3382always takes 0).
3383
3384Hardware-Dependent Devices
3385--------------------------
3386
3387Some chips need user-space access for special controls or for loading
3388the micro code. In such a case, you can create a hwdep
3389(hardware-dependent) device. The hwdep API is defined in
3390``<sound/hwdep.h>``. You can find examples in opl3 driver or
3391``isa/sb/sb16_csp.c``.
3392
3393The creation of the ``hwdep`` instance is done via
3394:c:func:`snd_hwdep_new()`.
3395
3396::
3397
3398 struct snd_hwdep *hw;
3399 snd_hwdep_new(card, "My HWDEP", 0, &hw);
3400
3401where the third argument is the index number.
3402
3403You can then pass any pointer value to the ``private_data``. If you
3404assign a private data, you should define the destructor, too. The
3405destructor function is set in the ``private_free`` field.
3406
3407::
3408
3409 struct mydata *p = kmalloc(sizeof(*p), GFP_KERNEL);
3410 hw->private_data = p;
3411 hw->private_free = mydata_free;
3412
3413and the implementation of the destructor would be:
3414
3415::
3416
3417 static void mydata_free(struct snd_hwdep *hw)
3418 {
3419 struct mydata *p = hw->private_data;
3420 kfree(p);
3421 }
3422
3423The arbitrary file operations can be defined for this instance. The file
3424operators are defined in the ``ops`` table. For example, assume that
3425this chip needs an ioctl.
3426
3427::
3428
3429 hw->ops.open = mydata_open;
3430 hw->ops.ioctl = mydata_ioctl;
3431 hw->ops.release = mydata_release;
3432
3433And implement the callback functions as you like.
3434
3435IEC958 (S/PDIF)
3436---------------
3437
3438Usually the controls for IEC958 devices are implemented via the control
3439interface. There is a macro to compose a name string for IEC958
3440controls, :c:func:`SNDRV_CTL_NAME_IEC958()` defined in
3441``<include/asound.h>``.
3442
3443There are some standard controls for IEC958 status bits. These controls
3444use the type ``SNDRV_CTL_ELEM_TYPE_IEC958``, and the size of element is
3445fixed as 4 bytes array (value.iec958.status[x]). For the ``info``
3446callback, you don't specify the value field for this type (the count
3447field must be set, though).
3448
3449“IEC958 Playback Con Mask” is used to return the bit-mask for the IEC958
3450status bits of consumer mode. Similarly, “IEC958 Playback Pro Mask”
3451returns the bitmask for professional mode. They are read-only controls,
3452and are defined as MIXER controls (iface =
3453``SNDRV_CTL_ELEM_IFACE_MIXER``).
3454
3455Meanwhile, “IEC958 Playback Default” control is defined for getting and
3456setting the current default IEC958 bits. Note that this one is usually
3457defined as a PCM control (iface = ``SNDRV_CTL_ELEM_IFACE_PCM``),
3458although in some places it's defined as a MIXER control.
3459
3460In addition, you can define the control switches to enable/disable or to
3461set the raw bit mode. The implementation will depend on the chip, but
3462the control should be named as “IEC958 xxx”, preferably using the
3463:c:func:`SNDRV_CTL_NAME_IEC958()` macro.
3464
3465You can find several cases, for example, ``pci/emu10k1``,
3466``pci/ice1712``, or ``pci/cmipci.c``.
3467
3468Buffer and Memory Management
3469============================
3470
3471Buffer Types
3472------------
3473
3474ALSA provides several different buffer allocation functions depending on
3475the bus and the architecture. All these have a consistent API. The
3476allocation of physically-contiguous pages is done via
3477:c:func:`snd_malloc_xxx_pages()` function, where xxx is the bus
3478type.
3479
3480The allocation of pages with fallback is
3481:c:func:`snd_malloc_xxx_pages_fallback()`. This function tries
3482to allocate the specified pages but if the pages are not available, it
3483tries to reduce the page sizes until enough space is found.
3484
3485The release the pages, call :c:func:`snd_free_xxx_pages()`
3486function.
3487
3488Usually, ALSA drivers try to allocate and reserve a large contiguous
3489physical space at the time the module is loaded for the later use. This
3490is called “pre-allocation”. As already written, you can call the
3491following function at pcm instance construction time (in the case of PCI
3492bus).
3493
3494::
3495
3496 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV,
3497 snd_dma_pci_data(pci), size, max);
3498
3499where ``size`` is the byte size to be pre-allocated and the ``max`` is
3500the maximum size to be changed via the ``prealloc`` proc file. The
3501allocator will try to get an area as large as possible within the
3502given size.
3503
3504The second argument (type) and the third argument (device pointer) are
3505dependent on the bus. In the case of the ISA bus, pass
3506:c:func:`snd_dma_isa_data()` as the third argument with
3507``SNDRV_DMA_TYPE_DEV`` type. For the continuous buffer unrelated to the
3508bus can be pre-allocated with ``SNDRV_DMA_TYPE_CONTINUOUS`` type and the
3509``snd_dma_continuous_data(GFP_KERNEL)`` device pointer, where
3510``GFP_KERNEL`` is the kernel allocation flag to use. For the PCI
3511scatter-gather buffers, use ``SNDRV_DMA_TYPE_DEV_SG`` with
3512``snd_dma_pci_data(pci)`` (see the `Non-Contiguous Buffers`_
3513section).
3514
3515Once the buffer is pre-allocated, you can use the allocator in the
3516``hw_params`` callback:
3517
3518::
3519
3520 snd_pcm_lib_malloc_pages(substream, size);
3521
3522Note that you have to pre-allocate to use this function.
3523
3524External Hardware Buffers
3525-------------------------
3526
3527Some chips have their own hardware buffers and the DMA transfer from the
3528host memory is not available. In such a case, you need to either 1)
3529copy/set the audio data directly to the external hardware buffer, or 2)
3530make an intermediate buffer and copy/set the data from it to the
3531external hardware buffer in interrupts (or in tasklets, preferably).
3532
3533The first case works fine if the external hardware buffer is large
3534enough. This method doesn't need any extra buffers and thus is more
3535effective. You need to define the ``copy`` and ``silence`` callbacks
3536for the data transfer. However, there is a drawback: it cannot be
3537mmapped. The examples are GUS's GF1 PCM or emu8000's wavetable PCM.
3538
3539The second case allows for mmap on the buffer, although you have to
3540handle an interrupt or a tasklet to transfer the data from the
3541intermediate buffer to the hardware buffer. You can find an example in
3542the vxpocket driver.
3543
3544Another case is when the chip uses a PCI memory-map region for the
3545buffer instead of the host memory. In this case, mmap is available only
3546on certain architectures like the Intel one. In non-mmap mode, the data
3547cannot be transferred as in the normal way. Thus you need to define the
3548``copy`` and ``silence`` callbacks as well, as in the cases above. The
3549examples are found in ``rme32.c`` and ``rme96.c``.
3550
3551The implementation of the ``copy`` and ``silence`` callbacks depends
3552upon whether the hardware supports interleaved or non-interleaved
3553samples. The ``copy`` callback is defined like below, a bit
3554differently depending whether the direction is playback or capture:
3555
3556::
3557
3558 static int playback_copy(struct snd_pcm_substream *substream, int channel,
3559 snd_pcm_uframes_t pos, void *src, snd_pcm_uframes_t count);
3560 static int capture_copy(struct snd_pcm_substream *substream, int channel,
3561 snd_pcm_uframes_t pos, void *dst, snd_pcm_uframes_t count);
3562
3563In the case of interleaved samples, the second argument (``channel``) is
3564not used. The third argument (``pos``) points the current position
3565offset in frames.
3566
3567The meaning of the fourth argument is different between playback and
3568capture. For playback, it holds the source data pointer, and for
3569capture, it's the destination data pointer.
3570
3571The last argument is the number of frames to be copied.
3572
3573What you have to do in this callback is again different between playback
3574and capture directions. In the playback case, you copy the given amount
3575of data (``count``) at the specified pointer (``src``) to the specified
3576offset (``pos``) on the hardware buffer. When coded like memcpy-like
3577way, the copy would be like:
3578
3579::
3580
3581 my_memcpy(my_buffer + frames_to_bytes(runtime, pos), src,
3582 frames_to_bytes(runtime, count));
3583
3584For the capture direction, you copy the given amount of data (``count``)
3585at the specified offset (``pos``) on the hardware buffer to the
3586specified pointer (``dst``).
3587
3588::
3589
3590 my_memcpy(dst, my_buffer + frames_to_bytes(runtime, pos),
3591 frames_to_bytes(runtime, count));
3592
3593Note that both the position and the amount of data are given in frames.
3594
3595In the case of non-interleaved samples, the implementation will be a bit
3596more complicated.
3597
3598You need to check the channel argument, and if it's -1, copy the whole
3599channels. Otherwise, you have to copy only the specified channel. Please
3600check ``isa/gus/gus_pcm.c`` as an example.
3601
3602The ``silence`` callback is also implemented in a similar way
3603
3604::
3605
3606 static int silence(struct snd_pcm_substream *substream, int channel,
3607 snd_pcm_uframes_t pos, snd_pcm_uframes_t count);
3608
3609The meanings of arguments are the same as in the ``copy`` callback,
3610although there is no ``src/dst`` argument. In the case of interleaved
3611samples, the channel argument has no meaning, as well as on ``copy``
3612callback.
3613
3614The role of ``silence`` callback is to set the given amount
3615(``count``) of silence data at the specified offset (``pos``) on the
3616hardware buffer. Suppose that the data format is signed (that is, the
3617silent-data is 0), and the implementation using a memset-like function
3618would be like:
3619
3620::
3621
3622 my_memcpy(my_buffer + frames_to_bytes(runtime, pos), 0,
3623 frames_to_bytes(runtime, count));
3624
3625In the case of non-interleaved samples, again, the implementation
3626becomes a bit more complicated. See, for example, ``isa/gus/gus_pcm.c``.
3627
3628Non-Contiguous Buffers
3629----------------------
3630
3631If your hardware supports the page table as in emu10k1 or the buffer
3632descriptors as in via82xx, you can use the scatter-gather (SG) DMA. ALSA
3633provides an interface for handling SG-buffers. The API is provided in
3634``<sound/pcm.h>``.
3635
3636For creating the SG-buffer handler, call
3637:c:func:`snd_pcm_lib_preallocate_pages()` or
3638:c:func:`snd_pcm_lib_preallocate_pages_for_all()` with
3639``SNDRV_DMA_TYPE_DEV_SG`` in the PCM constructor like other PCI
3640pre-allocator. You need to pass ``snd_dma_pci_data(pci)``, where pci is
3641the :c:type:`struct pci_dev <pci_dev>` pointer of the chip as
3642well. The ``struct snd_sg_buf`` instance is created as
3643``substream->dma_private``. You can cast the pointer like:
3644
3645::
3646
3647 struct snd_sg_buf *sgbuf = (struct snd_sg_buf *)substream->dma_private;
3648
3649Then call :c:func:`snd_pcm_lib_malloc_pages()` in the ``hw_params``
3650callback as well as in the case of normal PCI buffer. The SG-buffer
3651handler will allocate the non-contiguous kernel pages of the given size
3652and map them onto the virtually contiguous memory. The virtual pointer
3653is addressed in runtime->dma_area. The physical address
3654(``runtime->dma_addr``) is set to zero, because the buffer is
3655physically non-contiguous. The physical address table is set up in
3656``sgbuf->table``. You can get the physical address at a certain offset
3657via :c:func:`snd_pcm_sgbuf_get_addr()`.
3658
3659When a SG-handler is used, you need to set
3660:c:func:`snd_pcm_sgbuf_ops_page()` as the ``page`` callback. (See
3661`page callback`_ section.)
3662
3663To release the data, call :c:func:`snd_pcm_lib_free_pages()` in
3664the ``hw_free`` callback as usual.
3665
3666Vmalloc'ed Buffers
3667------------------
3668
3669It's possible to use a buffer allocated via :c:func:`vmalloc()`, for
3670example, for an intermediate buffer. Since the allocated pages are not
3671contiguous, you need to set the ``page`` callback to obtain the physical
3672address at every offset.
3673
3674The implementation of ``page`` callback would be like this:
3675
3676::
3677
3678 #include <linux/vmalloc.h>
3679
3680 /* get the physical page pointer on the given offset */
3681 static struct page *mychip_page(struct snd_pcm_substream *substream,
3682 unsigned long offset)
3683 {
3684 void *pageptr = substream->runtime->dma_area + offset;
3685 return vmalloc_to_page(pageptr);
3686 }
3687
3688Proc Interface
3689==============
3690
3691ALSA provides an easy interface for procfs. The proc files are very
3692useful for debugging. I recommend you set up proc files if you write a
3693driver and want to get a running status or register dumps. The API is
3694found in ``<sound/info.h>``.
3695
3696To create a proc file, call :c:func:`snd_card_proc_new()`.
3697
3698::
3699
3700 struct snd_info_entry *entry;
3701 int err = snd_card_proc_new(card, "my-file", &entry);
3702
3703where the second argument specifies the name of the proc file to be
3704created. The above example will create a file ``my-file`` under the
3705card directory, e.g. ``/proc/asound/card0/my-file``.
3706
3707Like other components, the proc entry created via
3708:c:func:`snd_card_proc_new()` will be registered and released
3709automatically in the card registration and release functions.
3710
3711When the creation is successful, the function stores a new instance in
3712the pointer given in the third argument. It is initialized as a text
3713proc file for read only. To use this proc file as a read-only text file
3714as it is, set the read callback with a private data via
3715:c:func:`snd_info_set_text_ops()`.
3716
3717::
3718
3719 snd_info_set_text_ops(entry, chip, my_proc_read);
3720
3721where the second argument (``chip``) is the private data to be used in
3722the callbacks. The third parameter specifies the read buffer size and
3723the fourth (``my_proc_read``) is the callback function, which is
3724defined like
3725
3726::
3727
3728 static void my_proc_read(struct snd_info_entry *entry,
3729 struct snd_info_buffer *buffer);
3730
3731In the read callback, use :c:func:`snd_iprintf()` for output
3732strings, which works just like normal :c:func:`printf()`. For
3733example,
3734
3735::
3736
3737 static void my_proc_read(struct snd_info_entry *entry,
3738 struct snd_info_buffer *buffer)
3739 {
3740 struct my_chip *chip = entry->private_data;
3741
3742 snd_iprintf(buffer, "This is my chip!\n");
3743 snd_iprintf(buffer, "Port = %ld\n", chip->port);
3744 }
3745
3746The file permissions can be changed afterwards. As default, it's set as
3747read only for all users. If you want to add write permission for the
3748user (root as default), do as follows:
3749
3750::
3751
3752 entry->mode = S_IFREG | S_IRUGO | S_IWUSR;
3753
3754and set the write buffer size and the callback
3755
3756::
3757
3758 entry->c.text.write = my_proc_write;
3759
3760For the write callback, you can use :c:func:`snd_info_get_line()`
3761to get a text line, and :c:func:`snd_info_get_str()` to retrieve
3762a string from the line. Some examples are found in
3763``core/oss/mixer_oss.c``, core/oss/and ``pcm_oss.c``.
3764
3765For a raw-data proc-file, set the attributes as follows:
3766
3767::
3768
3769 static struct snd_info_entry_ops my_file_io_ops = {
3770 .read = my_file_io_read,
3771 };
3772
3773 entry->content = SNDRV_INFO_CONTENT_DATA;
3774 entry->private_data = chip;
3775 entry->c.ops = &my_file_io_ops;
3776 entry->size = 4096;
3777 entry->mode = S_IFREG | S_IRUGO;
3778
3779For the raw data, ``size`` field must be set properly. This specifies
3780the maximum size of the proc file access.
3781
3782The read/write callbacks of raw mode are more direct than the text mode.
3783You need to use a low-level I/O functions such as
3784:c:func:`copy_from/to_user()` to transfer the data.
3785
3786::
3787
3788 static ssize_t my_file_io_read(struct snd_info_entry *entry,
3789 void *file_private_data,
3790 struct file *file,
3791 char *buf,
3792 size_t count,
3793 loff_t pos)
3794 {
3795 if (copy_to_user(buf, local_data + pos, count))
3796 return -EFAULT;
3797 return count;
3798 }
3799
3800If the size of the info entry has been set up properly, ``count`` and
3801``pos`` are guaranteed to fit within 0 and the given size. You don't
3802have to check the range in the callbacks unless any other condition is
3803required.
3804
3805Power Management
3806================
3807
3808If the chip is supposed to work with suspend/resume functions, you need
3809to add power-management code to the driver. The additional code for
3810power-management should be ifdef-ed with ``CONFIG_PM``.
3811
3812If the driver *fully* supports suspend/resume that is, the device can be
3813properly resumed to its state when suspend was called, you can set the
3814``SNDRV_PCM_INFO_RESUME`` flag in the pcm info field. Usually, this is
3815possible when the registers of the chip can be safely saved and restored
3816to RAM. If this is set, the trigger callback is called with
3817``SNDRV_PCM_TRIGGER_RESUME`` after the resume callback completes.
3818
3819Even if the driver doesn't support PM fully but partial suspend/resume
3820is still possible, it's still worthy to implement suspend/resume
3821callbacks. In such a case, applications would reset the status by
3822calling :c:func:`snd_pcm_prepare()` and restart the stream
3823appropriately. Hence, you can define suspend/resume callbacks below but
3824don't set ``SNDRV_PCM_INFO_RESUME`` info flag to the PCM.
3825
3826Note that the trigger with SUSPEND can always be called when
3827:c:func:`snd_pcm_suspend_all()` is called, regardless of the
3828``SNDRV_PCM_INFO_RESUME`` flag. The ``RESUME`` flag affects only the
3829behavior of :c:func:`snd_pcm_resume()`. (Thus, in theory,
3830``SNDRV_PCM_TRIGGER_RESUME`` isn't needed to be handled in the trigger
3831callback when no ``SNDRV_PCM_INFO_RESUME`` flag is set. But, it's better
3832to keep it for compatibility reasons.)
3833
3834In the earlier version of ALSA drivers, a common power-management layer
3835was provided, but it has been removed. The driver needs to define the
3836suspend/resume hooks according to the bus the device is connected to. In
3837the case of PCI drivers, the callbacks look like below:
3838
3839::
3840
3841 #ifdef CONFIG_PM
3842 static int snd_my_suspend(struct pci_dev *pci, pm_message_t state)
3843 {
3844 .... /* do things for suspend */
3845 return 0;
3846 }
3847 static int snd_my_resume(struct pci_dev *pci)
3848 {
3849 .... /* do things for suspend */
3850 return 0;
3851 }
3852 #endif
3853
3854The scheme of the real suspend job is as follows.
3855
38561. Retrieve the card and the chip data.
3857
38582. Call :c:func:`snd_power_change_state()` with
3859 ``SNDRV_CTL_POWER_D3hot`` to change the power status.
3860
38613. Call :c:func:`snd_pcm_suspend_all()` to suspend the running
3862 PCM streams.
3863
38644. If AC97 codecs are used, call :c:func:`snd_ac97_suspend()` for
3865 each codec.
3866
38675. Save the register values if necessary.
3868
38696. Stop the hardware if necessary.
3870
38717. Disable the PCI device by calling
3872 :c:func:`pci_disable_device()`. Then, call
3873 :c:func:`pci_save_state()` at last.
3874
3875A typical code would be like:
3876
3877::
3878
3879 static int mychip_suspend(struct pci_dev *pci, pm_message_t state)
3880 {
3881 /* (1) */
3882 struct snd_card *card = pci_get_drvdata(pci);
3883 struct mychip *chip = card->private_data;
3884 /* (2) */
3885 snd_power_change_state(card, SNDRV_CTL_POWER_D3hot);
3886 /* (3) */
3887 snd_pcm_suspend_all(chip->pcm);
3888 /* (4) */
3889 snd_ac97_suspend(chip->ac97);
3890 /* (5) */
3891 snd_mychip_save_registers(chip);
3892 /* (6) */
3893 snd_mychip_stop_hardware(chip);
3894 /* (7) */
3895 pci_disable_device(pci);
3896 pci_save_state(pci);
3897 return 0;
3898 }
3899
3900
3901The scheme of the real resume job is as follows.
3902
39031. Retrieve the card and the chip data.
3904
39052. Set up PCI. First, call :c:func:`pci_restore_state()`. Then
3906 enable the pci device again by calling
3907 :c:func:`pci_enable_device()`. Call
3908 :c:func:`pci_set_master()` if necessary, too.
3909
39103. Re-initialize the chip.
3911
39124. Restore the saved registers if necessary.
3913
39145. Resume the mixer, e.g. calling :c:func:`snd_ac97_resume()`.
3915
39166. Restart the hardware (if any).
3917
39187. Call :c:func:`snd_power_change_state()` with
3919 ``SNDRV_CTL_POWER_D0`` to notify the processes.
3920
3921A typical code would be like:
3922
3923::
3924
3925 static int mychip_resume(struct pci_dev *pci)
3926 {
3927 /* (1) */
3928 struct snd_card *card = pci_get_drvdata(pci);
3929 struct mychip *chip = card->private_data;
3930 /* (2) */
3931 pci_restore_state(pci);
3932 pci_enable_device(pci);
3933 pci_set_master(pci);
3934 /* (3) */
3935 snd_mychip_reinit_chip(chip);
3936 /* (4) */
3937 snd_mychip_restore_registers(chip);
3938 /* (5) */
3939 snd_ac97_resume(chip->ac97);
3940 /* (6) */
3941 snd_mychip_restart_chip(chip);
3942 /* (7) */
3943 snd_power_change_state(card, SNDRV_CTL_POWER_D0);
3944 return 0;
3945 }
3946
3947As shown in the above, it's better to save registers after suspending
3948the PCM operations via :c:func:`snd_pcm_suspend_all()` or
3949:c:func:`snd_pcm_suspend()`. It means that the PCM streams are
3950already stopped when the register snapshot is taken. But, remember that
3951you don't have to restart the PCM stream in the resume callback. It'll
3952be restarted via trigger call with ``SNDRV_PCM_TRIGGER_RESUME`` when
3953necessary.
3954
3955OK, we have all callbacks now. Let's set them up. In the initialization
3956of the card, make sure that you can get the chip data from the card
3957instance, typically via ``private_data`` field, in case you created the
3958chip data individually.
3959
3960::
3961
3962 static int snd_mychip_probe(struct pci_dev *pci,
3963 const struct pci_device_id *pci_id)
3964 {
3965 ....
3966 struct snd_card *card;
3967 struct mychip *chip;
3968 int err;
3969 ....
3970 err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
3971 0, &card);
3972 ....
3973 chip = kzalloc(sizeof(*chip), GFP_KERNEL);
3974 ....
3975 card->private_data = chip;
3976 ....
3977 }
3978
3979When you created the chip data with :c:func:`snd_card_new()`, it's
3980anyway accessible via ``private_data`` field.
3981
3982::
3983
3984 static int snd_mychip_probe(struct pci_dev *pci,
3985 const struct pci_device_id *pci_id)
3986 {
3987 ....
3988 struct snd_card *card;
3989 struct mychip *chip;
3990 int err;
3991 ....
3992 err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
3993 sizeof(struct mychip), &card);
3994 ....
3995 chip = card->private_data;
3996 ....
3997 }
3998
3999If you need a space to save the registers, allocate the buffer for it
4000here, too, since it would be fatal if you cannot allocate a memory in
4001the suspend phase. The allocated buffer should be released in the
4002corresponding destructor.
4003
4004And next, set suspend/resume callbacks to the pci_driver.
4005
4006::
4007
4008 static struct pci_driver driver = {
4009 .name = KBUILD_MODNAME,
4010 .id_table = snd_my_ids,
4011 .probe = snd_my_probe,
4012 .remove = snd_my_remove,
4013 #ifdef CONFIG_PM
4014 .suspend = snd_my_suspend,
4015 .resume = snd_my_resume,
4016 #endif
4017 };
4018
4019Module Parameters
4020=================
4021
4022There are standard module options for ALSA. At least, each module should
4023have the ``index``, ``id`` and ``enable`` options.
4024
4025If the module supports multiple cards (usually up to 8 = ``SNDRV_CARDS``
4026cards), they should be arrays. The default initial values are defined
4027already as constants for easier programming:
4028
4029::
4030
4031 static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;
4032 static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR;
4033 static int enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP;
4034
4035If the module supports only a single card, they could be single
4036variables, instead. ``enable`` option is not always necessary in this
4037case, but it would be better to have a dummy option for compatibility.
4038
4039The module parameters must be declared with the standard
4040``module_param()()``, ``module_param_array()()`` and
4041:c:func:`MODULE_PARM_DESC()` macros.
4042
4043The typical coding would be like below:
4044
4045::
4046
4047 #define CARD_NAME "My Chip"
4048
4049 module_param_array(index, int, NULL, 0444);
4050 MODULE_PARM_DESC(index, "Index value for " CARD_NAME " soundcard.");
4051 module_param_array(id, charp, NULL, 0444);
4052 MODULE_PARM_DESC(id, "ID string for " CARD_NAME " soundcard.");
4053 module_param_array(enable, bool, NULL, 0444);
4054 MODULE_PARM_DESC(enable, "Enable " CARD_NAME " soundcard.");
4055
4056Also, don't forget to define the module description, classes, license
4057and devices. Especially, the recent modprobe requires to define the
4058module license as GPL, etc., otherwise the system is shown as “tainted”.
4059
4060::
4061
4062 MODULE_DESCRIPTION("My Chip");
4063 MODULE_LICENSE("GPL");
4064 MODULE_SUPPORTED_DEVICE("{{Vendor,My Chip Name}}");
4065
4066
4067How To Put Your Driver Into ALSA Tree
4068=====================================
4069
4070General
4071-------
4072
4073So far, you've learned how to write the driver codes. And you might have
4074a question now: how to put my own driver into the ALSA driver tree? Here
4075(finally :) the standard procedure is described briefly.
4076
4077Suppose that you create a new PCI driver for the card “xyz”. The card
4078module name would be snd-xyz. The new driver is usually put into the
4079alsa-driver tree, ``alsa-driver/pci`` directory in the case of PCI
4080cards. Then the driver is evaluated, audited and tested by developers
4081and users. After a certain time, the driver will go to the alsa-kernel
4082tree (to the corresponding directory, such as ``alsa-kernel/pci``) and
4083eventually will be integrated into the Linux 2.6 tree (the directory
4084would be ``linux/sound/pci``).
4085
4086In the following sections, the driver code is supposed to be put into
4087alsa-driver tree. The two cases are covered: a driver consisting of a
4088single source file and one consisting of several source files.
4089
4090Driver with A Single Source File
4091--------------------------------
4092
40931. Modify alsa-driver/pci/Makefile
4094
4095 Suppose you have a file xyz.c. Add the following two lines
4096
4097::
4098
4099 snd-xyz-objs := xyz.o
4100 obj-$(CONFIG_SND_XYZ) += snd-xyz.o
4101
41022. Create the Kconfig entry
4103
4104 Add the new entry of Kconfig for your xyz driver. config SND_XYZ
4105 tristate "Foobar XYZ" depends on SND select SND_PCM help Say Y here
4106 to include support for Foobar XYZ soundcard. To compile this driver
4107 as a module, choose M here: the module will be called snd-xyz. the
4108 line, select SND_PCM, specifies that the driver xyz supports PCM. In
4109 addition to SND_PCM, the following components are supported for
4110 select command: SND_RAWMIDI, SND_TIMER, SND_HWDEP,
4111 SND_MPU401_UART, SND_OPL3_LIB, SND_OPL4_LIB, SND_VX_LIB,
4112 SND_AC97_CODEC. Add the select command for each supported
4113 component.
4114
4115 Note that some selections imply the lowlevel selections. For example,
4116 PCM includes TIMER, MPU401_UART includes RAWMIDI, AC97_CODEC
4117 includes PCM, and OPL3_LIB includes HWDEP. You don't need to give
4118 the lowlevel selections again.
4119
4120 For the details of Kconfig script, refer to the kbuild documentation.
4121
41223. Run cvscompile script to re-generate the configure script and build
4123 the whole stuff again.
4124
4125Drivers with Several Source Files
4126---------------------------------
4127
4128Suppose that the driver snd-xyz have several source files. They are
4129located in the new subdirectory, pci/xyz.
4130
41311. Add a new directory (``xyz``) in ``alsa-driver/pci/Makefile`` as
4132 below
4133
4134::
4135
4136 obj-$(CONFIG_SND) += xyz/
4137
4138
41392. Under the directory ``xyz``, create a Makefile
4140
4141::
4142
4143 ifndef SND_TOPDIR
4144 SND_TOPDIR=../..
4145 endif
4146
4147 include $(SND_TOPDIR)/toplevel.config
4148 include $(SND_TOPDIR)/Makefile.conf
4149
4150 snd-xyz-objs := xyz.o abc.o def.o
4151
4152 obj-$(CONFIG_SND_XYZ) += snd-xyz.o
4153
4154 include $(SND_TOPDIR)/Rules.make
4155
41563. Create the Kconfig entry
4157
4158 This procedure is as same as in the last section.
4159
41604. Run cvscompile script to re-generate the configure script and build
4161 the whole stuff again.
4162
4163Useful Functions
4164================
4165
4166:c:func:`snd_printk()` and friends
4167---------------------------------------
4168
4169ALSA provides a verbose version of the :c:func:`printk()` function.
4170If a kernel config ``CONFIG_SND_VERBOSE_PRINTK`` is set, this function
4171prints the given message together with the file name and the line of the
4172caller. The ``KERN_XXX`` prefix is processed as well as the original
4173:c:func:`printk()` does, so it's recommended to add this prefix,
4174e.g. snd_printk(KERN_ERR "Oh my, sorry, it's extremely bad!\\n");
4175
4176There are also :c:func:`printk()`'s for debugging.
4177:c:func:`snd_printd()` can be used for general debugging purposes.
4178If ``CONFIG_SND_DEBUG`` is set, this function is compiled, and works
4179just like :c:func:`snd_printk()`. If the ALSA is compiled without
4180the debugging flag, it's ignored.
4181
4182:c:func:`snd_printdd()` is compiled in only when
4183``CONFIG_SND_DEBUG_VERBOSE`` is set. Please note that
4184``CONFIG_SND_DEBUG_VERBOSE`` is not set as default even if you configure
4185the alsa-driver with ``--with-debug=full`` option. You need to give
4186explicitly ``--with-debug=detect`` option instead.
4187
4188:c:func:`snd_BUG()`
4189------------------------
4190
4191It shows the ``BUG?`` message and stack trace as well as
4192:c:func:`snd_BUG_ON()` at the point. It's useful to show that a
4193fatal error happens there.
4194
4195When no debug flag is set, this macro is ignored.
4196
4197:c:func:`snd_BUG_ON()`
4198----------------------------
4199
4200:c:func:`snd_BUG_ON()` macro is similar with
4201:c:func:`WARN_ON()` macro. For example, snd_BUG_ON(!pointer); or
4202it can be used as the condition, if (snd_BUG_ON(non_zero_is_bug))
4203return -EINVAL;
4204
4205The macro takes an conditional expression to evaluate. When
4206``CONFIG_SND_DEBUG``, is set, if the expression is non-zero, it shows
4207the warning message such as ``BUG? (xxx)`` normally followed by stack
4208trace. In both cases it returns the evaluated value.
4209
4210Acknowledgments
4211===============
4212
4213I would like to thank Phil Kerr for his help for improvement and
4214corrections of this document.
4215
4216Kevin Conder reformatted the original plain-text to the DocBook format.
4217
4218Giuliano Pochini corrected typos and contributed the example codes in
4219the hardware constraints section.