[PATCH] Driver Core: pm diagnostics update, check for errors
[linux-2.6/verdex.git] / sound / oss / cs4281 / cs4281_hwdefs.h
blob701d595e33f59f943a20f3b100afb88b632991a3
1 //****************************************************************************
2 //
3 // HWDEFS.H - Definitions of the registers and data structures used by the
4 // CS4281
5 //
6 // Copyright (c) 1999,2000,2001 Crystal Semiconductor Corp.
7 //
8 //****************************************************************************
10 #ifndef _H_HWDEFS
11 #define _H_HWDEFS
13 //****************************************************************************
15 // The following define the offsets of the registers located in the PCI
16 // configuration space of the CS4281 part.
18 //****************************************************************************
19 #define PCICONFIG_DEVID_VENID 0x00000000L
20 #define PCICONFIG_STATUS_COMMAND 0x00000004L
21 #define PCICONFIG_CLASS_REVISION 0x00000008L
22 #define PCICONFIG_LATENCY_TIMER 0x0000000CL
23 #define PCICONFIG_BA0 0x00000010L
24 #define PCICONFIG_BA1 0x00000014L
25 #define PCICONFIG_SUBSYSID_SUBSYSVENID 0x0000002CL
26 #define PCICONFIG_INTERRUPT 0x0000003CL
28 //****************************************************************************
30 // The following define the offsets of the registers accessed via base address
31 // register zero on the CS4281 part.
33 //****************************************************************************
34 #define BA0_HISR 0x00000000L
35 #define BA0_HICR 0x00000008L
36 #define BA0_HIMR 0x0000000CL
37 #define BA0_IIER 0x00000010L
38 #define BA0_HDSR0 0x000000F0L
39 #define BA0_HDSR1 0x000000F4L
40 #define BA0_HDSR2 0x000000F8L
41 #define BA0_HDSR3 0x000000FCL
42 #define BA0_DCA0 0x00000110L
43 #define BA0_DCC0 0x00000114L
44 #define BA0_DBA0 0x00000118L
45 #define BA0_DBC0 0x0000011CL
46 #define BA0_DCA1 0x00000120L
47 #define BA0_DCC1 0x00000124L
48 #define BA0_DBA1 0x00000128L
49 #define BA0_DBC1 0x0000012CL
50 #define BA0_DCA2 0x00000130L
51 #define BA0_DCC2 0x00000134L
52 #define BA0_DBA2 0x00000138L
53 #define BA0_DBC2 0x0000013CL
54 #define BA0_DCA3 0x00000140L
55 #define BA0_DCC3 0x00000144L
56 #define BA0_DBA3 0x00000148L
57 #define BA0_DBC3 0x0000014CL
58 #define BA0_DMR0 0x00000150L
59 #define BA0_DCR0 0x00000154L
60 #define BA0_DMR1 0x00000158L
61 #define BA0_DCR1 0x0000015CL
62 #define BA0_DMR2 0x00000160L
63 #define BA0_DCR2 0x00000164L
64 #define BA0_DMR3 0x00000168L
65 #define BA0_DCR3 0x0000016CL
66 #define BA0_DLMR 0x00000170L
67 #define BA0_DLSR 0x00000174L
68 #define BA0_FCR0 0x00000180L
69 #define BA0_FCR1 0x00000184L
70 #define BA0_FCR2 0x00000188L
71 #define BA0_FCR3 0x0000018CL
72 #define BA0_FPDR0 0x00000190L
73 #define BA0_FPDR1 0x00000194L
74 #define BA0_FPDR2 0x00000198L
75 #define BA0_FPDR3 0x0000019CL
76 #define BA0_FCHS 0x0000020CL
77 #define BA0_FSIC0 0x00000210L
78 #define BA0_FSIC1 0x00000214L
79 #define BA0_FSIC2 0x00000218L
80 #define BA0_FSIC3 0x0000021CL
81 #define BA0_PCICFG00 0x00000300L
82 #define BA0_PCICFG04 0x00000304L
83 #define BA0_PCICFG08 0x00000308L
84 #define BA0_PCICFG0C 0x0000030CL
85 #define BA0_PCICFG10 0x00000310L
86 #define BA0_PCICFG14 0x00000314L
87 #define BA0_PCICFG18 0x00000318L
88 #define BA0_PCICFG1C 0x0000031CL
89 #define BA0_PCICFG20 0x00000320L
90 #define BA0_PCICFG24 0x00000324L
91 #define BA0_PCICFG28 0x00000328L
92 #define BA0_PCICFG2C 0x0000032CL
93 #define BA0_PCICFG30 0x00000330L
94 #define BA0_PCICFG34 0x00000334L
95 #define BA0_PCICFG38 0x00000338L
96 #define BA0_PCICFG3C 0x0000033CL
97 #define BA0_PCICFG40 0x00000340L
98 #define BA0_PMCS 0x00000344L
99 #define BA0_CWPR 0x000003E0L
100 #define BA0_EPPMC 0x000003E4L
101 #define BA0_GPIOR 0x000003E8L
102 #define BA0_SPMC 0x000003ECL
103 #define BA0_CFLR 0x000003F0L
104 #define BA0_IISR 0x000003F4L
105 #define BA0_TMS 0x000003F8L
106 #define BA0_SSVID 0x000003FCL
107 #define BA0_CLKCR1 0x00000400L
108 #define BA0_FRR 0x00000410L
109 #define BA0_SLT12O 0x0000041CL
110 #define BA0_SERMC 0x00000420L
111 #define BA0_SERC1 0x00000428L
112 #define BA0_SERC2 0x0000042CL
113 #define BA0_SLT12M 0x0000045CL
114 #define BA0_ACCTL 0x00000460L
115 #define BA0_ACSTS 0x00000464L
116 #define BA0_ACOSV 0x00000468L
117 #define BA0_ACCAD 0x0000046CL
118 #define BA0_ACCDA 0x00000470L
119 #define BA0_ACISV 0x00000474L
120 #define BA0_ACSAD 0x00000478L
121 #define BA0_ACSDA 0x0000047CL
122 #define BA0_JSPT 0x00000480L
123 #define BA0_JSCTL 0x00000484L
124 #define BA0_MIDCR 0x00000490L
125 #define BA0_MIDCMD 0x00000494L
126 #define BA0_MIDSR 0x00000494L
127 #define BA0_MIDWP 0x00000498L
128 #define BA0_MIDRP 0x0000049CL
129 #define BA0_AODSD1 0x000004A8L
130 #define BA0_AODSD2 0x000004ACL
131 #define BA0_CFGI 0x000004B0L
132 #define BA0_SLT12M2 0x000004DCL
133 #define BA0_ACSTS2 0x000004E4L
134 #define BA0_ACISV2 0x000004F4L
135 #define BA0_ACSAD2 0x000004F8L
136 #define BA0_ACSDA2 0x000004FCL
137 #define BA0_IOTGP 0x00000500L
138 #define BA0_IOTSB 0x00000504L
139 #define BA0_IOTFM 0x00000508L
140 #define BA0_IOTDMA 0x0000050CL
141 #define BA0_IOTAC0 0x00000500L
142 #define BA0_IOTAC1 0x00000504L
143 #define BA0_IOTAC2 0x00000508L
144 #define BA0_IOTAC3 0x0000050CL
145 #define BA0_IOTPCP 0x0000052CL
146 #define BA0_IOTCC 0x00000530L
147 #define BA0_IOTCR 0x0000058CL
148 #define BA0_PCPRR 0x00000600L
149 #define BA0_PCPGR 0x00000604L
150 #define BA0_PCPCR 0x00000608L
151 #define BA0_PCPCIEN 0x00000608L
152 #define BA0_SBMAR 0x00000700L
153 #define BA0_SBMDR 0x00000704L
154 #define BA0_SBRR 0x00000708L
155 #define BA0_SBRDP 0x0000070CL
156 #define BA0_SBWDP 0x00000710L
157 #define BA0_SBWBS 0x00000710L
158 #define BA0_SBRBS 0x00000714L
159 #define BA0_FMSR 0x00000730L
160 #define BA0_B0AP 0x00000730L
161 #define BA0_FMDP 0x00000734L
162 #define BA0_B1AP 0x00000738L
163 #define BA0_B1DP 0x0000073CL
164 #define BA0_SSPM 0x00000740L
165 #define BA0_DACSR 0x00000744L
166 #define BA0_ADCSR 0x00000748L
167 #define BA0_SSCR 0x0000074CL
168 #define BA0_FMLVC 0x00000754L
169 #define BA0_FMRVC 0x00000758L
170 #define BA0_SRCSA 0x0000075CL
171 #define BA0_PPLVC 0x00000760L
172 #define BA0_PPRVC 0x00000764L
173 #define BA0_PASR 0x00000768L
174 #define BA0_CASR 0x0000076CL
176 //****************************************************************************
178 // The following define the offsets of the AC97 shadow registers, which appear
179 // as a virtual extension to the base address register zero memory range.
181 //****************************************************************************
182 #define AC97_REG_OFFSET_MASK 0x0000007EL
183 #define AC97_CODEC_NUMBER_MASK 0x00003000L
185 #define BA0_AC97_RESET 0x00001000L
186 #define BA0_AC97_MASTER_VOLUME 0x00001002L
187 #define BA0_AC97_HEADPHONE_VOLUME 0x00001004L
188 #define BA0_AC97_MASTER_VOLUME_MONO 0x00001006L
189 #define BA0_AC97_MASTER_TONE 0x00001008L
190 #define BA0_AC97_PC_BEEP_VOLUME 0x0000100AL
191 #define BA0_AC97_PHONE_VOLUME 0x0000100CL
192 #define BA0_AC97_MIC_VOLUME 0x0000100EL
193 #define BA0_AC97_LINE_IN_VOLUME 0x00001010L
194 #define BA0_AC97_CD_VOLUME 0x00001012L
195 #define BA0_AC97_VIDEO_VOLUME 0x00001014L
196 #define BA0_AC97_AUX_VOLUME 0x00001016L
197 #define BA0_AC97_PCM_OUT_VOLUME 0x00001018L
198 #define BA0_AC97_RECORD_SELECT 0x0000101AL
199 #define BA0_AC97_RECORD_GAIN 0x0000101CL
200 #define BA0_AC97_RECORD_GAIN_MIC 0x0000101EL
201 #define BA0_AC97_GENERAL_PURPOSE 0x00001020L
202 #define BA0_AC97_3D_CONTROL 0x00001022L
203 #define BA0_AC97_MODEM_RATE 0x00001024L
204 #define BA0_AC97_POWERDOWN 0x00001026L
205 #define BA0_AC97_EXT_AUDIO_ID 0x00001028L
206 #define BA0_AC97_EXT_AUDIO_POWER 0x0000102AL
207 #define BA0_AC97_PCM_FRONT_DAC_RATE 0x0000102CL
208 #define BA0_AC97_PCM_SURR_DAC_RATE 0x0000102EL
209 #define BA0_AC97_PCM_LFE_DAC_RATE 0x00001030L
210 #define BA0_AC97_PCM_LR_ADC_RATE 0x00001032L
211 #define BA0_AC97_MIC_ADC_RATE 0x00001034L
212 #define BA0_AC97_6CH_VOL_C_LFE 0x00001036L
213 #define BA0_AC97_6CH_VOL_SURROUND 0x00001038L
214 #define BA0_AC97_RESERVED_3A 0x0000103AL
215 #define BA0_AC97_EXT_MODEM_ID 0x0000103CL
216 #define BA0_AC97_EXT_MODEM_POWER 0x0000103EL
217 #define BA0_AC97_LINE1_CODEC_RATE 0x00001040L
218 #define BA0_AC97_LINE2_CODEC_RATE 0x00001042L
219 #define BA0_AC97_HANDSET_CODEC_RATE 0x00001044L
220 #define BA0_AC97_LINE1_CODEC_LEVEL 0x00001046L
221 #define BA0_AC97_LINE2_CODEC_LEVEL 0x00001048L
222 #define BA0_AC97_HANDSET_CODEC_LEVEL 0x0000104AL
223 #define BA0_AC97_GPIO_PIN_CONFIG 0x0000104CL
224 #define BA0_AC97_GPIO_PIN_TYPE 0x0000104EL
225 #define BA0_AC97_GPIO_PIN_STICKY 0x00001050L
226 #define BA0_AC97_GPIO_PIN_WAKEUP 0x00001052L
227 #define BA0_AC97_GPIO_PIN_STATUS 0x00001054L
228 #define BA0_AC97_MISC_MODEM_AFE_STAT 0x00001056L
229 #define BA0_AC97_RESERVED_58 0x00001058L
230 #define BA0_AC97_CRYSTAL_REV_N_FAB_ID 0x0000105AL
231 #define BA0_AC97_TEST_AND_MISC_CTRL 0x0000105CL
232 #define BA0_AC97_AC_MODE 0x0000105EL
233 #define BA0_AC97_MISC_CRYSTAL_CONTROL 0x00001060L
234 #define BA0_AC97_LINE1_HYPRID_CTRL 0x00001062L
235 #define BA0_AC97_VENDOR_RESERVED_64 0x00001064L
236 #define BA0_AC97_VENDOR_RESERVED_66 0x00001066L
237 #define BA0_AC97_SPDIF_CONTROL 0x00001068L
238 #define BA0_AC97_VENDOR_RESERVED_6A 0x0000106AL
239 #define BA0_AC97_VENDOR_RESERVED_6C 0x0000106CL
240 #define BA0_AC97_VENDOR_RESERVED_6E 0x0000106EL
241 #define BA0_AC97_VENDOR_RESERVED_70 0x00001070L
242 #define BA0_AC97_VENDOR_RESERVED_72 0x00001072L
243 #define BA0_AC97_VENDOR_RESERVED_74 0x00001074L
244 #define BA0_AC97_CAL_ADDRESS 0x00001076L
245 #define BA0_AC97_CAL_DATA 0x00001078L
246 #define BA0_AC97_VENDOR_RESERVED_7A 0x0000107AL
247 #define BA0_AC97_VENDOR_ID1 0x0000107CL
248 #define BA0_AC97_VENDOR_ID2 0x0000107EL
250 //****************************************************************************
252 // The following define the offsets of the registers and memories accessed via
253 // base address register one on the CS4281 part.
255 //****************************************************************************
257 //****************************************************************************
259 // The following defines are for the flags in the PCI device ID/vendor ID
260 // register.
262 //****************************************************************************
263 #define PDV_VENID_MASK 0x0000FFFFL
264 #define PDV_DEVID_MASK 0xFFFF0000L
265 #define PDV_VENID_SHIFT 0L
266 #define PDV_DEVID_SHIFT 16L
267 #define VENID_CIRRUS_LOGIC 0x1013L
268 #define DEVID_CS4281 0x6005L
270 //****************************************************************************
272 // The following defines are for the flags in the PCI status and command
273 // register.
275 //****************************************************************************
276 #define PSC_IO_SPACE_ENABLE 0x00000001L
277 #define PSC_MEMORY_SPACE_ENABLE 0x00000002L
278 #define PSC_BUS_MASTER_ENABLE 0x00000004L
279 #define PSC_SPECIAL_CYCLES 0x00000008L
280 #define PSC_MWI_ENABLE 0x00000010L
281 #define PSC_VGA_PALETTE_SNOOP 0x00000020L
282 #define PSC_PARITY_RESPONSE 0x00000040L
283 #define PSC_WAIT_CONTROL 0x00000080L
284 #define PSC_SERR_ENABLE 0x00000100L
285 #define PSC_FAST_B2B_ENABLE 0x00000200L
286 #define PSC_UDF_MASK 0x007F0000L
287 #define PSC_FAST_B2B_CAPABLE 0x00800000L
288 #define PSC_PARITY_ERROR_DETECTED 0x01000000L
289 #define PSC_DEVSEL_TIMING_MASK 0x06000000L
290 #define PSC_TARGET_ABORT_SIGNALLED 0x08000000L
291 #define PSC_RECEIVED_TARGET_ABORT 0x10000000L
292 #define PSC_RECEIVED_MASTER_ABORT 0x20000000L
293 #define PSC_SIGNALLED_SERR 0x40000000L
294 #define PSC_DETECTED_PARITY_ERROR 0x80000000L
295 #define PSC_UDF_SHIFT 16L
296 #define PSC_DEVSEL_TIMING_SHIFT 25L
298 //****************************************************************************
300 // The following defines are for the flags in the PCI class/revision ID
301 // register.
303 //****************************************************************************
304 #define PCR_REVID_MASK 0x000000FFL
305 #define PCR_INTERFACE_MASK 0x0000FF00L
306 #define PCR_SUBCLASS_MASK 0x00FF0000L
307 #define PCR_CLASS_MASK 0xFF000000L
308 #define PCR_REVID_SHIFT 0L
309 #define PCR_INTERFACE_SHIFT 8L
310 #define PCR_SUBCLASS_SHIFT 16L
311 #define PCR_CLASS_SHIFT 24L
313 //****************************************************************************
315 // The following defines are for the flags in the PCI latency timer register.
317 //****************************************************************************
318 #define PLT_CACHE_LINE_SIZE_MASK 0x000000FFL
319 #define PLT_LATENCY_TIMER_MASK 0x0000FF00L
320 #define PLT_HEADER_TYPE_MASK 0x00FF0000L
321 #define PLT_BIST_MASK 0xFF000000L
322 #define PLT_CACHE_LINE_SIZE_SHIFT 0L
323 #define PLT_LATENCY_TIMER_SHIFT 8L
324 #define PLT_HEADER_TYPE_SHIFT 16L
325 #define PLT_BIST_SHIFT 24L
327 //****************************************************************************
329 // The following defines are for the flags in the PCI base address registers.
331 //****************************************************************************
332 #define PBAR_MEMORY_SPACE_INDICATOR 0x00000001L
333 #define PBAR_LOCATION_TYPE_MASK 0x00000006L
334 #define PBAR_NOT_PREFETCHABLE 0x00000008L
335 #define PBAR_ADDRESS_MASK 0xFFFFFFF0L
336 #define PBAR_LOCATION_TYPE_SHIFT 1L
338 //****************************************************************************
340 // The following defines are for the flags in the PCI subsystem ID/subsystem
341 // vendor ID register.
343 //****************************************************************************
344 #define PSS_SUBSYSTEM_VENDOR_ID_MASK 0x0000FFFFL
345 #define PSS_SUBSYSTEM_ID_MASK 0xFFFF0000L
346 #define PSS_SUBSYSTEM_VENDOR_ID_SHIFT 0L
347 #define PSS_SUBSYSTEM_ID_SHIFT 16L
349 //****************************************************************************
351 // The following defines are for the flags in the PCI interrupt register.
353 //****************************************************************************
354 #define PI_LINE_MASK 0x000000FFL
355 #define PI_PIN_MASK 0x0000FF00L
356 #define PI_MIN_GRANT_MASK 0x00FF0000L
357 #define PI_MAX_LATENCY_MASK 0xFF000000L
358 #define PI_LINE_SHIFT 0L
359 #define PI_PIN_SHIFT 8L
360 #define PI_MIN_GRANT_SHIFT 16L
361 #define PI_MAX_LATENCY_SHIFT 24L
363 //****************************************************************************
365 // The following defines are for the flags in the host interrupt status
366 // register.
368 //****************************************************************************
369 #define HISR_HVOLMASK 0x00000003L
370 #define HISR_VDNI 0x00000001L
371 #define HISR_VUPI 0x00000002L
372 #define HISR_GP1I 0x00000004L
373 #define HISR_GP3I 0x00000008L
374 #define HISR_GPSI 0x00000010L
375 #define HISR_GPPI 0x00000020L
376 #define HISR_DMAI 0x00040000L
377 #define HISR_FIFOI 0x00100000L
378 #define HISR_HVOL 0x00200000L
379 #define HISR_MIDI 0x00400000L
380 #define HISR_SBINT 0x00800000L
381 #define HISR_INTENA 0x80000000L
382 #define HISR_DMA_MASK 0x00000F00L
383 #define HISR_FIFO_MASK 0x0000F000L
384 #define HISR_DMA_SHIFT 8L
385 #define HISR_FIFO_SHIFT 12L
386 #define HISR_FIFO0 0x00001000L
387 #define HISR_FIFO1 0x00002000L
388 #define HISR_FIFO2 0x00004000L
389 #define HISR_FIFO3 0x00008000L
390 #define HISR_DMA0 0x00000100L
391 #define HISR_DMA1 0x00000200L
392 #define HISR_DMA2 0x00000400L
393 #define HISR_DMA3 0x00000800L
394 #define HISR_RESERVED 0x40000000L
396 //****************************************************************************
398 // The following defines are for the flags in the host interrupt control
399 // register.
401 //****************************************************************************
402 #define HICR_IEV 0x00000001L
403 #define HICR_CHGM 0x00000002L
405 //****************************************************************************
407 // The following defines are for the flags in the DMA Mode Register n
408 // (DMRn)
410 //****************************************************************************
411 #define DMRn_TR_MASK 0x0000000CL
412 #define DMRn_TR_SHIFT 2L
413 #define DMRn_AUTO 0x00000010L
414 #define DMRn_TR_READ 0x00000008L
415 #define DMRn_TR_WRITE 0x00000004L
416 #define DMRn_TYPE_MASK 0x000000C0L
417 #define DMRn_TYPE_SHIFT 6L
418 #define DMRn_SIZE8 0x00010000L
419 #define DMRn_MONO 0x00020000L
420 #define DMRn_BEND 0x00040000L
421 #define DMRn_USIGN 0x00080000L
422 #define DMRn_SIZE20 0x00100000L
423 #define DMRn_SWAPC 0x00400000L
424 #define DMRn_CBC 0x01000000L
425 #define DMRn_TBC 0x02000000L
426 #define DMRn_POLL 0x10000000L
427 #define DMRn_DMA 0x20000000L
428 #define DMRn_FSEL_MASK 0xC0000000L
429 #define DMRn_FSEL_SHIFT 30L
430 #define DMRn_FSEL0 0x00000000L
431 #define DMRn_FSEL1 0x40000000L
432 #define DMRn_FSEL2 0x80000000L
433 #define DMRn_FSEL3 0xC0000000L
435 //****************************************************************************
437 // The following defines are for the flags in the DMA Command Register n
438 // (DCRn)
440 //****************************************************************************
441 #define DCRn_HTCIE 0x00020000L
442 #define DCRn_TCIE 0x00010000L
443 #define DCRn_MSK 0x00000001L
445 //****************************************************************************
447 // The following defines are for the flags in the FIFO Control
448 // register n.(FCRn)
450 //****************************************************************************
451 #define FCRn_OF_MASK 0x0000007FL
452 #define FCRn_OF_SHIFT 0L
453 #define FCRn_SZ_MASK 0x00007F00L
454 #define FCRn_SZ_SHIFT 8L
455 #define FCRn_LS_MASK 0x001F0000L
456 #define FCRn_LS_SHIFT 16L
457 #define FCRn_RS_MASK 0x1F000000L
458 #define FCRn_RS_SHIFT 24L
459 #define FCRn_FEN 0x80000000L
460 #define FCRn_PSH 0x20000000L
461 #define FCRn_DACZ 0x40000000L
463 //****************************************************************************
465 // The following defines are for the flags in the serial port Power Management
466 // control register.(SPMC)
468 //****************************************************************************
469 #define SPMC_RSTN 0x00000001L
470 #define SPMC_ASYN 0x00000002L
471 #define SPMC_WUP1 0x00000004L
472 #define SPMC_WUP2 0x00000008L
473 #define SPMC_ASDI2E 0x00000100L
474 #define SPMC_ESSPD 0x00000200L
475 #define SPMC_GISPEN 0x00004000L
476 #define SPMC_GIPPEN 0x00008000L
478 //****************************************************************************
480 // The following defines are for the flags in the Configuration Load register.
481 // (CFLR)
483 //****************************************************************************
484 #define CFLR_CLOCK_SOURCE_MASK 0x00000003L
485 #define CFLR_CLOCK_SOURCE_AC97 0x00000001L
487 #define CFLR_CB0_MASK 0x000000FFL
488 #define CFLR_CB1_MASK 0x0000FF00L
489 #define CFLR_CB2_MASK 0x00FF0000L
490 #define CFLR_CB3_MASK 0xFF000000L
491 #define CFLR_CB0_SHIFT 0L
492 #define CFLR_CB1_SHIFT 8L
493 #define CFLR_CB2_SHIFT 16L
494 #define CFLR_CB3_SHIFT 24L
496 #define IOTCR_DMA0 0x00000000L
497 #define IOTCR_DMA1 0x00000400L
498 #define IOTCR_DMA2 0x00000800L
499 #define IOTCR_DMA3 0x00000C00L
500 #define IOTCR_CCLS 0x00000100L
501 #define IOTCR_PCPCI 0x00000200L
502 #define IOTCR_DDMA 0x00000300L
504 #define SBWBS_WBB 0x00000080L
506 //****************************************************************************
508 // The following defines are for the flags in the SRC Slot Assignment Register
509 // (SRCSA)
511 //****************************************************************************
512 #define SRCSA_PLSS_MASK 0x0000001FL
513 #define SRCSA_PLSS_SHIFT 0L
514 #define SRCSA_PRSS_MASK 0x00001F00L
515 #define SRCSA_PRSS_SHIFT 8L
516 #define SRCSA_CLSS_MASK 0x001F0000L
517 #define SRCSA_CLSS_SHIFT 16L
518 #define SRCSA_CRSS_MASK 0x1F000000L
519 #define SRCSA_CRSS_SHIFT 24L
521 //****************************************************************************
523 // The following defines are for the flags in the Sound System Power Management
524 // register.(SSPM)
526 //****************************************************************************
527 #define SSPM_FPDN 0x00000080L
528 #define SSPM_MIXEN 0x00000040L
529 #define SSPM_CSRCEN 0x00000020L
530 #define SSPM_PSRCEN 0x00000010L
531 #define SSPM_JSEN 0x00000008L
532 #define SSPM_ACLEN 0x00000004L
533 #define SSPM_FMEN 0x00000002L
535 //****************************************************************************
537 // The following defines are for the flags in the Sound System Control
538 // Register. (SSCR)
540 //****************************************************************************
541 #define SSCR_SB 0x00000004L
542 #define SSCR_HVC 0x00000008L
543 #define SSCR_LPFIFO 0x00000040L
544 #define SSCR_LPSRC 0x00000080L
545 #define SSCR_XLPSRC 0x00000100L
546 #define SSCR_MVMD 0x00010000L
547 #define SSCR_MVAD 0x00020000L
548 #define SSCR_MVLD 0x00040000L
549 #define SSCR_MVCS 0x00080000L
551 //****************************************************************************
553 // The following defines are for the flags in the Clock Control Register 1.
554 // (CLKCR1)
556 //****************************************************************************
557 #define CLKCR1_DLLSS_MASK 0x0000000CL
558 #define CLKCR1_DLLSS_SHIFT 2L
559 #define CLKCR1_DLLP 0x00000010L
560 #define CLKCR1_SWCE 0x00000020L
561 #define CLKCR1_DLLOS 0x00000040L
562 #define CLKCR1_CKRA 0x00010000L
563 #define CLKCR1_CKRN 0x00020000L
564 #define CLKCR1_DLLRDY 0x01000000L
565 #define CLKCR1_CLKON 0x02000000L
567 //****************************************************************************
569 // The following defines are for the flags in the Sound Blaster Read Buffer
570 // Status.(SBRBS)
572 //****************************************************************************
573 #define SBRBS_RD_MASK 0x0000007FL
574 #define SBRBS_RD_SHIFT 0L
575 #define SBRBS_RBF 0x00000080L
577 //****************************************************************************
579 // The following defines are for the flags in the serial port master control
580 // register.(SERMC)
582 //****************************************************************************
583 #define SERMC_MSPE 0x00000001L
584 #define SERMC_PTC_MASK 0x0000000EL
585 #define SERMC_PTC_SHIFT 1L
586 #define SERMC_PTC_AC97 0x00000002L
587 #define SERMC_PLB 0x00000010L
588 #define SERMC_PXLB 0x00000020L
589 #define SERMC_LOFV 0x00080000L
590 #define SERMC_SLB 0x00100000L
591 #define SERMC_SXLB 0x00200000L
592 #define SERMC_ODSEN1 0x01000000L
593 #define SERMC_ODSEN2 0x02000000L
595 //****************************************************************************
597 // The following defines are for the flags in the General Purpose I/O Register.
598 // (GPIOR)
600 //****************************************************************************
601 #define GPIOR_VDNS 0x00000001L
602 #define GPIOR_VUPS 0x00000002L
603 #define GPIOR_GP1S 0x00000004L
604 #define GPIOR_GP3S 0x00000008L
605 #define GPIOR_GPSS 0x00000010L
606 #define GPIOR_GPPS 0x00000020L
607 #define GPIOR_GP1D 0x00000400L
608 #define GPIOR_GP3D 0x00000800L
609 #define GPIOR_VDNLT 0x00010000L
610 #define GPIOR_VDNPO 0x00020000L
611 #define GPIOR_VDNST 0x00040000L
612 #define GPIOR_VDNW 0x00080000L
613 #define GPIOR_VUPLT 0x00100000L
614 #define GPIOR_VUPPO 0x00200000L
615 #define GPIOR_VUPST 0x00400000L
616 #define GPIOR_VUPW 0x00800000L
617 #define GPIOR_GP1OE 0x01000000L
618 #define GPIOR_GP1PT 0x02000000L
619 #define GPIOR_GP1ST 0x04000000L
620 #define GPIOR_GP1W 0x08000000L
621 #define GPIOR_GP3OE 0x10000000L
622 #define GPIOR_GP3PT 0x20000000L
623 #define GPIOR_GP3ST 0x40000000L
624 #define GPIOR_GP3W 0x80000000L
626 //****************************************************************************
628 // The following defines are for the flags in the clock control register 1.
630 //****************************************************************************
631 #define CLKCR1_PLLSS_MASK 0x0000000CL
632 #define CLKCR1_PLLSS_SERIAL 0x00000000L
633 #define CLKCR1_PLLSS_CRYSTAL 0x00000004L
634 #define CLKCR1_PLLSS_PCI 0x00000008L
635 #define CLKCR1_PLLSS_RESERVED 0x0000000CL
636 #define CLKCR1_PLLP 0x00000010L
637 #define CLKCR1_SWCE 0x00000020L
638 #define CLKCR1_PLLOS 0x00000040L
640 //****************************************************************************
642 // The following defines are for the flags in the feature reporting register.
644 //****************************************************************************
645 #define FRR_FAB_MASK 0x00000003L
646 #define FRR_MASK_MASK 0x0000001CL
647 #define FRR_ID_MASK 0x00003000L
648 #define FRR_FAB_SHIFT 0L
649 #define FRR_MASK_SHIFT 2L
650 #define FRR_ID_SHIFT 12L
652 //****************************************************************************
654 // The following defines are for the flags in the serial port 1 configuration
655 // register.
657 //****************************************************************************
658 #define SERC1_VALUE 0x00000003L
659 #define SERC1_SO1EN 0x00000001L
660 #define SERC1_SO1F_MASK 0x0000000EL
661 #define SERC1_SO1F_CS423X 0x00000000L
662 #define SERC1_SO1F_AC97 0x00000002L
663 #define SERC1_SO1F_DAC 0x00000004L
664 #define SERC1_SO1F_SPDIF 0x00000006L
666 //****************************************************************************
668 // The following defines are for the flags in the serial port 2 configuration
669 // register.
671 //****************************************************************************
672 #define SERC2_VALUE 0x00000003L
673 #define SERC2_SI1EN 0x00000001L
674 #define SERC2_SI1F_MASK 0x0000000EL
675 #define SERC2_SI1F_CS423X 0x00000000L
676 #define SERC2_SI1F_AC97 0x00000002L
677 #define SERC2_SI1F_ADC 0x00000004L
678 #define SERC2_SI1F_SPDIF 0x00000006L
680 //****************************************************************************
682 // The following defines are for the flags in the AC97 control register.
684 //****************************************************************************
685 #define ACCTL_ESYN 0x00000002L
686 #define ACCTL_VFRM 0x00000004L
687 #define ACCTL_DCV 0x00000008L
688 #define ACCTL_CRW 0x00000010L
689 #define ACCTL_TC 0x00000040L
691 //****************************************************************************
693 // The following defines are for the flags in the AC97 status register.
695 //****************************************************************************
696 #define ACSTS_CRDY 0x00000001L
697 #define ACSTS_VSTS 0x00000002L
699 //****************************************************************************
701 // The following defines are for the flags in the AC97 output slot valid
702 // register.
704 //****************************************************************************
705 #define ACOSV_SLV3 0x00000001L
706 #define ACOSV_SLV4 0x00000002L
707 #define ACOSV_SLV5 0x00000004L
708 #define ACOSV_SLV6 0x00000008L
709 #define ACOSV_SLV7 0x00000010L
710 #define ACOSV_SLV8 0x00000020L
711 #define ACOSV_SLV9 0x00000040L
712 #define ACOSV_SLV10 0x00000080L
713 #define ACOSV_SLV11 0x00000100L
714 #define ACOSV_SLV12 0x00000200L
716 //****************************************************************************
718 // The following defines are for the flags in the AC97 command address
719 // register.
721 //****************************************************************************
722 #define ACCAD_CI_MASK 0x0000007FL
723 #define ACCAD_CI_SHIFT 0L
725 //****************************************************************************
727 // The following defines are for the flags in the AC97 command data register.
729 //****************************************************************************
730 #define ACCDA_CD_MASK 0x0000FFFFL
731 #define ACCDA_CD_SHIFT 0L
733 //****************************************************************************
735 // The following defines are for the flags in the AC97 input slot valid
736 // register.
738 //****************************************************************************
739 #define ACISV_ISV3 0x00000001L
740 #define ACISV_ISV4 0x00000002L
741 #define ACISV_ISV5 0x00000004L
742 #define ACISV_ISV6 0x00000008L
743 #define ACISV_ISV7 0x00000010L
744 #define ACISV_ISV8 0x00000020L
745 #define ACISV_ISV9 0x00000040L
746 #define ACISV_ISV10 0x00000080L
747 #define ACISV_ISV11 0x00000100L
748 #define ACISV_ISV12 0x00000200L
750 //****************************************************************************
752 // The following defines are for the flags in the AC97 status address
753 // register.
755 //****************************************************************************
756 #define ACSAD_SI_MASK 0x0000007FL
757 #define ACSAD_SI_SHIFT 0L
759 //****************************************************************************
761 // The following defines are for the flags in the AC97 status data register.
763 //****************************************************************************
764 #define ACSDA_SD_MASK 0x0000FFFFL
765 #define ACSDA_SD_SHIFT 0L
767 //****************************************************************************
769 // The following defines are for the flags in the I/O trap address and control
770 // registers (all 12).
772 //****************************************************************************
773 #define IOTAC_SA_MASK 0x0000FFFFL
774 #define IOTAC_MSK_MASK 0x000F0000L
775 #define IOTAC_IODC_MASK 0x06000000L
776 #define IOTAC_IODC_16_BIT 0x00000000L
777 #define IOTAC_IODC_10_BIT 0x02000000L
778 #define IOTAC_IODC_12_BIT 0x04000000L
779 #define IOTAC_WSPI 0x08000000L
780 #define IOTAC_RSPI 0x10000000L
781 #define IOTAC_WSE 0x20000000L
782 #define IOTAC_WE 0x40000000L
783 #define IOTAC_RE 0x80000000L
784 #define IOTAC_SA_SHIFT 0L
785 #define IOTAC_MSK_SHIFT 16L
787 //****************************************************************************
789 // The following defines are for the flags in the PC/PCI master enable
790 // register.
792 //****************************************************************************
793 #define PCPCIEN_EN 0x00000001L
795 //****************************************************************************
797 // The following defines are for the flags in the joystick poll/trigger
798 // register.
800 //****************************************************************************
801 #define JSPT_CAX 0x00000001L
802 #define JSPT_CAY 0x00000002L
803 #define JSPT_CBX 0x00000004L
804 #define JSPT_CBY 0x00000008L
805 #define JSPT_BA1 0x00000010L
806 #define JSPT_BA2 0x00000020L
807 #define JSPT_BB1 0x00000040L
808 #define JSPT_BB2 0x00000080L
810 //****************************************************************************
812 // The following defines are for the flags in the joystick control register.
813 // The TBF bit has been moved from MIDSR register to JSCTL register bit 8.
815 //****************************************************************************
816 #define JSCTL_SP_MASK 0x00000003L
817 #define JSCTL_SP_SLOW 0x00000000L
818 #define JSCTL_SP_MEDIUM_SLOW 0x00000001L
819 #define JSCTL_SP_MEDIUM_FAST 0x00000002L
820 #define JSCTL_SP_FAST 0x00000003L
821 #define JSCTL_ARE 0x00000004L
822 #define JSCTL_TBF 0x00000100L
825 //****************************************************************************
827 // The following defines are for the flags in the MIDI control register.
829 //****************************************************************************
830 #define MIDCR_TXE 0x00000001L
831 #define MIDCR_RXE 0x00000002L
832 #define MIDCR_RIE 0x00000004L
833 #define MIDCR_TIE 0x00000008L
834 #define MIDCR_MLB 0x00000010L
835 #define MIDCR_MRST 0x00000020L
837 //****************************************************************************
839 // The following defines are for the flags in the MIDI status register.
841 //****************************************************************************
842 #define MIDSR_RBE 0x00000080L
843 #define MIDSR_RDA 0x00008000L
845 //****************************************************************************
847 // The following defines are for the flags in the MIDI write port register.
849 //****************************************************************************
850 #define MIDWP_MWD_MASK 0x000000FFL
851 #define MIDWP_MWD_SHIFT 0L
853 //****************************************************************************
855 // The following defines are for the flags in the MIDI read port register.
857 //****************************************************************************
858 #define MIDRP_MRD_MASK 0x000000FFL
859 #define MIDRP_MRD_SHIFT 0L
861 //****************************************************************************
863 // The following defines are for the flags in the configuration interface
864 // register.
866 //****************************************************************************
867 #define CFGI_CLK 0x00000001L
868 #define CFGI_DOUT 0x00000002L
869 #define CFGI_DIN_EEN 0x00000004L
870 #define CFGI_EELD 0x00000008L
872 //****************************************************************************
874 // The following defines are for the flags in the subsystem ID and vendor ID
875 // register.
877 //****************************************************************************
878 #define SSVID_VID_MASK 0x0000FFFFL
879 #define SSVID_SID_MASK 0xFFFF0000L
880 #define SSVID_VID_SHIFT 0L
881 #define SSVID_SID_SHIFT 16L
883 //****************************************************************************
885 // The following defines are for the flags in the GPIO pin interface register.
887 //****************************************************************************
888 #define GPIOR_VOLDN 0x00000001L
889 #define GPIOR_VOLUP 0x00000002L
890 #define GPIOR_SI2D 0x00000004L
891 #define GPIOR_SI2OE 0x00000008L
893 //****************************************************************************
895 // The following defines are for the flags in the AC97 status register 2.
897 //****************************************************************************
898 #define ACSTS2_CRDY 0x00000001L
899 #define ACSTS2_VSTS 0x00000002L
901 //****************************************************************************
903 // The following defines are for the flags in the AC97 input slot valid
904 // register 2.
906 //****************************************************************************
907 #define ACISV2_ISV3 0x00000001L
908 #define ACISV2_ISV4 0x00000002L
909 #define ACISV2_ISV5 0x00000004L
910 #define ACISV2_ISV6 0x00000008L
911 #define ACISV2_ISV7 0x00000010L
912 #define ACISV2_ISV8 0x00000020L
913 #define ACISV2_ISV9 0x00000040L
914 #define ACISV2_ISV10 0x00000080L
915 #define ACISV2_ISV11 0x00000100L
916 #define ACISV2_ISV12 0x00000200L
918 //****************************************************************************
920 // The following defines are for the flags in the AC97 status address
921 // register 2.
923 //****************************************************************************
924 #define ACSAD2_SI_MASK 0x0000007FL
925 #define ACSAD2_SI_SHIFT 0L
927 //****************************************************************************
929 // The following defines are for the flags in the AC97 status data register 2.
931 //****************************************************************************
932 #define ACSDA2_SD_MASK 0x0000FFFFL
933 #define ACSDA2_SD_SHIFT 0L
935 //****************************************************************************
937 // The following defines are for the flags in the I/O trap control register.
939 //****************************************************************************
940 #define IOTCR_ITD 0x00000001L
941 #define IOTCR_HRV 0x00000002L
942 #define IOTCR_SRV 0x00000004L
943 #define IOTCR_DTI 0x00000008L
944 #define IOTCR_DFI 0x00000010L
945 #define IOTCR_DDP 0x00000020L
946 #define IOTCR_JTE 0x00000040L
947 #define IOTCR_PPE 0x00000080L
949 //****************************************************************************
951 // The following defines are for the flags in the I/O trap address and control
952 // registers for Hardware Master Volume.
954 //****************************************************************************
955 #define IOTGP_SA_MASK 0x0000FFFFL
956 #define IOTGP_MSK_MASK 0x000F0000L
957 #define IOTGP_IODC_MASK 0x06000000L
958 #define IOTGP_IODC_16_BIT 0x00000000L
959 #define IOTGP_IODC_10_BIT 0x02000000L
960 #define IOTGP_IODC_12_BIT 0x04000000L
961 #define IOTGP_WSPI 0x08000000L
962 #define IOTGP_RSPI 0x10000000L
963 #define IOTGP_WSE 0x20000000L
964 #define IOTGP_WE 0x40000000L
965 #define IOTGP_RE 0x80000000L
966 #define IOTGP_SA_SHIFT 0L
967 #define IOTGP_MSK_SHIFT 16L
969 //****************************************************************************
971 // The following defines are for the flags in the I/O trap address and control
972 // registers for Sound Blaster
974 //****************************************************************************
975 #define IOTSB_SA_MASK 0x0000FFFFL
976 #define IOTSB_MSK_MASK 0x000F0000L
977 #define IOTSB_IODC_MASK 0x06000000L
978 #define IOTSB_IODC_16_BIT 0x00000000L
979 #define IOTSB_IODC_10_BIT 0x02000000L
980 #define IOTSB_IODC_12_BIT 0x04000000L
981 #define IOTSB_WSPI 0x08000000L
982 #define IOTSB_RSPI 0x10000000L
983 #define IOTSB_WSE 0x20000000L
984 #define IOTSB_WE 0x40000000L
985 #define IOTSB_RE 0x80000000L
986 #define IOTSB_SA_SHIFT 0L
987 #define IOTSB_MSK_SHIFT 16L
989 //****************************************************************************
991 // The following defines are for the flags in the I/O trap address and control
992 // registers for FM.
994 //****************************************************************************
995 #define IOTFM_SA_MASK 0x0000FFFFL
996 #define IOTFM_MSK_MASK 0x000F0000L
997 #define IOTFM_IODC_MASK 0x06000000L
998 #define IOTFM_IODC_16_BIT 0x00000000L
999 #define IOTFM_IODC_10_BIT 0x02000000L
1000 #define IOTFM_IODC_12_BIT 0x04000000L
1001 #define IOTFM_WSPI 0x08000000L
1002 #define IOTFM_RSPI 0x10000000L
1003 #define IOTFM_WSE 0x20000000L
1004 #define IOTFM_WE 0x40000000L
1005 #define IOTFM_RE 0x80000000L
1006 #define IOTFM_SA_SHIFT 0L
1007 #define IOTFM_MSK_SHIFT 16L
1009 //****************************************************************************
1011 // The following defines are for the flags in the PC/PCI request register.
1013 //****************************************************************************
1014 #define PCPRR_RDC_MASK 0x00000007L
1015 #define PCPRR_REQ 0x00008000L
1016 #define PCPRR_RDC_SHIFT 0L
1018 //****************************************************************************
1020 // The following defines are for the flags in the PC/PCI grant register.
1022 //****************************************************************************
1023 #define PCPGR_GDC_MASK 0x00000007L
1024 #define PCPGR_VL 0x00008000L
1025 #define PCPGR_GDC_SHIFT 0L
1027 //****************************************************************************
1029 // The following defines are for the flags in the PC/PCI Control Register.
1031 //****************************************************************************
1032 #define PCPCR_EN 0x00000001L
1034 //****************************************************************************
1036 // The following defines are for the flags in the debug index register.
1038 //****************************************************************************
1039 #define DREG_REGID_MASK 0x0000007FL
1040 #define DREG_DEBUG 0x00000080L
1041 #define DREG_RGBK_MASK 0x00000700L
1042 #define DREG_TRAP 0x00000800L
1043 #if !defined(NO_CS4612)
1044 #if !defined(NO_CS4615)
1045 #define DREG_TRAPX 0x00001000L
1046 #endif
1047 #endif
1048 #define DREG_REGID_SHIFT 0L
1049 #define DREG_RGBK_SHIFT 8L
1050 #define DREG_RGBK_REGID_MASK 0x0000077FL
1051 #define DREG_REGID_R0 0x00000010L
1052 #define DREG_REGID_R1 0x00000011L
1053 #define DREG_REGID_R2 0x00000012L
1054 #define DREG_REGID_R3 0x00000013L
1055 #define DREG_REGID_R4 0x00000014L
1056 #define DREG_REGID_R5 0x00000015L
1057 #define DREG_REGID_R6 0x00000016L
1058 #define DREG_REGID_R7 0x00000017L
1059 #define DREG_REGID_R8 0x00000018L
1060 #define DREG_REGID_R9 0x00000019L
1061 #define DREG_REGID_RA 0x0000001AL
1062 #define DREG_REGID_RB 0x0000001BL
1063 #define DREG_REGID_RC 0x0000001CL
1064 #define DREG_REGID_RD 0x0000001DL
1065 #define DREG_REGID_RE 0x0000001EL
1066 #define DREG_REGID_RF 0x0000001FL
1067 #define DREG_REGID_RA_BUS_LOW 0x00000020L
1068 #define DREG_REGID_RA_BUS_HIGH 0x00000038L
1069 #define DREG_REGID_YBUS_LOW 0x00000050L
1070 #define DREG_REGID_YBUS_HIGH 0x00000058L
1071 #define DREG_REGID_TRAP_0 0x00000100L
1072 #define DREG_REGID_TRAP_1 0x00000101L
1073 #define DREG_REGID_TRAP_2 0x00000102L
1074 #define DREG_REGID_TRAP_3 0x00000103L
1075 #define DREG_REGID_TRAP_4 0x00000104L
1076 #define DREG_REGID_TRAP_5 0x00000105L
1077 #define DREG_REGID_TRAP_6 0x00000106L
1078 #define DREG_REGID_TRAP_7 0x00000107L
1079 #define DREG_REGID_INDIRECT_ADDRESS 0x0000010EL
1080 #define DREG_REGID_TOP_OF_STACK 0x0000010FL
1081 #if !defined(NO_CS4612)
1082 #if !defined(NO_CS4615)
1083 #define DREG_REGID_TRAP_8 0x00000110L
1084 #define DREG_REGID_TRAP_9 0x00000111L
1085 #define DREG_REGID_TRAP_10 0x00000112L
1086 #define DREG_REGID_TRAP_11 0x00000113L
1087 #define DREG_REGID_TRAP_12 0x00000114L
1088 #define DREG_REGID_TRAP_13 0x00000115L
1089 #define DREG_REGID_TRAP_14 0x00000116L
1090 #define DREG_REGID_TRAP_15 0x00000117L
1091 #define DREG_REGID_TRAP_16 0x00000118L
1092 #define DREG_REGID_TRAP_17 0x00000119L
1093 #define DREG_REGID_TRAP_18 0x0000011AL
1094 #define DREG_REGID_TRAP_19 0x0000011BL
1095 #define DREG_REGID_TRAP_20 0x0000011CL
1096 #define DREG_REGID_TRAP_21 0x0000011DL
1097 #define DREG_REGID_TRAP_22 0x0000011EL
1098 #define DREG_REGID_TRAP_23 0x0000011FL
1099 #endif
1100 #endif
1101 #define DREG_REGID_RSA0_LOW 0x00000200L
1102 #define DREG_REGID_RSA0_HIGH 0x00000201L
1103 #define DREG_REGID_RSA1_LOW 0x00000202L
1104 #define DREG_REGID_RSA1_HIGH 0x00000203L
1105 #define DREG_REGID_RSA2 0x00000204L
1106 #define DREG_REGID_RSA3 0x00000205L
1107 #define DREG_REGID_RSI0_LOW 0x00000206L
1108 #define DREG_REGID_RSI0_HIGH 0x00000207L
1109 #define DREG_REGID_RSI1 0x00000208L
1110 #define DREG_REGID_RSI2 0x00000209L
1111 #define DREG_REGID_SAGUSTATUS 0x0000020AL
1112 #define DREG_REGID_RSCONFIG01_LOW 0x0000020BL
1113 #define DREG_REGID_RSCONFIG01_HIGH 0x0000020CL
1114 #define DREG_REGID_RSCONFIG23_LOW 0x0000020DL
1115 #define DREG_REGID_RSCONFIG23_HIGH 0x0000020EL
1116 #define DREG_REGID_RSDMA01E 0x0000020FL
1117 #define DREG_REGID_RSDMA23E 0x00000210L
1118 #define DREG_REGID_RSD0_LOW 0x00000211L
1119 #define DREG_REGID_RSD0_HIGH 0x00000212L
1120 #define DREG_REGID_RSD1_LOW 0x00000213L
1121 #define DREG_REGID_RSD1_HIGH 0x00000214L
1122 #define DREG_REGID_RSD2_LOW 0x00000215L
1123 #define DREG_REGID_RSD2_HIGH 0x00000216L
1124 #define DREG_REGID_RSD3_LOW 0x00000217L
1125 #define DREG_REGID_RSD3_HIGH 0x00000218L
1126 #define DREG_REGID_SRAR_HIGH 0x0000021AL
1127 #define DREG_REGID_SRAR_LOW 0x0000021BL
1128 #define DREG_REGID_DMA_STATE 0x0000021CL
1129 #define DREG_REGID_CURRENT_DMA_STREAM 0x0000021DL
1130 #define DREG_REGID_NEXT_DMA_STREAM 0x0000021EL
1131 #define DREG_REGID_CPU_STATUS 0x00000300L
1132 #define DREG_REGID_MAC_MODE 0x00000301L
1133 #define DREG_REGID_STACK_AND_REPEAT 0x00000302L
1134 #define DREG_REGID_INDEX0 0x00000304L
1135 #define DREG_REGID_INDEX1 0x00000305L
1136 #define DREG_REGID_DMA_STATE_0_3 0x00000400L
1137 #define DREG_REGID_DMA_STATE_4_7 0x00000404L
1138 #define DREG_REGID_DMA_STATE_8_11 0x00000408L
1139 #define DREG_REGID_DMA_STATE_12_15 0x0000040CL
1140 #define DREG_REGID_DMA_STATE_16_19 0x00000410L
1141 #define DREG_REGID_DMA_STATE_20_23 0x00000414L
1142 #define DREG_REGID_DMA_STATE_24_27 0x00000418L
1143 #define DREG_REGID_DMA_STATE_28_31 0x0000041CL
1144 #define DREG_REGID_DMA_STATE_32_35 0x00000420L
1145 #define DREG_REGID_DMA_STATE_36_39 0x00000424L
1146 #define DREG_REGID_DMA_STATE_40_43 0x00000428L
1147 #define DREG_REGID_DMA_STATE_44_47 0x0000042CL
1148 #define DREG_REGID_DMA_STATE_48_51 0x00000430L
1149 #define DREG_REGID_DMA_STATE_52_55 0x00000434L
1150 #define DREG_REGID_DMA_STATE_56_59 0x00000438L
1151 #define DREG_REGID_DMA_STATE_60_63 0x0000043CL
1152 #define DREG_REGID_DMA_STATE_64_67 0x00000440L
1153 #define DREG_REGID_DMA_STATE_68_71 0x00000444L
1154 #define DREG_REGID_DMA_STATE_72_75 0x00000448L
1155 #define DREG_REGID_DMA_STATE_76_79 0x0000044CL
1156 #define DREG_REGID_DMA_STATE_80_83 0x00000450L
1157 #define DREG_REGID_DMA_STATE_84_87 0x00000454L
1158 #define DREG_REGID_DMA_STATE_88_91 0x00000458L
1159 #define DREG_REGID_DMA_STATE_92_95 0x0000045CL
1160 #define DREG_REGID_TRAP_SELECT 0x00000500L
1161 #define DREG_REGID_TRAP_WRITE_0 0x00000500L
1162 #define DREG_REGID_TRAP_WRITE_1 0x00000501L
1163 #define DREG_REGID_TRAP_WRITE_2 0x00000502L
1164 #define DREG_REGID_TRAP_WRITE_3 0x00000503L
1165 #define DREG_REGID_TRAP_WRITE_4 0x00000504L
1166 #define DREG_REGID_TRAP_WRITE_5 0x00000505L
1167 #define DREG_REGID_TRAP_WRITE_6 0x00000506L
1168 #define DREG_REGID_TRAP_WRITE_7 0x00000507L
1169 #if !defined(NO_CS4612)
1170 #if !defined(NO_CS4615)
1171 #define DREG_REGID_TRAP_WRITE_8 0x00000510L
1172 #define DREG_REGID_TRAP_WRITE_9 0x00000511L
1173 #define DREG_REGID_TRAP_WRITE_10 0x00000512L
1174 #define DREG_REGID_TRAP_WRITE_11 0x00000513L
1175 #define DREG_REGID_TRAP_WRITE_12 0x00000514L
1176 #define DREG_REGID_TRAP_WRITE_13 0x00000515L
1177 #define DREG_REGID_TRAP_WRITE_14 0x00000516L
1178 #define DREG_REGID_TRAP_WRITE_15 0x00000517L
1179 #define DREG_REGID_TRAP_WRITE_16 0x00000518L
1180 #define DREG_REGID_TRAP_WRITE_17 0x00000519L
1181 #define DREG_REGID_TRAP_WRITE_18 0x0000051AL
1182 #define DREG_REGID_TRAP_WRITE_19 0x0000051BL
1183 #define DREG_REGID_TRAP_WRITE_20 0x0000051CL
1184 #define DREG_REGID_TRAP_WRITE_21 0x0000051DL
1185 #define DREG_REGID_TRAP_WRITE_22 0x0000051EL
1186 #define DREG_REGID_TRAP_WRITE_23 0x0000051FL
1187 #endif
1188 #endif
1189 #define DREG_REGID_MAC0_ACC0_LOW 0x00000600L
1190 #define DREG_REGID_MAC0_ACC1_LOW 0x00000601L
1191 #define DREG_REGID_MAC0_ACC2_LOW 0x00000602L
1192 #define DREG_REGID_MAC0_ACC3_LOW 0x00000603L
1193 #define DREG_REGID_MAC1_ACC0_LOW 0x00000604L
1194 #define DREG_REGID_MAC1_ACC1_LOW 0x00000605L
1195 #define DREG_REGID_MAC1_ACC2_LOW 0x00000606L
1196 #define DREG_REGID_MAC1_ACC3_LOW 0x00000607L
1197 #define DREG_REGID_MAC0_ACC0_MID 0x00000608L
1198 #define DREG_REGID_MAC0_ACC1_MID 0x00000609L
1199 #define DREG_REGID_MAC0_ACC2_MID 0x0000060AL
1200 #define DREG_REGID_MAC0_ACC3_MID 0x0000060BL
1201 #define DREG_REGID_MAC1_ACC0_MID 0x0000060CL
1202 #define DREG_REGID_MAC1_ACC1_MID 0x0000060DL
1203 #define DREG_REGID_MAC1_ACC2_MID 0x0000060EL
1204 #define DREG_REGID_MAC1_ACC3_MID 0x0000060FL
1205 #define DREG_REGID_MAC0_ACC0_HIGH 0x00000610L
1206 #define DREG_REGID_MAC0_ACC1_HIGH 0x00000611L
1207 #define DREG_REGID_MAC0_ACC2_HIGH 0x00000612L
1208 #define DREG_REGID_MAC0_ACC3_HIGH 0x00000613L
1209 #define DREG_REGID_MAC1_ACC0_HIGH 0x00000614L
1210 #define DREG_REGID_MAC1_ACC1_HIGH 0x00000615L
1211 #define DREG_REGID_MAC1_ACC2_HIGH 0x00000616L
1212 #define DREG_REGID_MAC1_ACC3_HIGH 0x00000617L
1213 #define DREG_REGID_RSHOUT_LOW 0x00000620L
1214 #define DREG_REGID_RSHOUT_MID 0x00000628L
1215 #define DREG_REGID_RSHOUT_HIGH 0x00000630L
1217 //****************************************************************************
1219 // The following defines are for the flags in the AC97 S/PDIF Control register.
1221 //****************************************************************************
1222 #define SPDIF_CONTROL_SPDIF_EN 0x00008000L
1223 #define SPDIF_CONTROL_VAL 0x00004000L
1224 #define SPDIF_CONTROL_COPY 0x00000004L
1225 #define SPDIF_CONTROL_CC0 0x00000010L
1226 #define SPDIF_CONTROL_CC1 0x00000020L
1227 #define SPDIF_CONTROL_CC2 0x00000040L
1228 #define SPDIF_CONTROL_CC3 0x00000080L
1229 #define SPDIF_CONTROL_CC4 0x00000100L
1230 #define SPDIF_CONTROL_CC5 0x00000200L
1231 #define SPDIF_CONTROL_CC6 0x00000400L
1232 #define SPDIF_CONTROL_L 0x00000800L
1234 #endif // _H_HWDEFS