/*! \mainpage Index Preamble and License \author Jaroslav Kysela \author Abramo Bagnara \author Takashi Iwai \author Frank van de Pol

Preface

The Advanced Linux Sound Architecture (\e ALSA) comes with a kernel API and a library API. This document describes the library API and how it interfaces with the kernel API.

Documentation License

This documentation is free; you can redistribute it without any restrictions. Modifications or derived work must retain the copyright and list all authors.

This documentation is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

API usage

Application programmers should use the library API rather than the kernel API. The library offers 100% of the functionality of the kernel API, but adds major improvements in usability, making the application code simpler and better looking. In addition, future fixes or compatibility code may be placed in the library code instead of the kernel driver.

API links

  • Page \ref control explains the primitive controls API.
  • Page \ref hcontrol explains the high-level primitive controls API.
  • Page \ref mixer explains the mixer controls API.
  • Page \ref pcm explains the design of the PCM (digital audio) API.
  • Page \ref pcm_plugins explains the design of PCM (digital audio) plugins.
  • Page \ref pcm_external_plugins explains the external PCM plugin SDK.
  • Page \ref ctl_external_plugins explains the external control plugin SDK.
  • Page \ref rawmidi explains the design of the RawMidi API.
  • Page \ref timer explains the design of the Timer API.
  • Page \ref seq explains the design of the Sequencer API.
  • Page \ref ucm explains the use case API.
  • Page \ref topology explains the DSP topology API.

Configuration

  • Page \ref conf explains the syntax of library configuration files.
  • Page \ref confarg explains the run-time argument syntax.
  • Page \ref conffunc explains run-time function definitions and their usage.
  • Page \ref confhooks explains run-time hook definitions and their usage.
*/