1 /* SPDX-License-Identifier: GPL-2.0 */
2 //
3 // ALSA SoC Texas Instruments TAS2563 Audio Smart Amplifier
4 //
5 // Copyright (C) 2022 - 2024 Texas Instruments Incorporated
6 // https://www.ti.com
7 //
8 // The TAS2563 driver implements a flexible and configurable
9 // algo coefficient setting for one, two, or even multiple
10 // TAS2563 chips.
11 //
12 // Author: Shenghao Ding <shenghao-ding@ti.com>
13 //
14 
15 #ifndef __TAS2563_TLV_H__
16 #define __TAS2563_TLV_H__
17 
18 static const __maybe_unused DECLARE_TLV_DB_SCALE(tas2563_dvc_tlv, -12150, 50, 1);
19 
20 /* pow(10, db/20) * pow(2,30) */
21 static const __maybe_unused unsigned char tas2563_dvc_table[][4] = {
22 	{ 0X00, 0X00, 0X00, 0X00 }, /* -121.5db */
23 	{ 0X00, 0X00, 0X03, 0XBC }, /* -121.0db */
24 	{ 0X00, 0X00, 0X03, 0XF5 }, /* -120.5db */
25 	{ 0X00, 0X00, 0X04, 0X31 }, /* -120.0db */
26 	{ 0X00, 0X00, 0X04, 0X71 }, /* -119.5db */
27 	{ 0X00, 0X00, 0X04, 0XB4 }, /* -119.0db */
28 	{ 0X00, 0X00, 0X04, 0XFC }, /* -118.5db */
29 	{ 0X00, 0X00, 0X05, 0X47 }, /* -118.0db */
30 	{ 0X00, 0X00, 0X05, 0X97 }, /* -117.5db */
31 	{ 0X00, 0X00, 0X05, 0XEC }, /* -117.0db */
32 	{ 0X00, 0X00, 0X06, 0X46 }, /* -116.5db */
33 	{ 0X00, 0X00, 0X06, 0XA5 }, /* -116.0db */
34 	{ 0X00, 0X00, 0X07, 0X0A }, /* -115.5db */
35 	{ 0X00, 0X00, 0X07, 0X75 }, /* -115.0db */
36 	{ 0X00, 0X00, 0X07, 0XE6 }, /* -114.5db */
37 	{ 0X00, 0X00, 0X08, 0X5E }, /* -114.0db */
38 	{ 0X00, 0X00, 0X08, 0XDD }, /* -113.5db */
39 	{ 0X00, 0X00, 0X09, 0X63 }, /* -113.0db */
40 	{ 0X00, 0X00, 0X09, 0XF2 }, /* -112.5db */
41 	{ 0X00, 0X00, 0X0A, 0X89 }, /* -112.0db */
42 	{ 0X00, 0X00, 0X0B, 0X28 }, /* -111.5db */
43 	{ 0X00, 0X00, 0X0B, 0XD2 }, /* -111.0db */
44 	{ 0X00, 0X00, 0X0C, 0X85 }, /* -110.5db */
45 	{ 0X00, 0X00, 0X0D, 0X43 }, /* -110.0db */
46 	{ 0X00, 0X00, 0X0E, 0X0C }, /* -109.5db */
47 	{ 0X00, 0X00, 0X0E, 0XE1 }, /* -109.0db */
48 	{ 0X00, 0X00, 0X0F, 0XC3 }, /* -108.5db */
49 	{ 0X00, 0X00, 0X10, 0XB2 }, /* -108.0db */
50 	{ 0X00, 0X00, 0X11, 0XAF }, /* -107.5db */
51 	{ 0X00, 0X00, 0X12, 0XBC }, /* -107.0db */
52 	{ 0X00, 0X00, 0X13, 0XD8 }, /* -106.5db */
53 	{ 0X00, 0X00, 0X15, 0X05 }, /* -106.0db */
54 	{ 0X00, 0X00, 0X16, 0X44 }, /* -105.5db */
55 	{ 0X00, 0X00, 0X17, 0X96 }, /* -105.0db */
56 	{ 0X00, 0X00, 0X18, 0XFB }, /* -104.5db */
57 	{ 0X00, 0X00, 0X1A, 0X76 }, /* -104.0db */
58 	{ 0X00, 0X00, 0X1C, 0X08 }, /* -103.5db */
59 	{ 0X00, 0X00, 0X1D, 0XB1 }, /* -103.0db */
60 	{ 0X00, 0X00, 0X1F, 0X73 }, /* -102.5db */
61 	{ 0X00, 0X00, 0X21, 0X51 }, /* -102.0db */
62 	{ 0X00, 0X00, 0X23, 0X4A }, /* -101.5db */
63 	{ 0X00, 0X00, 0X25, 0X61 }, /* -101.0db */
64 	{ 0X00, 0X00, 0X27, 0X98 }, /* -100.5db */
65 	{ 0X00, 0X00, 0X29, 0XF1 }, /* -100.0db */
66 	{ 0X00, 0X00, 0X2C, 0X6D }, /* -99.5db */
67 	{ 0X00, 0X00, 0X2F, 0X0F }, /* -99.0db */
68 	{ 0X00, 0X00, 0X31, 0XD9 }, /* -98.5db */
69 	{ 0X00, 0X00, 0X34, 0XCD }, /* -98.0db */
70 	{ 0X00, 0X00, 0X37, 0XEE }, /* -97.5db */
71 	{ 0X00, 0X00, 0X3B, 0X3F }, /* -97.0db */
72 	{ 0X00, 0X00, 0X3E, 0XC1 }, /* -96.5db */
73 	{ 0X00, 0X00, 0X42, 0X79 }, /* -96.0db */
74 	{ 0X00, 0X00, 0X46, 0X6A }, /* -95.5db */
75 	{ 0X00, 0X00, 0X4A, 0X96 }, /* -95.0db */
76 	{ 0X00, 0X00, 0X4F, 0X01 }, /* -94.5db */
77 	{ 0X00, 0X00, 0X53, 0XAF }, /* -94.0db */
78 	{ 0X00, 0X00, 0X58, 0XA5 }, /* -93.5db */
79 	{ 0X00, 0X00, 0X5D, 0XE6 }, /* -93.0db */
80 	{ 0X00, 0X00, 0X63, 0X76 }, /* -92.5db */
81 	{ 0X00, 0X00, 0X69, 0X5B }, /* -92.0db */
82 	{ 0X00, 0X00, 0X6F, 0X99 }, /* -91.5db */
83 	{ 0X00, 0X00, 0X76, 0X36 }, /* -91.0db */
84 	{ 0X00, 0X00, 0X7D, 0X37 }, /* -90.5db */
85 	{ 0X00, 0X00, 0X84, 0XA2 }, /* -90.0db */
86 	{ 0X00, 0X00, 0X8C, 0X7E }, /* -89.5db */
87 	{ 0X00, 0X00, 0X94, 0XD1 }, /* -89.0db */
88 	{ 0X00, 0X00, 0X9D, 0XA3 }, /* -88.5db */
89 	{ 0X00, 0X00, 0XA6, 0XFA }, /* -88.0db */
90 	{ 0X00, 0X00, 0XB0, 0XDF }, /* -87.5db */
91 	{ 0X00, 0X00, 0XBB, 0X5A }, /* -87.0db */
92 	{ 0X00, 0X00, 0XC6, 0X74 }, /* -86.5db */
93 	{ 0X00, 0X00, 0XD2, 0X36 }, /* -86.0db */
94 	{ 0X00, 0X00, 0XDE, 0XAB }, /* -85.5db */
95 	{ 0X00, 0X00, 0XEB, 0XDC }, /* -85.0db */
96 	{ 0X00, 0X00, 0XF9, 0XD6 }, /* -84.5db */
97 	{ 0X00, 0X01, 0X08, 0XA4 }, /* -84.0db */
98 	{ 0X00, 0X01, 0X18, 0X52 }, /* -83.5db */
99 	{ 0X00, 0X01, 0X28, 0XEF }, /* -83.0db */
100 	{ 0X00, 0X01, 0X3A, 0X87 }, /* -82.5db */
101 	{ 0X00, 0X01, 0X4D, 0X2A }, /* -82.0db */
102 	{ 0X00, 0X01, 0X60, 0XE8 }, /* -81.5db */
103 	{ 0X00, 0X01, 0X75, 0XD1 }, /* -81.0db */
104 	{ 0X00, 0X01, 0X8B, 0XF7 }, /* -80.5db */
105 	{ 0X00, 0X01, 0XA3, 0X6E }, /* -80.0db */
106 	{ 0X00, 0X01, 0XBC, 0X48 }, /* -79.5db */
107 	{ 0X00, 0X01, 0XD6, 0X9B }, /* -79.0db */
108 	{ 0X00, 0X01, 0XF2, 0X7E }, /* -78.5db */
109 	{ 0X00, 0X02, 0X10, 0X08 }, /* -78.0db */
110 	{ 0X00, 0X02, 0X2F, 0X51 }, /* -77.5db */
111 	{ 0X00, 0X02, 0X50, 0X76 }, /* -77.0db */
112 	{ 0X00, 0X02, 0X73, 0X91 }, /* -76.5db */
113 	{ 0X00, 0X02, 0X98, 0XC0 }, /* -76.0db */
114 	{ 0X00, 0X02, 0XC0, 0X24 }, /* -75.5db */
115 	{ 0X00, 0X02, 0XE9, 0XDD }, /* -75.0db */
116 	{ 0X00, 0X03, 0X16, 0X0F }, /* -74.5db */
117 	{ 0X00, 0X03, 0X44, 0XDF }, /* -74.0db */
118 	{ 0X00, 0X03, 0X76, 0X76 }, /* -73.5db */
119 	{ 0X00, 0X03, 0XAA, 0XFC }, /* -73.0db */
120 	{ 0X00, 0X03, 0XE2, 0XA0 }, /* -72.5db */
121 	{ 0X00, 0X04, 0X1D, 0X8F }, /* -72.0db */
122 	{ 0X00, 0X04, 0X5B, 0XFD }, /* -71.5db */
123 	{ 0X00, 0X04, 0X9E, 0X1D }, /* -71.0db */
124 	{ 0X00, 0X04, 0XE4, 0X29 }, /* -70.5db */
125 	{ 0X00, 0X05, 0X2E, 0X5A }, /* -70.0db */
126 	{ 0X00, 0X05, 0X7C, 0XF2 }, /* -69.5db */
127 	{ 0X00, 0X05, 0XD0, 0X31 }, /* -69.0db */
128 	{ 0X00, 0X06, 0X28, 0X60 }, /* -68.5db */
129 	{ 0X00, 0X06, 0X85, 0XC8 }, /* -68.0db */
130 	{ 0X00, 0X06, 0XE8, 0XB9 }, /* -67.5db */
131 	{ 0X00, 0X07, 0X51, 0X86 }, /* -67.0db */
132 	{ 0X00, 0X07, 0XC0, 0X8A }, /* -66.5db */
133 	{ 0X00, 0X08, 0X36, 0X21 }, /* -66.0db */
134 	{ 0X00, 0X08, 0XB2, 0XB0 }, /* -65.5db */
135 	{ 0X00, 0X09, 0X36, 0XA1 }, /* -65.0db */
136 	{ 0X00, 0X09, 0XC2, 0X63 }, /* -64.5db */
137 	{ 0X00, 0X0A, 0X56, 0X6D }, /* -64.0db */
138 	{ 0X00, 0X0A, 0XF3, 0X3C }, /* -63.5db */
139 	{ 0X00, 0X0B, 0X99, 0X56 }, /* -63.0db */
140 	{ 0X00, 0X0C, 0X49, 0X48 }, /* -62.5db */
141 	{ 0X00, 0X0D, 0X03, 0XA7 }, /* -62.0db */
142 	{ 0X00, 0X0D, 0XC9, 0X11 }, /* -61.5db */
143 	{ 0X00, 0X0E, 0X9A, 0X2D }, /* -61.0db */
144 	{ 0X00, 0X0F, 0X77, 0XAD }, /* -60.5db */
145 	{ 0X00, 0X10, 0X62, 0X4D }, /* -60.0db */
146 	{ 0X00, 0X11, 0X5A, 0XD5 }, /* -59.5db */
147 	{ 0X00, 0X12, 0X62, 0X16 }, /* -59.0db */
148 	{ 0X00, 0X13, 0X78, 0XF0 }, /* -58.5db */
149 	{ 0X00, 0X14, 0XA0, 0X50 }, /* -58.0db */
150 	{ 0X00, 0X15, 0XD9, 0X31 }, /* -57.5db */
151 	{ 0X00, 0X17, 0X24, 0X9C }, /* -57.0db */
152 	{ 0X00, 0X18, 0X83, 0XAA }, /* -56.5db */
153 	{ 0X00, 0X19, 0XF7, 0X86 }, /* -56.0db */
154 	{ 0X00, 0X1B, 0X81, 0X6A }, /* -55.5db */
155 	{ 0X00, 0X1D, 0X22, 0XA4 }, /* -55.0db */
156 	{ 0X00, 0X1E, 0XDC, 0X98 }, /* -54.5db */
157 	{ 0X00, 0X20, 0XB0, 0XBC }, /* -54.0db */
158 	{ 0X00, 0X22, 0XA0, 0X9D }, /* -53.5db */
159 	{ 0X00, 0X24, 0XAD, 0XE0 }, /* -53.0db */
160 	{ 0X00, 0X26, 0XDA, 0X43 }, /* -52.5db */
161 	{ 0X00, 0X29, 0X27, 0X9D }, /* -52.0db */
162 	{ 0X00, 0X2B, 0X97, 0XE3 }, /* -51.5db */
163 	{ 0X00, 0X2E, 0X2D, 0X27 }, /* -51.0db */
164 	{ 0X00, 0X30, 0XE9, 0X9A }, /* -50.5db */
165 	{ 0X00, 0X33, 0XCF, 0X8D }, /* -50.0db */
166 	{ 0X00, 0X36, 0XE1, 0X78 }, /* -49.5db */
167 	{ 0X00, 0X3A, 0X21, 0XF3 }, /* -49.0db */
168 	{ 0X00, 0X3D, 0X93, 0XC3 }, /* -48.5db */
169 	{ 0X00, 0X41, 0X39, 0XD3 }, /* -48.0db */
170 	{ 0X00, 0X45, 0X17, 0X3B }, /* -47.5db */
171 	{ 0X00, 0X49, 0X2F, 0X44 }, /* -47.0db */
172 	{ 0X00, 0X4D, 0X85, 0X66 }, /* -46.5db */
173 	{ 0X00, 0X52, 0X1D, 0X50 }, /* -46.0db */
174 	{ 0X00, 0X56, 0XFA, 0XE8 }, /* -45.5db */
175 	{ 0X00, 0X5C, 0X22, 0X4E }, /* -45.0db */
176 	{ 0X00, 0X61, 0X97, 0XE1 }, /* -44.5db */
177 	{ 0X00, 0X67, 0X60, 0X44 }, /* -44.0db */
178 	{ 0X00, 0X6D, 0X80, 0X60 }, /* -43.5db */
179 	{ 0X00, 0X73, 0XFD, 0X65 }, /* -43.0db */
180 	{ 0X00, 0X7A, 0XDC, 0XD7 }, /* -42.5db */
181 	{ 0X00, 0X82, 0X24, 0X8A }, /* -42.0db */
182 	{ 0X00, 0X89, 0XDA, 0XAB }, /* -41.5db */
183 	{ 0X00, 0X92, 0X05, 0XC6 }, /* -41.0db */
184 	{ 0X00, 0X9A, 0XAC, 0XC8 }, /* -40.5db */
185 	{ 0X00, 0XA3, 0XD7, 0X0A }, /* -40.0db */
186 	{ 0X00, 0XAD, 0X8C, 0X52 }, /* -39.5db */
187 	{ 0X00, 0XB7, 0XD4, 0XDD }, /* -39.0db */
188 	{ 0X00, 0XC2, 0XB9, 0X65 }, /* -38.5db */
189 	{ 0X00, 0XCE, 0X43, 0X28 }, /* -38.0db */
190 	{ 0X00, 0XDA, 0X7B, 0XF1 }, /* -37.5db */
191 	{ 0X00, 0XE7, 0X6E, 0X1E }, /* -37.0db */
192 	{ 0X00, 0XF5, 0X24, 0XAC }, /* -36.5db */
193 	{ 0X01, 0X03, 0XAB, 0X3D }, /* -36.0db */
194 	{ 0X01, 0X13, 0X0E, 0X24 }, /* -35.5db */
195 	{ 0X01, 0X23, 0X5A, 0X71 }, /* -35.0db */
196 	{ 0X01, 0X34, 0X9D, 0XF8 }, /* -34.5db */
197 	{ 0X01, 0X46, 0XE7, 0X5D }, /* -34.0db */
198 	{ 0X01, 0X5A, 0X46, 0X27 }, /* -33.5db */
199 	{ 0X01, 0X6E, 0XCA, 0XC5 }, /* -33.0db */
200 	{ 0X01, 0X84, 0X86, 0X9F }, /* -32.5db */
201 	{ 0X01, 0X9B, 0X8C, 0X27 }, /* -32.0db */
202 	{ 0X01, 0XB3, 0XEE, 0XE5 }, /* -31.5db */
203 	{ 0X01, 0XCD, 0XC3, 0X8C }, /* -31.0db */
204 	{ 0X01, 0XE9, 0X20, 0X05 }, /* -30.5db */
205 	{ 0X02, 0X06, 0X1B, 0X89 }, /* -30.0db */
206 	{ 0X02, 0X24, 0XCE, 0XB0 }, /* -29.5db */
207 	{ 0X02, 0X45, 0X53, 0X85 }, /* -29.0db */
208 	{ 0X02, 0X67, 0XC5, 0XA2 }, /* -28.5db */
209 	{ 0X02, 0X8C, 0X42, 0X3F }, /* -28.0db */
210 	{ 0X02, 0XB2, 0XE8, 0X55 }, /* -27.5db */
211 	{ 0X02, 0XDB, 0XD8, 0XAD }, /* -27.0db */
212 	{ 0X03, 0X07, 0X36, 0X05 }, /* -26.5db */
213 	{ 0X03, 0X35, 0X25, 0X29 }, /* -26.0db */
214 	{ 0X03, 0X65, 0XCD, 0X13 }, /* -25.5db */
215 	{ 0X03, 0X99, 0X57, 0X0C }, /* -25.0db */
216 	{ 0X03, 0XCF, 0XEE, 0XCF }, /* -24.5db */
217 	{ 0X04, 0X09, 0XC2, 0XB0 }, /* -24.0db */
218 	{ 0X04, 0X47, 0X03, 0XC1 }, /* -23.5db */
219 	{ 0X04, 0X87, 0XE5, 0XFB }, /* -23.0db */
220 	{ 0X04, 0XCC, 0XA0, 0X6D }, /* -22.5db */
221 	{ 0X05, 0X15, 0X6D, 0X68 }, /* -22.0db */
222 	{ 0X05, 0X62, 0X8A, 0XB3 }, /* -21.5db */
223 	{ 0X05, 0XB4, 0X39, 0XBC }, /* -21.0db */
224 	{ 0X06, 0X0A, 0XBF, 0XD4 }, /* -20.5db */
225 	{ 0X06, 0X66, 0X66, 0X66 }, /* -20.0db */
226 	{ 0X06, 0XC7, 0X7B, 0X36 }, /* -19.5db */
227 	{ 0X07, 0X2E, 0X50, 0XA6 }, /* -19.0db */
228 	{ 0X07, 0X9B, 0X3D, 0XF6 }, /* -18.5db */
229 	{ 0X08, 0X0E, 0X9F, 0X96 }, /* -18.0db */
230 	{ 0X08, 0X88, 0XD7, 0X6D }, /* -17.5db */
231 	{ 0X09, 0X0A, 0X4D, 0X2F }, /* -17.0db */
232 	{ 0X09, 0X93, 0X6E, 0XB8 }, /* -16.5db */
233 	{ 0X0A, 0X24, 0XB0, 0X62 }, /* -16.0db */
234 	{ 0X0A, 0XBE, 0X8D, 0X70 }, /* -15.5db */
235 	{ 0X0B, 0X61, 0X88, 0X71 }, /* -15.0db */
236 	{ 0X0C, 0X0E, 0X2B, 0XB0 }, /* -14.5db */
237 	{ 0X0C, 0XC5, 0X09, 0XAB }, /* -14.0db */
238 	{ 0X0D, 0X86, 0XBD, 0X8D }, /* -13.5db */
239 	{ 0X0E, 0X53, 0XEB, 0XB3 }, /* -13.0db */
240 	{ 0X0F, 0X2D, 0X42, 0X38 }, /* -12.5db */
241 	{ 0X10, 0X13, 0X79, 0X87 }, /* -12.0db */
242 	{ 0X11, 0X07, 0X54, 0XF9 }, /* -11.5db */
243 	{ 0X12, 0X09, 0XA3, 0X7A }, /* -11.0db */
244 	{ 0X13, 0X1B, 0X40, 0X39 }, /* -10.5db */
245 	{ 0X14, 0X3D, 0X13, 0X62 }, /* -10.0db */
246 	{ 0X15, 0X70, 0X12, 0XE1 }, /* -9.5db */
247 	{ 0X16, 0XB5, 0X43, 0X37 }, /* -9.0db */
248 	{ 0X18, 0X0D, 0XB8, 0X54 }, /* -8.5db */
249 	{ 0X19, 0X7A, 0X96, 0X7F }, /* -8.0db */
250 	{ 0X1A, 0XFD, 0X13, 0X54 }, /* -7.5db */
251 	{ 0X1C, 0X96, 0X76, 0XC6 }, /* -7.0db */
252 	{ 0X1E, 0X48, 0X1C, 0X37 }, /* -6.5db */
253 	{ 0X20, 0X13, 0X73, 0X9E }, /* -6.0db */
254 	{ 0X21, 0XFA, 0X02, 0XBF }, /* -5.5db */
255 	{ 0X23, 0XFD, 0X66, 0X78 }, /* -5.0db */
256 	{ 0X26, 0X1F, 0X54, 0X1C }, /* -4.5db */
257 	{ 0X28, 0X61, 0X9A, 0XE9 }, /* -4.0db */
258 	{ 0X2A, 0XC6, 0X25, 0X91 }, /* -3.5db */
259 	{ 0X2D, 0X4E, 0XFB, 0XD5 }, /* -3.0db */
260 	{ 0X2F, 0XFE, 0X44, 0X48 }, /* -2.5db */
261 	{ 0X32, 0XD6, 0X46, 0X17 }, /* -2.0db */
262 	{ 0X35, 0XD9, 0X6B, 0X02 }, /* -1.5db */
263 	{ 0X39, 0X0A, 0X41, 0X5F }, /* -1.0db */
264 	{ 0X3C, 0X6B, 0X7E, 0X4F }, /* -0.5db */
265 	{ 0X40, 0X00, 0X00, 0X00 }, /* 0.0db */
266 	{ 0X43, 0XCA, 0XD0, 0X22 }, /* 0.5db */
267 	{ 0X47, 0XCF, 0X26, 0X7D }, /* 1.0db */
268 	{ 0X4C, 0X10, 0X6B, 0XA5 }, /* 1.5db */
269 	{ 0X50, 0X92, 0X3B, 0XE3 }, /* 2.0db */
270 	{ 0X55, 0X58, 0X6A, 0X46 }, /* 2.5db */
271 	{ 0X5A, 0X67, 0X03, 0XDF }, /* 3.0db */
272 	{ 0X5F, 0XC2, 0X53, 0X32 }, /* 3.5db */
273 	{ 0X65, 0X6E, 0XE3, 0XDB }, /* 4.0db */
274 	{ 0X6B, 0X71, 0X86, 0X68 }, /* 4.5db */
275 	{ 0X71, 0XCF, 0X54, 0X71 }, /* 5.0db */
276 	{ 0X78, 0X8D, 0XB4, 0XE9 }, /* 5.5db */
277 	{ 0X7F, 0XFF, 0XFF, 0XFF }, /* 6.0db */
278 };
279 #endif
280