OSDN Git Service

topology: ABI - Update physical DAI link configurations to ABI v5
[android-x86/external-alsa-lib.git] / include / pcm.h
1 /**
2  * \file include/pcm.h
3  * \brief Application interface library for the ALSA driver
4  * \author Jaroslav Kysela <perex@perex.cz>
5  * \author Abramo Bagnara <abramo@alsa-project.org>
6  * \author Takashi Iwai <tiwai@suse.de>
7  * \date 1998-2001
8  *
9  * Application interface library for the ALSA driver.
10  * See the \ref pcm page for more details.
11  */
12 /*
13  *   This library is free software; you can redistribute it and/or modify
14  *   it under the terms of the GNU Lesser General Public License as
15  *   published by the Free Software Foundation; either version 2.1 of
16  *   the License, or (at your option) any later version.
17  *
18  *   This program is distributed in the hope that it will be useful,
19  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
20  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21  *   GNU Lesser General Public License for more details.
22  *
23  *   You should have received a copy of the GNU Lesser General Public
24  *   License along with this library; if not, write to the Free Software
25  *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
26  *
27  */
28
29 #ifndef __ALSA_PCM_H
30 #define __ALSA_PCM_H
31
32 #ifdef __cplusplus
33 extern "C" {
34 #endif
35
36 /**
37  *  \defgroup PCM PCM Interface
38  *  See the \ref pcm page for more details.
39  *  \{
40  */
41
42 /** dlsym version for interface entry callback */
43 #define SND_PCM_DLSYM_VERSION           _dlsym_pcm_001
44
45 /** PCM generic info container */
46 typedef struct _snd_pcm_info snd_pcm_info_t;
47
48 /** PCM hardware configuration space container
49  *
50  *  snd_pcm_hw_params_t is an opaque structure which contains a set of possible
51  *  PCM hardware configurations. For example, a given instance might include a
52  *  range of buffer sizes, a range of period sizes, and a set of several sample
53  *  formats. Some subset of all possible combinations these sets may be valid,
54  *  but not necessarily any combination will be valid.
55  *
56  *  When a parameter is set or restricted using a snd_pcm_hw_params_set*
57  *  function, all of the other ranges will be updated to exclude as many
58  *  impossible configurations as possible. Attempting to set a parameter
59  *  outside of its acceptable range will result in the function failing
60  *  and an error code being returned.
61  */
62 typedef struct _snd_pcm_hw_params snd_pcm_hw_params_t;
63
64 /** PCM software configuration container */
65 typedef struct _snd_pcm_sw_params snd_pcm_sw_params_t;
66 /** PCM status container */
67  typedef struct _snd_pcm_status snd_pcm_status_t;
68 /** PCM access types mask */
69 typedef struct _snd_pcm_access_mask snd_pcm_access_mask_t;
70 /** PCM formats mask */
71 typedef struct _snd_pcm_format_mask snd_pcm_format_mask_t;
72 /** PCM subformats mask */
73 typedef struct _snd_pcm_subformat_mask snd_pcm_subformat_mask_t;
74
75 /** PCM class */
76 typedef enum _snd_pcm_class {
77         /** standard device */
78
79         SND_PCM_CLASS_GENERIC = 0,
80         /** multichannel device */
81         SND_PCM_CLASS_MULTI,
82         /** software modem device */
83         SND_PCM_CLASS_MODEM,
84         /** digitizer device */
85         SND_PCM_CLASS_DIGITIZER,
86         SND_PCM_CLASS_LAST = SND_PCM_CLASS_DIGITIZER
87 } snd_pcm_class_t;
88
89 /** PCM subclass */
90 typedef enum _snd_pcm_subclass {
91         /** subdevices are mixed together */
92         SND_PCM_SUBCLASS_GENERIC_MIX = 0,
93         /** multichannel subdevices are mixed together */
94         SND_PCM_SUBCLASS_MULTI_MIX,
95         SND_PCM_SUBCLASS_LAST = SND_PCM_SUBCLASS_MULTI_MIX
96 } snd_pcm_subclass_t;
97
98 /** PCM stream (direction) */
99 typedef enum _snd_pcm_stream {
100         /** Playback stream */
101         SND_PCM_STREAM_PLAYBACK = 0,
102         /** Capture stream */
103         SND_PCM_STREAM_CAPTURE,
104         SND_PCM_STREAM_LAST = SND_PCM_STREAM_CAPTURE
105 } snd_pcm_stream_t;
106
107 /** PCM access type */
108 typedef enum _snd_pcm_access {
109         /** mmap access with simple interleaved channels */
110         SND_PCM_ACCESS_MMAP_INTERLEAVED = 0,
111         /** mmap access with simple non interleaved channels */
112         SND_PCM_ACCESS_MMAP_NONINTERLEAVED,
113         /** mmap access with complex placement */
114         SND_PCM_ACCESS_MMAP_COMPLEX,
115         /** snd_pcm_readi/snd_pcm_writei access */
116         SND_PCM_ACCESS_RW_INTERLEAVED,
117         /** snd_pcm_readn/snd_pcm_writen access */
118         SND_PCM_ACCESS_RW_NONINTERLEAVED,
119         SND_PCM_ACCESS_LAST = SND_PCM_ACCESS_RW_NONINTERLEAVED
120 } snd_pcm_access_t;
121
122 /** PCM sample format */
123 typedef enum _snd_pcm_format {
124         /** Unknown */
125         SND_PCM_FORMAT_UNKNOWN = -1,
126         /** Signed 8 bit */
127         SND_PCM_FORMAT_S8 = 0,
128         /** Unsigned 8 bit */
129         SND_PCM_FORMAT_U8,
130         /** Signed 16 bit Little Endian */
131         SND_PCM_FORMAT_S16_LE,
132         /** Signed 16 bit Big Endian */
133         SND_PCM_FORMAT_S16_BE,
134         /** Unsigned 16 bit Little Endian */
135         SND_PCM_FORMAT_U16_LE,
136         /** Unsigned 16 bit Big Endian */
137         SND_PCM_FORMAT_U16_BE,
138         /** Signed 24 bit Little Endian using low three bytes in 32-bit word */
139         SND_PCM_FORMAT_S24_LE,
140         /** Signed 24 bit Big Endian using low three bytes in 32-bit word */
141         SND_PCM_FORMAT_S24_BE,
142         /** Unsigned 24 bit Little Endian using low three bytes in 32-bit word */
143         SND_PCM_FORMAT_U24_LE,
144         /** Unsigned 24 bit Big Endian using low three bytes in 32-bit word */
145         SND_PCM_FORMAT_U24_BE,
146         /** Signed 32 bit Little Endian */
147         SND_PCM_FORMAT_S32_LE,
148         /** Signed 32 bit Big Endian */
149         SND_PCM_FORMAT_S32_BE,
150         /** Unsigned 32 bit Little Endian */
151         SND_PCM_FORMAT_U32_LE,
152         /** Unsigned 32 bit Big Endian */
153         SND_PCM_FORMAT_U32_BE,
154         /** Float 32 bit Little Endian, Range -1.0 to 1.0 */
155         SND_PCM_FORMAT_FLOAT_LE,
156         /** Float 32 bit Big Endian, Range -1.0 to 1.0 */
157         SND_PCM_FORMAT_FLOAT_BE,
158         /** Float 64 bit Little Endian, Range -1.0 to 1.0 */
159         SND_PCM_FORMAT_FLOAT64_LE,
160         /** Float 64 bit Big Endian, Range -1.0 to 1.0 */
161         SND_PCM_FORMAT_FLOAT64_BE,
162         /** IEC-958 Little Endian */
163         SND_PCM_FORMAT_IEC958_SUBFRAME_LE,
164         /** IEC-958 Big Endian */
165         SND_PCM_FORMAT_IEC958_SUBFRAME_BE,
166         /** Mu-Law */
167         SND_PCM_FORMAT_MU_LAW,
168         /** A-Law */
169         SND_PCM_FORMAT_A_LAW,
170         /** Ima-ADPCM */
171         SND_PCM_FORMAT_IMA_ADPCM,
172         /** MPEG */
173         SND_PCM_FORMAT_MPEG,
174         /** GSM */
175         SND_PCM_FORMAT_GSM,
176         /** Special */
177         SND_PCM_FORMAT_SPECIAL = 31,
178         /** Signed 24bit Little Endian in 3bytes format */
179         SND_PCM_FORMAT_S24_3LE = 32,
180         /** Signed 24bit Big Endian in 3bytes format */
181         SND_PCM_FORMAT_S24_3BE,
182         /** Unsigned 24bit Little Endian in 3bytes format */
183         SND_PCM_FORMAT_U24_3LE,
184         /** Unsigned 24bit Big Endian in 3bytes format */
185         SND_PCM_FORMAT_U24_3BE,
186         /** Signed 20bit Little Endian in 3bytes format */
187         SND_PCM_FORMAT_S20_3LE,
188         /** Signed 20bit Big Endian in 3bytes format */
189         SND_PCM_FORMAT_S20_3BE,
190         /** Unsigned 20bit Little Endian in 3bytes format */
191         SND_PCM_FORMAT_U20_3LE,
192         /** Unsigned 20bit Big Endian in 3bytes format */
193         SND_PCM_FORMAT_U20_3BE,
194         /** Signed 18bit Little Endian in 3bytes format */
195         SND_PCM_FORMAT_S18_3LE,
196         /** Signed 18bit Big Endian in 3bytes format */
197         SND_PCM_FORMAT_S18_3BE,
198         /** Unsigned 18bit Little Endian in 3bytes format */
199         SND_PCM_FORMAT_U18_3LE,
200         /** Unsigned 18bit Big Endian in 3bytes format */
201         SND_PCM_FORMAT_U18_3BE,
202         /* G.723 (ADPCM) 24 kbit/s, 8 samples in 3 bytes */
203         SND_PCM_FORMAT_G723_24,
204         /* G.723 (ADPCM) 24 kbit/s, 1 sample in 1 byte */
205         SND_PCM_FORMAT_G723_24_1B,
206         /* G.723 (ADPCM) 40 kbit/s, 8 samples in 3 bytes */
207         SND_PCM_FORMAT_G723_40,
208         /* G.723 (ADPCM) 40 kbit/s, 1 sample in 1 byte */
209         SND_PCM_FORMAT_G723_40_1B,
210         /* Direct Stream Digital (DSD) in 1-byte samples (x8) */
211         SND_PCM_FORMAT_DSD_U8,
212         /* Direct Stream Digital (DSD) in 2-byte samples (x16) */
213         SND_PCM_FORMAT_DSD_U16_LE,
214         /* Direct Stream Digital (DSD) in 4-byte samples (x32) */
215         SND_PCM_FORMAT_DSD_U32_LE,
216         /* Direct Stream Digital (DSD) in 2-byte samples (x16) */
217         SND_PCM_FORMAT_DSD_U16_BE,
218         /* Direct Stream Digital (DSD) in 4-byte samples (x32) */
219         SND_PCM_FORMAT_DSD_U32_BE,
220         SND_PCM_FORMAT_LAST = SND_PCM_FORMAT_DSD_U32_BE,
221
222 #if __BYTE_ORDER == __LITTLE_ENDIAN
223         /** Signed 16 bit CPU endian */
224         SND_PCM_FORMAT_S16 = SND_PCM_FORMAT_S16_LE,
225         /** Unsigned 16 bit CPU endian */
226         SND_PCM_FORMAT_U16 = SND_PCM_FORMAT_U16_LE,
227         /** Signed 24 bit CPU endian */
228         SND_PCM_FORMAT_S24 = SND_PCM_FORMAT_S24_LE,
229         /** Unsigned 24 bit CPU endian */
230         SND_PCM_FORMAT_U24 = SND_PCM_FORMAT_U24_LE,
231         /** Signed 32 bit CPU endian */
232         SND_PCM_FORMAT_S32 = SND_PCM_FORMAT_S32_LE,
233         /** Unsigned 32 bit CPU endian */
234         SND_PCM_FORMAT_U32 = SND_PCM_FORMAT_U32_LE,
235         /** Float 32 bit CPU endian */
236         SND_PCM_FORMAT_FLOAT = SND_PCM_FORMAT_FLOAT_LE,
237         /** Float 64 bit CPU endian */
238         SND_PCM_FORMAT_FLOAT64 = SND_PCM_FORMAT_FLOAT64_LE,
239         /** IEC-958 CPU Endian */
240         SND_PCM_FORMAT_IEC958_SUBFRAME = SND_PCM_FORMAT_IEC958_SUBFRAME_LE
241 #elif __BYTE_ORDER == __BIG_ENDIAN
242         /** Signed 16 bit CPU endian */
243         SND_PCM_FORMAT_S16 = SND_PCM_FORMAT_S16_BE,
244         /** Unsigned 16 bit CPU endian */
245         SND_PCM_FORMAT_U16 = SND_PCM_FORMAT_U16_BE,
246         /** Signed 24 bit CPU endian */
247         SND_PCM_FORMAT_S24 = SND_PCM_FORMAT_S24_BE,
248         /** Unsigned 24 bit CPU endian */
249         SND_PCM_FORMAT_U24 = SND_PCM_FORMAT_U24_BE,
250         /** Signed 32 bit CPU endian */
251         SND_PCM_FORMAT_S32 = SND_PCM_FORMAT_S32_BE,
252         /** Unsigned 32 bit CPU endian */
253         SND_PCM_FORMAT_U32 = SND_PCM_FORMAT_U32_BE,
254         /** Float 32 bit CPU endian */
255         SND_PCM_FORMAT_FLOAT = SND_PCM_FORMAT_FLOAT_BE,
256         /** Float 64 bit CPU endian */
257         SND_PCM_FORMAT_FLOAT64 = SND_PCM_FORMAT_FLOAT64_BE,
258         /** IEC-958 CPU Endian */
259         SND_PCM_FORMAT_IEC958_SUBFRAME = SND_PCM_FORMAT_IEC958_SUBFRAME_BE
260 #else
261 #error "Unknown endian"
262 #endif
263 } snd_pcm_format_t;
264
265 /** PCM sample subformat */
266 typedef enum _snd_pcm_subformat {
267         /** Standard */
268         SND_PCM_SUBFORMAT_STD = 0,
269         SND_PCM_SUBFORMAT_LAST = SND_PCM_SUBFORMAT_STD
270 } snd_pcm_subformat_t;
271
272 /** PCM state */
273 typedef enum _snd_pcm_state {
274         /** Open */
275         SND_PCM_STATE_OPEN = 0,
276         /** Setup installed */ 
277         SND_PCM_STATE_SETUP,
278         /** Ready to start */
279         SND_PCM_STATE_PREPARED,
280         /** Running */
281         SND_PCM_STATE_RUNNING,
282         /** Stopped: underrun (playback) or overrun (capture) detected */
283         SND_PCM_STATE_XRUN,
284         /** Draining: running (playback) or stopped (capture) */
285         SND_PCM_STATE_DRAINING,
286         /** Paused */
287         SND_PCM_STATE_PAUSED,
288         /** Hardware is suspended */
289         SND_PCM_STATE_SUSPENDED,
290         /** Hardware is disconnected */
291         SND_PCM_STATE_DISCONNECTED,
292         SND_PCM_STATE_LAST = SND_PCM_STATE_DISCONNECTED
293 } snd_pcm_state_t;
294
295 /** PCM start mode */
296 typedef enum _snd_pcm_start {
297         /** Automatic start on data read/write */
298         SND_PCM_START_DATA = 0,
299         /** Explicit start */
300         SND_PCM_START_EXPLICIT,
301         SND_PCM_START_LAST = SND_PCM_START_EXPLICIT
302 } snd_pcm_start_t;
303
304 /** PCM xrun mode */
305 typedef enum _snd_pcm_xrun {
306         /** Xrun detection disabled */
307         SND_PCM_XRUN_NONE = 0,
308         /** Stop on xrun detection */
309         SND_PCM_XRUN_STOP,
310         SND_PCM_XRUN_LAST = SND_PCM_XRUN_STOP
311 } snd_pcm_xrun_t;
312
313 /** PCM timestamp mode */
314 typedef enum _snd_pcm_tstamp {
315         /** No timestamp */
316         SND_PCM_TSTAMP_NONE = 0,
317         /** Update timestamp at every hardware position update */
318         SND_PCM_TSTAMP_ENABLE,
319         /** Equivalent with #SND_PCM_TSTAMP_ENABLE,
320          * just for compatibility with older versions
321          */
322         SND_PCM_TSTAMP_MMAP = SND_PCM_TSTAMP_ENABLE,
323         SND_PCM_TSTAMP_LAST = SND_PCM_TSTAMP_ENABLE
324 } snd_pcm_tstamp_t;
325
326 typedef enum _snd_pcm_tstamp_type {
327         SND_PCM_TSTAMP_TYPE_GETTIMEOFDAY = 0,   /**< gettimeofday equivalent */
328         SND_PCM_TSTAMP_TYPE_MONOTONIC,  /**< posix_clock_monotonic equivalent */
329         SND_PCM_TSTAMP_TYPE_MONOTONIC_RAW,      /**< monotonic_raw (no NTP) */
330         SND_PCM_TSTAMP_TYPE_LAST = SND_PCM_TSTAMP_TYPE_MONOTONIC_RAW,
331 } snd_pcm_tstamp_type_t;
332
333 typedef struct _snd_pcm_audio_tstamp_config {
334         /* 5 of max 16 bits used */
335         unsigned int type_requested:4;
336         unsigned int report_delay:1; /* add total delay to A/D or D/A */
337 } snd_pcm_audio_tstamp_config_t;
338
339 typedef struct _snd_pcm_audio_tstamp_report {
340         /* 6 of max 16 bits used for bit-fields */
341
342         /* for backwards compatibility */
343         unsigned int valid:1;
344
345         /* actual type if hardware could not support requested timestamp */
346         unsigned int actual_type:4;
347
348         /* accuracy represented in ns units */
349         unsigned int accuracy_report:1; /* 0 if accuracy unknown, 1 if accuracy field is valid */
350         unsigned int accuracy; /* up to 4.29s, will be packed in separate field  */
351 } snd_pcm_audio_tstamp_report_t;
352
353 /** Unsigned frames quantity */
354 typedef unsigned long snd_pcm_uframes_t;
355 /** Signed frames quantity */
356 typedef long snd_pcm_sframes_t;
357
358 /** Non blocking mode (flag for open mode) \hideinitializer */
359 #define SND_PCM_NONBLOCK                0x00000001
360 /** Async notification (flag for open mode) \hideinitializer */
361 #define SND_PCM_ASYNC                   0x00000002
362 /** In an abort state (internal, not allowed for open) */
363 #define SND_PCM_ABORT                   0x00008000
364 /** Disable automatic (but not forced!) rate resamplinig */
365 #define SND_PCM_NO_AUTO_RESAMPLE        0x00010000
366 /** Disable automatic (but not forced!) channel conversion */
367 #define SND_PCM_NO_AUTO_CHANNELS        0x00020000
368 /** Disable automatic (but not forced!) format conversion */
369 #define SND_PCM_NO_AUTO_FORMAT          0x00040000
370 /** Disable soft volume control */
371 #define SND_PCM_NO_SOFTVOL              0x00080000
372
373 /** PCM handle */
374 typedef struct _snd_pcm snd_pcm_t;
375
376 /** PCM type */
377 enum _snd_pcm_type {
378         /** Kernel level PCM */
379         SND_PCM_TYPE_HW = 0,
380         /** Hooked PCM */
381         SND_PCM_TYPE_HOOKS,
382         /** One or more linked PCM with exclusive access to selected
383             channels */
384         SND_PCM_TYPE_MULTI,
385         /** File writing plugin */
386         SND_PCM_TYPE_FILE,
387         /** Null endpoint PCM */
388         SND_PCM_TYPE_NULL,
389         /** Shared memory client PCM */
390         SND_PCM_TYPE_SHM,
391         /** INET client PCM (not yet implemented) */
392         SND_PCM_TYPE_INET,
393         /** Copying plugin */
394         SND_PCM_TYPE_COPY,
395         /** Linear format conversion PCM */
396         SND_PCM_TYPE_LINEAR,
397         /** A-Law format conversion PCM */
398         SND_PCM_TYPE_ALAW,
399         /** Mu-Law format conversion PCM */
400         SND_PCM_TYPE_MULAW,
401         /** IMA-ADPCM format conversion PCM */
402         SND_PCM_TYPE_ADPCM,
403         /** Rate conversion PCM */
404         SND_PCM_TYPE_RATE,
405         /** Attenuated static route PCM */
406         SND_PCM_TYPE_ROUTE,
407         /** Format adjusted PCM */
408         SND_PCM_TYPE_PLUG,
409         /** Sharing PCM */
410         SND_PCM_TYPE_SHARE,
411         /** Meter plugin */
412         SND_PCM_TYPE_METER,
413         /** Mixing PCM */
414         SND_PCM_TYPE_MIX,
415         /** Attenuated dynamic route PCM (not yet implemented) */
416         SND_PCM_TYPE_DROUTE,
417         /** Loopback server plugin (not yet implemented) */
418         SND_PCM_TYPE_LBSERVER,
419         /** Linear Integer <-> Linear Float format conversion PCM */
420         SND_PCM_TYPE_LINEAR_FLOAT,
421         /** LADSPA integration plugin */
422         SND_PCM_TYPE_LADSPA,
423         /** Direct Mixing plugin */
424         SND_PCM_TYPE_DMIX,
425         /** Jack Audio Connection Kit plugin */
426         SND_PCM_TYPE_JACK,
427         /** Direct Snooping plugin */
428         SND_PCM_TYPE_DSNOOP,
429         /** Direct Sharing plugin */
430         SND_PCM_TYPE_DSHARE,
431         /** IEC958 subframe plugin */
432         SND_PCM_TYPE_IEC958,
433         /** Soft volume plugin */
434         SND_PCM_TYPE_SOFTVOL,
435         /** External I/O plugin */
436         SND_PCM_TYPE_IOPLUG,
437         /** External filter plugin */
438         SND_PCM_TYPE_EXTPLUG,
439         /** Mmap-emulation plugin */
440         SND_PCM_TYPE_MMAP_EMUL,
441         SND_PCM_TYPE_LAST = SND_PCM_TYPE_MMAP_EMUL
442 };
443
444 /** PCM type */
445 typedef enum _snd_pcm_type snd_pcm_type_t;
446
447 /** PCM area specification */
448 typedef struct _snd_pcm_channel_area {
449         /** base address of channel samples */
450         void *addr;
451         /** offset to first sample in bits */
452         unsigned int first;
453         /** samples distance in bits */
454         unsigned int step;
455 } snd_pcm_channel_area_t;
456
457 /** PCM synchronization ID */
458 typedef union _snd_pcm_sync_id {
459         /** 8-bit ID */
460         unsigned char id[16];
461         /** 16-bit ID */
462         unsigned short id16[8];
463         /** 32-bit ID */
464         unsigned int id32[4];
465 } snd_pcm_sync_id_t;
466
467 /** #SND_PCM_TYPE_METER scope handle */
468 typedef struct _snd_pcm_scope snd_pcm_scope_t;
469
470 int snd_pcm_open(snd_pcm_t **pcm, const char *name, 
471                  snd_pcm_stream_t stream, int mode);
472 int snd_pcm_open_lconf(snd_pcm_t **pcm, const char *name, 
473                        snd_pcm_stream_t stream, int mode,
474                        snd_config_t *lconf);
475 int snd_pcm_open_fallback(snd_pcm_t **pcm, snd_config_t *root,
476                           const char *name, const char *orig_name,
477                           snd_pcm_stream_t stream, int mode);
478
479 int snd_pcm_close(snd_pcm_t *pcm);
480 const char *snd_pcm_name(snd_pcm_t *pcm);
481 snd_pcm_type_t snd_pcm_type(snd_pcm_t *pcm);
482 snd_pcm_stream_t snd_pcm_stream(snd_pcm_t *pcm);
483 int snd_pcm_poll_descriptors_count(snd_pcm_t *pcm);
484 int snd_pcm_poll_descriptors(snd_pcm_t *pcm, struct pollfd *pfds, unsigned int space);
485 int snd_pcm_poll_descriptors_revents(snd_pcm_t *pcm, struct pollfd *pfds, unsigned int nfds, unsigned short *revents);
486 int snd_pcm_nonblock(snd_pcm_t *pcm, int nonblock);
487 static __inline__ int snd_pcm_abort(snd_pcm_t *pcm) { return snd_pcm_nonblock(pcm, 2); }
488 int snd_async_add_pcm_handler(snd_async_handler_t **handler, snd_pcm_t *pcm, 
489                               snd_async_callback_t callback, void *private_data);
490 snd_pcm_t *snd_async_handler_get_pcm(snd_async_handler_t *handler);
491 int snd_pcm_info(snd_pcm_t *pcm, snd_pcm_info_t *info);
492 int snd_pcm_hw_params_current(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
493 int snd_pcm_hw_params(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
494 int snd_pcm_hw_free(snd_pcm_t *pcm);
495 int snd_pcm_sw_params_current(snd_pcm_t *pcm, snd_pcm_sw_params_t *params);
496 int snd_pcm_sw_params(snd_pcm_t *pcm, snd_pcm_sw_params_t *params);
497 int snd_pcm_prepare(snd_pcm_t *pcm);
498 int snd_pcm_reset(snd_pcm_t *pcm);
499 int snd_pcm_status(snd_pcm_t *pcm, snd_pcm_status_t *status);
500 int snd_pcm_start(snd_pcm_t *pcm);
501 int snd_pcm_drop(snd_pcm_t *pcm);
502 int snd_pcm_drain(snd_pcm_t *pcm);
503 int snd_pcm_pause(snd_pcm_t *pcm, int enable);
504 snd_pcm_state_t snd_pcm_state(snd_pcm_t *pcm);
505 int snd_pcm_hwsync(snd_pcm_t *pcm);
506 int snd_pcm_delay(snd_pcm_t *pcm, snd_pcm_sframes_t *delayp);
507 int snd_pcm_resume(snd_pcm_t *pcm);
508 int snd_pcm_htimestamp(snd_pcm_t *pcm, snd_pcm_uframes_t *avail, snd_htimestamp_t *tstamp);
509 snd_pcm_sframes_t snd_pcm_avail(snd_pcm_t *pcm);
510 snd_pcm_sframes_t snd_pcm_avail_update(snd_pcm_t *pcm);
511 int snd_pcm_avail_delay(snd_pcm_t *pcm, snd_pcm_sframes_t *availp, snd_pcm_sframes_t *delayp);
512 snd_pcm_sframes_t snd_pcm_rewindable(snd_pcm_t *pcm);
513 snd_pcm_sframes_t snd_pcm_rewind(snd_pcm_t *pcm, snd_pcm_uframes_t frames);
514 snd_pcm_sframes_t snd_pcm_forwardable(snd_pcm_t *pcm);
515 snd_pcm_sframes_t snd_pcm_forward(snd_pcm_t *pcm, snd_pcm_uframes_t frames);
516 snd_pcm_sframes_t snd_pcm_writei(snd_pcm_t *pcm, const void *buffer, snd_pcm_uframes_t size);
517 snd_pcm_sframes_t snd_pcm_readi(snd_pcm_t *pcm, void *buffer, snd_pcm_uframes_t size);
518 snd_pcm_sframes_t snd_pcm_writen(snd_pcm_t *pcm, void **bufs, snd_pcm_uframes_t size);
519 snd_pcm_sframes_t snd_pcm_readn(snd_pcm_t *pcm, void **bufs, snd_pcm_uframes_t size);
520 int snd_pcm_wait(snd_pcm_t *pcm, int timeout);
521
522 int snd_pcm_link(snd_pcm_t *pcm1, snd_pcm_t *pcm2);
523 int snd_pcm_unlink(snd_pcm_t *pcm);
524
525 /** channel mapping API version number */
526 #define SND_CHMAP_API_VERSION   ((1 << 16) | (0 << 8) | 1)
527
528 /** channel map list type */
529 enum snd_pcm_chmap_type {
530         SND_CHMAP_TYPE_NONE = 0,/**< unspecified channel position */
531         SND_CHMAP_TYPE_FIXED,   /**< fixed channel position */
532         SND_CHMAP_TYPE_VAR,     /**< freely swappable channel position */
533         SND_CHMAP_TYPE_PAIRED,  /**< pair-wise swappable channel position */
534         SND_CHMAP_TYPE_LAST = SND_CHMAP_TYPE_PAIRED, /**< last entry */
535 };
536
537 /** channel positions */
538 enum snd_pcm_chmap_position {
539         SND_CHMAP_UNKNOWN = 0,  /**< unspecified */
540         SND_CHMAP_NA,           /**< N/A, silent */
541         SND_CHMAP_MONO,         /**< mono stream */
542         SND_CHMAP_FL,           /**< front left */
543         SND_CHMAP_FR,           /**< front right */
544         SND_CHMAP_RL,           /**< rear left */
545         SND_CHMAP_RR,           /**< rear right */
546         SND_CHMAP_FC,           /**< front center */
547         SND_CHMAP_LFE,          /**< LFE */
548         SND_CHMAP_SL,           /**< side left */
549         SND_CHMAP_SR,           /**< side right */
550         SND_CHMAP_RC,           /**< rear center */
551         SND_CHMAP_FLC,          /**< front left center */
552         SND_CHMAP_FRC,          /**< front right center */
553         SND_CHMAP_RLC,          /**< rear left center */
554         SND_CHMAP_RRC,          /**< rear right center */
555         SND_CHMAP_FLW,          /**< front left wide */
556         SND_CHMAP_FRW,          /**< front right wide */
557         SND_CHMAP_FLH,          /**< front left high */
558         SND_CHMAP_FCH,          /**< front center high */
559         SND_CHMAP_FRH,          /**< front right high */
560         SND_CHMAP_TC,           /**< top center */
561         SND_CHMAP_TFL,          /**< top front left */
562         SND_CHMAP_TFR,          /**< top front right */
563         SND_CHMAP_TFC,          /**< top front center */
564         SND_CHMAP_TRL,          /**< top rear left */
565         SND_CHMAP_TRR,          /**< top rear right */
566         SND_CHMAP_TRC,          /**< top rear center */
567         SND_CHMAP_TFLC,         /**< top front left center */
568         SND_CHMAP_TFRC,         /**< top front right center */
569         SND_CHMAP_TSL,          /**< top side left */
570         SND_CHMAP_TSR,          /**< top side right */
571         SND_CHMAP_LLFE,         /**< left LFE */
572         SND_CHMAP_RLFE,         /**< right LFE */
573         SND_CHMAP_BC,           /**< bottom center */
574         SND_CHMAP_BLC,          /**< bottom left center */
575         SND_CHMAP_BRC,          /**< bottom right center */
576         SND_CHMAP_LAST = SND_CHMAP_BRC,
577 };
578
579 /** bitmask for channel position */
580 #define SND_CHMAP_POSITION_MASK         0xffff
581
582 /** bit flag indicating the channel is phase inverted */
583 #define SND_CHMAP_PHASE_INVERSE         (0x01 << 16)
584 /** bit flag indicating the non-standard channel value */
585 #define SND_CHMAP_DRIVER_SPEC           (0x02 << 16)
586
587 /** the channel map header */
588 typedef struct snd_pcm_chmap {
589         unsigned int channels;  /**< number of channels */
590         unsigned int pos[0];    /**< channel position array */
591 } snd_pcm_chmap_t;
592
593 /** the header of array items returned from snd_pcm_query_chmaps() */
594 typedef struct snd_pcm_chmap_query {
595         enum snd_pcm_chmap_type type;   /**< channel map type */
596         snd_pcm_chmap_t map;            /**< available channel map */
597 } snd_pcm_chmap_query_t;
598
599
600 snd_pcm_chmap_query_t **snd_pcm_query_chmaps(snd_pcm_t *pcm);
601 snd_pcm_chmap_query_t **snd_pcm_query_chmaps_from_hw(int card, int dev,
602                                                      int subdev,
603                                                      snd_pcm_stream_t stream);
604 void snd_pcm_free_chmaps(snd_pcm_chmap_query_t **maps);
605 snd_pcm_chmap_t *snd_pcm_get_chmap(snd_pcm_t *pcm);
606 int snd_pcm_set_chmap(snd_pcm_t *pcm, const snd_pcm_chmap_t *map);
607
608 const char *snd_pcm_chmap_type_name(enum snd_pcm_chmap_type val);
609 const char *snd_pcm_chmap_name(enum snd_pcm_chmap_position val);
610 const char *snd_pcm_chmap_long_name(enum snd_pcm_chmap_position val);
611 int snd_pcm_chmap_print(const snd_pcm_chmap_t *map, size_t maxlen, char *buf);
612 unsigned int snd_pcm_chmap_from_string(const char *str);
613 snd_pcm_chmap_t *snd_pcm_chmap_parse_string(const char *str);
614
615 //int snd_pcm_mixer_element(snd_pcm_t *pcm, snd_mixer_t *mixer, snd_mixer_elem_t **elem);
616
617 /*
618  * application helpers - these functions are implemented on top
619  * of the basic API
620  */
621
622 int snd_pcm_recover(snd_pcm_t *pcm, int err, int silent);
623 int snd_pcm_set_params(snd_pcm_t *pcm,
624                        snd_pcm_format_t format,
625                        snd_pcm_access_t access,
626                        unsigned int channels,
627                        unsigned int rate,
628                        int soft_resample,
629                        unsigned int latency);
630 int snd_pcm_get_params(snd_pcm_t *pcm,
631                        snd_pcm_uframes_t *buffer_size,
632                        snd_pcm_uframes_t *period_size);
633
634 /** \} */
635
636 /**
637  * \defgroup PCM_Info Stream Information
638  * \ingroup PCM
639  * See the \ref pcm page for more details.
640  * \{
641  */
642
643 size_t snd_pcm_info_sizeof(void);
644 /** \hideinitializer
645  * \brief allocate an invalid #snd_pcm_info_t using standard alloca
646  * \param ptr returned pointer
647  */
648 #define snd_pcm_info_alloca(ptr) __snd_alloca(ptr, snd_pcm_info)
649 int snd_pcm_info_malloc(snd_pcm_info_t **ptr);
650 void snd_pcm_info_free(snd_pcm_info_t *obj);
651 void snd_pcm_info_copy(snd_pcm_info_t *dst, const snd_pcm_info_t *src);
652 unsigned int snd_pcm_info_get_device(const snd_pcm_info_t *obj);
653 unsigned int snd_pcm_info_get_subdevice(const snd_pcm_info_t *obj);
654 snd_pcm_stream_t snd_pcm_info_get_stream(const snd_pcm_info_t *obj);
655 int snd_pcm_info_get_card(const snd_pcm_info_t *obj);
656 const char *snd_pcm_info_get_id(const snd_pcm_info_t *obj);
657 const char *snd_pcm_info_get_name(const snd_pcm_info_t *obj);
658 const char *snd_pcm_info_get_subdevice_name(const snd_pcm_info_t *obj);
659 snd_pcm_class_t snd_pcm_info_get_class(const snd_pcm_info_t *obj);
660 snd_pcm_subclass_t snd_pcm_info_get_subclass(const snd_pcm_info_t *obj);
661 unsigned int snd_pcm_info_get_subdevices_count(const snd_pcm_info_t *obj);
662 unsigned int snd_pcm_info_get_subdevices_avail(const snd_pcm_info_t *obj);
663 snd_pcm_sync_id_t snd_pcm_info_get_sync(const snd_pcm_info_t *obj);
664 void snd_pcm_info_set_device(snd_pcm_info_t *obj, unsigned int val);
665 void snd_pcm_info_set_subdevice(snd_pcm_info_t *obj, unsigned int val);
666 void snd_pcm_info_set_stream(snd_pcm_info_t *obj, snd_pcm_stream_t val);
667
668 /** \} */
669
670 /**
671  * \defgroup PCM_HW_Params Hardware Parameters
672  * \ingroup PCM
673  * See the \ref pcm page for more details.
674  * \{
675  */
676
677 int snd_pcm_hw_params_any(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
678
679 int snd_pcm_hw_params_can_mmap_sample_resolution(const snd_pcm_hw_params_t *params);
680 int snd_pcm_hw_params_is_double(const snd_pcm_hw_params_t *params);
681 int snd_pcm_hw_params_is_batch(const snd_pcm_hw_params_t *params);
682 int snd_pcm_hw_params_is_block_transfer(const snd_pcm_hw_params_t *params);
683 int snd_pcm_hw_params_is_monotonic(const snd_pcm_hw_params_t *params);
684 int snd_pcm_hw_params_can_overrange(const snd_pcm_hw_params_t *params);
685 int snd_pcm_hw_params_can_pause(const snd_pcm_hw_params_t *params);
686 int snd_pcm_hw_params_can_resume(const snd_pcm_hw_params_t *params);
687 int snd_pcm_hw_params_is_half_duplex(const snd_pcm_hw_params_t *params);
688 int snd_pcm_hw_params_is_joint_duplex(const snd_pcm_hw_params_t *params);
689 int snd_pcm_hw_params_can_sync_start(const snd_pcm_hw_params_t *params);
690 int snd_pcm_hw_params_can_disable_period_wakeup(const snd_pcm_hw_params_t *params);
691 int snd_pcm_hw_params_supports_audio_wallclock_ts(const snd_pcm_hw_params_t *params); /* deprecated, use audio_ts_type */
692 int snd_pcm_hw_params_supports_audio_ts_type(const snd_pcm_hw_params_t *params, int type);
693 int snd_pcm_hw_params_get_rate_numden(const snd_pcm_hw_params_t *params,
694                                       unsigned int *rate_num,
695                                       unsigned int *rate_den);
696 int snd_pcm_hw_params_get_sbits(const snd_pcm_hw_params_t *params);
697 int snd_pcm_hw_params_get_fifo_size(const snd_pcm_hw_params_t *params);
698
699 #if 0
700 typedef struct _snd_pcm_hw_strategy snd_pcm_hw_strategy_t;
701
702 /* choices need to be sorted on ascending badness */
703 typedef struct _snd_pcm_hw_strategy_simple_choices_list {
704         unsigned int value;
705         unsigned int badness;
706 } snd_pcm_hw_strategy_simple_choices_list_t;
707
708 int snd_pcm_hw_params_strategy(snd_pcm_t *pcm, snd_pcm_hw_params_t *params,
709                                const snd_pcm_hw_strategy_t *strategy,
710                                unsigned int badness_min,
711                                unsigned int badness_max);
712
713 void snd_pcm_hw_strategy_free(snd_pcm_hw_strategy_t *strategy);
714 int snd_pcm_hw_strategy_simple(snd_pcm_hw_strategy_t **strategyp,
715                                unsigned int badness_min,
716                                unsigned int badness_max);
717 int snd_pcm_hw_params_try_explain_failure(snd_pcm_t *pcm,
718                                           snd_pcm_hw_params_t *fail,
719                                           snd_pcm_hw_params_t *success,
720                                           unsigned int depth,
721                                           snd_output_t *out);
722
723 #endif
724
725 size_t snd_pcm_hw_params_sizeof(void);
726 /** \hideinitializer
727  * \brief allocate an invalid #snd_pcm_hw_params_t using standard alloca
728  * \param ptr returned pointer
729  */
730 #define snd_pcm_hw_params_alloca(ptr) __snd_alloca(ptr, snd_pcm_hw_params)
731 int snd_pcm_hw_params_malloc(snd_pcm_hw_params_t **ptr);
732 void snd_pcm_hw_params_free(snd_pcm_hw_params_t *obj);
733 void snd_pcm_hw_params_copy(snd_pcm_hw_params_t *dst, const snd_pcm_hw_params_t *src);
734
735 #if !defined(ALSA_LIBRARY_BUILD) && !defined(ALSA_PCM_OLD_HW_PARAMS_API)
736
737 int snd_pcm_hw_params_get_access(const snd_pcm_hw_params_t *params, snd_pcm_access_t *_access);
738 int snd_pcm_hw_params_test_access(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t _access);
739 int snd_pcm_hw_params_set_access(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t _access);
740 int snd_pcm_hw_params_set_access_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t *_access);
741 int snd_pcm_hw_params_set_access_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_t *_access);
742 int snd_pcm_hw_params_set_access_mask(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_access_mask_t *mask);
743 int snd_pcm_hw_params_get_access_mask(snd_pcm_hw_params_t *params, snd_pcm_access_mask_t *mask);
744
745 int snd_pcm_hw_params_get_format(const snd_pcm_hw_params_t *params, snd_pcm_format_t *val);
746 int snd_pcm_hw_params_test_format(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_t val);
747 int snd_pcm_hw_params_set_format(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_t val);
748 int snd_pcm_hw_params_set_format_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_t *format);
749 int snd_pcm_hw_params_set_format_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_t *format);
750 int snd_pcm_hw_params_set_format_mask(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_format_mask_t *mask);
751 void snd_pcm_hw_params_get_format_mask(snd_pcm_hw_params_t *params, snd_pcm_format_mask_t *mask);
752
753 int snd_pcm_hw_params_get_subformat(const snd_pcm_hw_params_t *params, snd_pcm_subformat_t *subformat);
754 int snd_pcm_hw_params_test_subformat(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t subformat);
755 int snd_pcm_hw_params_set_subformat(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t subformat);
756 int snd_pcm_hw_params_set_subformat_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t *subformat);
757 int snd_pcm_hw_params_set_subformat_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_t *subformat);
758 int snd_pcm_hw_params_set_subformat_mask(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_subformat_mask_t *mask);
759 void snd_pcm_hw_params_get_subformat_mask(snd_pcm_hw_params_t *params, snd_pcm_subformat_mask_t *mask);
760
761 int snd_pcm_hw_params_get_channels(const snd_pcm_hw_params_t *params, unsigned int *val);
762 int snd_pcm_hw_params_get_channels_min(const snd_pcm_hw_params_t *params, unsigned int *val);
763 int snd_pcm_hw_params_get_channels_max(const snd_pcm_hw_params_t *params, unsigned int *val);
764 int snd_pcm_hw_params_test_channels(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val);
765 int snd_pcm_hw_params_set_channels(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val);
766 int snd_pcm_hw_params_set_channels_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val);
767 int snd_pcm_hw_params_set_channels_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val);
768 int snd_pcm_hw_params_set_channels_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, unsigned int *max);
769 int snd_pcm_hw_params_set_channels_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val);
770 int snd_pcm_hw_params_set_channels_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val);
771 int snd_pcm_hw_params_set_channels_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val);
772
773 int snd_pcm_hw_params_get_rate(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
774 int snd_pcm_hw_params_get_rate_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
775 int snd_pcm_hw_params_get_rate_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
776 int snd_pcm_hw_params_test_rate(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
777 int snd_pcm_hw_params_set_rate(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
778 int snd_pcm_hw_params_set_rate_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
779 int snd_pcm_hw_params_set_rate_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
780 int snd_pcm_hw_params_set_rate_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir);
781 int snd_pcm_hw_params_set_rate_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
782 int snd_pcm_hw_params_set_rate_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
783 int snd_pcm_hw_params_set_rate_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
784 int snd_pcm_hw_params_set_rate_resample(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val);
785 int snd_pcm_hw_params_get_rate_resample(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val);
786 int snd_pcm_hw_params_set_export_buffer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val);
787 int snd_pcm_hw_params_get_export_buffer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val);
788 int snd_pcm_hw_params_set_period_wakeup(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val);
789 int snd_pcm_hw_params_get_period_wakeup(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val);
790
791 int snd_pcm_hw_params_get_period_time(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
792 int snd_pcm_hw_params_get_period_time_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
793 int snd_pcm_hw_params_get_period_time_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
794 int snd_pcm_hw_params_test_period_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
795 int snd_pcm_hw_params_set_period_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
796 int snd_pcm_hw_params_set_period_time_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
797 int snd_pcm_hw_params_set_period_time_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
798 int snd_pcm_hw_params_set_period_time_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir);
799 int snd_pcm_hw_params_set_period_time_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
800 int snd_pcm_hw_params_set_period_time_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
801 int snd_pcm_hw_params_set_period_time_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
802
803 int snd_pcm_hw_params_get_period_size(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *frames, int *dir);
804 int snd_pcm_hw_params_get_period_size_min(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *frames, int *dir);
805 int snd_pcm_hw_params_get_period_size_max(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *frames, int *dir);
806 int snd_pcm_hw_params_test_period_size(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t val, int dir);
807 int snd_pcm_hw_params_set_period_size(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t val, int dir);
808 int snd_pcm_hw_params_set_period_size_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir);
809 int snd_pcm_hw_params_set_period_size_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir);
810 int snd_pcm_hw_params_set_period_size_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *min, int *mindir, snd_pcm_uframes_t *max, int *maxdir);
811 int snd_pcm_hw_params_set_period_size_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir);
812 int snd_pcm_hw_params_set_period_size_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir);
813 int snd_pcm_hw_params_set_period_size_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val, int *dir);
814 int snd_pcm_hw_params_set_period_size_integer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
815
816 int snd_pcm_hw_params_get_periods(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
817 int snd_pcm_hw_params_get_periods_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
818 int snd_pcm_hw_params_get_periods_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
819 int snd_pcm_hw_params_test_periods(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
820 int snd_pcm_hw_params_set_periods(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
821 int snd_pcm_hw_params_set_periods_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
822 int snd_pcm_hw_params_set_periods_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
823 int snd_pcm_hw_params_set_periods_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir);
824 int snd_pcm_hw_params_set_periods_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
825 int snd_pcm_hw_params_set_periods_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
826 int snd_pcm_hw_params_set_periods_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
827 int snd_pcm_hw_params_set_periods_integer(snd_pcm_t *pcm, snd_pcm_hw_params_t *params);
828
829 int snd_pcm_hw_params_get_buffer_time(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
830 int snd_pcm_hw_params_get_buffer_time_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
831 int snd_pcm_hw_params_get_buffer_time_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
832 int snd_pcm_hw_params_test_buffer_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
833 int snd_pcm_hw_params_set_buffer_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir);
834 int snd_pcm_hw_params_set_buffer_time_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
835 int snd_pcm_hw_params_set_buffer_time_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
836 int snd_pcm_hw_params_set_buffer_time_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir);
837 int snd_pcm_hw_params_set_buffer_time_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
838 int snd_pcm_hw_params_set_buffer_time_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
839 int snd_pcm_hw_params_set_buffer_time_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir);
840
841 int snd_pcm_hw_params_get_buffer_size(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val);
842 int snd_pcm_hw_params_get_buffer_size_min(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val);
843 int snd_pcm_hw_params_get_buffer_size_max(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val);
844 int snd_pcm_hw_params_test_buffer_size(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t val);
845 int snd_pcm_hw_params_set_buffer_size(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t val);
846 int snd_pcm_hw_params_set_buffer_size_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val);
847 int snd_pcm_hw_params_set_buffer_size_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val);
848 int snd_pcm_hw_params_set_buffer_size_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *min, snd_pcm_uframes_t *max);
849 int snd_pcm_hw_params_set_buffer_size_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val);
850 int snd_pcm_hw_params_set_buffer_size_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val);
851 int snd_pcm_hw_params_set_buffer_size_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val);
852
853 #endif /* !ALSA_LIBRARY_BUILD && !ALSA_PCM_OLD_HW_PARAMS_API */
854
855 int snd_pcm_hw_params_get_min_align(const snd_pcm_hw_params_t *params, snd_pcm_uframes_t *val);
856
857 /** \} */
858
859 /**
860  * \defgroup PCM_SW_Params Software Parameters
861  * \ingroup PCM
862  * See the \ref pcm page for more details.
863  * \{
864  */
865
866 size_t snd_pcm_sw_params_sizeof(void);
867 /** \hideinitializer
868  * \brief allocate an invalid #snd_pcm_sw_params_t using standard alloca
869  * \param ptr returned pointer
870  */
871 #define snd_pcm_sw_params_alloca(ptr) __snd_alloca(ptr, snd_pcm_sw_params)
872 int snd_pcm_sw_params_malloc(snd_pcm_sw_params_t **ptr);
873 void snd_pcm_sw_params_free(snd_pcm_sw_params_t *obj);
874 void snd_pcm_sw_params_copy(snd_pcm_sw_params_t *dst, const snd_pcm_sw_params_t *src);
875 int snd_pcm_sw_params_get_boundary(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val);
876
877 #if !defined(ALSA_LIBRARY_BUILD) && !defined(ALSA_PCM_OLD_SW_PARAMS_API)
878
879 int snd_pcm_sw_params_set_tstamp_mode(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_tstamp_t val);
880 int snd_pcm_sw_params_get_tstamp_mode(const snd_pcm_sw_params_t *params, snd_pcm_tstamp_t *val);
881 int snd_pcm_sw_params_set_tstamp_type(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_tstamp_type_t val);
882 int snd_pcm_sw_params_get_tstamp_type(const snd_pcm_sw_params_t *params, snd_pcm_tstamp_type_t *val);
883 int snd_pcm_sw_params_set_avail_min(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
884 int snd_pcm_sw_params_get_avail_min(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val);
885 int snd_pcm_sw_params_set_period_event(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, int val);
886 int snd_pcm_sw_params_get_period_event(const snd_pcm_sw_params_t *params, int *val);
887 int snd_pcm_sw_params_set_start_threshold(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
888 int snd_pcm_sw_params_get_start_threshold(const snd_pcm_sw_params_t *paramsm, snd_pcm_uframes_t *val);
889 int snd_pcm_sw_params_set_stop_threshold(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
890 int snd_pcm_sw_params_get_stop_threshold(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val);
891 int snd_pcm_sw_params_set_silence_threshold(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
892 int snd_pcm_sw_params_get_silence_threshold(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val);
893 int snd_pcm_sw_params_set_silence_size(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val);
894 int snd_pcm_sw_params_get_silence_size(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val);
895
896 #endif /* !ALSA_LIBRARY_BUILD && !ALSA_PCM_OLD_SW_PARAMS_API */
897
898 /** \} */
899
900 /* include old API */
901 #ifndef ALSA_LIBRARY_BUILD
902 #if defined(ALSA_PCM_OLD_HW_PARAMS_API) || defined(ALSA_PCM_OLD_SW_PARAMS_API)
903 #include "pcm_old.h"
904 #endif
905 #endif
906
907 /**
908  * \defgroup PCM_Access Access Mask Functions
909  * \ingroup PCM
910  * See the \ref pcm page for more details.
911  * \{
912  */
913
914 size_t snd_pcm_access_mask_sizeof(void);
915 /** \hideinitializer
916  * \brief allocate an empty #snd_pcm_access_mask_t using standard alloca
917  * \param ptr returned pointer
918  */
919 #define snd_pcm_access_mask_alloca(ptr) __snd_alloca(ptr, snd_pcm_access_mask)
920 int snd_pcm_access_mask_malloc(snd_pcm_access_mask_t **ptr);
921 void snd_pcm_access_mask_free(snd_pcm_access_mask_t *obj);
922 void snd_pcm_access_mask_copy(snd_pcm_access_mask_t *dst, const snd_pcm_access_mask_t *src);
923 void snd_pcm_access_mask_none(snd_pcm_access_mask_t *mask);
924 void snd_pcm_access_mask_any(snd_pcm_access_mask_t *mask);
925 int snd_pcm_access_mask_test(const snd_pcm_access_mask_t *mask, snd_pcm_access_t val);
926 int snd_pcm_access_mask_empty(const snd_pcm_access_mask_t *mask);
927 void snd_pcm_access_mask_set(snd_pcm_access_mask_t *mask, snd_pcm_access_t val);
928 void snd_pcm_access_mask_reset(snd_pcm_access_mask_t *mask, snd_pcm_access_t val);
929
930 /** \} */
931
932 /**
933  * \defgroup PCM_Format Format Mask Functions
934  * \ingroup PCM
935  * See the \ref pcm page for more details.
936  * \{
937  */
938
939 size_t snd_pcm_format_mask_sizeof(void);
940 /** \hideinitializer
941  * \brief allocate an empty #snd_pcm_format_mask_t using standard alloca
942  * \param ptr returned pointer
943  */
944 #define snd_pcm_format_mask_alloca(ptr) __snd_alloca(ptr, snd_pcm_format_mask)
945 int snd_pcm_format_mask_malloc(snd_pcm_format_mask_t **ptr);
946 void snd_pcm_format_mask_free(snd_pcm_format_mask_t *obj);
947 void snd_pcm_format_mask_copy(snd_pcm_format_mask_t *dst, const snd_pcm_format_mask_t *src);
948 void snd_pcm_format_mask_none(snd_pcm_format_mask_t *mask);
949 void snd_pcm_format_mask_any(snd_pcm_format_mask_t *mask);
950 int snd_pcm_format_mask_test(const snd_pcm_format_mask_t *mask, snd_pcm_format_t val);
951 int snd_pcm_format_mask_empty(const snd_pcm_format_mask_t *mask);
952 void snd_pcm_format_mask_set(snd_pcm_format_mask_t *mask, snd_pcm_format_t val);
953 void snd_pcm_format_mask_reset(snd_pcm_format_mask_t *mask, snd_pcm_format_t val);
954
955 /** \} */
956
957 /**
958  * \defgroup PCM_SubFormat Subformat Mask Functions
959  * \ingroup PCM
960  * See the \ref pcm page for more details.
961  * \{
962  */
963
964 size_t snd_pcm_subformat_mask_sizeof(void);
965 /** \hideinitializer
966  * \brief allocate an empty #snd_pcm_subformat_mask_t using standard alloca
967  * \param ptr returned pointer
968  */
969 #define snd_pcm_subformat_mask_alloca(ptr) __snd_alloca(ptr, snd_pcm_subformat_mask)
970 int snd_pcm_subformat_mask_malloc(snd_pcm_subformat_mask_t **ptr);
971 void snd_pcm_subformat_mask_free(snd_pcm_subformat_mask_t *obj);
972 void snd_pcm_subformat_mask_copy(snd_pcm_subformat_mask_t *dst, const snd_pcm_subformat_mask_t *src);
973 void snd_pcm_subformat_mask_none(snd_pcm_subformat_mask_t *mask);
974 void snd_pcm_subformat_mask_any(snd_pcm_subformat_mask_t *mask);
975 int snd_pcm_subformat_mask_test(const snd_pcm_subformat_mask_t *mask, snd_pcm_subformat_t val);
976 int snd_pcm_subformat_mask_empty(const snd_pcm_subformat_mask_t *mask);
977 void snd_pcm_subformat_mask_set(snd_pcm_subformat_mask_t *mask, snd_pcm_subformat_t val);
978 void snd_pcm_subformat_mask_reset(snd_pcm_subformat_mask_t *mask, snd_pcm_subformat_t val);
979
980 /** \} */
981
982 /**
983  * \defgroup PCM_Status Status Functions
984  * \ingroup PCM
985  * See the \ref pcm page for more details.
986  * \{
987  */
988
989 size_t snd_pcm_status_sizeof(void);
990 /** \hideinitializer
991  * \brief allocate an invalid #snd_pcm_status_t using standard alloca
992  * \param ptr returned pointer
993  */
994 #define snd_pcm_status_alloca(ptr) __snd_alloca(ptr, snd_pcm_status)
995 int snd_pcm_status_malloc(snd_pcm_status_t **ptr);
996 void snd_pcm_status_free(snd_pcm_status_t *obj);
997 void snd_pcm_status_copy(snd_pcm_status_t *dst, const snd_pcm_status_t *src);
998 snd_pcm_state_t snd_pcm_status_get_state(const snd_pcm_status_t *obj);
999 void snd_pcm_status_get_trigger_tstamp(const snd_pcm_status_t *obj, snd_timestamp_t *ptr);
1000 void snd_pcm_status_get_trigger_htstamp(const snd_pcm_status_t *obj, snd_htimestamp_t *ptr);
1001 void snd_pcm_status_get_tstamp(const snd_pcm_status_t *obj, snd_timestamp_t *ptr);
1002 void snd_pcm_status_get_htstamp(const snd_pcm_status_t *obj, snd_htimestamp_t *ptr);
1003 void snd_pcm_status_get_audio_htstamp(const snd_pcm_status_t *obj, snd_htimestamp_t *ptr);
1004 void snd_pcm_status_get_driver_htstamp(const snd_pcm_status_t *obj, snd_htimestamp_t *ptr);
1005 void snd_pcm_status_get_audio_htstamp_report(const snd_pcm_status_t *obj,
1006                                              snd_pcm_audio_tstamp_report_t *audio_tstamp_report);
1007 void snd_pcm_status_set_audio_htstamp_config(snd_pcm_status_t *obj,
1008                                              snd_pcm_audio_tstamp_config_t *audio_tstamp_config);
1009
1010 static inline void snd_pcm_pack_audio_tstamp_config(unsigned int *data,
1011                                                 snd_pcm_audio_tstamp_config_t *config)
1012 {
1013         *data = config->report_delay;
1014         *data <<= 4;
1015         *data |= config->type_requested;
1016 }
1017
1018 static inline void snd_pcm_unpack_audio_tstamp_report(unsigned int data, unsigned int accuracy,
1019                                                 snd_pcm_audio_tstamp_report_t *report)
1020 {
1021         data >>= 16;
1022         report->valid = data & 1;
1023         report->actual_type = (data >> 1) & 0xF;
1024         report->accuracy_report = (data >> 5) & 1;
1025         report->accuracy = accuracy;
1026 }
1027
1028 snd_pcm_sframes_t snd_pcm_status_get_delay(const snd_pcm_status_t *obj);
1029 snd_pcm_uframes_t snd_pcm_status_get_avail(const snd_pcm_status_t *obj);
1030 snd_pcm_uframes_t snd_pcm_status_get_avail_max(const snd_pcm_status_t *obj);
1031 snd_pcm_uframes_t snd_pcm_status_get_overrange(const snd_pcm_status_t *obj);
1032
1033 /** \} */
1034
1035 /**
1036  * \defgroup PCM_Description Description Functions
1037  * \ingroup PCM
1038  * See the \ref pcm page for more details.
1039  * \{
1040  */
1041
1042 const char *snd_pcm_type_name(snd_pcm_type_t type);
1043 const char *snd_pcm_stream_name(const snd_pcm_stream_t stream);
1044 const char *snd_pcm_access_name(const snd_pcm_access_t _access);
1045 const char *snd_pcm_format_name(const snd_pcm_format_t format);
1046 const char *snd_pcm_format_description(const snd_pcm_format_t format);
1047 const char *snd_pcm_subformat_name(const snd_pcm_subformat_t subformat);
1048 const char *snd_pcm_subformat_description(const snd_pcm_subformat_t subformat);
1049 snd_pcm_format_t snd_pcm_format_value(const char* name);
1050 const char *snd_pcm_tstamp_mode_name(const snd_pcm_tstamp_t mode);
1051 const char *snd_pcm_state_name(const snd_pcm_state_t state);
1052
1053 /** \} */
1054
1055 /**
1056  * \defgroup PCM_Dump Debug Functions
1057  * \ingroup PCM
1058  * See the \ref pcm page for more details.
1059  * \{
1060  */
1061
1062 int snd_pcm_dump(snd_pcm_t *pcm, snd_output_t *out);
1063 int snd_pcm_dump_hw_setup(snd_pcm_t *pcm, snd_output_t *out);
1064 int snd_pcm_dump_sw_setup(snd_pcm_t *pcm, snd_output_t *out);
1065 int snd_pcm_dump_setup(snd_pcm_t *pcm, snd_output_t *out);
1066 int snd_pcm_hw_params_dump(snd_pcm_hw_params_t *params, snd_output_t *out);
1067 int snd_pcm_sw_params_dump(snd_pcm_sw_params_t *params, snd_output_t *out);
1068 int snd_pcm_status_dump(snd_pcm_status_t *status, snd_output_t *out);
1069
1070 /** \} */
1071
1072 /**
1073  * \defgroup PCM_Direct Direct Access (MMAP) Functions
1074  * \ingroup PCM
1075  * See the \ref pcm page for more details.
1076  * \{
1077  */
1078
1079 int snd_pcm_mmap_begin(snd_pcm_t *pcm,
1080                        const snd_pcm_channel_area_t **areas,
1081                        snd_pcm_uframes_t *offset,
1082                        snd_pcm_uframes_t *frames);
1083 snd_pcm_sframes_t snd_pcm_mmap_commit(snd_pcm_t *pcm,
1084                                       snd_pcm_uframes_t offset,
1085                                       snd_pcm_uframes_t frames);
1086 snd_pcm_sframes_t snd_pcm_mmap_writei(snd_pcm_t *pcm, const void *buffer, snd_pcm_uframes_t size);
1087 snd_pcm_sframes_t snd_pcm_mmap_readi(snd_pcm_t *pcm, void *buffer, snd_pcm_uframes_t size);
1088 snd_pcm_sframes_t snd_pcm_mmap_writen(snd_pcm_t *pcm, void **bufs, snd_pcm_uframes_t size);
1089 snd_pcm_sframes_t snd_pcm_mmap_readn(snd_pcm_t *pcm, void **bufs, snd_pcm_uframes_t size);                                                                
1090
1091 /** \} */
1092
1093 /**
1094  * \defgroup PCM_Helpers Helper Functions
1095  * \ingroup PCM
1096  * See the \ref pcm page for more details.
1097  * \{
1098  */
1099
1100 int snd_pcm_format_signed(snd_pcm_format_t format);
1101 int snd_pcm_format_unsigned(snd_pcm_format_t format);
1102 int snd_pcm_format_linear(snd_pcm_format_t format);
1103 int snd_pcm_format_float(snd_pcm_format_t format);
1104 int snd_pcm_format_little_endian(snd_pcm_format_t format);
1105 int snd_pcm_format_big_endian(snd_pcm_format_t format);
1106 int snd_pcm_format_cpu_endian(snd_pcm_format_t format);
1107 int snd_pcm_format_width(snd_pcm_format_t format);                      /* in bits */
1108 int snd_pcm_format_physical_width(snd_pcm_format_t format);             /* in bits */
1109 snd_pcm_format_t snd_pcm_build_linear_format(int width, int pwidth, int unsignd, int big_endian);
1110 ssize_t snd_pcm_format_size(snd_pcm_format_t format, size_t samples);
1111 u_int8_t snd_pcm_format_silence(snd_pcm_format_t format);
1112 u_int16_t snd_pcm_format_silence_16(snd_pcm_format_t format);
1113 u_int32_t snd_pcm_format_silence_32(snd_pcm_format_t format);
1114 u_int64_t snd_pcm_format_silence_64(snd_pcm_format_t format);
1115 int snd_pcm_format_set_silence(snd_pcm_format_t format, void *buf, unsigned int samples);
1116
1117 snd_pcm_sframes_t snd_pcm_bytes_to_frames(snd_pcm_t *pcm, ssize_t bytes);
1118 ssize_t snd_pcm_frames_to_bytes(snd_pcm_t *pcm, snd_pcm_sframes_t frames);
1119 long snd_pcm_bytes_to_samples(snd_pcm_t *pcm, ssize_t bytes);
1120 ssize_t snd_pcm_samples_to_bytes(snd_pcm_t *pcm, long samples);
1121
1122 int snd_pcm_area_silence(const snd_pcm_channel_area_t *dst_channel, snd_pcm_uframes_t dst_offset,
1123                          unsigned int samples, snd_pcm_format_t format);
1124 int snd_pcm_areas_silence(const snd_pcm_channel_area_t *dst_channels, snd_pcm_uframes_t dst_offset,
1125                           unsigned int channels, snd_pcm_uframes_t frames, snd_pcm_format_t format);
1126 int snd_pcm_area_copy(const snd_pcm_channel_area_t *dst_channel, snd_pcm_uframes_t dst_offset,
1127                       const snd_pcm_channel_area_t *src_channel, snd_pcm_uframes_t src_offset,
1128                       unsigned int samples, snd_pcm_format_t format);
1129 int snd_pcm_areas_copy(const snd_pcm_channel_area_t *dst_channels, snd_pcm_uframes_t dst_offset,
1130                        const snd_pcm_channel_area_t *src_channels, snd_pcm_uframes_t src_offset,
1131                        unsigned int channels, snd_pcm_uframes_t frames, snd_pcm_format_t format);
1132
1133 /** \} */
1134
1135 /**
1136  * \defgroup PCM_Hook Hook Extension
1137  * \ingroup PCM
1138  * See the \ref pcm page for more details.
1139  * \{
1140  */
1141
1142 /** type of pcm hook */
1143 typedef enum _snd_pcm_hook_type {
1144         SND_PCM_HOOK_TYPE_HW_PARAMS = 0,
1145         SND_PCM_HOOK_TYPE_HW_FREE,
1146         SND_PCM_HOOK_TYPE_CLOSE,
1147         SND_PCM_HOOK_TYPE_LAST = SND_PCM_HOOK_TYPE_CLOSE
1148 } snd_pcm_hook_type_t;
1149
1150 /** PCM hook container */
1151 typedef struct _snd_pcm_hook snd_pcm_hook_t;
1152 /** PCM hook callback function */
1153 typedef int (*snd_pcm_hook_func_t)(snd_pcm_hook_t *hook);
1154 snd_pcm_t *snd_pcm_hook_get_pcm(snd_pcm_hook_t *hook);
1155 void *snd_pcm_hook_get_private(snd_pcm_hook_t *hook);
1156 void snd_pcm_hook_set_private(snd_pcm_hook_t *hook, void *private_data);
1157 int snd_pcm_hook_add(snd_pcm_hook_t **hookp, snd_pcm_t *pcm,
1158                      snd_pcm_hook_type_t type,
1159                      snd_pcm_hook_func_t func, void *private_data);
1160 int snd_pcm_hook_remove(snd_pcm_hook_t *hook);
1161
1162 /** \} */
1163
1164 /**
1165  * \defgroup PCM_Scope Scope Plugin Extension
1166  * \ingroup PCM
1167  * See the \ref pcm page for more details.
1168  * \{
1169  */
1170
1171 /** #SND_PCM_TYPE_METER scope functions */
1172 typedef struct _snd_pcm_scope_ops {
1173         /** \brief Enable and prepare it using current params
1174          * \param scope scope handle
1175          */
1176         int (*enable)(snd_pcm_scope_t *scope);
1177         /** \brief Disable
1178          * \param scope scope handle
1179          */
1180         void (*disable)(snd_pcm_scope_t *scope);
1181         /** \brief PCM has been started
1182          * \param scope scope handle
1183          */
1184         void (*start)(snd_pcm_scope_t *scope);
1185         /** \brief PCM has been stopped
1186          * \param scope scope handle
1187          */
1188         void (*stop)(snd_pcm_scope_t *scope);
1189         /** \brief New frames are present
1190          * \param scope scope handle
1191          */
1192         void (*update)(snd_pcm_scope_t *scope);
1193         /** \brief Reset status
1194          * \param scope scope handle
1195          */
1196         void (*reset)(snd_pcm_scope_t *scope);
1197         /** \brief PCM is closing
1198          * \param scope scope handle
1199          */
1200         void (*close)(snd_pcm_scope_t *scope);
1201 } snd_pcm_scope_ops_t;
1202
1203 snd_pcm_uframes_t snd_pcm_meter_get_bufsize(snd_pcm_t *pcm);
1204 unsigned int snd_pcm_meter_get_channels(snd_pcm_t *pcm);
1205 unsigned int snd_pcm_meter_get_rate(snd_pcm_t *pcm);
1206 snd_pcm_uframes_t snd_pcm_meter_get_now(snd_pcm_t *pcm);
1207 snd_pcm_uframes_t snd_pcm_meter_get_boundary(snd_pcm_t *pcm);
1208 int snd_pcm_meter_add_scope(snd_pcm_t *pcm, snd_pcm_scope_t *scope);
1209 snd_pcm_scope_t *snd_pcm_meter_search_scope(snd_pcm_t *pcm, const char *name);
1210 int snd_pcm_scope_malloc(snd_pcm_scope_t **ptr);
1211 void snd_pcm_scope_set_ops(snd_pcm_scope_t *scope,
1212                            const snd_pcm_scope_ops_t *val);
1213 void snd_pcm_scope_set_name(snd_pcm_scope_t *scope, const char *val);
1214 const char *snd_pcm_scope_get_name(snd_pcm_scope_t *scope);
1215 void *snd_pcm_scope_get_callback_private(snd_pcm_scope_t *scope);
1216 void snd_pcm_scope_set_callback_private(snd_pcm_scope_t *scope, void *val);
1217 int snd_pcm_scope_s16_open(snd_pcm_t *pcm, const char *name,
1218                            snd_pcm_scope_t **scopep);
1219 int16_t *snd_pcm_scope_s16_get_channel_buffer(snd_pcm_scope_t *scope,
1220                                               unsigned int channel);
1221
1222 /** \} */
1223
1224 /**
1225  * \defgroup PCM_Simple Simple setup functions
1226  * \ingroup PCM
1227  * See the \ref pcm page for more details.
1228  * \{
1229  */
1230
1231 /** Simple PCM latency type */
1232 typedef enum _snd_spcm_latency {
1233         /** standard latency - for standard playback or capture
1234             (estimated latency in one direction 350ms) */
1235         SND_SPCM_LATENCY_STANDARD = 0,
1236         /** medium latency - software phones etc.
1237             (estimated latency in one direction maximally 25ms */
1238         SND_SPCM_LATENCY_MEDIUM,
1239         /** realtime latency - realtime applications (effect processors etc.)
1240             (estimated latency in one direction 5ms and better) */
1241         SND_SPCM_LATENCY_REALTIME
1242 } snd_spcm_latency_t;
1243
1244 /** Simple PCM xrun type */
1245 typedef enum _snd_spcm_xrun_type {
1246         /** driver / library will ignore all xruns, the stream runs forever */
1247         SND_SPCM_XRUN_IGNORE = 0,
1248         /** driver / library stops the stream when an xrun occurs */
1249         SND_SPCM_XRUN_STOP
1250 } snd_spcm_xrun_type_t;
1251
1252 /** Simple PCM duplex type */
1253 typedef enum _snd_spcm_duplex_type {
1254         /** liberal duplex - the buffer and period sizes might not match */
1255         SND_SPCM_DUPLEX_LIBERAL = 0,
1256         /** pedantic duplex - the buffer and period sizes MUST match */
1257         SND_SPCM_DUPLEX_PEDANTIC
1258 } snd_spcm_duplex_type_t;
1259
1260 int snd_spcm_init(snd_pcm_t *pcm,
1261                   unsigned int rate,
1262                   unsigned int channels,
1263                   snd_pcm_format_t format,
1264                   snd_pcm_subformat_t subformat,
1265                   snd_spcm_latency_t latency,
1266                   snd_pcm_access_t _access,
1267                   snd_spcm_xrun_type_t xrun_type);
1268
1269 int snd_spcm_init_duplex(snd_pcm_t *playback_pcm,
1270                          snd_pcm_t *capture_pcm,
1271                          unsigned int rate,
1272                          unsigned int channels,
1273                          snd_pcm_format_t format,
1274                          snd_pcm_subformat_t subformat,
1275                          snd_spcm_latency_t latency,
1276                          snd_pcm_access_t _access,
1277                          snd_spcm_xrun_type_t xrun_type,
1278                          snd_spcm_duplex_type_t duplex_type);
1279
1280 int snd_spcm_init_get_params(snd_pcm_t *pcm,
1281                              unsigned int *rate,
1282                              snd_pcm_uframes_t *buffer_size,
1283                              snd_pcm_uframes_t *period_size);
1284
1285 /** \} */
1286
1287 /**
1288  * \defgroup PCM_Deprecated Deprecated Functions
1289  * \ingroup PCM
1290  * See the \ref pcm page for more details.
1291  * \{
1292  */
1293
1294 /* Deprecated functions, for compatibility */
1295 const char *snd_pcm_start_mode_name(snd_pcm_start_t mode) __attribute__((deprecated));
1296 const char *snd_pcm_xrun_mode_name(snd_pcm_xrun_t mode) __attribute__((deprecated));
1297 int snd_pcm_sw_params_set_start_mode(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_start_t val) __attribute__((deprecated));
1298 snd_pcm_start_t snd_pcm_sw_params_get_start_mode(const snd_pcm_sw_params_t *params) __attribute__((deprecated));
1299 int snd_pcm_sw_params_set_xrun_mode(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_xrun_t val) __attribute__((deprecated));
1300 snd_pcm_xrun_t snd_pcm_sw_params_get_xrun_mode(const snd_pcm_sw_params_t *params) __attribute__((deprecated));
1301 #if !defined(ALSA_LIBRARY_BUILD) && !defined(ALSA_PCM_OLD_SW_PARAMS_API)
1302 int snd_pcm_sw_params_set_xfer_align(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, snd_pcm_uframes_t val) __attribute__((deprecated));
1303 int snd_pcm_sw_params_get_xfer_align(const snd_pcm_sw_params_t *params, snd_pcm_uframes_t *val) __attribute__((deprecated));
1304 int snd_pcm_sw_params_set_sleep_min(snd_pcm_t *pcm, snd_pcm_sw_params_t *params, unsigned int val) __attribute__((deprecated));
1305 int snd_pcm_sw_params_get_sleep_min(const snd_pcm_sw_params_t *params, unsigned int *val) __attribute__((deprecated));
1306 #endif /* !ALSA_LIBRARY_BUILD && !ALSA_PCM_OLD_SW_PARAMS_API */
1307 #if !defined(ALSA_LIBRARY_BUILD) && !defined(ALSA_PCM_OLD_HW_PARAMS_API)
1308 int snd_pcm_hw_params_get_tick_time(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated));
1309 int snd_pcm_hw_params_get_tick_time_min(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated));
1310 int snd_pcm_hw_params_get_tick_time_max(const snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated));
1311 int snd_pcm_hw_params_test_tick_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir) __attribute__((deprecated));
1312 int snd_pcm_hw_params_set_tick_time(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int val, int dir) __attribute__((deprecated));
1313 int snd_pcm_hw_params_set_tick_time_min(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated));
1314 int snd_pcm_hw_params_set_tick_time_max(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated));
1315 int snd_pcm_hw_params_set_tick_time_minmax(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *min, int *mindir, unsigned int *max, int *maxdir) __attribute__((deprecated));
1316 int snd_pcm_hw_params_set_tick_time_near(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated));
1317 int snd_pcm_hw_params_set_tick_time_first(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated));
1318 int snd_pcm_hw_params_set_tick_time_last(snd_pcm_t *pcm, snd_pcm_hw_params_t *params, unsigned int *val, int *dir) __attribute__((deprecated));
1319 #endif /* !ALSA_LIBRARY_BUILD && !ALSA_PCM_OLD_HW_PARAMS_API */
1320
1321 /** \} */
1322
1323 #ifdef __cplusplus
1324 }
1325 #endif
1326
1327 #endif /* __ALSA_PCM_H */