xref: /OK3568_Linux_fs/kernel/sound/soc/codecs/ml26124.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * Copyright (C) 2011 LAPIS Semiconductor Co., Ltd.
4*4882a593Smuzhiyun  */
5*4882a593Smuzhiyun 
6*4882a593Smuzhiyun #ifndef ML26124_H
7*4882a593Smuzhiyun #define ML26124_H
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun /* Clock Control Register */
10*4882a593Smuzhiyun #define ML26124_SMPLING_RATE		0x00
11*4882a593Smuzhiyun #define ML26124_PLLNL			0x02
12*4882a593Smuzhiyun #define ML26124_PLLNH			0x04
13*4882a593Smuzhiyun #define ML26124_PLLML			0x06
14*4882a593Smuzhiyun #define ML26124_PLLMH			0x08
15*4882a593Smuzhiyun #define ML26124_PLLDIV			0x0a
16*4882a593Smuzhiyun #define ML26124_CLK_EN			0x0c
17*4882a593Smuzhiyun #define ML26124_CLK_CTL			0x0e
18*4882a593Smuzhiyun 
19*4882a593Smuzhiyun /* System Control Register */
20*4882a593Smuzhiyun #define ML26124_SW_RST			0x10
21*4882a593Smuzhiyun #define ML26124_REC_PLYBAK_RUN		0x12
22*4882a593Smuzhiyun #define ML26124_MIC_TIM			0x14
23*4882a593Smuzhiyun 
24*4882a593Smuzhiyun /* Power Mnagement Register */
25*4882a593Smuzhiyun #define ML26124_PW_REF_PW_MNG		0x20
26*4882a593Smuzhiyun #define ML26124_PW_IN_PW_MNG		0x22
27*4882a593Smuzhiyun #define ML26124_PW_DAC_PW_MNG		0x24
28*4882a593Smuzhiyun #define ML26124_PW_SPAMP_PW_MNG		0x26
29*4882a593Smuzhiyun #define ML26124_PW_LOUT_PW_MNG		0x28
30*4882a593Smuzhiyun #define ML26124_PW_VOUT_PW_MNG		0x2a
31*4882a593Smuzhiyun #define ML26124_PW_ZCCMP_PW_MNG		0x2e
32*4882a593Smuzhiyun 
33*4882a593Smuzhiyun /* Analog Reference Control Register */
34*4882a593Smuzhiyun #define ML26124_PW_MICBIAS_VOL		0x30
35*4882a593Smuzhiyun 
36*4882a593Smuzhiyun /* Input/Output Amplifier Control Register */
37*4882a593Smuzhiyun #define ML26124_PW_MIC_IN_VOL		0x32
38*4882a593Smuzhiyun #define ML26124_PW_MIC_BOST_VOL		0x38
39*4882a593Smuzhiyun #define ML26124_PW_SPK_AMP_VOL		0x3a
40*4882a593Smuzhiyun #define ML26124_PW_AMP_VOL_FUNC		0x48
41*4882a593Smuzhiyun #define ML26124_PW_AMP_VOL_FADE		0x4a
42*4882a593Smuzhiyun 
43*4882a593Smuzhiyun /* Analog Path Control Register */
44*4882a593Smuzhiyun #define ML26124_SPK_AMP_OUT		0x54
45*4882a593Smuzhiyun #define ML26124_MIC_IF_CTL		0x5a
46*4882a593Smuzhiyun #define ML26124_MIC_SELECT		0xe8
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun /* Audio Interface Control Register */
49*4882a593Smuzhiyun #define ML26124_SAI_TRANS_CTL		0x60
50*4882a593Smuzhiyun #define ML26124_SAI_RCV_CTL		0x62
51*4882a593Smuzhiyun #define ML26124_SAI_MODE_SEL		0x64
52*4882a593Smuzhiyun 
53*4882a593Smuzhiyun /* DSP Control Register */
54*4882a593Smuzhiyun #define ML26124_FILTER_EN		0x66
55*4882a593Smuzhiyun #define ML26124_DVOL_CTL		0x68
56*4882a593Smuzhiyun #define ML26124_MIXER_VOL_CTL		0x6a
57*4882a593Smuzhiyun #define ML26124_RECORD_DIG_VOL		0x6c
58*4882a593Smuzhiyun #define ML26124_PLBAK_DIG_VOL		0x70
59*4882a593Smuzhiyun #define ML26124_DIGI_BOOST_VOL		0x72
60*4882a593Smuzhiyun #define ML26124_EQ_GAIN_BRAND0		0x74
61*4882a593Smuzhiyun #define ML26124_EQ_GAIN_BRAND1		0x76
62*4882a593Smuzhiyun #define ML26124_EQ_GAIN_BRAND2		0x78
63*4882a593Smuzhiyun #define ML26124_EQ_GAIN_BRAND3		0x7a
64*4882a593Smuzhiyun #define ML26124_EQ_GAIN_BRAND4		0x7c
65*4882a593Smuzhiyun #define ML26124_HPF2_CUTOFF		0x7e
66*4882a593Smuzhiyun #define ML26124_EQBRAND0_F0L		0x80
67*4882a593Smuzhiyun #define ML26124_EQBRAND0_F0H		0x82
68*4882a593Smuzhiyun #define ML26124_EQBRAND0_F1L		0x84
69*4882a593Smuzhiyun #define ML26124_EQBRAND0_F1H		0x86
70*4882a593Smuzhiyun #define ML26124_EQBRAND1_F0L		0x88
71*4882a593Smuzhiyun #define ML26124_EQBRAND1_F0H		0x8a
72*4882a593Smuzhiyun #define ML26124_EQBRAND1_F1L		0x8c
73*4882a593Smuzhiyun #define ML26124_EQBRAND1_F1H		0x8e
74*4882a593Smuzhiyun #define ML26124_EQBRAND2_F0L		0x90
75*4882a593Smuzhiyun #define ML26124_EQBRAND2_F0H		0x92
76*4882a593Smuzhiyun #define ML26124_EQBRAND2_F1L		0x94
77*4882a593Smuzhiyun #define ML26124_EQBRAND2_F1H		0x96
78*4882a593Smuzhiyun #define ML26124_EQBRAND3_F0L		0x98
79*4882a593Smuzhiyun #define ML26124_EQBRAND3_F0H		0x9a
80*4882a593Smuzhiyun #define ML26124_EQBRAND3_F1L		0x9c
81*4882a593Smuzhiyun #define ML26124_EQBRAND3_F1H		0x9e
82*4882a593Smuzhiyun #define ML26124_EQBRAND4_F0L		0xa0
83*4882a593Smuzhiyun #define ML26124_EQBRAND4_F0H		0xa2
84*4882a593Smuzhiyun #define ML26124_EQBRAND4_F1L		0xa4
85*4882a593Smuzhiyun #define ML26124_EQBRAND4_F1H		0xa6
86*4882a593Smuzhiyun 
87*4882a593Smuzhiyun /* ALC Control Register */
88*4882a593Smuzhiyun #define ML26124_ALC_MODE		0xb0
89*4882a593Smuzhiyun #define ML26124_ALC_ATTACK_TIM		0xb2
90*4882a593Smuzhiyun #define ML26124_ALC_DECAY_TIM		0xb4
91*4882a593Smuzhiyun #define ML26124_ALC_HOLD_TIM		0xb6
92*4882a593Smuzhiyun #define ML26124_ALC_TARGET_LEV		0xb8
93*4882a593Smuzhiyun #define ML26124_ALC_MAXMIN_GAIN		0xba
94*4882a593Smuzhiyun #define ML26124_NOIS_GATE_THRSH		0xbc
95*4882a593Smuzhiyun #define ML26124_ALC_ZERO_TIMOUT		0xbe
96*4882a593Smuzhiyun 
97*4882a593Smuzhiyun /* Playback Limiter Control Register */
98*4882a593Smuzhiyun #define ML26124_PL_ATTACKTIME		0xc0
99*4882a593Smuzhiyun #define ML26124_PL_DECAYTIME		0xc2
100*4882a593Smuzhiyun #define ML26124_PL_TARGETTIME		0xc4
101*4882a593Smuzhiyun #define ML26124_PL_MAXMIN_GAIN		0xc6
102*4882a593Smuzhiyun #define ML26124_PLYBAK_BOST_VOL		0xc8
103*4882a593Smuzhiyun #define ML26124_PL_0CROSS_TIMOUT	0xca
104*4882a593Smuzhiyun 
105*4882a593Smuzhiyun /* Video Amplifer Control Register */
106*4882a593Smuzhiyun #define ML26124_VIDEO_AMP_GAIN_CTL	0xd0
107*4882a593Smuzhiyun #define ML26124_VIDEO_AMP_SETUP1	0xd2
108*4882a593Smuzhiyun #define ML26124_VIDEO_AMP_CTL2		0xd4
109*4882a593Smuzhiyun 
110*4882a593Smuzhiyun /* Clock select for machine driver */
111*4882a593Smuzhiyun #define ML26124_USE_PLL			0
112*4882a593Smuzhiyun #define ML26124_USE_MCLKI_256FS		1
113*4882a593Smuzhiyun #define ML26124_USE_MCLKI_512FS		2
114*4882a593Smuzhiyun #define ML26124_USE_MCLKI_1024FS	3
115*4882a593Smuzhiyun 
116*4882a593Smuzhiyun /* Register Mask */
117*4882a593Smuzhiyun #define ML26124_R0_MASK	0xf
118*4882a593Smuzhiyun #define ML26124_R2_MASK	0xff
119*4882a593Smuzhiyun #define ML26124_R4_MASK	0x1
120*4882a593Smuzhiyun #define ML26124_R6_MASK	0xf
121*4882a593Smuzhiyun #define ML26124_R8_MASK	0x3f
122*4882a593Smuzhiyun #define ML26124_Ra_MASK	0x1f
123*4882a593Smuzhiyun #define ML26124_Rc_MASK	0x1f
124*4882a593Smuzhiyun #define ML26124_Re_MASK	0x7
125*4882a593Smuzhiyun #define ML26124_R10_MASK	0x1
126*4882a593Smuzhiyun #define ML26124_R12_MASK	0x17
127*4882a593Smuzhiyun #define ML26124_R14_MASK	0x3f
128*4882a593Smuzhiyun #define ML26124_R20_MASK	0x47
129*4882a593Smuzhiyun #define ML26124_R22_MASK	0xa
130*4882a593Smuzhiyun #define ML26124_R24_MASK	0x2
131*4882a593Smuzhiyun #define ML26124_R26_MASK	0x1f
132*4882a593Smuzhiyun #define ML26124_R28_MASK	0x2
133*4882a593Smuzhiyun #define ML26124_R2a_MASK	0x2
134*4882a593Smuzhiyun #define ML26124_R2e_MASK	0x2
135*4882a593Smuzhiyun #define ML26124_R30_MASK	0x7
136*4882a593Smuzhiyun #define ML26124_R32_MASK	0x3f
137*4882a593Smuzhiyun #define ML26124_R38_MASK	0x38
138*4882a593Smuzhiyun #define ML26124_R3a_MASK	0x3f
139*4882a593Smuzhiyun #define ML26124_R48_MASK	0x3
140*4882a593Smuzhiyun #define ML26124_R4a_MASK	0x7
141*4882a593Smuzhiyun #define ML26124_R54_MASK	0x2a
142*4882a593Smuzhiyun #define ML26124_R5a_MASK	0x3
143*4882a593Smuzhiyun #define ML26124_Re8_MASK	0x3
144*4882a593Smuzhiyun #define ML26124_R60_MASK	0xff
145*4882a593Smuzhiyun #define ML26124_R62_MASK	0xff
146*4882a593Smuzhiyun #define ML26124_R64_MASK	0x1
147*4882a593Smuzhiyun #define ML26124_R66_MASK	0xff
148*4882a593Smuzhiyun #define ML26124_R68_MASK	0x3b
149*4882a593Smuzhiyun #define ML26124_R6a_MASK	0xf3
150*4882a593Smuzhiyun #define ML26124_R6c_MASK	0xff
151*4882a593Smuzhiyun #define ML26124_R70_MASK	0xff
152*4882a593Smuzhiyun 
153*4882a593Smuzhiyun #define ML26124_MCLKEN		BIT(0)
154*4882a593Smuzhiyun #define ML26124_PLLEN		BIT(1)
155*4882a593Smuzhiyun #define ML26124_PLLOE		BIT(2)
156*4882a593Smuzhiyun #define ML26124_MCLKOE		BIT(3)
157*4882a593Smuzhiyun 
158*4882a593Smuzhiyun #define ML26124_BLT_ALL_ON	0x1f
159*4882a593Smuzhiyun #define ML26124_BLT_PREAMP_ON	0x13
160*4882a593Smuzhiyun 
161*4882a593Smuzhiyun #define ML26124_MICBEN_ON	BIT(2)
162*4882a593Smuzhiyun 
163*4882a593Smuzhiyun enum ml26124_regs {
164*4882a593Smuzhiyun 	ML26124_MCLK = 0,
165*4882a593Smuzhiyun };
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun enum ml26124_clk_in {
168*4882a593Smuzhiyun 	ML26124_USE_PLLOUT = 0,
169*4882a593Smuzhiyun 	ML26124_USE_MCLKI,
170*4882a593Smuzhiyun };
171*4882a593Smuzhiyun 
172*4882a593Smuzhiyun #endif
173