xref: /haiku/src/add-ons/kernel/drivers/audio/ac97/es1370/es1370reg.h (revision 68ea01249e1e2088933cb12f9c28d4e5c5d1c9ef)
1 /*-
2  * This supports the ENSONIQ AudioPCI board based on the ES1370.
3  *
4  * Copyright (c) 1998 Joachim Kuebart <joki@kuebart.stuttgart.netsurf.de>
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 immediately at the beginning of the file, without modification,
12  *    this list of conditions, and the following disclaimer.
13  * 2. Redistributions in binary form must reproduce the above copyright
14  *    notice, this list of conditions and the following disclaimer in the
15  *    documentation and/or other materials provided with the distribution.
16  * 3. Absolutely no warranty of function or purpose is made by the author
17  *    Joachim Kuebart.
18  * 4. Modifications may be freely made to this file if the above conditions
19  *    are met.
20  *
21  * $FreeBSD: /repoman/r/ncvs/src/sys/dev/sound/pci/es137x.h,v 1.6 2005/07/31 13:19:38 netchild Exp $
22  */
23 
24 #ifndef _ES1370_REG_H
25 #define _ES1370_REG_H
26 
27 #define ES1370_REG_CONTROL		0x00
28 #define ES1370_REG_STATUS		0x04
29 #define ES1370_REG_UART_DATA		0x08
30 #define ES1370_REG_UART_STATUS		0x09
31 #define ES1370_REG_UART_CONTROL		0x09
32 #define ES1370_REG_UART_TEST		0x0a
33 #define ES1370_REG_MEMPAGE		0x0c
34 #define ES1370_REG_CODEC		0x10
35 #define CODEC_INDEX_SHIFT		8
36 #define ES1370_REG_SERIAL_CONTROL	0x20
37 #define ES1370_REG_DAC1_SCOUNT		0x24
38 #define ES1370_REG_DAC2_SCOUNT		0x28
39 #define ES1370_REG_ADC_SCOUNT		0x2c
40 
41 #define ES1370_REG_DAC1_FRAMEADR	0xc30
42 #define ES1370_REG_DAC1_FRAMECNT	0xc34
43 #define ES1370_REG_DAC2_FRAMEADR	0xc38
44 #define ES1370_REG_DAC2_FRAMECNT	0xc3c
45 #define ES1370_REG_ADC_FRAMEADR		0xd30
46 #define ES1370_REG_ADC_FRAMECNT		0xd34
47 
48 #define DAC2_SRTODIV(x)	(((1411200 + (x) / 2) / (x) - 2) & 0x1fff)
49 #define DAC2_DIVTOSR(x)	(1411200 / ((x) + 2))
50 
51 #define CTRL_ADC_STOP   0x80000000	/* 1 = ADC stopped */
52 #define CTRL_XCTL1      0x40000000	/* SERR pin if enabled */
53 #define CTRL_OPEN       0x20000000	/* no function, can be read and
54 					 * written */
55 #define CTRL_PCLKDIV    0x1fff0000	/* ADC/DAC2 clock divider */
56 #define CTRL_SH_PCLKDIV 16
57 #define CTRL_MSFMTSEL   0x00008000	/* MPEG serial data fmt: 0 = Sony, 1
58 					 * = I2S */
59 #define CTRL_M_SBB      0x00004000	/* DAC2 clock: 0 = PCLKDIV, 1 = MPEG */
60 #define CTRL_WTSRSEL    0x00003000	/* DAC1 clock freq: 0=5512, 1=11025,
61 					 * 2=22050, 3=44100 */
62 #define CTRL_SH_WTSRSEL 12
63 #define CTRL_DAC_SYNC   0x00000800	/* 1 = DAC2 runs off DAC1 clock */
64 #define CTRL_CCB_INTRM  0x00000400	/* 1 = CCB "voice" ints enabled */
65 #define CTRL_M_CB       0x00000200	/* recording source: 0 = ADC, 1 =
66 					 * MPEG */
67 #define CTRL_XCTL0      0x00000100	/* 0 = Line in, 1 = Line out */
68 #define CTRL_BREQ       0x00000080	/* 1 = test mode (internal mem test) */
69 #define CTRL_DAC1_EN    0x00000040	/* enable DAC1 */
70 #define CTRL_DAC2_EN    0x00000020	/* enable DAC2 */
71 #define CTRL_ADC_EN     0x00000010	/* enable ADC */
72 #define CTRL_UART_EN    0x00000008	/* enable MIDI uart */
73 #define CTRL_JYSTK_EN   0x00000004	/* enable Joystick port (presumably
74 					 * at address 0x200) */
75 #define CTRL_CDC_EN     0x00000002	/* enable serial (CODEC) interface */
76 #define CTRL_SERR_DIS   0x00000001	/* 1 = disable PCI SERR signal */
77 
78 #define SCTRL_P2ENDINC    0x00380000	/* */
79 #define SCTRL_SH_P2ENDINC 19
80 #define SCTRL_P2STINC     0x00070000	/* */
81 #define SCTRL_SH_P2STINC  16
82 #define SCTRL_R1LOOPSEL   0x00008000	/* 0 = loop mode */
83 #define SCTRL_P2LOOPSEL   0x00004000	/* 0 = loop mode */
84 #define SCTRL_P1LOOPSEL   0x00002000	/* 0 = loop mode */
85 #define SCTRL_P2PAUSE     0x00001000	/* 1 = pause mode */
86 #define SCTRL_P1PAUSE     0x00000800	/* 1 = pause mode */
87 #define SCTRL_R1INTEN     0x00000400	/* enable interrupt */
88 #define SCTRL_P2INTEN     0x00000200	/* enable interrupt */
89 #define SCTRL_P1INTEN     0x00000100	/* enable interrupt */
90 #define SCTRL_P1SCTRLD    0x00000080	/* reload sample count register for
91 					 * DAC1 */
92 #define SCTRL_P2DACSEN    0x00000040	/* 1 = DAC2 play back last sample
93 					 * when disabled */
94 #define SCTRL_R1SEB       0x00000020	/* 1 = 16bit */
95 #define SCTRL_R1SMB       0x00000010	/* 1 = stereo */
96 #define SCTRL_R1FMT       0x00000030	/* format mask */
97 #define SCTRL_SH_R1FMT    4
98 #define SCTRL_P2SEB       0x00000008	/* 1 = 16bit */
99 #define SCTRL_P2SMB       0x00000004	/* 1 = stereo */
100 #define SCTRL_P2FMT       0x0000000c	/* format mask */
101 #define SCTRL_SH_P2FMT    2
102 #define SCTRL_P1SEB       0x00000002	/* 1 = 16bit */
103 #define SCTRL_P1SMB       0x00000001	/* 1 = stereo */
104 #define SCTRL_P1FMT       0x00000003	/* format mask */
105 #define SCTRL_SH_P1FMT    0
106 
107 #define STAT_INTR       0x80000000	/* wired or of all interrupt bits */
108 #define STAT_CSTAT      0x00000400	/* 1 = codec busy or codec write in
109 					 * progress */
110 #define STAT_CBUSY      0x00000200	/* 1 = codec busy */
111 #define STAT_CWRIP      0x00000100	/* 1 = codec write in progress */
112 #define STAT_VC         0x00000060	/* CCB int source, 0=DAC1, 1=DAC2,
113 					 * 2=ADC, 3=undef */
114 #define STAT_SH_VC      5
115 #define STAT_MCCB       0x00000010	/* CCB int pending */
116 #define STAT_UART       0x00000008	/* UART int pending */
117 #define STAT_DAC1       0x00000004	/* DAC1 int pending */
118 #define STAT_DAC2       0x00000002	/* DAC2 int pending */
119 #define STAT_ADC        0x00000001	/* ADC int pending */
120 
121 /* AKM AK4531 CODEC Control Register Map */
122 
123 #define CODEC_MASTER_VOL_L	0x00
124 #define CODEC_MASTER_VOL_R	0x01
125 #define CODEC_VOICE_VOL_L	0x02
126 #define CODEC_VOICE_VOL_R	0x03
127 #define CODEC_FM_VOL_L		0x04
128 #define CODEC_FM_VOL_R		0x05
129 #define CODEC_CD_VOL_L		0x06
130 #define CODEC_CD_VOL_R		0x07
131 #define CODEC_LINE_VOL_L	0x08
132 #define CODEC_LINE_VOL_R	0x09
133 #define CODEC_AUX_VOL_L		0x0A
134 #define CODEC_AUX_VOL_R		0x0B
135 #define CODEC_MONO1_VOL		0x0C
136 #define CODEC_MONO2_VOL		0x0D
137 #define CODEC_MIC_VOL		0x0E
138 #define CODEC_MONO_OUT_VOL	0x0F
139 #define CODEC_OUTPUT_MIX1	0x10
140 #define CODEC_OUTPUT_MIX2	0x11
141 #define CODEC_L_INPUT_MIX1	0x12
142 #define CODEC_R_INPUT_MIX1	0x13
143 #define CODEC_L_INPUT_MIX2	0x14
144 #define CODEC_R_INPUT_MIX2	0x15
145 #define CODEC_RESET_PWRDWN	0x16
146 #define CODEC_CLOCK_SEL		0x17
147 #define CODEC_AD_INPUT_SEL	0x18
148 #define CODEC_MIC_AMP_GAIN	0x19
149 
150 /* output mixer mute bit positions */
151 #define ES1370_OUTPUT_MIX1_FML		(1<<6)
152 #define ES1370_OUTPUT_MIX1_FMR		(1<<5)
153 #define ES1370_OUTPUT_MIX1_LINEL	(1<<4)
154 #define ES1370_OUTPUT_MIX1_LINER	(1<<3)
155 #define ES1370_OUTPUT_MIX1_CDL		(1<<2)
156 #define ES1370_OUTPUT_MIX1_CDR		(1<<1)
157 #define ES1370_OUTPUT_MIX1_MIC		(1<<0)
158 #define ES1370_OUTPUT_MIX2_AUXL		(1<<5)
159 #define ES1370_OUTPUT_MIX2_AUXR		(1<<4)
160 #define ES1370_OUTPUT_MIX2_VOICEL	(1<<3)
161 #define ES1370_OUTPUT_MIX2_VOICER	(1<<2)
162 #define ES1370_OUTPUT_MIX2_MONO2	(1<<1)
163 #define ES1370_OUTPUT_MIX2_MONO1	(1<<0)
164 
165 /* ES1371 specific */
166 
167 #define CODEC_ID_SESHIFT	10
168 #define CODEC_ID_SEMASK		0x1f
169 
170 #define CODEC_PIRD		0x00800000  /* 0 = write AC97 register */
171 #define CODEC_PIADD_MASK	0x007f0000
172 #define CODEC_PIADD_SHIFT	16
173 #define CODEC_PIDAT_MASK	0x0000ffff
174 #define CODEC_PIDAT_SHIFT	0
175 
176 #define CODEC_PORD		0x00800000  /* 0 = write AC97 register */
177 #define CODEC_POADD_MASK	0x007f0000
178 #define CODEC_POADD_SHIFT	16
179 #define CODEC_PODAT_MASK	0x0000ffff
180 #define CODEC_PODAT_SHIFT	0
181 
182 #define CODEC_RDY		0x80000000  /* AC97 read data valid */
183 #define CODEC_WIP		0x40000000  /* AC97 write in progress */
184 
185 #define ES1370_REG_CONTROL	0x00
186 #define ES1370_REG_SERIAL_CONTROL	0x20
187 #define ES1371_REG_CODEC	0x14
188 #define ES1371_REG_LEGACY	0x18	     /* W/R: Legacy control/status register */
189 #define ES1371_REG_SMPRATE	0x10	     /* W/R: Codec rate converter interface register */
190 
191 #define ES1371_SYNC_RES		(1<<14)	 /* Warm AC97 reset */
192 #define ES1371_DIS_R1		(1<<19)	 /* record channel accumulator update disable */
193 #define ES1371_DIS_P2		(1<<20)	 /* playback channel 2 accumulator update disable */
194 #define ES1371_DIS_P1		(1<<21)	 /* playback channel 1 accumulator update disable */
195 #define ES1371_DIS_SRC		(1<<22)	 /* sample rate converter disable */
196 #define ES1371_SRC_RAM_BUSY	(1<<23)	 /* R/O: sample rate memory is busy */
197 #define ES1371_SRC_RAM_WE	(1<<24)	 /* R/W: read/write control for sample rate converter */
198 #define ES1371_SRC_RAM_ADDRO(o) (((o)&0x7f)<<25)	/* address of the sample rate converter */
199 #define ES1371_SRC_RAM_DATAO(o) (((o)&0xffff)<<0)	/* current value of the sample rate converter */
200 #define ES1371_SRC_RAM_DATAI(i) (((i)>>0)&0xffff)	/* current value of the sample rate converter */
201 
202 /*
203  * S/PDIF specific
204  */
205 
206 /* Use ES1370_REG_CONTROL */
207 #define RECEN_B			0x08000000	/* Used to control mixing of analog with digital data */
208 #define SPDIFEN_B		0x04000000	/* Reset to switch digital output mux to "THRU" mode */
209 /* Use ES1370_REG_STATUS */
210 #define ENABLE_SPDIF		0x00040000	/* Used to enable the S/PDIF circuitry */
211 #define TEST_SPDIF		0x00020000	/* Used to put the S/PDIF module in "test mode" */
212 
213 /*
214  *  Sample rate converter addresses
215  */
216 
217 #define ES_SMPREG_DAC1		0x70
218 #define ES_SMPREG_DAC2		0x74
219 #define ES_SMPREG_ADC		0x78
220 #define ES_SMPREG_TRUNC_N	0x00
221 #define ES_SMPREG_INT_REGS	0x01
222 #define ES_SMPREG_VFREQ_FRAC	0x03
223 #define ES_SMPREG_VOL_ADC	0x6c
224 #define ES_SMPREG_VOL_DAC1	0x7c
225 #define ES_SMPREG_VOL_DAC2	0x7e
226 
227 #endif
228