xref: /netbsd/sys/sys/audioio.h (revision 778f5600)
1 /*	$NetBSD: audioio.h,v 1.40 2022/04/07 19:33:38 andvar Exp $	*/
2 
3 /*
4  * Copyright (c) 1991-1993 Regents of the University of California.
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  * 3. All advertising materials mentioning features or use of this software
16  *    must display the following acknowledgement:
17  *	This product includes software developed by the Computer Systems
18  *	Engineering Group at Lawrence Berkeley Laboratory.
19  * 4. Neither the name of the University nor of the Laboratory may be used
20  *    to endorse or promote products derived from this software without
21  *    specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33  * SUCH DAMAGE.
34  *
35  */
36 
37 #ifndef _SYS_AUDIOIO_H_
38 #define _SYS_AUDIOIO_H_
39 
40 #include <sys/types.h>
41 #include <sys/ioccom.h>
42 
43 #ifndef _KERNEL
44 #include <string.h>	/* Required for memset(3) prototype (AUDIO_INITINFO) */
45 #endif /* _KERNEL */
46 
47 /*
48  * Audio device
49  */
50 struct audio_prinfo {
51 	u_int	sample_rate;	/* sample rate in bit/s */
52 	u_int	channels;	/* number of channels, usually 1 or 2 */
53 	u_int	precision;	/* number of bits/sample */
54 	u_int	encoding;	/* data encoding (AUDIO_ENCODING_* below) */
55 	u_int	gain;		/* volume level */
56 	u_int	port;		/* selected I/O port */
57 	u_int	seek;		/* BSD extension */
58 	u_int	avail_ports;	/* available I/O ports */
59 	u_int	buffer_size;	/* total size audio buffer */
60 	u_int	_ispare[1];
61 	/* Current state of device: */
62 	u_int	samples;	/* number of samples */
63 	u_int	eof;		/* End Of File (zero-size writes) counter */
64 	u_char	pause;		/* non-zero if paused, zero to resume */
65 	u_char	error;		/* non-zero if underflow/overflow occurred */
66 	u_char	waiting;	/* non-zero if another process hangs in open */
67 	u_char	balance;	/* stereo channel balance */
68 	u_char	cspare[2];
69 	u_char	open;		/* non-zero if currently open */
70 	u_char	active;		/* non-zero if I/O is currently active */
71 };
72 typedef struct audio_prinfo audio_prinfo_t;
73 
74 struct audio_info {
75 	struct	audio_prinfo play;	/* Info for play (output) side */
76 	struct	audio_prinfo record;	/* Info for record (input) side */
77 
78 	u_int	monitor_gain;	/* input to output mix */
79 	/* BSD extensions */
80 	u_int	blocksize;	/* H/W read/write block size */
81 	u_int	hiwat;		/* output high water mark */
82 	u_int	lowat;		/* output low water mark */
83 	u_int	_ispare1;
84 	u_int	mode;		/* current device mode */
85 #define AUMODE_PLAY	0x01
86 #define AUMODE_RECORD	0x02
87 #define AUMODE_PLAY_ALL	0x04	/* don't do real-time correction */
88 };
89 typedef struct audio_info audio_info_t;
90 
91 #define AUDIO_INITINFO(p) \
92 	(void)memset((void *)(p), 0xff, sizeof(struct audio_info))
93 
94 /*
95  * Parameter for the AUDIO_GETDEV ioctl to determine current
96  * audio devices.
97  */
98 #define MAX_AUDIO_DEV_LEN       16
99 typedef struct audio_device {
100         char name[MAX_AUDIO_DEV_LEN];
101         char version[MAX_AUDIO_DEV_LEN];
102         char config[MAX_AUDIO_DEV_LEN];
103 } audio_device_t;
104 
105 typedef struct audio_offset {
106 	u_int	samples;	/* Total number of bytes transferred */
107 	u_int	deltablks;	/* Blocks transferred since last checked */
108 	u_int	offset;		/* Physical transfer offset in buffer */
109 } audio_offset_t;
110 
111 /*
112  * Supported audio encodings
113  */
114 /* Encoding ID's */
115 #define	AUDIO_ENCODING_NONE		0 /* no encoding assigned */
116 #define	AUDIO_ENCODING_ULAW		1 /* ITU G.711 mu-law */
117 #define	AUDIO_ENCODING_ALAW		2 /* ITU G.711 A-law */
118 #define	AUDIO_ENCODING_PCM16		3 /* signed linear PCM, obsolete */
119 #define AUDIO_ENCODING_LINEAR		AUDIO_ENCODING_PCM16 /* SunOS compat */
120 #define	AUDIO_ENCODING_PCM8		4 /* unsigned linear PCM, obsolete */
121 #define AUDIO_ENCODING_LINEAR8		AUDIO_ENCODING_PCM8 /* SunOS compat */
122 #define	AUDIO_ENCODING_ADPCM		5 /* adaptive differential PCM */
123 #define AUDIO_ENCODING_SLINEAR_LE	6
124 #define AUDIO_ENCODING_SLINEAR_BE	7
125 #define AUDIO_ENCODING_ULINEAR_LE	8
126 #define AUDIO_ENCODING_ULINEAR_BE	9
127 #define AUDIO_ENCODING_SLINEAR		10
128 #define AUDIO_ENCODING_ULINEAR		11
129 #define AUDIO_ENCODING_MPEG_L1_STREAM	12
130 #define AUDIO_ENCODING_MPEG_L1_PACKETS	13
131 #define AUDIO_ENCODING_MPEG_L1_SYSTEM	14
132 #define AUDIO_ENCODING_MPEG_L2_STREAM	15
133 #define AUDIO_ENCODING_MPEG_L2_PACKETS	16
134 #define AUDIO_ENCODING_MPEG_L2_SYSTEM	17
135 #define AUDIO_ENCODING_AC3		18
136 
137 /* XXX Consider whether to export to userland? */
138 #if defined(_KERNEL)
139 #if BYTE_ORDER == LITTLE_ENDIAN
140 #define AUDIO_ENCODING_SLINEAR_NE AUDIO_ENCODING_SLINEAR_LE
141 #define AUDIO_ENCODING_ULINEAR_NE AUDIO_ENCODING_ULINEAR_LE
142 #define AUDIO_ENCODING_SLINEAR_OE AUDIO_ENCODING_SLINEAR_BE
143 #define AUDIO_ENCODING_ULINEAR_OE AUDIO_ENCODING_ULINEAR_BE
144 #else
145 #define AUDIO_ENCODING_SLINEAR_NE AUDIO_ENCODING_SLINEAR_BE
146 #define AUDIO_ENCODING_ULINEAR_NE AUDIO_ENCODING_ULINEAR_BE
147 #define AUDIO_ENCODING_SLINEAR_OE AUDIO_ENCODING_SLINEAR_LE
148 #define AUDIO_ENCODING_ULINEAR_OE AUDIO_ENCODING_ULINEAR_LE
149 #endif
150 #endif /* _KERNEL */
151 
152 typedef struct audio_encoding {
153 	int	index;
154 	char	name[MAX_AUDIO_DEV_LEN];
155 	int	encoding;
156 	int	precision;
157 	int	flags;
158 #define AUDIO_ENCODINGFLAG_EMULATED 1 /* software emulation mode */
159 } audio_encoding_t;
160 
161 struct audio_format {
162 	/**
163 	 * Device-dependent audio drivers may use this field freely.
164 	 */
165 	void *driver_data;
166 
167 	/**
168 	 * combination of AUMODE_PLAY and AUMODE_RECORD
169 	 */
170 	int32_t mode;
171 
172 	/**
173 	 * Encoding type.  AUDIO_ENCODING_*.
174 	 * Don't use AUDIO_ENCODING_SLINEAR/ULINEAR/LINEAR/LINEAR8
175 	 */
176 	u_int encoding;
177 
178 	/**
179 	 * The size of valid bits in one sample.
180 	 * It must be <= precision.
181 	 */
182 	u_int validbits;
183 
184 	/**
185 	 * The bit size of one sample.
186 	 * It must be >= validbits, and is usually a multiple of 8.
187 	 */
188 	u_int precision;
189 
190 	/**
191 	 * The number of channels.  >= 1
192 	 */
193 	u_int channels;
194 
195 	u_int channel_mask;
196 #define	AUFMT_UNKNOWN_POSITION		0U
197 #define	AUFMT_FRONT_LEFT		0x00001U /* USB audio compatible */
198 #define	AUFMT_FRONT_RIGHT		0x00002U /* USB audio compatible */
199 #define	AUFMT_FRONT_CENTER		0x00004U /* USB audio compatible */
200 #define	AUFMT_LOW_FREQUENCY		0x00008U /* USB audio compatible */
201 #define	AUFMT_BACK_LEFT			0x00010U /* USB audio compatible */
202 #define	AUFMT_BACK_RIGHT		0x00020U /* USB audio compatible */
203 #define	AUFMT_FRONT_LEFT_OF_CENTER	0x00040U /* USB audio compatible */
204 #define	AUFMT_FRONT_RIGHT_OF_CENTER	0x00080U /* USB audio compatible */
205 #define	AUFMT_BACK_CENTER		0x00100U /* USB audio compatible */
206 #define	AUFMT_SIDE_LEFT			0x00200U /* USB audio compatible */
207 #define	AUFMT_SIDE_RIGHT		0x00400U /* USB audio compatible */
208 #define	AUFMT_TOP_CENTER		0x00800U /* USB audio compatible */
209 #define	AUFMT_TOP_FRONT_LEFT		0x01000U
210 #define	AUFMT_TOP_FRONT_CENTER		0x02000U
211 #define	AUFMT_TOP_FRONT_RIGHT		0x04000U
212 #define	AUFMT_TOP_BACK_LEFT		0x08000U
213 #define	AUFMT_TOP_BACK_CENTER		0x10000U
214 #define	AUFMT_TOP_BACK_RIGHT		0x20000U
215 
216 #define	AUFMT_MONAURAL		AUFMT_FRONT_CENTER
217 #define	AUFMT_STEREO		(AUFMT_FRONT_LEFT | AUFMT_FRONT_RIGHT)
218 #define	AUFMT_SURROUND4		(AUFMT_STEREO | AUFMT_BACK_LEFT \
219 				| AUFMT_BACK_RIGHT)
220 #define	AUFMT_DOLBY_5_1		(AUFMT_SURROUND4 | AUFMT_FRONT_CENTER \
221 				| AUFMT_LOW_FREQUENCY)
222 
223 	/**
224 	 * 0: frequency[0] is lower limit, and frequency[1] is higher limit.
225 	 * 1-16: frequency[0] to frequency[frequency_type-1] are valid.
226 	 */
227 	u_int frequency_type;
228 
229 #define	AUFMT_MAX_FREQUENCIES	16
230 	/**
231 	 * sampling rates
232 	 */
233 	u_int frequency[AUFMT_MAX_FREQUENCIES];
234 
235 	/**
236 	 * 0-3: priority.  0 is the lowest.
237 	 * -1: hardware supports this format but driver doesn't (e.g. AC3).
238 	 */
239 	int priority;
240 };
241 
242 typedef struct audio_format_query {
243 	u_int	index;
244 	struct audio_format fmt;
245 } audio_format_query_t;
246 
247 /*
248  * Balance settings.
249  */
250 #define	AUDIO_LEFT_BALANCE	0	/* left channel only	*/
251 #define	AUDIO_MID_BALANCE	32	/* equal left/right channel */
252 #define	AUDIO_RIGHT_BALANCE	64	/* right channel only	*/
253 #define	AUDIO_BALANCE_SHIFT	3
254 
255 /*
256  * Output ports
257  */
258 #define	AUDIO_SPEAKER		0x01	/* built-in speaker */
259 #define	AUDIO_HEADPHONE		0x02	/* headphone jack */
260 #define	AUDIO_LINE_OUT		0x04	/* line out	 */
261 #define	VC_OUT			0x08	/* virt chan out */
262 
263 /*
264  * Input ports
265  */
266 #define	AUDIO_MICROPHONE	0x01	/* microphone */
267 #define	AUDIO_LINE_IN		0x02	/* line in	 */
268 #define	AUDIO_CD		0x04	/* on-board CD inputs */
269 #define	AUDIO_INTERNAL_CD_IN	AUDIO_CD	/* internal CDROM */
270 #define	VC_IN			0x08	/* virt chan in */
271 
272 /*
273  * Audio device operations
274  */
275 #define AUDIO_GETINFO	_IOR('A', 21, struct audio_info)
276 #define AUDIO_SETINFO	_IOWR('A', 22, struct audio_info)
277 #define AUDIO_DRAIN	_IO('A', 23)
278 #define AUDIO_FLUSH	_IO('A', 24)
279 #define AUDIO_WSEEK	_IOR('A', 25, u_long)
280 #define AUDIO_RERROR	_IOR('A', 26, int)
281 #define AUDIO_GETDEV	_IOR('A', 27, struct audio_device)
282 #define AUDIO_GETENC	_IOWR('A', 28, struct audio_encoding)
283 #define AUDIO_GETFD	_IOR('A', 29, int)
284 #define AUDIO_SETFD	_IOWR('A', 30, int)
285 #define AUDIO_PERROR	_IOR('A', 31, int)
286 #define AUDIO_GETIOFFS	_IOR('A', 32, struct audio_offset)
287 #define AUDIO_GETOOFFS	_IOR('A', 33, struct audio_offset)
288 #define AUDIO_GETPROPS	_IOR('A', 34, int)
289 #define  AUDIO_PROP_FULLDUPLEX	0x01
290 #define  AUDIO_PROP_MMAP	0x02
291 #define  AUDIO_PROP_INDEPENDENT	0x04
292 #define  AUDIO_PROP_PLAYBACK	0x10
293 #define  AUDIO_PROP_CAPTURE	0x20
294 #define AUDIO_GETBUFINFO	_IOR('A', 35, struct audio_info)
295 #define AUDIO_SETCHAN	_IOW('A', 36, int)
296 #define AUDIO_GETCHAN	_IOR('A', 37, int)
297 #define AUDIO_QUERYFORMAT	_IOWR('A', 38, struct audio_format_query)
298 #define AUDIO_GETFORMAT	_IOR('A', 39, struct audio_info)
299 #define AUDIO_SETFORMAT	_IOW('A', 40, struct audio_info)
300 
301 /*
302  * Mixer device
303  */
304 #define AUDIO_MIN_GAIN	0
305 #define AUDIO_MAX_GAIN	255
306 
307 typedef struct mixer_level {
308 	int num_channels;
309 	u_char level[8];	/* [num_channels] */
310 } mixer_level_t;
311 #define AUDIO_MIXER_LEVEL_MONO	0
312 #define AUDIO_MIXER_LEVEL_LEFT	0
313 #define AUDIO_MIXER_LEVEL_RIGHT	1
314 
315 /*
316  * Device operations
317  */
318 
319 typedef struct audio_mixer_name {
320 	char name[MAX_AUDIO_DEV_LEN];
321 	int msg_id;
322 } audio_mixer_name_t;
323 
324 typedef struct mixer_devinfo {
325 	int index;
326 	audio_mixer_name_t label;
327 	int type;
328 #define AUDIO_MIXER_CLASS	0
329 #define AUDIO_MIXER_ENUM	1
330 #define AUDIO_MIXER_SET		2
331 #define AUDIO_MIXER_VALUE	3
332 	int mixer_class;
333 	int next, prev;
334 #define AUDIO_MIXER_LAST	-1
335 	union {
336 		struct audio_mixer_enum {
337 			int num_mem;
338 			struct {
339 				audio_mixer_name_t label;
340 				int ord;
341 			} member[32];
342 		} e;
343 		struct audio_mixer_set {
344 			int num_mem;
345 			struct {
346 				audio_mixer_name_t label;
347 				int mask;
348 			} member[32];
349 		} s;
350 		struct audio_mixer_value {
351 			audio_mixer_name_t units;
352 			int num_channels;
353 			int delta;
354 		} v;
355 	} un;
356 } mixer_devinfo_t;
357 
358 
359 typedef struct mixer_ctrl {
360 	int dev;
361 	int type;
362 	union {
363 		int ord;		/* enum */
364 		int mask;		/* set */
365 		mixer_level_t value;	/* value */
366 	} un;
367 } mixer_ctrl_t;
368 
369 /*
370  * Mixer operations
371  */
372 #define AUDIO_MIXER_READ		_IOWR('M', 0, mixer_ctrl_t)
373 #define AUDIO_MIXER_WRITE		_IOWR('M', 1, mixer_ctrl_t)
374 #define AUDIO_MIXER_DEVINFO		_IOWR('M', 2, mixer_devinfo_t)
375 
376 /*
377  * Well known device names
378  */
379 #define AudioNmicrophone	"mic"
380 #define AudioNline	"line"
381 #define AudioNcd	"cd"
382 #define AudioNdac	"dac"
383 #define AudioNaux	"aux"
384 #define AudioNrecord	"record"
385 #define AudioNvolume	"volume"
386 #define AudioNmonitor	"monitor"
387 #define AudioNtreble	"treble"
388 #define AudioNmid	"mid"
389 #define AudioNbass	"bass"
390 #define AudioNbassboost	"bassboost"
391 #define AudioNspeaker	"speaker"
392 #define AudioNheadphone	"headphones"
393 #define AudioNoutput	"output"
394 #define AudioNinput	"input"
395 #define AudioNmaster	"master"
396 #define AudioNstereo	"stereo"
397 #define AudioNmono	"mono"
398 #define AudioNloudness	"loudness"
399 #define AudioNspatial	"spatial"
400 #define AudioNsurround	"surround"
401 #define AudioNpseudo	"pseudo"
402 #define AudioNmute	"mute"
403 #define AudioNenhanced	"enhanced"
404 #define AudioNpreamp	"preamp"
405 #define AudioNon	"on"
406 #define AudioNoff	"off"
407 #define AudioNmode	"mode"
408 #define AudioNsource	"source"
409 #define AudioNfmsynth	"fmsynth"
410 #define AudioNwave	"wave"
411 #define AudioNmidi	"midi"
412 #define AudioNmixerout	"mixerout"
413 #define AudioNswap	"swap"	/* swap left and right channels */
414 #define AudioNagc	"agc"
415 #define AudioNdelay	"delay"
416 #define AudioNselect	"select" /* select destination */
417 #define AudioNvideo     "video"
418 #define AudioNcenter    "center"
419 #define AudioNdepth     "depth"
420 #define AudioNlfe       "lfe"
421 
422 #define AudioEmulaw		"mulaw"
423 #define AudioEalaw		"alaw"
424 #define AudioEadpcm		"adpcm"
425 #define AudioEslinear		"slinear"
426 #define AudioEslinear_le	"slinear_le"
427 #define AudioEslinear_be	"slinear_be"
428 #define AudioEulinear		"ulinear"
429 #define AudioEulinear_le	"ulinear_le"
430 #define AudioEulinear_be	"ulinear_be"
431 #define AudioEmpeg_l1_stream	"mpeg_l1_stream"
432 #define AudioEmpeg_l1_packets	"mpeg_l1_packets"
433 #define AudioEmpeg_l1_system	"mpeg_l1_system"
434 #define AudioEmpeg_l2_stream	"mpeg_l2_stream"
435 #define AudioEmpeg_l2_packets	"mpeg_l2_packets"
436 #define AudioEmpeg_l2_system	"mpeg_l2_system"
437 #define AudioEac3		"ac3"
438 
439 #define AudioCinputs	"inputs"
440 #define AudioCoutputs	"outputs"
441 #define AudioCrecord	"record"
442 #define AudioCmonitor	"monitor"
443 #define AudioCequalization	"equalization"
444 #define AudioCmodem	"modem"
445 #define AudioCvirtchan	"vchan"
446 
447 #endif /* !_SYS_AUDIOIO_H_ */
448