audio_if.h revision 1.2 1 1.2 isaki /* $NetBSD: audio_if.h,v 1.2 2019/05/08 13:40:17 isaki Exp $ */
2 1.2 isaki
3 1.2 isaki /*
4 1.2 isaki * Copyright (c) 1994 Havard Eidnes.
5 1.2 isaki * All rights reserved.
6 1.2 isaki *
7 1.2 isaki * Redistribution and use in source and binary forms, with or without
8 1.2 isaki * modification, are permitted provided that the following conditions
9 1.2 isaki * are met:
10 1.2 isaki * 1. Redistributions of source code must retain the above copyright
11 1.2 isaki * notice, this list of conditions and the following disclaimer.
12 1.2 isaki * 2. Redistributions in binary form must reproduce the above copyright
13 1.2 isaki * notice, this list of conditions and the following disclaimer in the
14 1.2 isaki * documentation and/or other materials provided with the distribution.
15 1.2 isaki * 3. All advertising materials mentioning features or use of this software
16 1.2 isaki * must display the following acknowledgement:
17 1.2 isaki * This product includes software developed by the Computer Systems
18 1.2 isaki * Engineering Group at Lawrence Berkeley Laboratory.
19 1.2 isaki * 4. Neither the name of the University nor of the Laboratory may be used
20 1.2 isaki * to endorse or promote products derived from this software without
21 1.2 isaki * specific prior written permission.
22 1.2 isaki *
23 1.2 isaki * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 1.2 isaki * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 1.2 isaki * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 1.2 isaki * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 1.2 isaki * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 1.2 isaki * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 1.2 isaki * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.2 isaki * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 1.2 isaki * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 1.2 isaki * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 1.2 isaki * SUCH DAMAGE.
34 1.2 isaki *
35 1.2 isaki */
36 1.2 isaki
37 1.2 isaki #ifndef _SYS_DEV_AUDIO_AUDIO_IF_H_
38 1.2 isaki #define _SYS_DEV_AUDIO_AUDIO_IF_H_
39 1.2 isaki
40 1.2 isaki #include <sys/types.h>
41 1.2 isaki #include <sys/audioio.h>
42 1.2 isaki #include <sys/mutex.h>
43 1.2 isaki
44 1.2 isaki /* check we have an audio(4) configured into kernel */
45 1.2 isaki #if defined(_KERNEL_OPT)
46 1.2 isaki #include "audio.h"
47 1.2 isaki
48 1.2 isaki #if (NAUDIO == 0) && (NMIDI == 0) && (NMIDIBUS == 0)
49 1.2 isaki #error "No 'audio* at audiobus?' or 'midi* at midibus?' or similar configured"
50 1.2 isaki #endif
51 1.2 isaki
52 1.2 isaki #endif /* _KERNEL_OPT */
53 1.2 isaki
54 1.2 isaki /*
55 1.2 isaki * Interfaces for hardware drivers and MI audio.
56 1.2 isaki */
57 1.2 isaki
58 1.2 isaki struct audio_softc;
59 1.2 isaki
60 1.2 isaki /**
61 1.2 isaki * audio stream format
62 1.2 isaki */
63 1.2 isaki typedef struct audio_params {
64 1.2 isaki u_int sample_rate; /* sample rate */
65 1.2 isaki u_int encoding; /* e.g. mu-law, linear, etc */
66 1.2 isaki u_int precision; /* bits/subframe */
67 1.2 isaki u_int validbits; /* valid bits in a subframe */
68 1.2 isaki u_int channels; /* mono(1), stereo(2) */
69 1.2 isaki } audio_params_t;
70 1.2 isaki
71 1.2 isaki #define AUFMT_INVALIDATE(fmt) (fmt)->mode |= 0x80000000
72 1.2 isaki #define AUFMT_VALIDATE(fmt) (fmt)->mode &= 0x7fffffff
73 1.2 isaki #define AUFMT_IS_VALID(fmt) (((fmt)->mode & 0x80000000) == 0)
74 1.2 isaki
75 1.2 isaki #include <dev/audio/audiofil.h>
76 1.2 isaki
77 1.2 isaki struct audio_hw_if {
78 1.2 isaki int (*open)(void *, int); /* open hardware */
79 1.2 isaki void (*close)(void *); /* close hardware */
80 1.2 isaki
81 1.2 isaki int (*query_format)(void *, audio_format_query_t *);
82 1.2 isaki int (*set_format)(void *, int,
83 1.2 isaki const audio_params_t *, const audio_params_t *,
84 1.2 isaki audio_filter_reg_t *, audio_filter_reg_t *);
85 1.2 isaki
86 1.2 isaki /* Hardware may have some say in the blocksize to choose */
87 1.2 isaki int (*round_blocksize)(void *, int, int, const audio_params_t *);
88 1.2 isaki
89 1.2 isaki /*
90 1.2 isaki * Changing settings may require taking device out of "data mode",
91 1.2 isaki * which can be quite expensive. Also, audiosetinfo() may
92 1.2 isaki * change several settings in quick succession. To avoid
93 1.2 isaki * having to take the device in/out of "data mode", we provide
94 1.2 isaki * this function which indicates completion of settings
95 1.2 isaki * adjustment.
96 1.2 isaki */
97 1.2 isaki int (*commit_settings)(void *);
98 1.2 isaki
99 1.2 isaki /* Start input/output routines. These usually control DMA. */
100 1.2 isaki int (*init_output)(void *, void *, int);
101 1.2 isaki int (*init_input)(void *, void *, int);
102 1.2 isaki int (*start_output)(void *, void *, int,
103 1.2 isaki void (*)(void *), void *);
104 1.2 isaki int (*start_input)(void *, void *, int,
105 1.2 isaki void (*)(void *), void *);
106 1.2 isaki int (*halt_output)(void *);
107 1.2 isaki int (*halt_input)(void *);
108 1.2 isaki
109 1.2 isaki int (*speaker_ctl)(void *, int);
110 1.2 isaki #define SPKR_ON 1
111 1.2 isaki #define SPKR_OFF 0
112 1.2 isaki
113 1.2 isaki int (*getdev)(void *, struct audio_device *);
114 1.2 isaki
115 1.2 isaki /* Mixer (in/out ports) */
116 1.2 isaki int (*set_port)(void *, mixer_ctrl_t *);
117 1.2 isaki int (*get_port)(void *, mixer_ctrl_t *);
118 1.2 isaki
119 1.2 isaki int (*query_devinfo)(void *, mixer_devinfo_t *);
120 1.2 isaki
121 1.2 isaki /* Allocate/free memory for the ring buffer. Usually malloc/free. */
122 1.2 isaki void *(*allocm)(void *, int, size_t);
123 1.2 isaki void (*freem)(void *, void *, size_t);
124 1.2 isaki size_t (*round_buffersize)(void *, int, size_t);
125 1.2 isaki
126 1.2 isaki int (*get_props)(void *); /* device properties */
127 1.2 isaki
128 1.2 isaki int (*trigger_output)(void *, void *, void *, int,
129 1.2 isaki void (*)(void *), void *, const audio_params_t *);
130 1.2 isaki int (*trigger_input)(void *, void *, void *, int,
131 1.2 isaki void (*)(void *), void *, const audio_params_t *);
132 1.2 isaki int (*dev_ioctl)(void *, u_long, void *, int, struct lwp *);
133 1.2 isaki void (*get_locks)(void *, kmutex_t **, kmutex_t **);
134 1.2 isaki };
135 1.2 isaki
136 1.2 isaki struct audio_attach_args {
137 1.2 isaki int type;
138 1.2 isaki const void *hwif; /* either audio_hw_if * or midi_hw_if * */
139 1.2 isaki void *hdl;
140 1.2 isaki };
141 1.2 isaki #define AUDIODEV_TYPE_AUDIO 0
142 1.2 isaki #define AUDIODEV_TYPE_MIDI 1
143 1.2 isaki #define AUDIODEV_TYPE_OPL 2
144 1.2 isaki #define AUDIODEV_TYPE_MPU 3
145 1.2 isaki #define AUDIODEV_TYPE_AUX 4
146 1.2 isaki
147 1.2 isaki /* Attach the MI driver(s) to the MD driver. */
148 1.2 isaki device_t audio_attach_mi(const struct audio_hw_if *, void *, device_t);
149 1.2 isaki int audioprint(void *, const char *);
150 1.2 isaki
151 1.2 isaki extern int audio_query_format(const struct audio_format *, int,
152 1.2 isaki audio_format_query_t *);
153 1.2 isaki extern int audio_indexof_format(const struct audio_format *, int, int,
154 1.2 isaki const audio_params_t *);
155 1.2 isaki extern const char *audio_encoding_name(int);
156 1.2 isaki
157 1.2 isaki /* Device identity flags */
158 1.2 isaki #define SOUND_DEVICE 0
159 1.2 isaki #define AUDIO_DEVICE 0x80
160 1.2 isaki #define AUDIOCTL_DEVICE 0xc0
161 1.2 isaki #define MIXER_DEVICE 0x10
162 1.2 isaki
163 1.2 isaki #define AUDIOUNIT(x) (minor(x)&0x0f)
164 1.2 isaki #define AUDIODEV(x) (minor(x)&0xf0)
165 1.2 isaki
166 1.2 isaki #define ISDEVSOUND(x) (AUDIODEV((x)) == SOUND_DEVICE)
167 1.2 isaki #define ISDEVAUDIO(x) (AUDIODEV((x)) == AUDIO_DEVICE)
168 1.2 isaki #define ISDEVAUDIOCTL(x) (AUDIODEV((x)) == AUDIOCTL_DEVICE)
169 1.2 isaki #define ISDEVMIXER(x) (AUDIODEV((x)) == MIXER_DEVICE)
170 1.2 isaki
171 1.2 isaki /*
172 1.2 isaki * USB Audio specification defines 12 channels:
173 1.2 isaki * L R C LFE Ls Rs Lc Rc S Sl Sr T
174 1.2 isaki */
175 1.2 isaki #define AUDIO_MAX_CHANNELS 12
176 1.2 isaki
177 1.2 isaki #endif /* _SYS_DEV_AUDIO_AUDIO_IF_H_ */
178 1.2 isaki
179