xref: /freebsd/sys/dev/sound/pci/hda/hda_reg.h (revision cc68614da8232d8baaca0ae0d0dd8f890f06623e)
1 /*-
2  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
3  *
4  * Copyright (c) 2006 Stephane E. Potvin <sepotvin@videotron.ca>
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  *
16  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26  * SUCH DAMAGE.
27  *
28  * $FreeBSD$
29  */
30 
31 #ifndef _HDA_REG_H_
32 #define _HDA_REG_H_
33 
34 /****************************************************************************
35  * HDA Device Verbs
36  ****************************************************************************/
37 
38 /* HDA Command */
39 #define HDA_CMD_VERB_MASK				0x000fffff
40 #define HDA_CMD_VERB_SHIFT				0
41 #define HDA_CMD_NID_MASK				0x0ff00000
42 #define HDA_CMD_NID_SHIFT				20
43 #define HDA_CMD_CAD_MASK				0xf0000000
44 #define HDA_CMD_CAD_SHIFT				28
45 
46 #define HDA_CMD_VERB_4BIT_SHIFT				16
47 #define HDA_CMD_VERB_12BIT_SHIFT			8
48 
49 #define HDA_CMD_VERB_4BIT(verb, payload)				\
50     (((verb) << HDA_CMD_VERB_4BIT_SHIFT) | (payload))
51 #define HDA_CMD_4BIT(cad, nid, verb, payload)				\
52     (((cad) << HDA_CMD_CAD_SHIFT) |					\
53     ((nid) << HDA_CMD_NID_SHIFT) |					\
54     (HDA_CMD_VERB_4BIT((verb), (payload))))
55 
56 #define HDA_CMD_VERB_12BIT(verb, payload)				\
57     (((verb) << HDA_CMD_VERB_12BIT_SHIFT) | (payload))
58 #define HDA_CMD_12BIT(cad, nid, verb, payload)				\
59     (((cad) << HDA_CMD_CAD_SHIFT) |					\
60     ((nid) << HDA_CMD_NID_SHIFT) |					\
61     (HDA_CMD_VERB_12BIT((verb), (payload))))
62 
63 /* Get Parameter */
64 #define HDA_CMD_VERB_GET_PARAMETER			0xf00
65 
66 #define HDA_CMD_GET_PARAMETER(cad, nid, payload)			\
67     (HDA_CMD_12BIT((cad), (nid),					\
68     HDA_CMD_VERB_GET_PARAMETER, (payload)))
69 
70 /* Connection Select Control */
71 #define HDA_CMD_VERB_GET_CONN_SELECT_CONTROL		0xf01
72 #define HDA_CMD_VERB_SET_CONN_SELECT_CONTROL		0x701
73 
74 #define HDA_CMD_GET_CONN_SELECT_CONTROL(cad, nid)			\
75     (HDA_CMD_12BIT((cad), (nid),					\
76     HDA_CMD_VERB_GET_CONN_SELECT_CONTROL, 0x0))
77 #define HDA_CMD_SET_CONNECTION_SELECT_CONTROL(cad, nid, payload)	\
78     (HDA_CMD_12BIT((cad), (nid),					\
79     HDA_CMD_VERB_SET_CONN_SELECT_CONTROL, (payload)))
80 
81 /* Connection List Entry */
82 #define HDA_CMD_VERB_GET_CONN_LIST_ENTRY		0xf02
83 
84 #define HDA_CMD_GET_CONN_LIST_ENTRY(cad, nid, payload)			\
85     (HDA_CMD_12BIT((cad), (nid),					\
86     HDA_CMD_VERB_GET_CONN_LIST_ENTRY, (payload)))
87 
88 #define HDA_CMD_GET_CONN_LIST_ENTRY_SIZE_SHORT		1
89 #define HDA_CMD_GET_CONN_LIST_ENTRY_SIZE_LONG		2
90 
91 /* Processing State */
92 #define HDA_CMD_VERB_GET_PROCESSING_STATE		0xf03
93 #define HDA_CMD_VERB_SET_PROCESSING_STATE		0x703
94 
95 #define HDA_CMD_GET_PROCESSING_STATE(cad, nid)				\
96     (HDA_CMD_12BIT((cad), (nid),					\
97     HDA_CMD_VERB_GET_PROCESSING_STATE, 0x0))
98 #define HDA_CMD_SET_PROCESSING_STATE(cad, nid, payload)			\
99     (HDA_CMD_12BIT((cad), (nid),					\
100     HDA_CMD_VERB_SET_PROCESSING_STATE, (payload)))
101 
102 #define HDA_CMD_GET_PROCESSING_STATE_STATE_OFF		0x00
103 #define HDA_CMD_GET_PROCESSING_STATE_STATE_ON		0x01
104 #define HDA_CMD_GET_PROCESSING_STATE_STATE_BENIGN	0x02
105 
106 /* Coefficient Index */
107 #define HDA_CMD_VERB_GET_COEFF_INDEX			0xd
108 #define HDA_CMD_VERB_SET_COEFF_INDEX			0x5
109 
110 #define HDA_CMD_GET_COEFF_INDEX(cad, nid)				\
111     (HDA_CMD_4BIT((cad), (nid),						\
112     HDA_CMD_VERB_GET_COEFF_INDEX, 0x0))
113 #define HDA_CMD_SET_COEFF_INDEX(cad, nid, payload)			\
114     (HDA_CMD_4BIT((cad), (nid),						\
115     HDA_CMD_VERB_SET_COEFF_INDEX, (payload)))
116 
117 /* Processing Coefficient */
118 #define HDA_CMD_VERB_GET_PROCESSING_COEFF		0xc
119 #define HDA_CMD_VERB_SET_PROCESSING_COEFF		0x4
120 
121 #define HDA_CMD_GET_PROCESSING_COEFF(cad, nid)				\
122     (HDA_CMD_4BIT((cad), (nid),						\
123     HDA_CMD_VERB_GET_PROCESSING_COEFF, 0x0))
124 #define HDA_CMD_SET_PROCESSING_COEFF(cad, nid, payload)			\
125     (HDA_CMD_4BIT((cad), (nid),						\
126     HDA_CMD_VERB_SET_PROCESSING_COEFF, (payload)))
127 
128 /* Amplifier Gain/Mute */
129 #define HDA_CMD_VERB_GET_AMP_GAIN_MUTE			0xb
130 #define HDA_CMD_VERB_SET_AMP_GAIN_MUTE			0x3
131 
132 #define HDA_CMD_GET_AMP_GAIN_MUTE(cad, nid, payload)			\
133     (HDA_CMD_4BIT((cad), (nid),						\
134     HDA_CMD_VERB_GET_AMP_GAIN_MUTE, (payload)))
135 #define HDA_CMD_SET_AMP_GAIN_MUTE(cad, nid, payload)			\
136     (HDA_CMD_4BIT((cad), (nid),						\
137     HDA_CMD_VERB_SET_AMP_GAIN_MUTE, (payload)))
138 
139 #define HDA_CMD_GET_AMP_GAIN_MUTE_INPUT		0x0000
140 #define HDA_CMD_GET_AMP_GAIN_MUTE_OUTPUT	0x8000
141 #define HDA_CMD_GET_AMP_GAIN_MUTE_RIGHT		0x0000
142 #define HDA_CMD_GET_AMP_GAIN_MUTE_LEFT		0x2000
143 
144 #define HDA_CMD_GET_AMP_GAIN_MUTE_MUTE_MASK	0x00000008
145 #define HDA_CMD_GET_AMP_GAIN_MUTE_MUTE_SHIFT	7
146 #define HDA_CMD_GET_AMP_GAIN_MUTE_GAIN_MASK	0x00000007
147 #define HDA_CMD_GET_AMP_GAIN_MUTE_GAIN_SHIFT	0
148 
149 #define HDA_CMD_GET_AMP_GAIN_MUTE_MUTE(rsp)				\
150     (((rsp) & HDA_CMD_GET_AMP_GAIN_MUTE_MUTE_MASK) >>			\
151     HDA_CMD_GET_AMP_GAIN_MUTE_MUTE_SHIFT)
152 #define HDA_CMD_GET_AMP_GAIN_MUTE_GAIN(rsp)				\
153     (((rsp) & HDA_CMD_GET_AMP_GAIN_MUTE_GAIN_MASK) >>			\
154     HDA_CMD_GET_AMP_GAIN_MUTE_GAIN_SHIFT)
155 
156 #define HDA_CMD_SET_AMP_GAIN_MUTE_OUTPUT	0x8000
157 #define HDA_CMD_SET_AMP_GAIN_MUTE_INPUT		0x4000
158 #define HDA_CMD_SET_AMP_GAIN_MUTE_LEFT		0x2000
159 #define HDA_CMD_SET_AMP_GAIN_MUTE_RIGHT		0x1000
160 #define HDA_CMD_SET_AMP_GAIN_MUTE_INDEX_MASK	0x0f00
161 #define HDA_CMD_SET_AMP_GAIN_MUTE_INDEX_SHIFT	8
162 #define HDA_CMD_SET_AMP_GAIN_MUTE_MUTE		0x0080
163 #define HDA_CMD_SET_AMP_GAIN_MUTE_GAIN_MASK	0x0007
164 #define HDA_CMD_SET_AMP_GAIN_MUTE_GAIN_SHIFT	0
165 
166 #define HDA_CMD_SET_AMP_GAIN_MUTE_INDEX(index)				\
167     (((index) << HDA_CMD_SET_AMP_GAIN_MUTE_INDEX_SHIFT) &		\
168     HDA_CMD_SET_AMP_GAIN_MUTE_INDEX_MASK)
169 #define HDA_CMD_SET_AMP_GAIN_MUTE_GAIN(index)				\
170     (((index) << HDA_CMD_SET_AMP_GAIN_MUTE_GAIN_SHIFT) &		\
171     HDA_CMD_SET_AMP_GAIN_MUTE_GAIN_MASK)
172 
173 /* Converter format */
174 #define HDA_CMD_VERB_GET_CONV_FMT			0xa
175 #define HDA_CMD_VERB_SET_CONV_FMT			0x2
176 
177 #define HDA_CMD_GET_CONV_FMT(cad, nid)					\
178     (HDA_CMD_4BIT((cad), (nid),						\
179     HDA_CMD_VERB_GET_CONV_FMT, 0x0))
180 #define HDA_CMD_SET_CONV_FMT(cad, nid, payload)				\
181     (HDA_CMD_4BIT((cad), (nid),						\
182     HDA_CMD_VERB_SET_CONV_FMT, (payload)))
183 
184 /* Digital Converter Control */
185 #define HDA_CMD_VERB_GET_DIGITAL_CONV_FMT1		0xf0d
186 #define HDA_CMD_VERB_GET_DIGITAL_CONV_FMT2		0xf0e
187 #define HDA_CMD_VERB_SET_DIGITAL_CONV_FMT1		0x70d
188 #define HDA_CMD_VERB_SET_DIGITAL_CONV_FMT2		0x70e
189 
190 #define HDA_CMD_GET_DIGITAL_CONV_FMT(cad, nid)				\
191     (HDA_CMD_12BIT((cad), (nid),					\
192     HDA_CMD_VERB_GET_DIGITAL_CONV_FMT1, 0x0))
193 #define HDA_CMD_SET_DIGITAL_CONV_FMT1(cad, nid, payload)		\
194     (HDA_CMD_12BIT((cad), (nid),					\
195     HDA_CMD_VERB_SET_DIGITAL_CONV_FMT1, (payload)))
196 #define HDA_CMD_SET_DIGITAL_CONV_FMT2(cad, nid, payload)		\
197     (HDA_CMD_12BIT((cad), (nid),					\
198     HDA_CMD_VERB_SET_DIGITAL_CONV_FMT2, (payload)))
199 
200 #define HDA_CMD_GET_DIGITAL_CONV_FMT_CC_MASK		0x7f00
201 #define HDA_CMD_GET_DIGITAL_CONV_FMT_CC_SHIFT		8
202 #define HDA_CMD_GET_DIGITAL_CONV_FMT_L_MASK		0x0080
203 #define HDA_CMD_GET_DIGITAL_CONV_FMT_L_SHIFT		7
204 #define HDA_CMD_GET_DIGITAL_CONV_FMT_PRO_MASK		0x0040
205 #define HDA_CMD_GET_DIGITAL_CONV_FMT_PRO_SHIFT		6
206 #define HDA_CMD_GET_DIGITAL_CONV_FMT_NAUDIO_MASK	0x0020
207 #define HDA_CMD_GET_DIGITAL_CONV_FMT_NAUDIO_SHIFT	5
208 #define HDA_CMD_GET_DIGITAL_CONV_FMT_COPY_MASK		0x0010
209 #define HDA_CMD_GET_DIGITAL_CONV_FMT_COPY_SHIFT		4
210 #define HDA_CMD_GET_DIGITAL_CONV_FMT_PRE_MASK		0x0008
211 #define HDA_CMD_GET_DIGITAL_CONV_FMT_PRE_SHIFT		3
212 #define HDA_CMD_GET_DIGITAL_CONV_FMT_VCFG_MASK		0x0004
213 #define HDA_CMD_GET_DIGITAL_CONV_FMT_VCFG_SHIFT		2
214 #define HDA_CMD_GET_DIGITAL_CONV_FMT_V_MASK		0x0002
215 #define HDA_CMD_GET_DIGITAL_CONV_FMT_V_SHIFT		1
216 #define HDA_CMD_GET_DIGITAL_CONV_FMT_DIGEN_MASK		0x0001
217 #define HDA_CMD_GET_DIGITAL_CONV_FMT_DIGEN_SHIFT	0
218 
219 #define HDA_CMD_GET_DIGITAL_CONV_FMT_CC(rsp)				\
220     (((rsp) & HDA_CMD_GET_DIGITAL_CONV_FMT_CC_MASK) >>			\
221     HDA_CMD_GET_DIGITAL_CONV_FMT_CC_SHIFT)
222 #define HDA_CMD_GET_DIGITAL_CONV_FMT_L(rsp)				\
223     (((rsp) & HDA_CMD_GET_DIGITAL_CONV_FMT_L_MASK) >>			\
224     HDA_CMD_GET_DIGITAL_CONV_FMT_L_SHIFT)
225 #define HDA_CMD_GET_DIGITAL_CONV_FMT_PRO(rsp)				\
226     (((rsp) & HDA_CMD_GET_DIGITAL_CONV_FMT_PRO_MASK) >>			\
227     HDA_CMD_GET_DIGITAL_CONV_FMT_PRO_SHIFT)
228 #define HDA_CMD_GET_DIGITAL_CONV_FMT_NAUDIO(rsp)			\
229     (((rsp) & HDA_CMD_GET_DIGITAL_CONV_FMT_NAUDIO_MASK) >>		\
230     HDA_CMD_GET_DIGITAL_CONV_FMT_NAUDIO_SHIFT)
231 #define HDA_CMD_GET_DIGITAL_CONV_FMT_COPY(rsp)				\
232     (((rsp) & HDA_CMD_GET_DIGITAL_CONV_FMT_COPY_MASK) >>		\
233     HDA_CMD_GET_DIGITAL_CONV_FMT_COPY_SHIFT)
234 #define HDA_CMD_GET_DIGITAL_CONV_FMT_PRE(rsp)				\
235     (((rsp) & HDA_CMD_GET_DIGITAL_CONV_FMT_PRE_MASK) >>			\
236     HDA_CMD_GET_DIGITAL_CONV_FMT_PRE_SHIFT)
237 #define HDA_CMD_GET_DIGITAL_CONV_FMT_VCFG(rsp)				\
238     (((rsp) & HDA_CMD_GET_DIGITAL_CONV_FMT_VCFG_MASK) >>		\
239     HDA_CMD_GET_DIGITAL_CONV_FMT_VCFG_SHIFT)
240 #define HDA_CMD_GET_DIGITAL_CONV_FMT_V(rsp)				\
241     (((rsp) & HDA_CMD_GET_DIGITAL_CONV_FMT_V_MASK) >>			\
242     HDA_CMD_GET_DIGITAL_CONV_FMT_V_SHIFT)
243 #define HDA_CMD_GET_DIGITAL_CONV_FMT_DIGEN(rsp)				\
244     (((rsp) & HDA_CMD_GET_DIGITAL_CONV_FMT_DIGEN_MASK) >>		\
245     HDA_CMD_GET_DIGITAL_CONV_FMT_DIGEN_SHIFT)
246 
247 #define HDA_CMD_SET_DIGITAL_CONV_FMT1_L			0x80
248 #define HDA_CMD_SET_DIGITAL_CONV_FMT1_PRO		0x40
249 #define HDA_CMD_SET_DIGITAL_CONV_FMT1_NAUDIO		0x20
250 #define HDA_CMD_SET_DIGITAL_CONV_FMT1_COPY		0x10
251 #define HDA_CMD_SET_DIGITAL_CONV_FMT1_PRE		0x08
252 #define HDA_CMD_SET_DIGITAL_CONV_FMT1_VCFG		0x04
253 #define HDA_CMD_SET_DIGITAL_CONV_FMT1_V			0x02
254 #define HDA_CMD_SET_DIGITAL_CONV_FMT1_DIGEN		0x01
255 
256 /* Power State */
257 #define HDA_CMD_VERB_GET_POWER_STATE			0xf05
258 #define HDA_CMD_VERB_SET_POWER_STATE			0x705
259 
260 #define HDA_CMD_GET_POWER_STATE(cad, nid)				\
261     (HDA_CMD_12BIT((cad), (nid),					\
262     HDA_CMD_VERB_GET_POWER_STATE, 0x0))
263 #define HDA_CMD_SET_POWER_STATE(cad, nid, payload)			\
264     (HDA_CMD_12BIT((cad), (nid),					\
265     HDA_CMD_VERB_SET_POWER_STATE, (payload)))
266 
267 #define HDA_CMD_POWER_STATE_D0				0x00
268 #define HDA_CMD_POWER_STATE_D1				0x01
269 #define HDA_CMD_POWER_STATE_D2				0x02
270 #define HDA_CMD_POWER_STATE_D3				0x03
271 
272 #define HDA_CMD_POWER_STATE_ACT_MASK			0x000000f0
273 #define HDA_CMD_POWER_STATE_ACT_SHIFT			4
274 #define HDA_CMD_POWER_STATE_SET_MASK			0x0000000f
275 #define HDA_CMD_POWER_STATE_SET_SHIFT			0
276 
277 #define HDA_CMD_GET_POWER_STATE_ACT(rsp)				\
278     (((rsp) & HDA_CMD_POWER_STATE_ACT_MASK) >>				\
279     HDA_CMD_POWER_STATE_ACT_SHIFT)
280 #define HDA_CMD_GET_POWER_STATE_SET(rsp)				\
281     (((rsp) & HDA_CMD_POWER_STATE_SET_MASK) >>				\
282     HDA_CMD_POWER_STATE_SET_SHIFT)
283 
284 #define HDA_CMD_SET_POWER_STATE_ACT(ps)					\
285     (((ps) << HDA_CMD_POWER_STATE_ACT_SHIFT) &				\
286     HDA_CMD_POWER_STATE_ACT_MASK)
287 #define HDA_CMD_SET_POWER_STATE_SET(ps)					\
288     (((ps) << HDA_CMD_POWER_STATE_SET_SHIFT) &				\
289     HDA_CMD_POWER_STATE_ACT_MASK)
290 
291 /* Converter Stream, Channel */
292 #define HDA_CMD_VERB_GET_CONV_STREAM_CHAN		0xf06
293 #define HDA_CMD_VERB_SET_CONV_STREAM_CHAN		0x706
294 
295 #define HDA_CMD_GET_CONV_STREAM_CHAN(cad, nid)				\
296     (HDA_CMD_12BIT((cad), (nid),					\
297     HDA_CMD_VERB_GET_CONV_STREAM_CHAN, 0x0))
298 #define HDA_CMD_SET_CONV_STREAM_CHAN(cad, nid, payload)			\
299     (HDA_CMD_12BIT((cad), (nid),					\
300     HDA_CMD_VERB_SET_CONV_STREAM_CHAN, (payload)))
301 
302 #define HDA_CMD_CONV_STREAM_CHAN_STREAM_MASK		0x000000f0
303 #define HDA_CMD_CONV_STREAM_CHAN_STREAM_SHIFT		4
304 #define HDA_CMD_CONV_STREAM_CHAN_CHAN_MASK		0x0000000f
305 #define HDA_CMD_CONV_STREAM_CHAN_CHAN_SHIFT		0
306 
307 #define HDA_CMD_GET_CONV_STREAM_CHAN_STREAM(rsp)			\
308     (((rsp) & HDA_CMD_CONV_STREAM_CHAN_STREAM_MASK) >>			\
309     HDA_CMD_CONV_STREAM_CHAN_STREAM_SHIFT)
310 #define HDA_CMD_GET_CONV_STREAM_CHAN_CHAN(rsp)				\
311     (((rsp) & HDA_CMD_CONV_STREAM_CHAN_CHAN_MASK) >>			\
312     HDA_CMD_CONV_STREAM_CHAN_CHAN_SHIFT)
313 
314 #define HDA_CMD_SET_CONV_STREAM_CHAN_STREAM(param)			\
315     (((param) << HDA_CMD_CONV_STREAM_CHAN_STREAM_SHIFT) &		\
316     HDA_CMD_CONV_STREAM_CHAN_STREAM_MASK)
317 #define HDA_CMD_SET_CONV_STREAM_CHAN_CHAN(param)			\
318     (((param) << HDA_CMD_CONV_STREAM_CHAN_CHAN_SHIFT) &			\
319     HDA_CMD_CONV_STREAM_CHAN_CHAN_MASK)
320 
321 /* Input Converter SDI Select */
322 #define HDA_CMD_VERB_GET_INPUT_CONVERTER_SDI_SELECT	0xf04
323 #define HDA_CMD_VERB_SET_INPUT_CONVERTER_SDI_SELECT	0x704
324 
325 #define HDA_CMD_GET_INPUT_CONVERTER_SDI_SELECT(cad, nid)		\
326     (HDA_CMD_12BIT((cad), (nid),					\
327     HDA_CMD_VERB_GET_INPUT_CONVERTER_SDI_SELECT, 0x0))
328 #define HDA_CMD_SET_INPUT_CONVERTER_SDI_SELECT(cad, nid, payload)	\
329     (HDA_CMD_12BIT((cad), (nid),					\
330     HDA_CMD_VERB_SET_INPUT_CONVERTER_SDI_SELECT, (payload)))
331 
332 /* Pin Widget Control */
333 #define HDA_CMD_VERB_GET_PIN_WIDGET_CTRL		0xf07
334 #define HDA_CMD_VERB_SET_PIN_WIDGET_CTRL		0x707
335 
336 #define HDA_CMD_GET_PIN_WIDGET_CTRL(cad, nid)				\
337     (HDA_CMD_12BIT((cad), (nid),					\
338     HDA_CMD_VERB_GET_PIN_WIDGET_CTRL, 0x0))
339 #define HDA_CMD_SET_PIN_WIDGET_CTRL(cad, nid, payload)			\
340     (HDA_CMD_12BIT((cad), (nid),					\
341     HDA_CMD_VERB_SET_PIN_WIDGET_CTRL, (payload)))
342 
343 #define HDA_CMD_GET_PIN_WIDGET_CTRL_HPHN_ENABLE_MASK	0x00000080
344 #define HDA_CMD_GET_PIN_WIDGET_CTRL_HPHN_ENABLE_SHIFT	7
345 #define HDA_CMD_GET_PIN_WIDGET_CTRL_OUT_ENABLE_MASK	0x00000040
346 #define HDA_CMD_GET_PIN_WIDGET_CTRL_OUT_ENABLE_SHIFT	6
347 #define HDA_CMD_GET_PIN_WIDGET_CTRL_IN_ENABLE_MASK	0x00000020
348 #define HDA_CMD_GET_PIN_WIDGET_CTRL_IN_ENABLE_SHIFT	5
349 #define HDA_CMD_GET_PIN_WIDGET_CTRL_VREF_ENABLE_MASK	0x00000007
350 #define HDA_CMD_GET_PIN_WIDGET_CTRL_VREF_ENABLE_SHIFT	0
351 
352 #define HDA_CMD_GET_PIN_WIDGET_CTRL_HPHN_ENABLE(rsp)			\
353     (((rsp) & HDA_CMD_GET_PIN_WIDGET_CTRL_HPHN_ENABLE_MASK) >>		\
354     HDA_CMD_GET_PIN_WIDGET_CTRL_HPHN_ENABLE_SHIFT)
355 #define HDA_CMD_GET_PIN_WIDGET_CTRL_OUT_ENABLE(rsp)			\
356     (((rsp) & HDA_CMD_GET_PIN_WIDGET_CTRL_OUT_ENABLE_MASK) >>		\
357     HDA_GET_CMD_PIN_WIDGET_CTRL_OUT_ENABLE_SHIFT)
358 #define HDA_CMD_GET_PIN_WIDGET_CTRL_IN_ENABLE(rsp)			\
359     (((rsp) & HDA_CMD_GET_PIN_WIDGET_CTRL_IN_ENABLE_MASK) >>		\
360     HDA_CMD_GET_PIN_WIDGET_CTRL_IN_ENABLE_SHIFT)
361 #define HDA_CMD_GET_PIN_WIDGET_CTRL_VREF_ENABLE(rsp)			\
362     (((rsp) & HDA_CMD_GET_PIN_WIDGET_CTRL_VREF_ENABLE_MASK) >>		\
363     HDA_CMD_GET_PIN_WIDGET_CTRL_VREF_ENABLE_SHIFT)
364 
365 #define HDA_CMD_SET_PIN_WIDGET_CTRL_HPHN_ENABLE		0x80
366 #define HDA_CMD_SET_PIN_WIDGET_CTRL_OUT_ENABLE		0x40
367 #define HDA_CMD_SET_PIN_WIDGET_CTRL_IN_ENABLE		0x20
368 #define HDA_CMD_SET_PIN_WIDGET_CTRL_VREF_ENABLE_MASK	0x07
369 #define HDA_CMD_SET_PIN_WIDGET_CTRL_VREF_ENABLE_SHIFT	0
370 
371 #define HDA_CMD_SET_PIN_WIDGET_CTRL_VREF_ENABLE(param)			\
372     (((param) << HDA_CMD_SET_PIN_WIDGET_CTRL_VREF_ENABLE_SHIFT) &	\
373     HDA_CMD_SET_PIN_WIDGET_CTRL_VREF_ENABLE_MASK)
374 
375 #define HDA_CMD_PIN_WIDGET_CTRL_VREF_ENABLE_HIZ		0
376 #define HDA_CMD_PIN_WIDGET_CTRL_VREF_ENABLE_50		1
377 #define HDA_CMD_PIN_WIDGET_CTRL_VREF_ENABLE_GROUND	2
378 #define HDA_CMD_PIN_WIDGET_CTRL_VREF_ENABLE_80		4
379 #define HDA_CMD_PIN_WIDGET_CTRL_VREF_ENABLE_100		5
380 
381 /* Unsolicited Response */
382 #define HDA_CMD_VERB_GET_UNSOLICITED_RESPONSE		0xf08
383 #define HDA_CMD_VERB_SET_UNSOLICITED_RESPONSE		0x708
384 
385 #define HDA_CMD_GET_UNSOLICITED_RESPONSE(cad, nid)			\
386     (HDA_CMD_12BIT((cad), (nid),					\
387     HDA_CMD_VERB_GET_UNSOLICITED_RESPONSE, 0x0))
388 #define HDA_CMD_SET_UNSOLICITED_RESPONSE(cad, nid, payload)		\
389     (HDA_CMD_12BIT((cad), (nid),					\
390     HDA_CMD_VERB_SET_UNSOLICITED_RESPONSE, (payload)))
391 
392 #define HDA_CMD_GET_UNSOLICITED_RESPONSE_ENABLE_MASK	0x00000080
393 #define HDA_CMD_GET_UNSOLICITED_RESPONSE_ENABLE_SHIFT	7
394 #define HDA_CMD_GET_UNSOLICITED_RESPONSE_TAG_MASK	0x0000001f
395 #define HDA_CMD_GET_UNSOLICITED_RESPONSE_TAG_SHIFT	0
396 
397 #define HDA_CMD_GET_UNSOLICITED_RESPONSE_ENABLE(rsp)			\
398     (((rsp) & HDA_CMD_GET_UNSOLICITED_RESPONSE_ENABLE_MASK) >>		\
399     HDA_CMD_GET_UNSOLICITED_RESPONSE_ENABLE_SHIFT)
400 #define HDA_CMD_GET_UNSOLICITED_RESPONSE_TAG(rsp)			\
401     (((rsp) & HDA_CMD_GET_UNSOLICITED_RESPONSE_TAG_MASK) >>		\
402     HDA_CMD_GET_UNSOLICITED_RESPONSE_TAG_SHIFT)
403 
404 #define HDA_CMD_SET_UNSOLICITED_RESPONSE_ENABLE		0x80
405 #define HDA_CMD_SET_UNSOLICITED_RESPONSE_TAG_MASK	0x3f
406 #define HDA_CMD_SET_UNSOLICITED_RESPONSE_TAG_SHIFT	0
407 
408 #define HDA_CMD_SET_UNSOLICITED_RESPONSE_TAG(param)			\
409     (((param) << HDA_CMD_SET_UNSOLICITED_RESPONSE_TAG_SHIFT) &		\
410     HDA_CMD_SET_UNSOLICITED_RESPONSE_TAG_MASK)
411 
412 /* Pin Sense */
413 #define HDA_CMD_VERB_GET_PIN_SENSE			0xf09
414 #define HDA_CMD_VERB_SET_PIN_SENSE			0x709
415 
416 #define HDA_CMD_GET_PIN_SENSE(cad, nid)					\
417     (HDA_CMD_12BIT((cad), (nid),					\
418     HDA_CMD_VERB_GET_PIN_SENSE, 0x0))
419 #define HDA_CMD_SET_PIN_SENSE(cad, nid, payload)			\
420     (HDA_CMD_12BIT((cad), (nid),					\
421     HDA_CMD_VERB_SET_PIN_SENSE, (payload)))
422 
423 #define HDA_CMD_GET_PIN_SENSE_PRESENCE_DETECT		0x80000000
424 #define HDA_CMD_GET_PIN_SENSE_ELD_VALID			0x40000000
425 #define HDA_CMD_GET_PIN_SENSE_IMP_SENSE_MASK		0x7fffffff
426 #define HDA_CMD_GET_PIN_SENSE_IMP_SENSE_SHIFT		0
427 
428 #define HDA_CMD_GET_PIN_SENSE_IMP_SENSE(rsp)				\
429     (((rsp) & HDA_CMD_GET_PIN_SENSE_IMP_SENSE_MASK) >>			\
430     HDA_CMD_GET_PIN_SENSE_IMP_SENSE_SHIFT)
431 
432 #define HDA_CMD_GET_PIN_SENSE_IMP_SENSE_INVALID		0x7fffffff
433 
434 #define HDA_CMD_SET_PIN_SENSE_LEFT_CHANNEL		0x00
435 #define HDA_CMD_SET_PIN_SENSE_RIGHT_CHANNEL		0x01
436 
437 /* EAPD/BTL Enable */
438 #define HDA_CMD_VERB_GET_EAPD_BTL_ENABLE		0xf0c
439 #define HDA_CMD_VERB_SET_EAPD_BTL_ENABLE		0x70c
440 
441 #define HDA_CMD_GET_EAPD_BTL_ENABLE(cad, nid)				\
442     (HDA_CMD_12BIT((cad), (nid),					\
443     HDA_CMD_VERB_GET_EAPD_BTL_ENABLE, 0x0))
444 #define HDA_CMD_SET_EAPD_BTL_ENABLE(cad, nid, payload)			\
445     (HDA_CMD_12BIT((cad), (nid),					\
446     HDA_CMD_VERB_SET_EAPD_BTL_ENABLE, (payload)))
447 
448 #define HDA_CMD_GET_EAPD_BTL_ENABLE_LR_SWAP_MASK	0x00000004
449 #define HDA_CMD_GET_EAPD_BTL_ENABLE_LR_SWAP_SHIFT	2
450 #define HDA_CMD_GET_EAPD_BTL_ENABLE_EAPD_MASK		0x00000002
451 #define HDA_CMD_GET_EAPD_BTL_ENABLE_EAPD_SHIFT		1
452 #define HDA_CMD_GET_EAPD_BTL_ENABLE_BTL_MASK		0x00000001
453 #define HDA_CMD_GET_EAPD_BTL_ENABLE_BTL_SHIFT		0
454 
455 #define HDA_CMD_GET_EAPD_BTL_ENABLE_LR_SWAP(rsp)			\
456     (((rsp) & HDA_CMD_GET_EAPD_BTL_ENABLE_LR_SWAP_MASK) >>		\
457     HDA_CMD_GET_EAPD_BTL_ENABLE_LR_SWAP_SHIFT)
458 #define HDA_CMD_GET_EAPD_BTL_ENABLE_EAPD(rsp)				\
459     (((rsp) & HDA_CMD_GET_EAPD_BTL_ENABLE_EAPD_MASK) >>			\
460     HDA_CMD_GET_EAPD_BTL_ENABLE_EAPD_SHIFT)
461 #define HDA_CMD_GET_EAPD_BTL_ENABLE_BTL(rsp)				\
462     (((rsp) & HDA_CMD_GET_EAPD_BTL_ENABLE_BTL_MASK) >>			\
463     HDA_CMD_GET_EAPD_BTL_ENABLE_BTL_SHIFT)
464 
465 #define HDA_CMD_SET_EAPD_BTL_ENABLE_LR_SWAP		0x04
466 #define HDA_CMD_SET_EAPD_BTL_ENABLE_EAPD		0x02
467 #define HDA_CMD_SET_EAPD_BTL_ENABLE_BTL			0x01
468 
469 /* GPI Data */
470 #define HDA_CMD_VERB_GET_GPI_DATA			0xf10
471 #define HDA_CMD_VERB_SET_GPI_DATA			0x710
472 
473 #define HDA_CMD_GET_GPI_DATA(cad, nid)					\
474     (HDA_CMD_12BIT((cad), (nid),					\
475     HDA_CMD_VERB_GET_GPI_DATA, 0x0))
476 #define HDA_CMD_SET_GPI_DATA(cad, nid)					\
477     (HDA_CMD_12BIT((cad), (nid),					\
478     HDA_CMD_VERB_SET_GPI_DATA, (payload)))
479 
480 /* GPI Wake Enable Mask */
481 #define HDA_CMD_VERB_GET_GPI_WAKE_ENABLE_MASK		0xf11
482 #define HDA_CMD_VERB_SET_GPI_WAKE_ENABLE_MASK		0x711
483 
484 #define HDA_CMD_GET_GPI_WAKE_ENABLE_MASK(cad, nid)			\
485     (HDA_CMD_12BIT((cad), (nid),					\
486     HDA_CMD_VERB_GET_GPI_WAKE_ENABLE_MASK, 0x0))
487 #define HDA_CMD_SET_GPI_WAKE_ENABLE_MASK(cad, nid, payload)		\
488     (HDA_CMD_12BIT((cad), (nid),					\
489     HDA_CMD_VERB_SET_GPI_WAKE_ENABLE_MASK, (payload)))
490 
491 /* GPI Unsolicited Enable Mask */
492 #define HDA_CMD_VERB_GET_GPI_UNSOLICITED_ENABLE_MASK	0xf12
493 #define HDA_CMD_VERB_SET_GPI_UNSOLICITED_ENABLE_MASK	0x712
494 
495 #define HDA_CMD_GET_GPI_UNSOLICITED_ENABLE_MASK(cad, nid)		\
496     (HDA_CMD_12BIT((cad), (nid),					\
497     HDA_CMD_VERB_GET_GPI_UNSOLICITED_ENABLE_MASK, 0x0))
498 #define HDA_CMD_SET_GPI_UNSOLICITED_ENABLE_MASK(cad, nid, payload)	\
499     (HDA_CMD_12BIT((cad), (nid),					\
500     HDA_CMD_VERB_SET_GPI_UNSOLICITED_ENABLE_MASK, (payload)))
501 
502 /* GPI Sticky Mask */
503 #define HDA_CMD_VERB_GET_GPI_STICKY_MASK		0xf13
504 #define HDA_CMD_VERB_SET_GPI_STICKY_MASK		0x713
505 
506 #define HDA_CMD_GET_GPI_STICKY_MASK(cad, nid)				\
507     (HDA_CMD_12BIT((cad), (nid),					\
508     HDA_CMD_VERB_GET_GPI_STICKY_MASK, 0x0))
509 #define HDA_CMD_SET_GPI_STICKY_MASK(cad, nid, payload)			\
510     (HDA_CMD_12BIT((cad), (nid),					\
511     HDA_CMD_VERB_SET_GPI_STICKY_MASK, (payload)))
512 
513 /* GPO Data */
514 #define HDA_CMD_VERB_GET_GPO_DATA			0xf14
515 #define HDA_CMD_VERB_SET_GPO_DATA			0x714
516 
517 #define HDA_CMD_GET_GPO_DATA(cad, nid)					\
518     (HDA_CMD_12BIT((cad), (nid),					\
519     HDA_CMD_VERB_GET_GPO_DATA, 0x0))
520 #define HDA_CMD_SET_GPO_DATA(cad, nid, payload)				\
521     (HDA_CMD_12BIT((cad), (nid),					\
522     HDA_CMD_VERB_SET_GPO_DATA, (payload)))
523 
524 /* GPIO Data */
525 #define HDA_CMD_VERB_GET_GPIO_DATA			0xf15
526 #define HDA_CMD_VERB_SET_GPIO_DATA			0x715
527 
528 #define HDA_CMD_GET_GPIO_DATA(cad, nid)					\
529     (HDA_CMD_12BIT((cad), (nid),					\
530     HDA_CMD_VERB_GET_GPIO_DATA, 0x0))
531 #define HDA_CMD_SET_GPIO_DATA(cad, nid, payload)			\
532     (HDA_CMD_12BIT((cad), (nid),					\
533     HDA_CMD_VERB_SET_GPIO_DATA, (payload)))
534 
535 /* GPIO Enable Mask */
536 #define HDA_CMD_VERB_GET_GPIO_ENABLE_MASK		0xf16
537 #define HDA_CMD_VERB_SET_GPIO_ENABLE_MASK		0x716
538 
539 #define HDA_CMD_GET_GPIO_ENABLE_MASK(cad, nid)				\
540     (HDA_CMD_12BIT((cad), (nid),					\
541     HDA_CMD_VERB_GET_GPIO_ENABLE_MASK, 0x0))
542 #define HDA_CMD_SET_GPIO_ENABLE_MASK(cad, nid, payload)			\
543     (HDA_CMD_12BIT((cad), (nid),					\
544     HDA_CMD_VERB_SET_GPIO_ENABLE_MASK, (payload)))
545 
546 /* GPIO Direction */
547 #define HDA_CMD_VERB_GET_GPIO_DIRECTION			0xf17
548 #define HDA_CMD_VERB_SET_GPIO_DIRECTION			0x717
549 
550 #define HDA_CMD_GET_GPIO_DIRECTION(cad, nid)				\
551     (HDA_CMD_12BIT((cad), (nid),					\
552     HDA_CMD_VERB_GET_GPIO_DIRECTION, 0x0))
553 #define HDA_CMD_SET_GPIO_DIRECTION(cad, nid, payload)			\
554     (HDA_CMD_12BIT((cad), (nid),					\
555     HDA_CMD_VERB_SET_GPIO_DIRECTION, (payload)))
556 
557 /* GPIO Wake Enable Mask */
558 #define HDA_CMD_VERB_GET_GPIO_WAKE_ENABLE_MASK		0xf18
559 #define HDA_CMD_VERB_SET_GPIO_WAKE_ENABLE_MASK		0x718
560 
561 #define HDA_CMD_GET_GPIO_WAKE_ENABLE_MASK(cad, nid)			\
562     (HDA_CMD_12BIT((cad), (nid),					\
563     HDA_CMD_VERB_GET_GPIO_WAKE_ENABLE_MASK, 0x0))
564 #define HDA_CMD_SET_GPIO_WAKE_ENABLE_MASK(cad, nid, payload)		\
565     (HDA_CMD_12BIT((cad), (nid),					\
566     HDA_CMD_VERB_SET_GPIO_WAKE_ENABLE_MASK, (payload)))
567 
568 /* GPIO Unsolicited Enable Mask */
569 #define HDA_CMD_VERB_GET_GPIO_UNSOLICITED_ENABLE_MASK	0xf19
570 #define HDA_CMD_VERB_SET_GPIO_UNSOLICITED_ENABLE_MASK	0x719
571 
572 #define HDA_CMD_GET_GPIO_UNSOLICITED_ENABLE_MASK(cad, nid)		\
573     (HDA_CMD_12BIT((cad), (nid),					\
574     HDA_CMD_VERB_GET_GPIO_UNSOLICITED_ENABLE_MASK, 0x0))
575 #define HDA_CMD_SET_GPIO_UNSOLICITED_ENABLE_MASK(cad, nid, payload)	\
576     (HDA_CMD_12BIT((cad), (nid),					\
577     HDA_CMD_VERB_SET_GPIO_UNSOLICITED_ENABLE_MASK, (payload)))
578 
579 /* GPIO_STICKY_MASK */
580 #define HDA_CMD_VERB_GET_GPIO_STICKY_MASK		0xf1a
581 #define HDA_CMD_VERB_SET_GPIO_STICKY_MASK		0x71a
582 
583 #define HDA_CMD_GET_GPIO_STICKY_MASK(cad, nid)				\
584     (HDA_CMD_12BIT((cad), (nid),					\
585     HDA_CMD_VERB_GET_GPIO_STICKY_MASK, 0x0))
586 #define HDA_CMD_SET_GPIO_STICKY_MASK(cad, nid, payload)			\
587     (HDA_CMD_12BIT((cad), (nid),					\
588     HDA_CMD_VERB_SET_GPIO_STICKY_MASK, (payload)))
589 
590 /* Beep Generation */
591 #define HDA_CMD_VERB_GET_BEEP_GENERATION		0xf0a
592 #define HDA_CMD_VERB_SET_BEEP_GENERATION		0x70a
593 
594 #define HDA_CMD_GET_BEEP_GENERATION(cad, nid)				\
595     (HDA_CMD_12BIT((cad), (nid),					\
596     HDA_CMD_VERB_GET_BEEP_GENERATION, 0x0))
597 #define HDA_CMD_SET_BEEP_GENERATION(cad, nid, payload)			\
598     (HDA_CMD_12BIT((cad), (nid),					\
599     HDA_CMD_VERB_SET_BEEP_GENERATION, (payload)))
600 
601 /* Volume Knob */
602 #define HDA_CMD_VERB_GET_VOLUME_KNOB			0xf0f
603 #define HDA_CMD_VERB_SET_VOLUME_KNOB			0x70f
604 
605 #define HDA_CMD_GET_VOLUME_KNOB(cad, nid)				\
606     (HDA_CMD_12BIT((cad), (nid),					\
607     HDA_CMD_VERB_GET_VOLUME_KNOB, 0x0))
608 #define HDA_CMD_SET_VOLUME_KNOB(cad, nid, payload)			\
609     (HDA_CMD_12BIT((cad), (nid),					\
610     HDA_CMD_VERB_SET_VOLUME_KNOB, (payload)))
611 
612 /* Subsystem ID */
613 #define HDA_CMD_VERB_GET_SUBSYSTEM_ID			0xf20
614 #define HDA_CMD_VERB_SET_SUSBYSTEM_ID1			0x720
615 #define HDA_CMD_VERB_SET_SUBSYSTEM_ID2			0x721
616 #define HDA_CMD_VERB_SET_SUBSYSTEM_ID3			0x722
617 #define HDA_CMD_VERB_SET_SUBSYSTEM_ID4			0x723
618 
619 #define HDA_CMD_GET_SUBSYSTEM_ID(cad, nid)				\
620     (HDA_CMD_12BIT((cad), (nid),					\
621     HDA_CMD_VERB_GET_SUBSYSTEM_ID, 0x0))
622 #define HDA_CMD_SET_SUBSYSTEM_ID1(cad, nid, payload)			\
623     (HDA_CMD_12BIT((cad), (nid),					\
624     HDA_CMD_VERB_SET_SUSBYSTEM_ID1, (payload)))
625 #define HDA_CMD_SET_SUBSYSTEM_ID2(cad, nid, payload)			\
626     (HDA_CMD_12BIT((cad), (nid),					\
627     HDA_CMD_VERB_SET_SUSBYSTEM_ID2, (payload)))
628 #define HDA_CMD_SET_SUBSYSTEM_ID3(cad, nid, payload)			\
629     (HDA_CMD_12BIT((cad), (nid),					\
630     HDA_CMD_VERB_SET_SUSBYSTEM_ID3, (payload)))
631 #define HDA_CMD_SET_SUBSYSTEM_ID4(cad, nid, payload)			\
632     (HDA_CMD_12BIT((cad), (nid),					\
633     HDA_CMD_VERB_SET_SUSBYSTEM_ID4, (payload)))
634 
635 /* Configuration Default */
636 #define HDA_CMD_VERB_GET_CONFIGURATION_DEFAULT		0xf1c
637 #define HDA_CMD_VERB_SET_CONFIGURATION_DEFAULT1		0x71c
638 #define HDA_CMD_VERB_SET_CONFIGURATION_DEFAULT2		0x71d
639 #define HDA_CMD_VERB_SET_CONFIGURATION_DEFAULT3		0x71e
640 #define HDA_CMD_VERB_SET_CONFIGURATION_DEFAULT4		0x71f
641 
642 #define HDA_CMD_GET_CONFIGURATION_DEFAULT(cad, nid)			\
643     (HDA_CMD_12BIT((cad), (nid),					\
644     HDA_CMD_VERB_GET_CONFIGURATION_DEFAULT, 0x0))
645 #define HDA_CMD_SET_CONFIGURATION_DEFAULT1(cad, nid, payload)		\
646     (HDA_CMD_12BIT((cad), (nid),					\
647     HDA_CMD_VERB_SET_CONFIGURATION_DEFAULT1, (payload)))
648 #define HDA_CMD_SET_CONFIGURATION_DEFAULT2(cad, nid, payload)		\
649     (HDA_CMD_12BIT((cad), (nid),					\
650     HDA_CMD_VERB_SET_CONFIGURATION_DEFAULT2, (payload)))
651 #define HDA_CMD_SET_CONFIGURATION_DEFAULT3(cad, nid, payload)		\
652     (HDA_CMD_12BIT((cad), (nid),					\
653     HDA_CMD_VERB_SET_CONFIGURATION_DEFAULT3, (payload)))
654 #define HDA_CMD_SET_CONFIGURATION_DEFAULT4(cad, nid, payload)		\
655     (HDA_CMD_12BIT((cad), (nid),					\
656     HDA_CMD_VERB_SET_CONFIGURATION_DEFAULT4, (payload)))
657 
658 /* Stripe Control */
659 #define HDA_CMD_VERB_GET_STRIPE_CONTROL			0xf24
660 #define HDA_CMD_VERB_SET_STRIPE_CONTROL			0x724
661 
662 #define HDA_CMD_GET_STRIPE_CONTROL(cad, nid)				\
663     (HDA_CMD_12BIT((cad), (nid),					\
664     HDA_CMD_VERB_GET_STRIPE_CONTROL, 0x0))
665 #define HDA_CMD_SET_STRIPE_CONTROL(cad, nid, payload)			\
666     (HDA_CMD_12BIT((cad), (nid),					\
667     HDA_CMD_VERB_SET_STRIPE_CONTROL, (payload)))
668 
669 /* Channel Count Control */
670 #define HDA_CMD_VERB_GET_CONV_CHAN_COUNT			0xf2d
671 #define HDA_CMD_VERB_SET_CONV_CHAN_COUNT			0x72d
672 
673 #define HDA_CMD_GET_CONV_CHAN_COUNT(cad, nid)				\
674     (HDA_CMD_12BIT((cad), (nid),					\
675     HDA_CMD_VERB_GET_CONV_CHAN_COUNT, 0x0))
676 #define HDA_CMD_SET_CONV_CHAN_COUNT(cad, nid, payload)			\
677     (HDA_CMD_12BIT((cad), (nid),					\
678     HDA_CMD_VERB_SET_CONV_CHAN_COUNT, (payload)))
679 
680 #define HDA_CMD_VERB_GET_HDMI_DIP_SIZE			0xf2e
681 
682 #define HDA_CMD_GET_HDMI_DIP_SIZE(cad, nid, arg)			\
683     (HDA_CMD_12BIT((cad), (nid),					\
684     HDA_CMD_VERB_GET_HDMI_DIP_SIZE, (arg)))
685 
686 #define HDA_CMD_VERB_GET_HDMI_ELDD			0xf2f
687 
688 #define HDA_CMD_GET_HDMI_ELDD(cad, nid, off)				\
689     (HDA_CMD_12BIT((cad), (nid),					\
690     HDA_CMD_VERB_GET_HDMI_ELDD, (off)))
691 
692 #define HDA_CMD_VERB_GET_HDMI_DIP_INDEX			0xf30
693 #define HDA_CMD_VERB_SET_HDMI_DIP_INDEX			0x730
694 
695 #define HDA_CMD_GET_HDMI_DIP_INDEX(cad, nid)				\
696     (HDA_CMD_12BIT((cad), (nid),					\
697     HDA_CMD_VERB_GET_HDMI_DIP_INDEX, 0x0))
698 #define HDA_CMD_SET_HDMI_DIP_INDEX(cad, nid, payload)			\
699     (HDA_CMD_12BIT((cad), (nid),					\
700     HDA_CMD_VERB_SET_HDMI_DIP_INDEX, (payload)))
701 
702 #define HDA_CMD_VERB_GET_HDMI_DIP_DATA			0xf31
703 #define HDA_CMD_VERB_SET_HDMI_DIP_DATA			0x731
704 
705 #define HDA_CMD_GET_HDMI_DIP_DATA(cad, nid)				\
706     (HDA_CMD_12BIT((cad), (nid),					\
707     HDA_CMD_VERB_GET_HDMI_DIP_DATA, 0x0))
708 #define HDA_CMD_SET_HDMI_DIP_DATA(cad, nid, payload)			\
709     (HDA_CMD_12BIT((cad), (nid),					\
710     HDA_CMD_VERB_SET_HDMI_DIP_DATA, (payload)))
711 
712 #define HDA_CMD_VERB_GET_HDMI_DIP_XMIT			0xf32
713 #define HDA_CMD_VERB_SET_HDMI_DIP_XMIT			0x732
714 
715 #define HDA_CMD_GET_HDMI_DIP_XMIT(cad, nid)				\
716     (HDA_CMD_12BIT((cad), (nid),					\
717     HDA_CMD_VERB_GET_HDMI_DIP_XMIT, 0x0))
718 #define HDA_CMD_SET_HDMI_DIP_XMIT(cad, nid, payload)			\
719     (HDA_CMD_12BIT((cad), (nid),					\
720     HDA_CMD_VERB_SET_HDMI_DIP_XMIT, (payload)))
721 
722 #define HDA_CMD_VERB_GET_HDMI_CP_CTRL			0xf33
723 #define HDA_CMD_VERB_SET_HDMI_CP_CTRL			0x733
724 
725 #define HDA_CMD_VERB_GET_HDMI_CHAN_SLOT			0xf34
726 #define HDA_CMD_VERB_SET_HDMI_CHAN_SLOT			0x734
727 
728 #define HDA_CMD_GET_HDMI_CHAN_SLOT(cad, nid)				\
729     (HDA_CMD_12BIT((cad), (nid),					\
730     HDA_CMD_VERB_GET_HDMI_CHAN_SLOT, 0x0))
731 #define HDA_CMD_SET_HDMI_CHAN_SLOT(cad, nid, payload)			\
732     (HDA_CMD_12BIT((cad), (nid),					\
733     HDA_CMD_VERB_SET_HDMI_CHAN_SLOT, (payload)))
734 
735 #define	HDA_HDMI_CODING_TYPE_REF_STREAM_HEADER		0
736 #define	HDA_HDMI_CODING_TYPE_LPCM			1
737 #define	HDA_HDMI_CODING_TYPE_AC3			2
738 #define	HDA_HDMI_CODING_TYPE_MPEG1			3
739 #define	HDA_HDMI_CODING_TYPE_MP3			4
740 #define	HDA_HDMI_CODING_TYPE_MPEG2			5
741 #define	HDA_HDMI_CODING_TYPE_AACLC			6
742 #define	HDA_HDMI_CODING_TYPE_DTS			7
743 #define	HDA_HDMI_CODING_TYPE_ATRAC			8
744 #define	HDA_HDMI_CODING_TYPE_SACD			9
745 #define	HDA_HDMI_CODING_TYPE_EAC3			10
746 #define	HDA_HDMI_CODING_TYPE_DTS_HD			11
747 #define	HDA_HDMI_CODING_TYPE_MLP			12
748 #define	HDA_HDMI_CODING_TYPE_DST			13
749 #define	HDA_HDMI_CODING_TYPE_WMAPRO			14
750 #define	HDA_HDMI_CODING_TYPE_REF_CTX			15
751 
752 /* Function Reset */
753 #define HDA_CMD_VERB_FUNCTION_RESET			0x7ff
754 
755 #define HDA_CMD_FUNCTION_RESET(cad, nid)				\
756     (HDA_CMD_12BIT((cad), (nid),					\
757     HDA_CMD_VERB_FUNCTION_RESET, 0x0))
758 
759 /****************************************************************************
760  * HDA Device Parameters
761  ****************************************************************************/
762 
763 /* Vendor ID */
764 #define HDA_PARAM_VENDOR_ID				0x00
765 
766 #define HDA_PARAM_VENDOR_ID_VENDOR_ID_MASK		0xffff0000
767 #define HDA_PARAM_VENDOR_ID_VENDOR_ID_SHIFT		16
768 #define HDA_PARAM_VENDOR_ID_DEVICE_ID_MASK		0x0000ffff
769 #define HDA_PARAM_VENDOR_ID_DEVICE_ID_SHIFT		0
770 
771 #define HDA_PARAM_VENDOR_ID_VENDOR_ID(param)				\
772     (((param) & HDA_PARAM_VENDOR_ID_VENDOR_ID_MASK) >>			\
773     HDA_PARAM_VENDOR_ID_VENDOR_ID_SHIFT)
774 #define HDA_PARAM_VENDOR_ID_DEVICE_ID(param)				\
775     (((param) & HDA_PARAM_VENDOR_ID_DEVICE_ID_MASK) >>			\
776     HDA_PARAM_VENDOR_ID_DEVICE_ID_SHIFT)
777 
778 /* Revision ID */
779 #define HDA_PARAM_REVISION_ID				0x02
780 
781 #define HDA_PARAM_REVISION_ID_MAJREV_MASK		0x00f00000
782 #define HDA_PARAM_REVISION_ID_MAJREV_SHIFT		20
783 #define HDA_PARAM_REVISION_ID_MINREV_MASK		0x000f0000
784 #define HDA_PARAM_REVISION_ID_MINREV_SHIFT		16
785 #define HDA_PARAM_REVISION_ID_REVISION_ID_MASK		0x0000ff00
786 #define HDA_PARAM_REVISION_ID_REVISION_ID_SHIFT		8
787 #define HDA_PARAM_REVISION_ID_STEPPING_ID_MASK		0x000000ff
788 #define HDA_PARAM_REVISION_ID_STEPPING_ID_SHIFT		0
789 
790 #define HDA_PARAM_REVISION_ID_MAJREV(param)				\
791     (((param) & HDA_PARAM_REVISION_ID_MAJREV_MASK) >>			\
792     HDA_PARAM_REVISION_ID_MAJREV_SHIFT)
793 #define HDA_PARAM_REVISION_ID_MINREV(param)				\
794     (((param) & HDA_PARAM_REVISION_ID_MINREV_MASK) >>			\
795     HDA_PARAM_REVISION_ID_MINREV_SHIFT)
796 #define HDA_PARAM_REVISION_ID_REVISION_ID(param)			\
797     (((param) & HDA_PARAM_REVISION_ID_REVISION_ID_MASK) >>		\
798     HDA_PARAM_REVISION_ID_REVISION_ID_SHIFT)
799 #define HDA_PARAM_REVISION_ID_STEPPING_ID(param)			\
800     (((param) & HDA_PARAM_REVISION_ID_STEPPING_ID_MASK) >>		\
801     HDA_PARAM_REVISION_ID_STEPPING_ID_SHIFT)
802 
803 /* Subordinate Node Cound */
804 #define HDA_PARAM_SUB_NODE_COUNT			0x04
805 
806 #define HDA_PARAM_SUB_NODE_COUNT_START_MASK		0x00ff0000
807 #define HDA_PARAM_SUB_NODE_COUNT_START_SHIFT		16
808 #define HDA_PARAM_SUB_NODE_COUNT_TOTAL_MASK		0x000000ff
809 #define HDA_PARAM_SUB_NODE_COUNT_TOTAL_SHIFT		0
810 
811 #define HDA_PARAM_SUB_NODE_COUNT_START(param)				\
812     (((param) & HDA_PARAM_SUB_NODE_COUNT_START_MASK) >>			\
813     HDA_PARAM_SUB_NODE_COUNT_START_SHIFT)
814 #define HDA_PARAM_SUB_NODE_COUNT_TOTAL(param)				\
815     (((param) & HDA_PARAM_SUB_NODE_COUNT_TOTAL_MASK) >>			\
816     HDA_PARAM_SUB_NODE_COUNT_TOTAL_SHIFT)
817 
818 /* Function Group Type */
819 #define HDA_PARAM_FCT_GRP_TYPE				0x05
820 
821 #define HDA_PARAM_FCT_GRP_TYPE_UNSOL_MASK		0x00000100
822 #define HDA_PARAM_FCT_GRP_TYPE_UNSOL_SHIFT		8
823 #define HDA_PARAM_FCT_GRP_TYPE_NODE_TYPE_MASK		0x000000ff
824 #define HDA_PARAM_FCT_GRP_TYPE_NODE_TYPE_SHIFT	0
825 
826 #define HDA_PARAM_FCT_GRP_TYPE_UNSOL(param)				\
827     (((param) & HDA_PARAM_FCT_GRP_TYPE_UNSOL_MASK) >>			\
828     HDA_PARAM_FCT_GROUP_TYPE_UNSOL_SHIFT)
829 #define HDA_PARAM_FCT_GRP_TYPE_NODE_TYPE(param)				\
830     (((param) & HDA_PARAM_FCT_GRP_TYPE_NODE_TYPE_MASK) >>		\
831     HDA_PARAM_FCT_GRP_TYPE_NODE_TYPE_SHIFT)
832 
833 #define HDA_PARAM_FCT_GRP_TYPE_NODE_TYPE_AUDIO		0x01
834 #define HDA_PARAM_FCT_GRP_TYPE_NODE_TYPE_MODEM		0x02
835 
836 /* Audio Function Group Capabilities */
837 #define HDA_PARAM_AUDIO_FCT_GRP_CAP			0x08
838 
839 #define HDA_PARAM_AUDIO_FCT_GRP_CAP_BEEP_GEN_MASK	0x00010000
840 #define HDA_PARAM_AUDIO_FCT_GRP_CAP_BEEP_GEN_SHIFT	16
841 #define HDA_PARAM_AUDIO_FCT_GRP_CAP_INPUT_DELAY_MASK	0x00000f00
842 #define HDA_PARAM_AUDIO_FCT_GRP_CAP_INPUT_DELAY_SHIFT	8
843 #define HDA_PARAM_AUDIO_FCT_GRP_CAP_OUTPUT_DELAY_MASK	0x0000000f
844 #define HDA_PARAM_AUDIO_FCT_GRP_CAP_OUTPUT_DELAY_SHIFT	0
845 
846 #define HDA_PARAM_AUDIO_FCT_GRP_CAP_BEEP_GEN(param)			\
847     (((param) & HDA_PARAM_AUDIO_FCT_GRP_CAP_BEEP_GEN_MASK) >>		\
848     HDA_PARAM_AUDIO_FCT_GRP_CAP_BEEP_GEN_SHIFT)
849 #define HDA_PARAM_AUDIO_FCT_GRP_CAP_INPUT_DELAY(param)			\
850     (((param) & HDA_PARAM_AUDIO_FCT_GRP_CAP_INPUT_DELAY_MASK) >>	\
851     HDA_PARAM_AUDIO_FCT_GRP_CAP_INPUT_DELAY_SHIFT)
852 #define HDA_PARAM_AUDIO_FCT_GRP_CAP_OUTPUT_DELAY(param)			\
853     (((param) & HDA_PARAM_AUDIO_FCT_GRP_CAP_OUTPUT_DELAY_MASK) >>	\
854     HDA_PARAM_AUDIO_FCT_GRP_CAP_OUTPUT_DELAY_SHIFT)
855 
856 /* Audio Widget Capabilities */
857 #define HDA_PARAM_AUDIO_WIDGET_CAP			0x09
858 
859 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_MASK		0x00f00000
860 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_SHIFT		20
861 #define HDA_PARAM_AUDIO_WIDGET_CAP_DELAY_MASK		0x000f0000
862 #define HDA_PARAM_AUDIO_WIDGET_CAP_DELAY_SHIFT		16
863 #define HDA_PARAM_AUDIO_WIDGET_CAP_CC_EXT_MASK		0x0000e000
864 #define HDA_PARAM_AUDIO_WIDGET_CAP_CC_EXT_SHIFT		13
865 #define HDA_PARAM_AUDIO_WIDGET_CAP_CP_MASK		0x00001000
866 #define HDA_PARAM_AUDIO_WIDGET_CAP_CP_SHIFT		12
867 #define HDA_PARAM_AUDIO_WIDGET_CAP_LR_SWAP_MASK		0x00000800
868 #define HDA_PARAM_AUDIO_WIDGET_CAP_LR_SWAP_SHIFT	11
869 #define HDA_PARAM_AUDIO_WIDGET_CAP_POWER_CTRL_MASK	0x00000400
870 #define HDA_PARAM_AUDIO_WIDGET_CAP_POWER_CTRL_SHIFT	10
871 #define HDA_PARAM_AUDIO_WIDGET_CAP_DIGITAL_MASK		0x00000200
872 #define HDA_PARAM_AUDIO_WIDGET_CAP_DIGITAL_SHIFT	9
873 #define HDA_PARAM_AUDIO_WIDGET_CAP_CONN_LIST_MASK	0x00000100
874 #define HDA_PARAM_AUDIO_WIDGET_CAP_CONN_LIST_SHIFT	8
875 #define HDA_PARAM_AUDIO_WIDGET_CAP_UNSOL_CAP_MASK	0x00000080
876 #define HDA_PARAM_AUDIO_WIDGET_CAP_UNSOL_CAP_SHIFT	7
877 #define HDA_PARAM_AUDIO_WIDGET_CAP_PROC_WIDGET_MASK	0x00000040
878 #define HDA_PARAM_AUDIO_WIDGET_CAP_PROC_WIDGET_SHIFT	6
879 #define HDA_PARAM_AUDIO_WIDGET_CAP_STRIPE_MASK		0x00000020
880 #define HDA_PARAM_AUDIO_WIDGET_CAP_STRIPE_SHIFT		5
881 #define HDA_PARAM_AUDIO_WIDGET_CAP_FORMAT_OVR_MASK	0x00000010
882 #define HDA_PARAM_AUDIO_WIDGET_CAP_FORMAT_OVR_SHIFT	4
883 #define HDA_PARAM_AUDIO_WIDGET_CAP_AMP_OVR_MASK		0x00000008
884 #define HDA_PARAM_AUDIO_WIDGET_CAP_AMP_OVR_SHIFT	3
885 #define HDA_PARAM_AUDIO_WIDGET_CAP_OUT_AMP_MASK		0x00000004
886 #define HDA_PARAM_AUDIO_WIDGET_CAP_OUT_AMP_SHIFT	2
887 #define HDA_PARAM_AUDIO_WIDGET_CAP_IN_AMP_MASK		0x00000002
888 #define HDA_PARAM_AUDIO_WIDGET_CAP_IN_AMP_SHIFT		1
889 #define HDA_PARAM_AUDIO_WIDGET_CAP_STEREO_MASK		0x00000001
890 #define HDA_PARAM_AUDIO_WIDGET_CAP_STEREO_SHIFT		0
891 
892 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE(param)				\
893     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_MASK) >>		\
894     HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_SHIFT)
895 #define HDA_PARAM_AUDIO_WIDGET_CAP_DELAY(param)				\
896     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_DELAY_MASK) >>		\
897     HDA_PARAM_AUDIO_WIDGET_CAP_DELAY_SHIFT)
898 #define HDA_PARAM_AUDIO_WIDGET_CAP_CC(param)				\
899     ((((param) & HDA_PARAM_AUDIO_WIDGET_CAP_CC_EXT_MASK) >>		\
900     (HDA_PARAM_AUDIO_WIDGET_CAP_CC_EXT_SHIFT - 1)) |			\
901     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_STEREO_MASK) >>		\
902     HDA_PARAM_AUDIO_WIDGET_CAP_STEREO_SHIFT))
903 #define HDA_PARAM_AUDIO_WIDGET_CAP_CP(param)				\
904     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_CP_MASK) >>			\
905     HDA_PARAM_AUDIO_WIDGET_CAP_CP_SHIFT)
906 #define HDA_PARAM_AUDIO_WIDGET_CAP_LR_SWAP(param)			\
907     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_LR_SWAP_MASK) >>		\
908     HDA_PARAM_AUDIO_WIDGET_CAP_LR_SWAP_SHIFT)
909 #define HDA_PARAM_AUDIO_WIDGET_CAP_POWER_CTRL(param)			\
910     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_POWER_CTRL_MASK) >>		\
911     HDA_PARAM_AUDIO_WIDGET_CAP_POWER_CTRL_SHIFT)
912 #define HDA_PARAM_AUDIO_WIDGET_CAP_DIGITAL(param)			\
913     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_DIGITAL_MASK) >>		\
914     HDA_PARAM_AUDIO_WIDGET_CAP_DIGITAL_SHIFT)
915 #define HDA_PARAM_AUDIO_WIDGET_CAP_CONN_LIST(param)			\
916     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_CONN_LIST_MASK) >>		\
917     HDA_PARAM_AUDIO_WIDGET_CAP_CONN_LIST_SHIFT)
918 #define HDA_PARAM_AUDIO_WIDGET_CAP_UNSOL_CAP(param)			\
919     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_UNSOL_CAP_MASK) >>		\
920     HDA_PARAM_AUDIO_WIDGET_CAP_UNSOL_CAP_SHIFT)
921 #define HDA_PARAM_AUDIO_WIDGET_CAP_PROC_WIDGET(param)			\
922     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_PROC_WIDGET_MASK) >>		\
923     HDA_PARAM_AUDIO_WIDGET_CAP_PROC_WIDGET_SHIFT)
924 #define HDA_PARAM_AUDIO_WIDGET_CAP_STRIPE(param)			\
925     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_STRIPE_MASK) >>		\
926     HDA_PARAM_AUDIO_WIDGET_CAP_STRIPE_SHIFT)
927 #define HDA_PARAM_AUDIO_WIDGET_CAP_FORMAT_OVR(param)			\
928     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_FORMAT_OVR_MASK) >>		\
929     HDA_PARAM_AUDIO_WIDGET_CAP_FORMAT_OVR_SHIFT)
930 #define HDA_PARAM_AUDIO_WIDGET_CAP_AMP_OVR(param)			\
931     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_AMP_OVR_MASK) >>		\
932     HDA_PARAM_AUDIO_WIDGET_CAP_AMP_OVR_SHIFT)
933 #define HDA_PARAM_AUDIO_WIDGET_CAP_OUT_AMP(param)			\
934     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_OUT_AMP_MASK) >>		\
935     HDA_PARAM_AUDIO_WIDGET_CAP_OUT_AMP_SHIFT)
936 #define HDA_PARAM_AUDIO_WIDGET_CAP_IN_AMP(param)			\
937     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_IN_AMP_MASK) >>		\
938     HDA_PARAM_AUDIO_WIDGET_CAP_IN_AMP_SHIFT)
939 #define HDA_PARAM_AUDIO_WIDGET_CAP_STEREO(param)			\
940     (((param) & HDA_PARAM_AUDIO_WIDGET_CAP_STEREO_MASK) >>		\
941     HDA_PARAM_AUDIO_WIDGET_CAP_STEREO_SHIFT)
942 
943 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_AUDIO_OUTPUT	0x0
944 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_AUDIO_INPUT	0x1
945 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_AUDIO_MIXER	0x2
946 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_AUDIO_SELECTOR	0x3
947 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_PIN_COMPLEX	0x4
948 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_POWER_WIDGET	0x5
949 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_VOLUME_WIDGET	0x6
950 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_BEEP_WIDGET	0x7
951 #define HDA_PARAM_AUDIO_WIDGET_CAP_TYPE_VENDOR_WIDGET	0xf
952 
953 /* Supported PCM Size, Rates */
954 
955 #define HDA_PARAM_SUPP_PCM_SIZE_RATE			0x0a
956 
957 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_32BIT_MASK		0x00100000
958 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_32BIT_SHIFT	20
959 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_24BIT_MASK		0x00080000
960 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_24BIT_SHIFT	19
961 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_20BIT_MASK		0x00040000
962 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_20BIT_SHIFT	18
963 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_16BIT_MASK		0x00020000
964 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_16BIT_SHIFT	17
965 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_8BIT_MASK		0x00010000
966 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_8BIT_SHIFT		16
967 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_8KHZ_MASK		0x00000001
968 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_8KHZ_SHIFT		0
969 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_11KHZ_MASK		0x00000002
970 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_11KHZ_SHIFT	1
971 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_16KHZ_MASK		0x00000004
972 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_16KHZ_SHIFT	2
973 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_22KHZ_MASK		0x00000008
974 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_22KHZ_SHIFT	3
975 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_32KHZ_MASK		0x00000010
976 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_32KHZ_SHIFT	4
977 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_44KHZ_MASK		0x00000020
978 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_44KHZ_SHIFT	5
979 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_48KHZ_MASK		0x00000040
980 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_48KHZ_SHIFT	6
981 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_88KHZ_MASK		0x00000080
982 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_88KHZ_SHIFT	7
983 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_96KHZ_MASK		0x00000100
984 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_96KHZ_SHIFT	8
985 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_176KHZ_MASK	0x00000200
986 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_176KHZ_SHIFT	9
987 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_192KHZ_MASK	0x00000400
988 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_192KHZ_SHIFT	10
989 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_384KHZ_MASK	0x00000800
990 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_384KHZ_SHIFT	11
991 
992 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_32BIT(param)			\
993     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_32BIT_MASK) >>		\
994     HDA_PARAM_SUPP_PCM_SIZE_RATE_32BIT_SHIFT)
995 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_24BIT(param)			\
996     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_24BIT_MASK) >>		\
997     HDA_PARAM_SUPP_PCM_SIZE_RATE_24BIT_SHIFT)
998 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_20BIT(param)			\
999     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_20BIT_MASK) >>		\
1000     HDA_PARAM_SUPP_PCM_SIZE_RATE_20BIT_SHIFT)
1001 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_16BIT(param)			\
1002     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_16BIT_MASK) >>		\
1003     HDA_PARAM_SUPP_PCM_SIZE_RATE_16BIT_SHIFT)
1004 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_8BIT(param)			\
1005     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_8BIT_MASK) >>		\
1006     HDA_PARAM_SUPP_PCM_SIZE_RATE_8BIT_SHIFT)
1007 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_8KHZ(param)			\
1008     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_8KHZ_MASK) >>		\
1009     HDA_PARAM_SUPP_PCM_SIZE_RATE_8KHZ_SHIFT)
1010 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_11KHZ(param)			\
1011     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_11KHZ_MASK) >>		\
1012     HDA_PARAM_SUPP_PCM_SIZE_RATE_11KHZ_SHIFT)
1013 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_16KHZ(param)			\
1014     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_16KHZ_MASK) >>		\
1015     HDA_PARAM_SUPP_PCM_SIZE_RATE_16KHZ_SHIFT)
1016 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_22KHZ(param)			\
1017     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_22KHZ_MASK) >>		\
1018     HDA_PARAM_SUPP_PCM_SIZE_RATE_22KHZ_SHIFT)
1019 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_32KHZ(param)			\
1020     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_32KHZ_MASK) >>		\
1021     HDA_PARAM_SUPP_PCM_SIZE_RATE_32KHZ_SHIFT)
1022 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_44KHZ(param)			\
1023     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_44KHZ_MASK) >>		\
1024     HDA_PARAM_SUPP_PCM_SIZE_RATE_44KHZ_SHIFT)
1025 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_48KHZ(param)			\
1026     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_48KHZ_MASK) >>		\
1027     HDA_PARAM_SUPP_PCM_SIZE_RATE_48KHZ_SHIFT)
1028 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_88KHZ(param)			\
1029     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_88KHZ_MASK) >>		\
1030     HDA_PARAM_SUPP_PCM_SIZE_RATE_88KHZ_SHIFT)
1031 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_96KHZ(param)			\
1032     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_96KHZ_MASK) >>		\
1033     HDA_PARAM_SUPP_PCM_SIZE_RATE_96KHZ_SHIFT)
1034 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_176KHZ(param)			\
1035     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_176KHZ_MASK) >>		\
1036     HDA_PARAM_SUPP_PCM_SIZE_RATE_176KHZ_SHIFT)
1037 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_192KHZ(param)			\
1038     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_192KHZ_MASK) >>		\
1039     HDA_PARAM_SUPP_PCM_SIZE_RATE_192KHZ_SHIFT)
1040 #define HDA_PARAM_SUPP_PCM_SIZE_RATE_384KHZ(param)			\
1041     (((param) & HDA_PARAM_SUPP_PCM_SIZE_RATE_384KHZ_MASK) >>		\
1042     HDA_PARAM_SUPP_PCM_SIZE_RATE_384KHZ_SHIFT)
1043 
1044 /* Supported Stream Formats */
1045 #define HDA_PARAM_SUPP_STREAM_FORMATS			0x0b
1046 
1047 #define HDA_PARAM_SUPP_STREAM_FORMATS_AC3_MASK		0x00000004
1048 #define HDA_PARAM_SUPP_STREAM_FORMATS_AC3_SHIFT		2
1049 #define HDA_PARAM_SUPP_STREAM_FORMATS_FLOAT32_MASK	0x00000002
1050 #define HDA_PARAM_SUPP_STREAM_FORMATS_FLOAT32_SHIFT	1
1051 #define HDA_PARAM_SUPP_STREAM_FORMATS_PCM_MASK		0x00000001
1052 #define HDA_PARAM_SUPP_STREAM_FORMATS_PCM_SHIFT		0
1053 
1054 #define HDA_PARAM_SUPP_STREAM_FORMATS_AC3(param)			\
1055     (((param) & HDA_PARAM_SUPP_STREAM_FORMATS_AC3_MASK) >>		\
1056     HDA_PARAM_SUPP_STREAM_FORMATS_AC3_SHIFT)
1057 #define HDA_PARAM_SUPP_STREAM_FORMATS_FLOAT32(param)			\
1058     (((param) & HDA_PARAM_SUPP_STREAM_FORMATS_FLOAT32_MASK) >>		\
1059     HDA_PARAM_SUPP_STREAM_FORMATS_FLOAT32_SHIFT)
1060 #define HDA_PARAM_SUPP_STREAM_FORMATS_PCM(param)			\
1061     (((param) & HDA_PARAM_SUPP_STREAM_FORMATS_PCM_MASK) >>		\
1062     HDA_PARAM_SUPP_STREAM_FORMATS_PCM_SHIFT)
1063 
1064 /* Pin Capabilities */
1065 #define HDA_PARAM_PIN_CAP				0x0c
1066 
1067 #define HDA_PARAM_PIN_CAP_HBR_MASK			0x08000000
1068 #define HDA_PARAM_PIN_CAP_HBR_SHIFT			27
1069 #define HDA_PARAM_PIN_CAP_DP_MASK			0x01000000
1070 #define HDA_PARAM_PIN_CAP_DP_SHIFT			24
1071 #define HDA_PARAM_PIN_CAP_EAPD_CAP_MASK			0x00010000
1072 #define HDA_PARAM_PIN_CAP_EAPD_CAP_SHIFT		16
1073 #define HDA_PARAM_PIN_CAP_VREF_CTRL_MASK		0x0000ff00
1074 #define HDA_PARAM_PIN_CAP_VREF_CTRL_SHIFT		8
1075 #define HDA_PARAM_PIN_CAP_VREF_CTRL_100_MASK		0x00002000
1076 #define HDA_PARAM_PIN_CAP_VREF_CTRL_100_SHIFT		13
1077 #define HDA_PARAM_PIN_CAP_VREF_CTRL_80_MASK		0x00001000
1078 #define HDA_PARAM_PIN_CAP_VREF_CTRL_80_SHIFT		12
1079 #define HDA_PARAM_PIN_CAP_VREF_CTRL_GROUND_MASK		0x00000400
1080 #define HDA_PARAM_PIN_CAP_VREF_CTRL_GROUND_SHIFT	10
1081 #define HDA_PARAM_PIN_CAP_VREF_CTRL_50_MASK		0x00000200
1082 #define HDA_PARAM_PIN_CAP_VREF_CTRL_50_SHIFT		9
1083 #define HDA_PARAM_PIN_CAP_VREF_CTRL_HIZ_MASK		0x00000100
1084 #define HDA_PARAM_PIN_CAP_VREF_CTRL_HIZ_SHIFT		8
1085 #define HDA_PARAM_PIN_CAP_HDMI_MASK			0x00000080
1086 #define HDA_PARAM_PIN_CAP_HDMI_SHIFT			7
1087 #define HDA_PARAM_PIN_CAP_BALANCED_IO_PINS_MASK		0x00000040
1088 #define HDA_PARAM_PIN_CAP_BALANCED_IO_PINS_SHIFT	6
1089 #define HDA_PARAM_PIN_CAP_INPUT_CAP_MASK		0x00000020
1090 #define HDA_PARAM_PIN_CAP_INPUT_CAP_SHIFT		5
1091 #define HDA_PARAM_PIN_CAP_OUTPUT_CAP_MASK		0x00000010
1092 #define HDA_PARAM_PIN_CAP_OUTPUT_CAP_SHIFT		4
1093 #define HDA_PARAM_PIN_CAP_HEADPHONE_CAP_MASK		0x00000008
1094 #define HDA_PARAM_PIN_CAP_HEADPHONE_CAP_SHIFT		3
1095 #define HDA_PARAM_PIN_CAP_PRESENCE_DETECT_CAP_MASK	0x00000004
1096 #define HDA_PARAM_PIN_CAP_PRESENCE_DETECT_CAP_SHIFT	2
1097 #define HDA_PARAM_PIN_CAP_TRIGGER_REQD_MASK		0x00000002
1098 #define HDA_PARAM_PIN_CAP_TRIGGER_REQD_SHIFT		1
1099 #define HDA_PARAM_PIN_CAP_IMP_SENSE_CAP_MASK		0x00000001
1100 #define HDA_PARAM_PIN_CAP_IMP_SENSE_CAP_SHIFT		0
1101 
1102 #define HDA_PARAM_PIN_CAP_HBR(param)					\
1103     (((param) & HDA_PARAM_PIN_CAP_HBR_MASK) >>				\
1104     HDA_PARAM_PIN_CAP_HBR_SHIFT)
1105 #define HDA_PARAM_PIN_CAP_DP(param)					\
1106     (((param) & HDA_PARAM_PIN_CAP_DP_MASK) >>				\
1107     HDA_PARAM_PIN_CAP_DP_SHIFT)
1108 #define HDA_PARAM_PIN_CAP_EAPD_CAP(param)				\
1109     (((param) & HDA_PARAM_PIN_CAP_EAPD_CAP_MASK) >>			\
1110     HDA_PARAM_PIN_CAP_EAPD_CAP_SHIFT)
1111 #define HDA_PARAM_PIN_CAP_VREF_CTRL(param)				\
1112     (((param) & HDA_PARAM_PIN_CAP_VREF_CTRL_MASK) >>			\
1113     HDA_PARAM_PIN_CAP_VREF_CTRL_SHIFT)
1114 #define HDA_PARAM_PIN_CAP_VREF_CTRL_100(param)				\
1115     (((param) & HDA_PARAM_PIN_CAP_VREF_CTRL_100_MASK) >>		\
1116     HDA_PARAM_PIN_CAP_VREF_CTRL_100_SHIFT)
1117 #define HDA_PARAM_PIN_CAP_VREF_CTRL_80(param)				\
1118     (((param) & HDA_PARAM_PIN_CAP_VREF_CTRL_80_MASK) >>			\
1119     HDA_PARAM_PIN_CAP_VREF_CTRL_80_SHIFT)
1120 #define HDA_PARAM_PIN_CAP_VREF_CTRL_GROUND(param)			\
1121     (((param) & HDA_PARAM_PIN_CAP_VREF_CTRL_GROUND_MASK) >>		\
1122     HDA_PARAM_PIN_CAP_VREF_CTRL_GROUND_SHIFT)
1123 #define HDA_PARAM_PIN_CAP_VREF_CTRL_50(param)				\
1124     (((param) & HDA_PARAM_PIN_CAP_VREF_CTRL_50_MASK) >>			\
1125     HDA_PARAM_PIN_CAP_VREF_CTRL_50_SHIFT)
1126 #define HDA_PARAM_PIN_CAP_VREF_CTRL_HIZ(param)				\
1127     (((param) & HDA_PARAM_PIN_CAP_VREF_CTRL_HIZ_MASK) >>		\
1128     HDA_PARAM_PIN_CAP_VREF_CTRL_HIZ_SHIFT)
1129 #define HDA_PARAM_PIN_CAP_HDMI(param)					\
1130     (((param) & HDA_PARAM_PIN_CAP_HDMI_MASK) >>				\
1131     HDA_PARAM_PIN_CAP_HDMI_SHIFT)
1132 #define HDA_PARAM_PIN_CAP_BALANCED_IO_PINS(param)			\
1133     (((param) & HDA_PARAM_PIN_CAP_BALANCED_IO_PINS_MASK) >>		\
1134     HDA_PARAM_PIN_CAP_BALANCED_IO_PINS_SHIFT)
1135 #define HDA_PARAM_PIN_CAP_INPUT_CAP(param)				\
1136     (((param) & HDA_PARAM_PIN_CAP_INPUT_CAP_MASK) >>			\
1137     HDA_PARAM_PIN_CAP_INPUT_CAP_SHIFT)
1138 #define HDA_PARAM_PIN_CAP_OUTPUT_CAP(param)				\
1139     (((param) & HDA_PARAM_PIN_CAP_OUTPUT_CAP_MASK) >>			\
1140     HDA_PARAM_PIN_CAP_OUTPUT_CAP_SHIFT)
1141 #define HDA_PARAM_PIN_CAP_HEADPHONE_CAP(param)				\
1142     (((param) & HDA_PARAM_PIN_CAP_HEADPHONE_CAP_MASK) >>		\
1143     HDA_PARAM_PIN_CAP_HEADPHONE_CAP_SHIFT)
1144 #define HDA_PARAM_PIN_CAP_PRESENCE_DETECT_CAP(param)			\
1145     (((param) & HDA_PARAM_PIN_CAP_PRESENCE_DETECT_CAP_MASK) >>		\
1146     HDA_PARAM_PIN_CAP_PRESENCE_DETECT_CAP_SHIFT)
1147 #define HDA_PARAM_PIN_CAP_TRIGGER_REQD(param)				\
1148     (((param) & HDA_PARAM_PIN_CAP_TRIGGER_REQD_MASK) >>			\
1149     HDA_PARAM_PIN_CAP_TRIGGER_REQD_SHIFT)
1150 #define HDA_PARAM_PIN_CAP_IMP_SENSE_CAP(param)				\
1151     (((param) & HDA_PARAM_PIN_CAP_IMP_SENSE_CAP_MASK) >>		\
1152     HDA_PARAM_PIN_CAP_IMP_SENSE_CAP_SHIFT)
1153 
1154 /* Input Amplifier Capabilities */
1155 #define HDA_PARAM_INPUT_AMP_CAP				0x0d
1156 
1157 #define HDA_PARAM_INPUT_AMP_CAP_MUTE_CAP_MASK		0x80000000
1158 #define HDA_PARAM_INPUT_AMP_CAP_MUTE_CAP_SHIFT		31
1159 #define HDA_PARAM_INPUT_AMP_CAP_STEPSIZE_MASK		0x007f0000
1160 #define HDA_PARAM_INPUT_AMP_CAP_STEPSIZE_SHIFT		16
1161 #define HDA_PARAM_INPUT_AMP_CAP_NUMSTEPS_MASK		0x00007f00
1162 #define HDA_PARAM_INPUT_AMP_CAP_NUMSTEPS_SHIFT		8
1163 #define HDA_PARAM_INPUT_AMP_CAP_OFFSET_MASK		0x0000007f
1164 #define HDA_PARAM_INPUT_AMP_CAP_OFFSET_SHIFT		0
1165 
1166 #define HDA_PARAM_INPUT_AMP_CAP_MUTE_CAP(param)				\
1167     (((param) & HDA_PARAM_INPUT_AMP_CAP_MUTE_CAP_MASK) >>		\
1168     HDA_PARAM_INPUT_AMP_CAP_MUTE_CAP_SHIFT)
1169 #define HDA_PARAM_INPUT_AMP_CAP_STEPSIZE(param)				\
1170     (((param) & HDA_PARAM_INPUT_AMP_CAP_STEPSIZE_MASK) >>		\
1171     HDA_PARAM_INPUT_AMP_CAP_STEPSIZE_SHIFT)
1172 #define HDA_PARAM_INPUT_AMP_CAP_NUMSTEPS(param)				\
1173     (((param) & HDA_PARAM_INPUT_AMP_CAP_NUMSTEPS_MASK) >>		\
1174     HDA_PARAM_INPUT_AMP_CAP_NUMSTEPS_SHIFT)
1175 #define HDA_PARAM_INPUT_AMP_CAP_OFFSET(param)				\
1176     (((param) & HDA_PARAM_INPUT_AMP_CAP_OFFSET_MASK) >>			\
1177     HDA_PARAM_INPUT_AMP_CAP_OFFSET_SHIFT)
1178 
1179 /* Output Amplifier Capabilities */
1180 #define HDA_PARAM_OUTPUT_AMP_CAP			0x12
1181 
1182 #define HDA_PARAM_OUTPUT_AMP_CAP_MUTE_CAP_MASK		0x80000000
1183 #define HDA_PARAM_OUTPUT_AMP_CAP_MUTE_CAP_SHIFT		31
1184 #define HDA_PARAM_OUTPUT_AMP_CAP_STEPSIZE_MASK		0x007f0000
1185 #define HDA_PARAM_OUTPUT_AMP_CAP_STEPSIZE_SHIFT		16
1186 #define HDA_PARAM_OUTPUT_AMP_CAP_NUMSTEPS_MASK		0x00007f00
1187 #define HDA_PARAM_OUTPUT_AMP_CAP_NUMSTEPS_SHIFT		8
1188 #define HDA_PARAM_OUTPUT_AMP_CAP_OFFSET_MASK		0x0000007f
1189 #define HDA_PARAM_OUTPUT_AMP_CAP_OFFSET_SHIFT		0
1190 
1191 #define HDA_PARAM_OUTPUT_AMP_CAP_MUTE_CAP(param)			\
1192     (((param) & HDA_PARAM_OUTPUT_AMP_CAP_MUTE_CAP_MASK) >>		\
1193     HDA_PARAM_OUTPUT_AMP_CAP_MUTE_CAP_SHIFT)
1194 #define HDA_PARAM_OUTPUT_AMP_CAP_STEPSIZE(param)			\
1195     (((param) & HDA_PARAM_OUTPUT_AMP_CAP_STEPSIZE_MASK) >>		\
1196     HDA_PARAM_OUTPUT_AMP_CAP_STEPSIZE_SHIFT)
1197 #define HDA_PARAM_OUTPUT_AMP_CAP_NUMSTEPS(param)			\
1198     (((param) & HDA_PARAM_OUTPUT_AMP_CAP_NUMSTEPS_MASK) >>		\
1199     HDA_PARAM_OUTPUT_AMP_CAP_NUMSTEPS_SHIFT)
1200 #define HDA_PARAM_OUTPUT_AMP_CAP_OFFSET(param)				\
1201     (((param) & HDA_PARAM_OUTPUT_AMP_CAP_OFFSET_MASK) >>		\
1202     HDA_PARAM_OUTPUT_AMP_CAP_OFFSET_SHIFT)
1203 
1204 /* Connection List Length */
1205 #define HDA_PARAM_CONN_LIST_LENGTH			0x0e
1206 
1207 #define HDA_PARAM_CONN_LIST_LENGTH_LONG_FORM_MASK	0x00000080
1208 #define HDA_PARAM_CONN_LIST_LENGTH_LONG_FORM_SHIFT	7
1209 #define HDA_PARAM_CONN_LIST_LENGTH_LIST_LENGTH_MASK	0x0000007f
1210 #define HDA_PARAM_CONN_LIST_LENGTH_LIST_LENGTH_SHIFT	0
1211 
1212 #define HDA_PARAM_CONN_LIST_LENGTH_LONG_FORM(param)			\
1213     (((param) & HDA_PARAM_CONN_LIST_LENGTH_LONG_FORM_MASK) >>		\
1214     HDA_PARAM_CONN_LIST_LENGTH_LONG_FORM_SHIFT)
1215 #define HDA_PARAM_CONN_LIST_LENGTH_LIST_LENGTH(param)			\
1216     (((param) & HDA_PARAM_CONN_LIST_LENGTH_LIST_LENGTH_MASK) >>		\
1217     HDA_PARAM_CONN_LIST_LENGTH_LIST_LENGTH_SHIFT)
1218 
1219 /* Supported Power States */
1220 #define HDA_PARAM_SUPP_POWER_STATES			0x0f
1221 
1222 #define HDA_PARAM_SUPP_POWER_STATES_D3_MASK		0x00000008
1223 #define HDA_PARAM_SUPP_POWER_STATES_D3_SHIFT		3
1224 #define HDA_PARAM_SUPP_POWER_STATES_D2_MASK		0x00000004
1225 #define HDA_PARAM_SUPP_POWER_STATES_D2_SHIFT		2
1226 #define HDA_PARAM_SUPP_POWER_STATES_D1_MASK		0x00000002
1227 #define HDA_PARAM_SUPP_POWER_STATES_D1_SHIFT		1
1228 #define HDA_PARAM_SUPP_POWER_STATES_D0_MASK		0x00000001
1229 #define HDA_PARAM_SUPP_POWER_STATES_D0_SHIFT		0
1230 
1231 #define HDA_PARAM_SUPP_POWER_STATES_D3(param)				\
1232     (((param) & HDA_PARAM_SUPP_POWER_STATES_D3_MASK) >>			\
1233     HDA_PARAM_SUPP_POWER_STATES_D3_SHIFT)
1234 #define HDA_PARAM_SUPP_POWER_STATES_D2(param)				\
1235     (((param) & HDA_PARAM_SUPP_POWER_STATES_D2_MASK) >>			\
1236     HDA_PARAM_SUPP_POWER_STATES_D2_SHIFT)
1237 #define HDA_PARAM_SUPP_POWER_STATES_D1(param)				\
1238     (((param) & HDA_PARAM_SUPP_POWER_STATES_D1_MASK) >>			\
1239     HDA_PARAM_SUPP_POWER_STATES_D1_SHIFT)
1240 #define HDA_PARAM_SUPP_POWER_STATES_D0(param)				\
1241     (((param) & HDA_PARAM_SUPP_POWER_STATES_D0_MASK) >>			\
1242     HDA_PARAM_SUPP_POWER_STATES_D0_SHIFT)
1243 
1244 /* Processing Capabilities */
1245 #define HDA_PARAM_PROCESSING_CAP			0x10
1246 
1247 #define HDA_PARAM_PROCESSING_CAP_NUMCOEFF_MASK		0x0000ff00
1248 #define HDA_PARAM_PROCESSING_CAP_NUMCOEFF_SHIFT		8
1249 #define HDA_PARAM_PROCESSING_CAP_BENIGN_MASK		0x00000001
1250 #define HDA_PARAM_PROCESSING_CAP_BENIGN_SHIFT		0
1251 
1252 #define HDA_PARAM_PROCESSING_CAP_NUMCOEFF(param)			\
1253     (((param) & HDA_PARAM_PROCESSING_CAP_NUMCOEFF_MASK) >>		\
1254     HDA_PARAM_PROCESSING_CAP_NUMCOEFF_SHIFT)
1255 #define HDA_PARAM_PROCESSING_CAP_BENIGN(param)				\
1256     (((param) & HDA_PARAM_PROCESSING_CAP_BENIGN_MASK) >>		\
1257     HDA_PARAM_PROCESSING_CAP_BENIGN_SHIFT)
1258 
1259 /* GPIO Count */
1260 #define HDA_PARAM_GPIO_COUNT				0x11
1261 
1262 #define HDA_PARAM_GPIO_COUNT_GPI_WAKE_MASK		0x80000000
1263 #define HDA_PARAM_GPIO_COUNT_GPI_WAKE_SHIFT		31
1264 #define HDA_PARAM_GPIO_COUNT_GPI_UNSOL_MASK		0x40000000
1265 #define HDA_PARAM_GPIO_COUNT_GPI_UNSOL_SHIFT		30
1266 #define HDA_PARAM_GPIO_COUNT_NUM_GPI_MASK		0x00ff0000
1267 #define HDA_PARAM_GPIO_COUNT_NUM_GPI_SHIFT		16
1268 #define HDA_PARAM_GPIO_COUNT_NUM_GPO_MASK		0x0000ff00
1269 #define HDA_PARAM_GPIO_COUNT_NUM_GPO_SHIFT		8
1270 #define HDA_PARAM_GPIO_COUNT_NUM_GPIO_MASK		0x000000ff
1271 #define HDA_PARAM_GPIO_COUNT_NUM_GPIO_SHIFT		0
1272 
1273 #define HDA_PARAM_GPIO_COUNT_GPI_WAKE(param)				\
1274     (((param) & HDA_PARAM_GPIO_COUNT_GPI_WAKE_MASK) >>			\
1275     HDA_PARAM_GPIO_COUNT_GPI_WAKE_SHIFT)
1276 #define HDA_PARAM_GPIO_COUNT_GPI_UNSOL(param)				\
1277     (((param) & HDA_PARAM_GPIO_COUNT_GPI_UNSOL_MASK) >>			\
1278     HDA_PARAM_GPIO_COUNT_GPI_UNSOL_SHIFT)
1279 #define HDA_PARAM_GPIO_COUNT_NUM_GPI(param)				\
1280     (((param) & HDA_PARAM_GPIO_COUNT_NUM_GPI_MASK) >>			\
1281     HDA_PARAM_GPIO_COUNT_NUM_GPI_SHIFT)
1282 #define HDA_PARAM_GPIO_COUNT_NUM_GPO(param)				\
1283     (((param) & HDA_PARAM_GPIO_COUNT_NUM_GPO_MASK) >>			\
1284     HDA_PARAM_GPIO_COUNT_NUM_GPO_SHIFT)
1285 #define HDA_PARAM_GPIO_COUNT_NUM_GPIO(param)				\
1286     (((param) & HDA_PARAM_GPIO_COUNT_NUM_GPIO_MASK) >>			\
1287     HDA_PARAM_GPIO_COUNT_NUM_GPIO_SHIFT)
1288 
1289 /* Volume Knob Capabilities */
1290 #define HDA_PARAM_VOLUME_KNOB_CAP			0x13
1291 
1292 #define HDA_PARAM_VOLUME_KNOB_CAP_DELTA_MASK		0x00000080
1293 #define HDA_PARAM_VOLUME_KNOB_CAP_DELTA_SHIFT		7
1294 #define HDA_PARAM_VOLUME_KNOB_CAP_NUM_STEPS_MASK	0x0000007f
1295 #define HDA_PARAM_VOLUME_KNOB_CAP_NUM_STEPS_SHIFT	0
1296 
1297 #define HDA_PARAM_VOLUME_KNOB_CAP_DELTA(param)				\
1298     (((param) & HDA_PARAM_VOLUME_KNOB_CAP_DELTA_MASK) >>		\
1299     HDA_PARAM_VOLUME_KNOB_CAP_DELTA_SHIFT)
1300 #define HDA_PARAM_VOLUME_KNOB_CAP_NUM_STEPS(param)			\
1301     (((param) & HDA_PARAM_VOLUME_KNOB_CAP_NUM_STEPS_MASK) >>		\
1302     HDA_PARAM_VOLUME_KNOB_CAP_NUM_STEPS_SHIFT)
1303 
1304 #define HDA_CONFIG_DEFAULTCONF_SEQUENCE_MASK		0x0000000f
1305 #define HDA_CONFIG_DEFAULTCONF_SEQUENCE_SHIFT		0
1306 #define HDA_CONFIG_DEFAULTCONF_ASSOCIATION_MASK		0x000000f0
1307 #define HDA_CONFIG_DEFAULTCONF_ASSOCIATION_SHIFT	4
1308 #define HDA_CONFIG_DEFAULTCONF_MISC_MASK		0x00000f00
1309 #define HDA_CONFIG_DEFAULTCONF_MISC_SHIFT		8
1310 #define HDA_CONFIG_DEFAULTCONF_COLOR_MASK		0x0000f000
1311 #define HDA_CONFIG_DEFAULTCONF_COLOR_SHIFT		12
1312 #define HDA_CONFIG_DEFAULTCONF_CONNECTION_TYPE_MASK	0x000f0000
1313 #define HDA_CONFIG_DEFAULTCONF_CONNECTION_TYPE_SHIFT	16
1314 #define HDA_CONFIG_DEFAULTCONF_DEVICE_MASK		0x00f00000
1315 #define HDA_CONFIG_DEFAULTCONF_DEVICE_SHIFT		20
1316 #define HDA_CONFIG_DEFAULTCONF_LOCATION_MASK		0x3f000000
1317 #define HDA_CONFIG_DEFAULTCONF_LOCATION_SHIFT		24
1318 #define HDA_CONFIG_DEFAULTCONF_CONNECTIVITY_MASK	0xc0000000
1319 #define HDA_CONFIG_DEFAULTCONF_CONNECTIVITY_SHIFT	30
1320 
1321 #define HDA_CONFIG_DEFAULTCONF_SEQUENCE(conf)				\
1322     (((conf) & HDA_CONFIG_DEFAULTCONF_SEQUENCE_MASK) >>			\
1323     HDA_CONFIG_DEFAULTCONF_SEQUENCE_SHIFT)
1324 #define HDA_CONFIG_DEFAULTCONF_ASSOCIATION(conf)			\
1325     (((conf) & HDA_CONFIG_DEFAULTCONF_ASSOCIATION_MASK) >>		\
1326     HDA_CONFIG_DEFAULTCONF_ASSOCIATION_SHIFT)
1327 #define HDA_CONFIG_DEFAULTCONF_MISC(conf)				\
1328     (((conf) & HDA_CONFIG_DEFAULTCONF_MISC_MASK) >>			\
1329     HDA_CONFIG_DEFAULTCONF_MISC_SHIFT)
1330 #define HDA_CONFIG_DEFAULTCONF_COLOR(conf)				\
1331     (((conf) & HDA_CONFIG_DEFAULTCONF_COLOR_MASK) >>			\
1332     HDA_CONFIG_DEFAULTCONF_COLOR_SHIFT)
1333 #define HDA_CONFIG_DEFAULTCONF_CONNECTION_TYPE(conf)			\
1334     (((conf) & HDA_CONFIG_DEFAULTCONF_CONNECTION_TYPE_MASK) >>		\
1335     HDA_CONFIG_DEFAULTCONF_CONNECTION_TYPE_SHIFT)
1336 #define HDA_CONFIG_DEFAULTCONF_DEVICE(conf)				\
1337     (((conf) & HDA_CONFIG_DEFAULTCONF_DEVICE_MASK) >>			\
1338     HDA_CONFIG_DEFAULTCONF_DEVICE_SHIFT)
1339 #define HDA_CONFIG_DEFAULTCONF_LOCATION(conf)				\
1340     (((conf) & HDA_CONFIG_DEFAULTCONF_LOCATION_MASK) >>			\
1341     HDA_CONFIG_DEFAULTCONF_LOCATION_SHIFT)
1342 #define HDA_CONFIG_DEFAULTCONF_CONNECTIVITY(conf)			\
1343     (((conf) & HDA_CONFIG_DEFAULTCONF_CONNECTIVITY_MASK) >>		\
1344     HDA_CONFIG_DEFAULTCONF_CONNECTIVITY_SHIFT)
1345 
1346 #define HDA_CONFIG_DEFAULTCONF_CONNECTIVITY_JACK		(0<<30)
1347 #define HDA_CONFIG_DEFAULTCONF_CONNECTIVITY_NONE		(1<<30)
1348 #define HDA_CONFIG_DEFAULTCONF_CONNECTIVITY_FIXED		(2<<30)
1349 #define HDA_CONFIG_DEFAULTCONF_CONNECTIVITY_BOTH		(3<<30)
1350 
1351 #define HDA_CONFIG_DEFAULTCONF_DEVICE_LINE_OUT			(0<<20)
1352 #define HDA_CONFIG_DEFAULTCONF_DEVICE_SPEAKER			(1<<20)
1353 #define HDA_CONFIG_DEFAULTCONF_DEVICE_HP_OUT			(2<<20)
1354 #define HDA_CONFIG_DEFAULTCONF_DEVICE_CD			(3<<20)
1355 #define HDA_CONFIG_DEFAULTCONF_DEVICE_SPDIF_OUT			(4<<20)
1356 #define HDA_CONFIG_DEFAULTCONF_DEVICE_DIGITAL_OTHER_OUT		(5<<20)
1357 #define HDA_CONFIG_DEFAULTCONF_DEVICE_MODEM_LINE		(6<<20)
1358 #define HDA_CONFIG_DEFAULTCONF_DEVICE_MODEM_HANDSET		(7<<20)
1359 #define HDA_CONFIG_DEFAULTCONF_DEVICE_LINE_IN			(8<<20)
1360 #define HDA_CONFIG_DEFAULTCONF_DEVICE_AUX			(9<<20)
1361 #define HDA_CONFIG_DEFAULTCONF_DEVICE_MIC_IN			(10<<20)
1362 #define HDA_CONFIG_DEFAULTCONF_DEVICE_TELEPHONY			(11<<20)
1363 #define HDA_CONFIG_DEFAULTCONF_DEVICE_SPDIF_IN			(12<<20)
1364 #define HDA_CONFIG_DEFAULTCONF_DEVICE_DIGITAL_OTHER_IN		(13<<20)
1365 #define HDA_CONFIG_DEFAULTCONF_DEVICE_OTHER			(15<<20)
1366 
1367 #endif
1368