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