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