blob: e0383eea988024b77116b96e07d7528fb3bd60e7 [file] [log] [blame]
Ian Minett95c6e9c2011-06-15 15:35:17 -07001/*
2 * HD audio interface patch for Creative CA0132 chip
3 *
4 * Copyright (c) 2011, Creative Technology Ltd.
5 *
6 * Based on patch_ca0110.c
7 * Copyright (c) 2008 Takashi Iwai <tiwai@suse.de>
8 *
9 * This driver is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * This driver is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 */
23
24#include <linux/init.h>
25#include <linux/delay.h>
26#include <linux/slab.h>
Ian Minett95c6e9c2011-06-15 15:35:17 -070027#include <linux/mutex.h>
Paul Gortmakerda155d52011-07-15 12:38:28 -040028#include <linux/module.h>
Ian Minett4aa3bb02012-09-20 20:29:15 -070029#include <linux/firmware.h>
Ian Minett95c6e9c2011-06-15 15:35:17 -070030#include <sound/core.h>
31#include "hda_codec.h"
32#include "hda_local.h"
Takashi Iwai128bc4b2012-05-07 17:42:31 +020033#include "hda_auto_parser.h"
Ian Minett5aaca442012-12-20 18:53:34 -080034#include "hda_jack.h"
Ian Minett95c6e9c2011-06-15 15:35:17 -070035
Ian Minettbcd109c2012-09-20 20:29:14 -070036#include "ca0132_regs.h"
37
Ian Minettef6b2ea2012-12-20 18:53:33 -080038/* Enable this to see controls for tuning purpose. */
39/*#define ENABLE_TUNING_CONTROLS*/
40
41#define FLOAT_ZERO 0x00000000
42#define FLOAT_ONE 0x3f800000
43#define FLOAT_TWO 0x40000000
44#define FLOAT_MINUS_5 0xc0a00000
45
46#define UNSOL_TAG_HP 0x10
47#define UNSOL_TAG_AMIC1 0x12
48#define UNSOL_TAG_DSP 0x16
49
Ian Minett4aa3bb02012-09-20 20:29:15 -070050#define DSP_DMA_WRITE_BUFLEN_INIT (1UL<<18)
51#define DSP_DMA_WRITE_BUFLEN_OVLY (1UL<<15)
52
53#define DMA_TRANSFER_FRAME_SIZE_NWORDS 8
54#define DMA_TRANSFER_MAX_FRAME_SIZE_NWORDS 32
55#define DMA_OVERLAY_FRAME_SIZE_NWORDS 2
56
57#define MASTERCONTROL 0x80
Ian Minettef6b2ea2012-12-20 18:53:33 -080058#define MASTERCONTROL_ALLOC_DMA_CHAN 10
59#define MASTERCONTROL_QUERY_SPEAKER_EQ_ADDRESS 60
Ian Minett4aa3bb02012-09-20 20:29:15 -070060
Ian Minett95c6e9c2011-06-15 15:35:17 -070061#define WIDGET_CHIP_CTRL 0x15
62#define WIDGET_DSP_CTRL 0x16
63
Ian Minett4aa3bb02012-09-20 20:29:15 -070064#define MEM_CONNID_MICIN1 3
65#define MEM_CONNID_MICIN2 5
66#define MEM_CONNID_MICOUT1 12
67#define MEM_CONNID_MICOUT2 14
68#define MEM_CONNID_WUH 10
69#define MEM_CONNID_DSP 16
70#define MEM_CONNID_DMIC 100
71
72#define SCP_SET 0
73#define SCP_GET 1
74
Ian Minett01ef7db2012-09-20 20:29:16 -070075#define EFX_FILE "ctefx.bin"
76
Takashi Iwai24f3ced2013-02-04 18:25:51 +010077#ifdef CONFIG_SND_HDA_CODEC_CA0132_DSP
Ian Minett01ef7db2012-09-20 20:29:16 -070078MODULE_FIRMWARE(EFX_FILE);
Takashi Iwai7a527ed2013-01-15 17:44:20 +010079#endif
Ian Minett01ef7db2012-09-20 20:29:16 -070080
Ian Minettef6b2ea2012-12-20 18:53:33 -080081static char *dirstr[2] = { "Playback", "Capture" };
82
83enum {
84 SPEAKER_OUT,
85 HEADPHONE_OUT
86};
87
88enum {
89 DIGITAL_MIC,
90 LINE_MIC_IN
91};
92
93enum {
94#define VNODE_START_NID 0x80
95 VNID_SPK = VNODE_START_NID, /* Speaker vnid */
96 VNID_MIC,
97 VNID_HP_SEL,
98 VNID_AMIC1_SEL,
99 VNID_HP_ASEL,
100 VNID_AMIC1_ASEL,
101 VNODE_END_NID,
102#define VNODES_COUNT (VNODE_END_NID - VNODE_START_NID)
103
104#define EFFECT_START_NID 0x90
105#define OUT_EFFECT_START_NID EFFECT_START_NID
106 SURROUND = OUT_EFFECT_START_NID,
107 CRYSTALIZER,
108 DIALOG_PLUS,
109 SMART_VOLUME,
110 X_BASS,
111 EQUALIZER,
112 OUT_EFFECT_END_NID,
113#define OUT_EFFECTS_COUNT (OUT_EFFECT_END_NID - OUT_EFFECT_START_NID)
114
115#define IN_EFFECT_START_NID OUT_EFFECT_END_NID
116 ECHO_CANCELLATION = IN_EFFECT_START_NID,
117 VOICE_FOCUS,
118 MIC_SVM,
119 NOISE_REDUCTION,
120 IN_EFFECT_END_NID,
121#define IN_EFFECTS_COUNT (IN_EFFECT_END_NID - IN_EFFECT_START_NID)
122
123 VOICEFX = IN_EFFECT_END_NID,
124 PLAY_ENHANCEMENT,
125 CRYSTAL_VOICE,
126 EFFECT_END_NID
127#define EFFECTS_COUNT (EFFECT_END_NID - EFFECT_START_NID)
128};
129
130/* Effects values size*/
131#define EFFECT_VALS_MAX_COUNT 12
132
Dylan Reide8412ca2013-04-04 13:55:09 -0700133/* Latency introduced by DSP blocks in milliseconds. */
134#define DSP_CAPTURE_INIT_LATENCY 0
135#define DSP_CRYSTAL_VOICE_LATENCY 124
136#define DSP_PLAYBACK_INIT_LATENCY 13
137#define DSP_PLAY_ENHANCEMENT_LATENCY 30
138#define DSP_SPEAKER_OUT_LATENCY 7
139
Ian Minettef6b2ea2012-12-20 18:53:33 -0800140struct ct_effect {
Takashi Iwai975cc022013-06-28 11:56:49 +0200141 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN];
Ian Minettef6b2ea2012-12-20 18:53:33 -0800142 hda_nid_t nid;
143 int mid; /*effect module ID*/
144 int reqs[EFFECT_VALS_MAX_COUNT]; /*effect module request*/
145 int direct; /* 0:output; 1:input*/
146 int params; /* number of default non-on/off params */
147 /*effect default values, 1st is on/off. */
148 unsigned int def_vals[EFFECT_VALS_MAX_COUNT];
149};
150
151#define EFX_DIR_OUT 0
152#define EFX_DIR_IN 1
153
154static struct ct_effect ca0132_effects[EFFECTS_COUNT] = {
155 { .name = "Surround",
156 .nid = SURROUND,
157 .mid = 0x96,
158 .reqs = {0, 1},
159 .direct = EFX_DIR_OUT,
160 .params = 1,
161 .def_vals = {0x3F800000, 0x3F2B851F}
162 },
163 { .name = "Crystalizer",
164 .nid = CRYSTALIZER,
165 .mid = 0x96,
166 .reqs = {7, 8},
167 .direct = EFX_DIR_OUT,
168 .params = 1,
169 .def_vals = {0x3F800000, 0x3F266666}
170 },
171 { .name = "Dialog Plus",
172 .nid = DIALOG_PLUS,
173 .mid = 0x96,
174 .reqs = {2, 3},
175 .direct = EFX_DIR_OUT,
176 .params = 1,
177 .def_vals = {0x00000000, 0x3F000000}
178 },
179 { .name = "Smart Volume",
180 .nid = SMART_VOLUME,
181 .mid = 0x96,
182 .reqs = {4, 5, 6},
183 .direct = EFX_DIR_OUT,
184 .params = 2,
185 .def_vals = {0x3F800000, 0x3F3D70A4, 0x00000000}
186 },
187 { .name = "X-Bass",
188 .nid = X_BASS,
189 .mid = 0x96,
190 .reqs = {24, 23, 25},
191 .direct = EFX_DIR_OUT,
192 .params = 2,
193 .def_vals = {0x3F800000, 0x42A00000, 0x3F000000}
194 },
195 { .name = "Equalizer",
196 .nid = EQUALIZER,
197 .mid = 0x96,
198 .reqs = {9, 10, 11, 12, 13, 14,
199 15, 16, 17, 18, 19, 20},
200 .direct = EFX_DIR_OUT,
201 .params = 11,
202 .def_vals = {0x00000000, 0x00000000, 0x00000000, 0x00000000,
203 0x00000000, 0x00000000, 0x00000000, 0x00000000,
204 0x00000000, 0x00000000, 0x00000000, 0x00000000}
205 },
206 { .name = "Echo Cancellation",
207 .nid = ECHO_CANCELLATION,
208 .mid = 0x95,
209 .reqs = {0, 1, 2, 3},
210 .direct = EFX_DIR_IN,
211 .params = 3,
212 .def_vals = {0x00000000, 0x3F3A9692, 0x00000000, 0x00000000}
213 },
214 { .name = "Voice Focus",
215 .nid = VOICE_FOCUS,
216 .mid = 0x95,
217 .reqs = {6, 7, 8, 9},
218 .direct = EFX_DIR_IN,
219 .params = 3,
220 .def_vals = {0x3F800000, 0x3D7DF3B6, 0x41F00000, 0x41F00000}
221 },
222 { .name = "Mic SVM",
223 .nid = MIC_SVM,
224 .mid = 0x95,
225 .reqs = {44, 45},
226 .direct = EFX_DIR_IN,
227 .params = 1,
228 .def_vals = {0x00000000, 0x3F3D70A4}
229 },
230 { .name = "Noise Reduction",
231 .nid = NOISE_REDUCTION,
232 .mid = 0x95,
233 .reqs = {4, 5},
234 .direct = EFX_DIR_IN,
235 .params = 1,
236 .def_vals = {0x3F800000, 0x3F000000}
237 },
238 { .name = "VoiceFX",
239 .nid = VOICEFX,
240 .mid = 0x95,
241 .reqs = {10, 11, 12, 13, 14, 15, 16, 17, 18},
242 .direct = EFX_DIR_IN,
243 .params = 8,
244 .def_vals = {0x00000000, 0x43C80000, 0x44AF0000, 0x44FA0000,
245 0x3F800000, 0x3F800000, 0x3F800000, 0x00000000,
246 0x00000000}
247 }
248};
249
250/* Tuning controls */
251#ifdef ENABLE_TUNING_CONTROLS
252
253enum {
254#define TUNING_CTL_START_NID 0xC0
255 WEDGE_ANGLE = TUNING_CTL_START_NID,
256 SVM_LEVEL,
257 EQUALIZER_BAND_0,
258 EQUALIZER_BAND_1,
259 EQUALIZER_BAND_2,
260 EQUALIZER_BAND_3,
261 EQUALIZER_BAND_4,
262 EQUALIZER_BAND_5,
263 EQUALIZER_BAND_6,
264 EQUALIZER_BAND_7,
265 EQUALIZER_BAND_8,
266 EQUALIZER_BAND_9,
267 TUNING_CTL_END_NID
268#define TUNING_CTLS_COUNT (TUNING_CTL_END_NID - TUNING_CTL_START_NID)
269};
270
271struct ct_tuning_ctl {
Takashi Iwai975cc022013-06-28 11:56:49 +0200272 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN];
Ian Minettef6b2ea2012-12-20 18:53:33 -0800273 hda_nid_t parent_nid;
274 hda_nid_t nid;
275 int mid; /*effect module ID*/
276 int req; /*effect module request*/
277 int direct; /* 0:output; 1:input*/
278 unsigned int def_val;/*effect default values*/
279};
280
281static struct ct_tuning_ctl ca0132_tuning_ctls[] = {
282 { .name = "Wedge Angle",
283 .parent_nid = VOICE_FOCUS,
284 .nid = WEDGE_ANGLE,
285 .mid = 0x95,
286 .req = 8,
287 .direct = EFX_DIR_IN,
288 .def_val = 0x41F00000
289 },
290 { .name = "SVM Level",
291 .parent_nid = MIC_SVM,
292 .nid = SVM_LEVEL,
293 .mid = 0x95,
294 .req = 45,
295 .direct = EFX_DIR_IN,
296 .def_val = 0x3F3D70A4
297 },
298 { .name = "EQ Band0",
299 .parent_nid = EQUALIZER,
300 .nid = EQUALIZER_BAND_0,
301 .mid = 0x96,
302 .req = 11,
303 .direct = EFX_DIR_OUT,
304 .def_val = 0x00000000
305 },
306 { .name = "EQ Band1",
307 .parent_nid = EQUALIZER,
308 .nid = EQUALIZER_BAND_1,
309 .mid = 0x96,
310 .req = 12,
311 .direct = EFX_DIR_OUT,
312 .def_val = 0x00000000
313 },
314 { .name = "EQ Band2",
315 .parent_nid = EQUALIZER,
316 .nid = EQUALIZER_BAND_2,
317 .mid = 0x96,
318 .req = 13,
319 .direct = EFX_DIR_OUT,
320 .def_val = 0x00000000
321 },
322 { .name = "EQ Band3",
323 .parent_nid = EQUALIZER,
324 .nid = EQUALIZER_BAND_3,
325 .mid = 0x96,
326 .req = 14,
327 .direct = EFX_DIR_OUT,
328 .def_val = 0x00000000
329 },
330 { .name = "EQ Band4",
331 .parent_nid = EQUALIZER,
332 .nid = EQUALIZER_BAND_4,
333 .mid = 0x96,
334 .req = 15,
335 .direct = EFX_DIR_OUT,
336 .def_val = 0x00000000
337 },
338 { .name = "EQ Band5",
339 .parent_nid = EQUALIZER,
340 .nid = EQUALIZER_BAND_5,
341 .mid = 0x96,
342 .req = 16,
343 .direct = EFX_DIR_OUT,
344 .def_val = 0x00000000
345 },
346 { .name = "EQ Band6",
347 .parent_nid = EQUALIZER,
348 .nid = EQUALIZER_BAND_6,
349 .mid = 0x96,
350 .req = 17,
351 .direct = EFX_DIR_OUT,
352 .def_val = 0x00000000
353 },
354 { .name = "EQ Band7",
355 .parent_nid = EQUALIZER,
356 .nid = EQUALIZER_BAND_7,
357 .mid = 0x96,
358 .req = 18,
359 .direct = EFX_DIR_OUT,
360 .def_val = 0x00000000
361 },
362 { .name = "EQ Band8",
363 .parent_nid = EQUALIZER,
364 .nid = EQUALIZER_BAND_8,
365 .mid = 0x96,
366 .req = 19,
367 .direct = EFX_DIR_OUT,
368 .def_val = 0x00000000
369 },
370 { .name = "EQ Band9",
371 .parent_nid = EQUALIZER,
372 .nid = EQUALIZER_BAND_9,
373 .mid = 0x96,
374 .req = 20,
375 .direct = EFX_DIR_OUT,
376 .def_val = 0x00000000
377 }
378};
379#endif
380
381/* Voice FX Presets */
382#define VOICEFX_MAX_PARAM_COUNT 9
383
384struct ct_voicefx {
385 char *name;
386 hda_nid_t nid;
387 int mid;
388 int reqs[VOICEFX_MAX_PARAM_COUNT]; /*effect module request*/
389};
390
391struct ct_voicefx_preset {
392 char *name; /*preset name*/
393 unsigned int vals[VOICEFX_MAX_PARAM_COUNT];
394};
395
Takashi Iwaiccd7bd32013-01-16 09:32:54 +0800396static struct ct_voicefx ca0132_voicefx = {
Ian Minettef6b2ea2012-12-20 18:53:33 -0800397 .name = "VoiceFX Capture Switch",
398 .nid = VOICEFX,
399 .mid = 0x95,
400 .reqs = {10, 11, 12, 13, 14, 15, 16, 17, 18}
401};
402
Takashi Iwaiccd7bd32013-01-16 09:32:54 +0800403static struct ct_voicefx_preset ca0132_voicefx_presets[] = {
Ian Minettef6b2ea2012-12-20 18:53:33 -0800404 { .name = "Neutral",
405 .vals = { 0x00000000, 0x43C80000, 0x44AF0000,
406 0x44FA0000, 0x3F800000, 0x3F800000,
407 0x3F800000, 0x00000000, 0x00000000 }
408 },
409 { .name = "Female2Male",
410 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
411 0x44FA0000, 0x3F19999A, 0x3F866666,
412 0x3F800000, 0x00000000, 0x00000000 }
413 },
414 { .name = "Male2Female",
415 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
416 0x450AC000, 0x4017AE14, 0x3F6B851F,
417 0x3F800000, 0x00000000, 0x00000000 }
418 },
419 { .name = "ScrappyKid",
420 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
421 0x44FA0000, 0x40400000, 0x3F28F5C3,
422 0x3F800000, 0x00000000, 0x00000000 }
423 },
424 { .name = "Elderly",
425 .vals = { 0x3F800000, 0x44324000, 0x44BB8000,
426 0x44E10000, 0x3FB33333, 0x3FB9999A,
427 0x3F800000, 0x3E3A2E43, 0x00000000 }
428 },
429 { .name = "Orc",
430 .vals = { 0x3F800000, 0x43EA0000, 0x44A52000,
431 0x45098000, 0x3F266666, 0x3FC00000,
432 0x3F800000, 0x00000000, 0x00000000 }
433 },
434 { .name = "Elf",
435 .vals = { 0x3F800000, 0x43C70000, 0x44AE6000,
436 0x45193000, 0x3F8E147B, 0x3F75C28F,
437 0x3F800000, 0x00000000, 0x00000000 }
438 },
439 { .name = "Dwarf",
440 .vals = { 0x3F800000, 0x43930000, 0x44BEE000,
441 0x45007000, 0x3F451EB8, 0x3F7851EC,
442 0x3F800000, 0x00000000, 0x00000000 }
443 },
444 { .name = "AlienBrute",
445 .vals = { 0x3F800000, 0x43BFC5AC, 0x44B28FDF,
446 0x451F6000, 0x3F266666, 0x3FA7D945,
447 0x3F800000, 0x3CF5C28F, 0x00000000 }
448 },
449 { .name = "Robot",
450 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
451 0x44FA0000, 0x3FB2718B, 0x3F800000,
452 0xBC07010E, 0x00000000, 0x00000000 }
453 },
454 { .name = "Marine",
455 .vals = { 0x3F800000, 0x43C20000, 0x44906000,
456 0x44E70000, 0x3F4CCCCD, 0x3F8A3D71,
457 0x3F0A3D71, 0x00000000, 0x00000000 }
458 },
459 { .name = "Emo",
460 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
461 0x44FA0000, 0x3F800000, 0x3F800000,
462 0x3E4CCCCD, 0x00000000, 0x00000000 }
463 },
464 { .name = "DeepVoice",
465 .vals = { 0x3F800000, 0x43A9C5AC, 0x44AA4FDF,
466 0x44FFC000, 0x3EDBB56F, 0x3F99C4CA,
467 0x3F800000, 0x00000000, 0x00000000 }
468 },
469 { .name = "Munchkin",
470 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
471 0x44FA0000, 0x3F800000, 0x3F1A043C,
472 0x3F800000, 0x00000000, 0x00000000 }
473 }
474};
475
Ian Minett95c6e9c2011-06-15 15:35:17 -0700476enum hda_cmd_vendor_io {
477 /* for DspIO node */
478 VENDOR_DSPIO_SCP_WRITE_DATA_LOW = 0x000,
479 VENDOR_DSPIO_SCP_WRITE_DATA_HIGH = 0x100,
480
481 VENDOR_DSPIO_STATUS = 0xF01,
482 VENDOR_DSPIO_SCP_POST_READ_DATA = 0x702,
483 VENDOR_DSPIO_SCP_READ_DATA = 0xF02,
484 VENDOR_DSPIO_DSP_INIT = 0x703,
485 VENDOR_DSPIO_SCP_POST_COUNT_QUERY = 0x704,
486 VENDOR_DSPIO_SCP_READ_COUNT = 0xF04,
487
488 /* for ChipIO node */
489 VENDOR_CHIPIO_ADDRESS_LOW = 0x000,
490 VENDOR_CHIPIO_ADDRESS_HIGH = 0x100,
491 VENDOR_CHIPIO_STREAM_FORMAT = 0x200,
492 VENDOR_CHIPIO_DATA_LOW = 0x300,
493 VENDOR_CHIPIO_DATA_HIGH = 0x400,
494
495 VENDOR_CHIPIO_GET_PARAMETER = 0xF00,
496 VENDOR_CHIPIO_STATUS = 0xF01,
497 VENDOR_CHIPIO_HIC_POST_READ = 0x702,
498 VENDOR_CHIPIO_HIC_READ_DATA = 0xF03,
499
Ian Minett4aa3bb02012-09-20 20:29:15 -0700500 VENDOR_CHIPIO_8051_DATA_WRITE = 0x707,
501 VENDOR_CHIPIO_8051_DATA_READ = 0xF07,
502
Ian Minett95c6e9c2011-06-15 15:35:17 -0700503 VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE = 0x70A,
Ian Minett4aa3bb02012-09-20 20:29:15 -0700504 VENDOR_CHIPIO_CT_EXTENSIONS_GET = 0xF0A,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700505
506 VENDOR_CHIPIO_PLL_PMU_WRITE = 0x70C,
507 VENDOR_CHIPIO_PLL_PMU_READ = 0xF0C,
508 VENDOR_CHIPIO_8051_ADDRESS_LOW = 0x70D,
509 VENDOR_CHIPIO_8051_ADDRESS_HIGH = 0x70E,
510 VENDOR_CHIPIO_FLAG_SET = 0x70F,
511 VENDOR_CHIPIO_FLAGS_GET = 0xF0F,
Ian Minett4aa3bb02012-09-20 20:29:15 -0700512 VENDOR_CHIPIO_PARAM_SET = 0x710,
513 VENDOR_CHIPIO_PARAM_GET = 0xF10,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700514
515 VENDOR_CHIPIO_PORT_ALLOC_CONFIG_SET = 0x711,
516 VENDOR_CHIPIO_PORT_ALLOC_SET = 0x712,
517 VENDOR_CHIPIO_PORT_ALLOC_GET = 0xF12,
518 VENDOR_CHIPIO_PORT_FREE_SET = 0x713,
519
Ian Minett4aa3bb02012-09-20 20:29:15 -0700520 VENDOR_CHIPIO_PARAM_EX_ID_GET = 0xF17,
521 VENDOR_CHIPIO_PARAM_EX_ID_SET = 0x717,
522 VENDOR_CHIPIO_PARAM_EX_VALUE_GET = 0xF18,
523 VENDOR_CHIPIO_PARAM_EX_VALUE_SET = 0x718,
524
525 VENDOR_CHIPIO_DMIC_CTL_SET = 0x788,
526 VENDOR_CHIPIO_DMIC_CTL_GET = 0xF88,
527 VENDOR_CHIPIO_DMIC_PIN_SET = 0x789,
528 VENDOR_CHIPIO_DMIC_PIN_GET = 0xF89,
529 VENDOR_CHIPIO_DMIC_MCLK_SET = 0x78A,
530 VENDOR_CHIPIO_DMIC_MCLK_GET = 0xF8A,
531
532 VENDOR_CHIPIO_EAPD_SEL_SET = 0x78D
Ian Minett95c6e9c2011-06-15 15:35:17 -0700533};
534
535/*
536 * Control flag IDs
537 */
538enum control_flag_id {
539 /* Connection manager stream setup is bypassed/enabled */
540 CONTROL_FLAG_C_MGR = 0,
541 /* DSP DMA is bypassed/enabled */
542 CONTROL_FLAG_DMA = 1,
543 /* 8051 'idle' mode is disabled/enabled */
544 CONTROL_FLAG_IDLE_ENABLE = 2,
545 /* Tracker for the SPDIF-in path is bypassed/enabled */
546 CONTROL_FLAG_TRACKER = 3,
547 /* DigitalOut to Spdif2Out connection is disabled/enabled */
548 CONTROL_FLAG_SPDIF2OUT = 4,
549 /* Digital Microphone is disabled/enabled */
550 CONTROL_FLAG_DMIC = 5,
551 /* ADC_B rate is 48 kHz/96 kHz */
552 CONTROL_FLAG_ADC_B_96KHZ = 6,
553 /* ADC_C rate is 48 kHz/96 kHz */
554 CONTROL_FLAG_ADC_C_96KHZ = 7,
555 /* DAC rate is 48 kHz/96 kHz (affects all DACs) */
556 CONTROL_FLAG_DAC_96KHZ = 8,
557 /* DSP rate is 48 kHz/96 kHz */
558 CONTROL_FLAG_DSP_96KHZ = 9,
559 /* SRC clock is 98 MHz/196 MHz (196 MHz forces rate to 96 KHz) */
560 CONTROL_FLAG_SRC_CLOCK_196MHZ = 10,
561 /* SRC rate is 48 kHz/96 kHz (48 kHz disabled when clock is 196 MHz) */
562 CONTROL_FLAG_SRC_RATE_96KHZ = 11,
563 /* Decode Loop (DSP->SRC->DSP) is disabled/enabled */
564 CONTROL_FLAG_DECODE_LOOP = 12,
565 /* De-emphasis filter on DAC-1 disabled/enabled */
566 CONTROL_FLAG_DAC1_DEEMPHASIS = 13,
567 /* De-emphasis filter on DAC-2 disabled/enabled */
568 CONTROL_FLAG_DAC2_DEEMPHASIS = 14,
569 /* De-emphasis filter on DAC-3 disabled/enabled */
570 CONTROL_FLAG_DAC3_DEEMPHASIS = 15,
571 /* High-pass filter on ADC_B disabled/enabled */
572 CONTROL_FLAG_ADC_B_HIGH_PASS = 16,
573 /* High-pass filter on ADC_C disabled/enabled */
574 CONTROL_FLAG_ADC_C_HIGH_PASS = 17,
575 /* Common mode on Port_A disabled/enabled */
576 CONTROL_FLAG_PORT_A_COMMON_MODE = 18,
577 /* Common mode on Port_D disabled/enabled */
578 CONTROL_FLAG_PORT_D_COMMON_MODE = 19,
579 /* Impedance for ramp generator on Port_A 16 Ohm/10K Ohm */
580 CONTROL_FLAG_PORT_A_10KOHM_LOAD = 20,
581 /* Impedance for ramp generator on Port_D, 16 Ohm/10K Ohm */
Ian Minett4aa3bb02012-09-20 20:29:15 -0700582 CONTROL_FLAG_PORT_D_10KOHM_LOAD = 21,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700583 /* ASI rate is 48kHz/96kHz */
584 CONTROL_FLAG_ASI_96KHZ = 22,
585 /* DAC power settings able to control attached ports no/yes */
586 CONTROL_FLAG_DACS_CONTROL_PORTS = 23,
587 /* Clock Stop OK reporting is disabled/enabled */
588 CONTROL_FLAG_CONTROL_STOP_OK_ENABLE = 24,
589 /* Number of control flags */
590 CONTROL_FLAGS_MAX = (CONTROL_FLAG_CONTROL_STOP_OK_ENABLE+1)
591};
592
593/*
594 * Control parameter IDs
595 */
Ian Minett4aa3bb02012-09-20 20:29:15 -0700596enum control_param_id {
Ian Minettef6b2ea2012-12-20 18:53:33 -0800597 /* 0: None, 1: Mic1In*/
598 CONTROL_PARAM_VIP_SOURCE = 1,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700599 /* 0: force HDA, 1: allow DSP if HDA Spdif1Out stream is idle */
600 CONTROL_PARAM_SPDIF1_SOURCE = 2,
Ian Minettef6b2ea2012-12-20 18:53:33 -0800601 /* Port A output stage gain setting to use when 16 Ohm output
602 * impedance is selected*/
603 CONTROL_PARAM_PORTA_160OHM_GAIN = 8,
604 /* Port D output stage gain setting to use when 16 Ohm output
605 * impedance is selected*/
606 CONTROL_PARAM_PORTD_160OHM_GAIN = 10,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700607
608 /* Stream Control */
609
610 /* Select stream with the given ID */
611 CONTROL_PARAM_STREAM_ID = 24,
612 /* Source connection point for the selected stream */
613 CONTROL_PARAM_STREAM_SOURCE_CONN_POINT = 25,
614 /* Destination connection point for the selected stream */
615 CONTROL_PARAM_STREAM_DEST_CONN_POINT = 26,
616 /* Number of audio channels in the selected stream */
617 CONTROL_PARAM_STREAMS_CHANNELS = 27,
618 /*Enable control for the selected stream */
619 CONTROL_PARAM_STREAM_CONTROL = 28,
620
621 /* Connection Point Control */
622
623 /* Select connection point with the given ID */
624 CONTROL_PARAM_CONN_POINT_ID = 29,
625 /* Connection point sample rate */
626 CONTROL_PARAM_CONN_POINT_SAMPLE_RATE = 30,
627
628 /* Node Control */
629
630 /* Select HDA node with the given ID */
631 CONTROL_PARAM_NODE_ID = 31
632};
633
634/*
635 * Dsp Io Status codes
636 */
637enum hda_vendor_status_dspio {
638 /* Success */
639 VENDOR_STATUS_DSPIO_OK = 0x00,
640 /* Busy, unable to accept new command, the host must retry */
641 VENDOR_STATUS_DSPIO_BUSY = 0x01,
642 /* SCP command queue is full */
643 VENDOR_STATUS_DSPIO_SCP_COMMAND_QUEUE_FULL = 0x02,
644 /* SCP response queue is empty */
645 VENDOR_STATUS_DSPIO_SCP_RESPONSE_QUEUE_EMPTY = 0x03
646};
647
648/*
649 * Chip Io Status codes
650 */
651enum hda_vendor_status_chipio {
652 /* Success */
653 VENDOR_STATUS_CHIPIO_OK = 0x00,
654 /* Busy, unable to accept new command, the host must retry */
655 VENDOR_STATUS_CHIPIO_BUSY = 0x01
656};
657
658/*
659 * CA0132 sample rate
660 */
661enum ca0132_sample_rate {
662 SR_6_000 = 0x00,
663 SR_8_000 = 0x01,
664 SR_9_600 = 0x02,
665 SR_11_025 = 0x03,
666 SR_16_000 = 0x04,
667 SR_22_050 = 0x05,
668 SR_24_000 = 0x06,
669 SR_32_000 = 0x07,
670 SR_44_100 = 0x08,
671 SR_48_000 = 0x09,
672 SR_88_200 = 0x0A,
673 SR_96_000 = 0x0B,
674 SR_144_000 = 0x0C,
675 SR_176_400 = 0x0D,
676 SR_192_000 = 0x0E,
677 SR_384_000 = 0x0F,
678
679 SR_COUNT = 0x10,
680
681 SR_RATE_UNKNOWN = 0x1F
682};
683
Ian Minett01ef7db2012-09-20 20:29:16 -0700684enum dsp_download_state {
685 DSP_DOWNLOAD_FAILED = -1,
686 DSP_DOWNLOAD_INIT = 0,
687 DSP_DOWNLOADING = 1,
688 DSP_DOWNLOADED = 2
689};
690
Ian Minett01ef7db2012-09-20 20:29:16 -0700691/* retrieve parameters from hda format */
692#define get_hdafmt_chs(fmt) (fmt & 0xf)
693#define get_hdafmt_bits(fmt) ((fmt >> 4) & 0x7)
694#define get_hdafmt_rate(fmt) ((fmt >> 8) & 0x7f)
695#define get_hdafmt_type(fmt) ((fmt >> 15) & 0x1)
Ian Minett95c6e9c2011-06-15 15:35:17 -0700696
697/*
698 * CA0132 specific
699 */
700
701struct ca0132_spec {
Ian Minetta7e76272012-12-20 18:53:35 -0800702 struct snd_kcontrol_new *mixers[5];
703 unsigned int num_mixers;
Ian Minett5aaca442012-12-20 18:53:34 -0800704 const struct hda_verb *base_init_verbs;
705 const struct hda_verb *base_exit_verbs;
706 const struct hda_verb *init_verbs[5];
707 unsigned int num_init_verbs; /* exclude base init verbs */
Ian Minett95c6e9c2011-06-15 15:35:17 -0700708 struct auto_pin_cfg autocfg;
Ian Minett5aaca442012-12-20 18:53:34 -0800709
710 /* Nodes configurations */
Ian Minett95c6e9c2011-06-15 15:35:17 -0700711 struct hda_multi_out multiout;
712 hda_nid_t out_pins[AUTO_CFG_MAX_OUTS];
713 hda_nid_t dacs[AUTO_CFG_MAX_OUTS];
Ian Minett5aaca442012-12-20 18:53:34 -0800714 unsigned int num_outputs;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700715 hda_nid_t input_pins[AUTO_PIN_LAST];
716 hda_nid_t adcs[AUTO_PIN_LAST];
717 hda_nid_t dig_out;
718 hda_nid_t dig_in;
719 unsigned int num_inputs;
Ian Minetta7e76272012-12-20 18:53:35 -0800720 hda_nid_t shared_mic_nid;
721 hda_nid_t shared_out_nid;
Ian Minett5aaca442012-12-20 18:53:34 -0800722 struct hda_pcm pcm_rec[5]; /* PCM information */
Ian Minett01ef7db2012-09-20 20:29:16 -0700723
724 /* chip access */
725 struct mutex chipio_mutex; /* chip access mutex */
726 u32 curr_chip_addx;
727
728 /* DSP download related */
729 enum dsp_download_state dsp_state;
730 unsigned int dsp_stream_id;
731 unsigned int wait_scp;
732 unsigned int wait_scp_header;
733 unsigned int wait_num_data;
734 unsigned int scp_resp_header;
735 unsigned int scp_resp_data[4];
736 unsigned int scp_resp_count;
Ian Minett5aaca442012-12-20 18:53:34 -0800737
738 /* mixer and effects related */
739 unsigned char dmic_ctl;
740 int cur_out_type;
741 int cur_mic_type;
742 long vnode_lvol[VNODES_COUNT];
743 long vnode_rvol[VNODES_COUNT];
744 long vnode_lswitch[VNODES_COUNT];
745 long vnode_rswitch[VNODES_COUNT];
746 long effects_switch[EFFECTS_COUNT];
747 long voicefx_val;
748 long cur_mic_boost;
Ian Minett44f0c972012-12-20 18:53:38 -0800749
Chih-Chung Chang993884f2013-03-25 10:39:23 -0700750 struct hda_codec *codec;
751 struct delayed_work unsol_hp_work;
752
Ian Minett44f0c972012-12-20 18:53:38 -0800753#ifdef ENABLE_TUNING_CONTROLS
754 long cur_ctl_vals[TUNING_CTLS_COUNT];
755#endif
Ian Minett95c6e9c2011-06-15 15:35:17 -0700756};
757
Ian Minett01ef7db2012-09-20 20:29:16 -0700758/*
759 * CA0132 codec access
760 */
Sachin Kamat399ae722013-09-13 15:14:22 +0530761static unsigned int codec_send_command(struct hda_codec *codec, hda_nid_t nid,
Ian Minett01ef7db2012-09-20 20:29:16 -0700762 unsigned int verb, unsigned int parm, unsigned int *res)
763{
764 unsigned int response;
765 response = snd_hda_codec_read(codec, nid, 0, verb, parm);
766 *res = response;
767
768 return ((response == -1) ? -1 : 0);
769}
770
771static int codec_set_converter_format(struct hda_codec *codec, hda_nid_t nid,
772 unsigned short converter_format, unsigned int *res)
773{
774 return codec_send_command(codec, nid, VENDOR_CHIPIO_STREAM_FORMAT,
775 converter_format & 0xffff, res);
776}
777
778static int codec_set_converter_stream_channel(struct hda_codec *codec,
779 hda_nid_t nid, unsigned char stream,
780 unsigned char channel, unsigned int *res)
781{
782 unsigned char converter_stream_channel = 0;
783
784 converter_stream_channel = (stream << 4) | (channel & 0x0f);
785 return codec_send_command(codec, nid, AC_VERB_SET_CHANNEL_STREAMID,
786 converter_stream_channel, res);
787}
788
Ian Minett95c6e9c2011-06-15 15:35:17 -0700789/* Chip access helper function */
790static int chipio_send(struct hda_codec *codec,
791 unsigned int reg,
792 unsigned int data)
793{
794 unsigned int res;
Ian Minett6d675302013-02-08 18:31:43 -0800795 unsigned long timeout = jiffies + msecs_to_jiffies(1000);
Ian Minett95c6e9c2011-06-15 15:35:17 -0700796
797 /* send bits of data specified by reg */
798 do {
799 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0,
800 reg, data);
801 if (res == VENDOR_STATUS_CHIPIO_OK)
802 return 0;
Ian Minett6d675302013-02-08 18:31:43 -0800803 msleep(20);
804 } while (time_before(jiffies, timeout));
805
Ian Minett95c6e9c2011-06-15 15:35:17 -0700806 return -EIO;
807}
808
809/*
810 * Write chip address through the vendor widget -- NOT protected by the Mutex!
811 */
812static int chipio_write_address(struct hda_codec *codec,
813 unsigned int chip_addx)
814{
Ian Minett4861af82012-09-20 20:29:20 -0700815 struct ca0132_spec *spec = codec->spec;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700816 int res;
817
Ian Minett4861af82012-09-20 20:29:20 -0700818 if (spec->curr_chip_addx == chip_addx)
819 return 0;
820
Ian Minett95c6e9c2011-06-15 15:35:17 -0700821 /* send low 16 bits of the address */
822 res = chipio_send(codec, VENDOR_CHIPIO_ADDRESS_LOW,
823 chip_addx & 0xffff);
824
825 if (res != -EIO) {
826 /* send high 16 bits of the address */
827 res = chipio_send(codec, VENDOR_CHIPIO_ADDRESS_HIGH,
828 chip_addx >> 16);
829 }
830
Ian Minett4861af82012-09-20 20:29:20 -0700831 spec->curr_chip_addx = (res < 0) ? ~0UL : chip_addx;
832
Ian Minett95c6e9c2011-06-15 15:35:17 -0700833 return res;
834}
835
836/*
837 * Write data through the vendor widget -- NOT protected by the Mutex!
838 */
Ian Minett95c6e9c2011-06-15 15:35:17 -0700839static int chipio_write_data(struct hda_codec *codec, unsigned int data)
840{
Ian Minett5aaca442012-12-20 18:53:34 -0800841 struct ca0132_spec *spec = codec->spec;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700842 int res;
843
844 /* send low 16 bits of the data */
845 res = chipio_send(codec, VENDOR_CHIPIO_DATA_LOW, data & 0xffff);
846
847 if (res != -EIO) {
848 /* send high 16 bits of the data */
849 res = chipio_send(codec, VENDOR_CHIPIO_DATA_HIGH,
850 data >> 16);
851 }
852
Ian Minett5aaca442012-12-20 18:53:34 -0800853 /*If no error encountered, automatically increment the address
854 as per chip behaviour*/
855 spec->curr_chip_addx = (res != -EIO) ?
856 (spec->curr_chip_addx + 4) : ~0UL;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700857 return res;
858}
859
Ian Minettd5c21b82012-09-20 20:29:18 -0700860/*
861 * Write multiple data through the vendor widget -- NOT protected by the Mutex!
862 */
Ian Minett01ef7db2012-09-20 20:29:16 -0700863static int chipio_write_data_multiple(struct hda_codec *codec,
864 const u32 *data,
865 unsigned int count)
866{
867 int status = 0;
868
869 if (data == NULL) {
Takashi Iwai4e76a882014-02-25 12:21:03 +0100870 codec_dbg(codec, "chipio_write_data null ptr\n");
Ian Minett01ef7db2012-09-20 20:29:16 -0700871 return -EINVAL;
872 }
873
874 while ((count-- != 0) && (status == 0))
875 status = chipio_write_data(codec, *data++);
876
877 return status;
878}
879
880
Ian Minett95c6e9c2011-06-15 15:35:17 -0700881/*
882 * Read data through the vendor widget -- NOT protected by the Mutex!
883 */
884static int chipio_read_data(struct hda_codec *codec, unsigned int *data)
885{
Ian Minett5aaca442012-12-20 18:53:34 -0800886 struct ca0132_spec *spec = codec->spec;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700887 int res;
888
889 /* post read */
890 res = chipio_send(codec, VENDOR_CHIPIO_HIC_POST_READ, 0);
891
892 if (res != -EIO) {
893 /* read status */
894 res = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
895 }
896
897 if (res != -EIO) {
898 /* read data */
899 *data = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0,
900 VENDOR_CHIPIO_HIC_READ_DATA,
901 0);
902 }
903
Ian Minett5aaca442012-12-20 18:53:34 -0800904 /*If no error encountered, automatically increment the address
905 as per chip behaviour*/
906 spec->curr_chip_addx = (res != -EIO) ?
907 (spec->curr_chip_addx + 4) : ~0UL;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700908 return res;
909}
910
911/*
912 * Write given value to the given address through the chip I/O widget.
913 * protected by the Mutex
914 */
915static int chipio_write(struct hda_codec *codec,
916 unsigned int chip_addx, const unsigned int data)
917{
918 struct ca0132_spec *spec = codec->spec;
919 int err;
920
921 mutex_lock(&spec->chipio_mutex);
922
923 /* write the address, and if successful proceed to write data */
924 err = chipio_write_address(codec, chip_addx);
925 if (err < 0)
926 goto exit;
927
928 err = chipio_write_data(codec, data);
929 if (err < 0)
930 goto exit;
931
932exit:
933 mutex_unlock(&spec->chipio_mutex);
934 return err;
935}
936
Ian Minettd5c21b82012-09-20 20:29:18 -0700937/*
938 * Write multiple values to the given address through the chip I/O widget.
939 * protected by the Mutex
940 */
Ian Minett01ef7db2012-09-20 20:29:16 -0700941static int chipio_write_multiple(struct hda_codec *codec,
942 u32 chip_addx,
943 const u32 *data,
944 unsigned int count)
945{
946 struct ca0132_spec *spec = codec->spec;
947 int status;
948
949 mutex_lock(&spec->chipio_mutex);
Ian Minett4861af82012-09-20 20:29:20 -0700950 status = chipio_write_address(codec, chip_addx);
Ian Minett01ef7db2012-09-20 20:29:16 -0700951 if (status < 0)
952 goto error;
953
954 status = chipio_write_data_multiple(codec, data, count);
955error:
956 mutex_unlock(&spec->chipio_mutex);
957
958 return status;
959}
960
Ian Minett95c6e9c2011-06-15 15:35:17 -0700961/*
962 * Read the given address through the chip I/O widget
963 * protected by the Mutex
964 */
965static int chipio_read(struct hda_codec *codec,
966 unsigned int chip_addx, unsigned int *data)
967{
968 struct ca0132_spec *spec = codec->spec;
969 int err;
970
971 mutex_lock(&spec->chipio_mutex);
972
973 /* write the address, and if successful proceed to write data */
974 err = chipio_write_address(codec, chip_addx);
975 if (err < 0)
976 goto exit;
977
978 err = chipio_read_data(codec, data);
979 if (err < 0)
980 goto exit;
981
982exit:
983 mutex_unlock(&spec->chipio_mutex);
984 return err;
985}
986
Ian Minettd5c21b82012-09-20 20:29:18 -0700987/*
988 * Set chip control flags through the chip I/O widget.
989 */
Ian Minett01ef7db2012-09-20 20:29:16 -0700990static void chipio_set_control_flag(struct hda_codec *codec,
991 enum control_flag_id flag_id,
992 bool flag_state)
993{
994 unsigned int val;
995 unsigned int flag_bit;
996
997 flag_bit = (flag_state ? 1 : 0);
998 val = (flag_bit << 7) | (flag_id);
999 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1000 VENDOR_CHIPIO_FLAG_SET, val);
1001}
1002
Ian Minettd5c21b82012-09-20 20:29:18 -07001003/*
1004 * Set chip parameters through the chip I/O widget.
1005 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001006static void chipio_set_control_param(struct hda_codec *codec,
1007 enum control_param_id param_id, int param_val)
1008{
1009 struct ca0132_spec *spec = codec->spec;
1010 int val;
1011
1012 if ((param_id < 32) && (param_val < 8)) {
1013 val = (param_val << 5) | (param_id);
1014 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1015 VENDOR_CHIPIO_PARAM_SET, val);
1016 } else {
1017 mutex_lock(&spec->chipio_mutex);
1018 if (chipio_send(codec, VENDOR_CHIPIO_STATUS, 0) == 0) {
1019 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1020 VENDOR_CHIPIO_PARAM_EX_ID_SET,
1021 param_id);
1022 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1023 VENDOR_CHIPIO_PARAM_EX_VALUE_SET,
1024 param_val);
1025 }
1026 mutex_unlock(&spec->chipio_mutex);
1027 }
1028}
1029
Ian Minettd5c21b82012-09-20 20:29:18 -07001030/*
1031 * Set sampling rate of the connection point.
1032 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001033static void chipio_set_conn_rate(struct hda_codec *codec,
1034 int connid, enum ca0132_sample_rate rate)
1035{
1036 chipio_set_control_param(codec, CONTROL_PARAM_CONN_POINT_ID, connid);
1037 chipio_set_control_param(codec, CONTROL_PARAM_CONN_POINT_SAMPLE_RATE,
1038 rate);
1039}
1040
Ian Minettd5c21b82012-09-20 20:29:18 -07001041/*
1042 * Enable clocks.
1043 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001044static void chipio_enable_clocks(struct hda_codec *codec)
1045{
1046 struct ca0132_spec *spec = codec->spec;
1047
1048 mutex_lock(&spec->chipio_mutex);
1049 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1050 VENDOR_CHIPIO_8051_ADDRESS_LOW, 0);
1051 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1052 VENDOR_CHIPIO_PLL_PMU_WRITE, 0xff);
1053 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1054 VENDOR_CHIPIO_8051_ADDRESS_LOW, 5);
1055 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1056 VENDOR_CHIPIO_PLL_PMU_WRITE, 0x0b);
1057 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1058 VENDOR_CHIPIO_8051_ADDRESS_LOW, 6);
1059 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1060 VENDOR_CHIPIO_PLL_PMU_WRITE, 0xff);
1061 mutex_unlock(&spec->chipio_mutex);
1062}
1063
1064/*
1065 * CA0132 DSP IO stuffs
1066 */
1067static int dspio_send(struct hda_codec *codec, unsigned int reg,
1068 unsigned int data)
1069{
Takashi Iwaib645d792013-01-15 17:39:29 +01001070 int res;
Ian Minett6d675302013-02-08 18:31:43 -08001071 unsigned long timeout = jiffies + msecs_to_jiffies(1000);
Ian Minett01ef7db2012-09-20 20:29:16 -07001072
1073 /* send bits of data specified by reg to dsp */
1074 do {
1075 res = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, reg, data);
1076 if ((res >= 0) && (res != VENDOR_STATUS_DSPIO_BUSY))
1077 return res;
Ian Minett6d675302013-02-08 18:31:43 -08001078 msleep(20);
1079 } while (time_before(jiffies, timeout));
Ian Minett01ef7db2012-09-20 20:29:16 -07001080
1081 return -EIO;
1082}
1083
Ian Minettd5c21b82012-09-20 20:29:18 -07001084/*
1085 * Wait for DSP to be ready for commands
1086 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001087static void dspio_write_wait(struct hda_codec *codec)
1088{
Ian Minett4861af82012-09-20 20:29:20 -07001089 int status;
1090 unsigned long timeout = jiffies + msecs_to_jiffies(1000);
Ian Minett01ef7db2012-09-20 20:29:16 -07001091
Ian Minett01ef7db2012-09-20 20:29:16 -07001092 do {
Ian Minett4861af82012-09-20 20:29:20 -07001093 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0,
1094 VENDOR_DSPIO_STATUS, 0);
1095 if ((status == VENDOR_STATUS_DSPIO_OK) ||
1096 (status == VENDOR_STATUS_DSPIO_SCP_RESPONSE_QUEUE_EMPTY))
1097 break;
1098 msleep(1);
1099 } while (time_before(jiffies, timeout));
Ian Minett01ef7db2012-09-20 20:29:16 -07001100}
1101
Ian Minettd5c21b82012-09-20 20:29:18 -07001102/*
1103 * Write SCP data to DSP
1104 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001105static int dspio_write(struct hda_codec *codec, unsigned int scp_data)
1106{
1107 struct ca0132_spec *spec = codec->spec;
1108 int status;
1109
1110 dspio_write_wait(codec);
1111
1112 mutex_lock(&spec->chipio_mutex);
1113 status = dspio_send(codec, VENDOR_DSPIO_SCP_WRITE_DATA_LOW,
1114 scp_data & 0xffff);
1115 if (status < 0)
1116 goto error;
1117
1118 status = dspio_send(codec, VENDOR_DSPIO_SCP_WRITE_DATA_HIGH,
1119 scp_data >> 16);
1120 if (status < 0)
1121 goto error;
1122
1123 /* OK, now check if the write itself has executed*/
1124 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0,
1125 VENDOR_DSPIO_STATUS, 0);
1126error:
1127 mutex_unlock(&spec->chipio_mutex);
1128
1129 return (status == VENDOR_STATUS_DSPIO_SCP_COMMAND_QUEUE_FULL) ?
1130 -EIO : 0;
1131}
1132
Ian Minettd5c21b82012-09-20 20:29:18 -07001133/*
1134 * Write multiple SCP data to DSP
1135 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001136static int dspio_write_multiple(struct hda_codec *codec,
1137 unsigned int *buffer, unsigned int size)
1138{
1139 int status = 0;
1140 unsigned int count;
1141
1142 if ((buffer == NULL))
1143 return -EINVAL;
1144
1145 count = 0;
1146 while (count < size) {
1147 status = dspio_write(codec, *buffer++);
1148 if (status != 0)
1149 break;
1150 count++;
1151 }
1152
1153 return status;
1154}
1155
Ian Minetta73d5112012-12-20 18:53:37 -08001156static int dspio_read(struct hda_codec *codec, unsigned int *data)
1157{
1158 int status;
1159
1160 status = dspio_send(codec, VENDOR_DSPIO_SCP_POST_READ_DATA, 0);
1161 if (status == -EIO)
1162 return status;
1163
1164 status = dspio_send(codec, VENDOR_DSPIO_STATUS, 0);
1165 if (status == -EIO ||
1166 status == VENDOR_STATUS_DSPIO_SCP_RESPONSE_QUEUE_EMPTY)
1167 return -EIO;
1168
1169 *data = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0,
1170 VENDOR_DSPIO_SCP_READ_DATA, 0);
1171
1172 return 0;
1173}
1174
1175static int dspio_read_multiple(struct hda_codec *codec, unsigned int *buffer,
1176 unsigned int *buf_size, unsigned int size_count)
1177{
1178 int status = 0;
1179 unsigned int size = *buf_size;
1180 unsigned int count;
1181 unsigned int skip_count;
1182 unsigned int dummy;
1183
1184 if ((buffer == NULL))
1185 return -1;
1186
1187 count = 0;
1188 while (count < size && count < size_count) {
1189 status = dspio_read(codec, buffer++);
1190 if (status != 0)
1191 break;
1192 count++;
1193 }
1194
1195 skip_count = count;
1196 if (status == 0) {
1197 while (skip_count < size) {
1198 status = dspio_read(codec, &dummy);
1199 if (status != 0)
1200 break;
1201 skip_count++;
1202 }
1203 }
1204 *buf_size = count;
1205
1206 return status;
1207}
1208
Ian Minettd5c21b82012-09-20 20:29:18 -07001209/*
1210 * Construct the SCP header using corresponding fields
1211 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001212static inline unsigned int
1213make_scp_header(unsigned int target_id, unsigned int source_id,
1214 unsigned int get_flag, unsigned int req,
1215 unsigned int device_flag, unsigned int resp_flag,
1216 unsigned int error_flag, unsigned int data_size)
1217{
1218 unsigned int header = 0;
1219
1220 header = (data_size & 0x1f) << 27;
1221 header |= (error_flag & 0x01) << 26;
1222 header |= (resp_flag & 0x01) << 25;
1223 header |= (device_flag & 0x01) << 24;
1224 header |= (req & 0x7f) << 17;
1225 header |= (get_flag & 0x01) << 16;
1226 header |= (source_id & 0xff) << 8;
1227 header |= target_id & 0xff;
1228
1229 return header;
1230}
1231
Ian Minettd5c21b82012-09-20 20:29:18 -07001232/*
1233 * Extract corresponding fields from SCP header
1234 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001235static inline void
1236extract_scp_header(unsigned int header,
1237 unsigned int *target_id, unsigned int *source_id,
1238 unsigned int *get_flag, unsigned int *req,
1239 unsigned int *device_flag, unsigned int *resp_flag,
1240 unsigned int *error_flag, unsigned int *data_size)
1241{
1242 if (data_size)
1243 *data_size = (header >> 27) & 0x1f;
1244 if (error_flag)
1245 *error_flag = (header >> 26) & 0x01;
1246 if (resp_flag)
1247 *resp_flag = (header >> 25) & 0x01;
1248 if (device_flag)
1249 *device_flag = (header >> 24) & 0x01;
1250 if (req)
1251 *req = (header >> 17) & 0x7f;
1252 if (get_flag)
1253 *get_flag = (header >> 16) & 0x01;
1254 if (source_id)
1255 *source_id = (header >> 8) & 0xff;
1256 if (target_id)
1257 *target_id = header & 0xff;
1258}
1259
1260#define SCP_MAX_DATA_WORDS (16)
1261
1262/* Structure to contain any SCP message */
1263struct scp_msg {
1264 unsigned int hdr;
1265 unsigned int data[SCP_MAX_DATA_WORDS];
1266};
1267
Ian Minetta73d5112012-12-20 18:53:37 -08001268static void dspio_clear_response_queue(struct hda_codec *codec)
1269{
1270 unsigned int dummy = 0;
1271 int status = -1;
1272
1273 /* clear all from the response queue */
1274 do {
1275 status = dspio_read(codec, &dummy);
1276 } while (status == 0);
1277}
1278
1279static int dspio_get_response_data(struct hda_codec *codec)
1280{
1281 struct ca0132_spec *spec = codec->spec;
1282 unsigned int data = 0;
1283 unsigned int count;
1284
1285 if (dspio_read(codec, &data) < 0)
1286 return -EIO;
1287
1288 if ((data & 0x00ffffff) == spec->wait_scp_header) {
1289 spec->scp_resp_header = data;
1290 spec->scp_resp_count = data >> 27;
1291 count = spec->wait_num_data;
1292 dspio_read_multiple(codec, spec->scp_resp_data,
1293 &spec->scp_resp_count, count);
1294 return 0;
1295 }
1296
1297 return -EIO;
1298}
1299
Ian Minettd5c21b82012-09-20 20:29:18 -07001300/*
1301 * Send SCP message to DSP
1302 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001303static int dspio_send_scp_message(struct hda_codec *codec,
1304 unsigned char *send_buf,
1305 unsigned int send_buf_size,
1306 unsigned char *return_buf,
1307 unsigned int return_buf_size,
1308 unsigned int *bytes_returned)
1309{
1310 struct ca0132_spec *spec = codec->spec;
Ian Minett01ef7db2012-09-20 20:29:16 -07001311 int status = -1;
1312 unsigned int scp_send_size = 0;
1313 unsigned int total_size;
1314 bool waiting_for_resp = false;
1315 unsigned int header;
1316 struct scp_msg *ret_msg;
1317 unsigned int resp_src_id, resp_target_id;
1318 unsigned int data_size, src_id, target_id, get_flag, device_flag;
1319
1320 if (bytes_returned)
1321 *bytes_returned = 0;
1322
1323 /* get scp header from buffer */
1324 header = *((unsigned int *)send_buf);
1325 extract_scp_header(header, &target_id, &src_id, &get_flag, NULL,
1326 &device_flag, NULL, NULL, &data_size);
1327 scp_send_size = data_size + 1;
1328 total_size = (scp_send_size * 4);
1329
1330 if (send_buf_size < total_size)
1331 return -EINVAL;
1332
1333 if (get_flag || device_flag) {
1334 if (!return_buf || return_buf_size < 4 || !bytes_returned)
1335 return -EINVAL;
1336
1337 spec->wait_scp_header = *((unsigned int *)send_buf);
1338
1339 /* swap source id with target id */
1340 resp_target_id = src_id;
1341 resp_src_id = target_id;
1342 spec->wait_scp_header &= 0xffff0000;
1343 spec->wait_scp_header |= (resp_src_id << 8) | (resp_target_id);
1344 spec->wait_num_data = return_buf_size/sizeof(unsigned int) - 1;
1345 spec->wait_scp = 1;
1346 waiting_for_resp = true;
1347 }
1348
1349 status = dspio_write_multiple(codec, (unsigned int *)send_buf,
1350 scp_send_size);
1351 if (status < 0) {
1352 spec->wait_scp = 0;
1353 return status;
1354 }
1355
1356 if (waiting_for_resp) {
Ian Minett6d675302013-02-08 18:31:43 -08001357 unsigned long timeout = jiffies + msecs_to_jiffies(1000);
Ian Minett01ef7db2012-09-20 20:29:16 -07001358 memset(return_buf, 0, return_buf_size);
Ian Minett01ef7db2012-09-20 20:29:16 -07001359 do {
1360 msleep(20);
Ian Minett6d675302013-02-08 18:31:43 -08001361 } while (spec->wait_scp && time_before(jiffies, timeout));
Ian Minett01ef7db2012-09-20 20:29:16 -07001362 waiting_for_resp = false;
Ian Minett6d675302013-02-08 18:31:43 -08001363 if (!spec->wait_scp) {
Ian Minett01ef7db2012-09-20 20:29:16 -07001364 ret_msg = (struct scp_msg *)return_buf;
1365 memcpy(&ret_msg->hdr, &spec->scp_resp_header, 4);
1366 memcpy(&ret_msg->data, spec->scp_resp_data,
1367 spec->wait_num_data);
1368 *bytes_returned = (spec->scp_resp_count + 1) * 4;
1369 status = 0;
1370 } else {
1371 status = -EIO;
1372 }
1373 spec->wait_scp = 0;
1374 }
1375
1376 return status;
1377}
1378
Ian Minettd5c21b82012-09-20 20:29:18 -07001379/**
1380 * Prepare and send the SCP message to DSP
1381 * @codec: the HDA codec
1382 * @mod_id: ID of the DSP module to send the command
1383 * @req: ID of request to send to the DSP module
1384 * @dir: SET or GET
1385 * @data: pointer to the data to send with the request, request specific
1386 * @len: length of the data, in bytes
1387 * @reply: point to the buffer to hold data returned for a reply
1388 * @reply_len: length of the reply buffer returned from GET
1389 *
1390 * Returns zero or a negative error code.
1391 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001392static int dspio_scp(struct hda_codec *codec,
1393 int mod_id, int req, int dir, void *data, unsigned int len,
1394 void *reply, unsigned int *reply_len)
1395{
1396 int status = 0;
1397 struct scp_msg scp_send, scp_reply;
1398 unsigned int ret_bytes, send_size, ret_size;
1399 unsigned int send_get_flag, reply_resp_flag, reply_error_flag;
1400 unsigned int reply_data_size;
1401
1402 memset(&scp_send, 0, sizeof(scp_send));
1403 memset(&scp_reply, 0, sizeof(scp_reply));
1404
1405 if ((len != 0 && data == NULL) || (len > SCP_MAX_DATA_WORDS))
1406 return -EINVAL;
1407
1408 if (dir == SCP_GET && reply == NULL) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001409 codec_dbg(codec, "dspio_scp get but has no buffer\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001410 return -EINVAL;
1411 }
1412
1413 if (reply != NULL && (reply_len == NULL || (*reply_len == 0))) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001414 codec_dbg(codec, "dspio_scp bad resp buf len parms\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001415 return -EINVAL;
1416 }
1417
1418 scp_send.hdr = make_scp_header(mod_id, 0x20, (dir == SCP_GET), req,
1419 0, 0, 0, len/sizeof(unsigned int));
1420 if (data != NULL && len > 0) {
1421 len = min((unsigned int)(sizeof(scp_send.data)), len);
1422 memcpy(scp_send.data, data, len);
1423 }
1424
1425 ret_bytes = 0;
1426 send_size = sizeof(unsigned int) + len;
1427 status = dspio_send_scp_message(codec, (unsigned char *)&scp_send,
1428 send_size, (unsigned char *)&scp_reply,
1429 sizeof(scp_reply), &ret_bytes);
1430
1431 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001432 codec_dbg(codec, "dspio_scp: send scp msg failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001433 return status;
1434 }
1435
1436 /* extract send and reply headers members */
1437 extract_scp_header(scp_send.hdr, NULL, NULL, &send_get_flag,
1438 NULL, NULL, NULL, NULL, NULL);
1439 extract_scp_header(scp_reply.hdr, NULL, NULL, NULL, NULL, NULL,
1440 &reply_resp_flag, &reply_error_flag,
1441 &reply_data_size);
1442
1443 if (!send_get_flag)
1444 return 0;
1445
1446 if (reply_resp_flag && !reply_error_flag) {
1447 ret_size = (ret_bytes - sizeof(scp_reply.hdr))
1448 / sizeof(unsigned int);
1449
1450 if (*reply_len < ret_size*sizeof(unsigned int)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001451 codec_dbg(codec, "reply too long for buf\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001452 return -EINVAL;
1453 } else if (ret_size != reply_data_size) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001454 codec_dbg(codec, "RetLen and HdrLen .NE.\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001455 return -EINVAL;
1456 } else {
1457 *reply_len = ret_size*sizeof(unsigned int);
1458 memcpy(reply, scp_reply.data, *reply_len);
1459 }
1460 } else {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001461 codec_dbg(codec, "reply ill-formed or errflag set\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001462 return -EIO;
1463 }
1464
1465 return status;
1466}
1467
Ian Minettd5c21b82012-09-20 20:29:18 -07001468/*
Ian Minett5aaca442012-12-20 18:53:34 -08001469 * Set DSP parameters
1470 */
1471static int dspio_set_param(struct hda_codec *codec, int mod_id,
1472 int req, void *data, unsigned int len)
1473{
1474 return dspio_scp(codec, mod_id, req, SCP_SET, data, len, NULL, NULL);
1475}
1476
1477static int dspio_set_uint_param(struct hda_codec *codec, int mod_id,
1478 int req, unsigned int data)
1479{
1480 return dspio_set_param(codec, mod_id, req, &data, sizeof(unsigned int));
1481}
1482
1483/*
Ian Minettd5c21b82012-09-20 20:29:18 -07001484 * Allocate a DSP DMA channel via an SCP message
1485 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001486static int dspio_alloc_dma_chan(struct hda_codec *codec, unsigned int *dma_chan)
1487{
1488 int status = 0;
1489 unsigned int size = sizeof(dma_chan);
1490
Takashi Iwai4e76a882014-02-25 12:21:03 +01001491 codec_dbg(codec, " dspio_alloc_dma_chan() -- begin\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001492 status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN,
1493 SCP_GET, NULL, 0, dma_chan, &size);
1494
1495 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001496 codec_dbg(codec, "dspio_alloc_dma_chan: SCP Failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001497 return status;
1498 }
1499
1500 if ((*dma_chan + 1) == 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001501 codec_dbg(codec, "no free dma channels to allocate\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001502 return -EBUSY;
1503 }
1504
Takashi Iwai4e76a882014-02-25 12:21:03 +01001505 codec_dbg(codec, "dspio_alloc_dma_chan: chan=%d\n", *dma_chan);
1506 codec_dbg(codec, " dspio_alloc_dma_chan() -- complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001507
1508 return status;
1509}
1510
Ian Minettd5c21b82012-09-20 20:29:18 -07001511/*
1512 * Free a DSP DMA via an SCP message
1513 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001514static int dspio_free_dma_chan(struct hda_codec *codec, unsigned int dma_chan)
1515{
1516 int status = 0;
1517 unsigned int dummy = 0;
1518
Takashi Iwai4e76a882014-02-25 12:21:03 +01001519 codec_dbg(codec, " dspio_free_dma_chan() -- begin\n");
1520 codec_dbg(codec, "dspio_free_dma_chan: chan=%d\n", dma_chan);
Ian Minett01ef7db2012-09-20 20:29:16 -07001521
1522 status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN,
1523 SCP_SET, &dma_chan, sizeof(dma_chan), NULL, &dummy);
1524
1525 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001526 codec_dbg(codec, "dspio_free_dma_chan: SCP Failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001527 return status;
1528 }
1529
Takashi Iwai4e76a882014-02-25 12:21:03 +01001530 codec_dbg(codec, " dspio_free_dma_chan() -- complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001531
1532 return status;
1533}
1534
1535/*
Ian Minettd5c21b82012-09-20 20:29:18 -07001536 * (Re)start the DSP
Ian Minett01ef7db2012-09-20 20:29:16 -07001537 */
1538static int dsp_set_run_state(struct hda_codec *codec)
1539{
1540 unsigned int dbg_ctrl_reg;
1541 unsigned int halt_state;
1542 int err;
1543
1544 err = chipio_read(codec, DSP_DBGCNTL_INST_OFFSET, &dbg_ctrl_reg);
1545 if (err < 0)
1546 return err;
1547
1548 halt_state = (dbg_ctrl_reg & DSP_DBGCNTL_STATE_MASK) >>
1549 DSP_DBGCNTL_STATE_LOBIT;
1550
1551 if (halt_state != 0) {
1552 dbg_ctrl_reg &= ~((halt_state << DSP_DBGCNTL_SS_LOBIT) &
1553 DSP_DBGCNTL_SS_MASK);
1554 err = chipio_write(codec, DSP_DBGCNTL_INST_OFFSET,
1555 dbg_ctrl_reg);
1556 if (err < 0)
1557 return err;
1558
1559 dbg_ctrl_reg |= (halt_state << DSP_DBGCNTL_EXEC_LOBIT) &
1560 DSP_DBGCNTL_EXEC_MASK;
1561 err = chipio_write(codec, DSP_DBGCNTL_INST_OFFSET,
1562 dbg_ctrl_reg);
1563 if (err < 0)
1564 return err;
1565 }
1566
1567 return 0;
1568}
1569
Ian Minettd5c21b82012-09-20 20:29:18 -07001570/*
1571 * Reset the DSP
1572 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001573static int dsp_reset(struct hda_codec *codec)
1574{
1575 unsigned int res;
1576 int retry = 20;
1577
Takashi Iwai4e76a882014-02-25 12:21:03 +01001578 codec_dbg(codec, "dsp_reset\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001579 do {
1580 res = dspio_send(codec, VENDOR_DSPIO_DSP_INIT, 0);
1581 retry--;
1582 } while (res == -EIO && retry);
1583
1584 if (!retry) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001585 codec_dbg(codec, "dsp_reset timeout\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001586 return -EIO;
1587 }
1588
1589 return 0;
1590}
1591
Ian Minettd5c21b82012-09-20 20:29:18 -07001592/*
1593 * Convert chip address to DSP address
1594 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001595static unsigned int dsp_chip_to_dsp_addx(unsigned int chip_addx,
1596 bool *code, bool *yram)
1597{
1598 *code = *yram = false;
1599
1600 if (UC_RANGE(chip_addx, 1)) {
1601 *code = true;
1602 return UC_OFF(chip_addx);
1603 } else if (X_RANGE_ALL(chip_addx, 1)) {
1604 return X_OFF(chip_addx);
1605 } else if (Y_RANGE_ALL(chip_addx, 1)) {
1606 *yram = true;
1607 return Y_OFF(chip_addx);
1608 }
1609
Takashi Iwai4a8b89f2013-02-12 10:15:15 +01001610 return INVALID_CHIP_ADDRESS;
Ian Minett01ef7db2012-09-20 20:29:16 -07001611}
1612
Ian Minettd5c21b82012-09-20 20:29:18 -07001613/*
1614 * Check if the DSP DMA is active
1615 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001616static bool dsp_is_dma_active(struct hda_codec *codec, unsigned int dma_chan)
1617{
1618 unsigned int dma_chnlstart_reg;
1619
1620 chipio_read(codec, DSPDMAC_CHNLSTART_INST_OFFSET, &dma_chnlstart_reg);
1621
1622 return ((dma_chnlstart_reg & (1 <<
1623 (DSPDMAC_CHNLSTART_EN_LOBIT + dma_chan))) != 0);
1624}
1625
1626static int dsp_dma_setup_common(struct hda_codec *codec,
1627 unsigned int chip_addx,
1628 unsigned int dma_chan,
1629 unsigned int port_map_mask,
1630 bool ovly)
1631{
1632 int status = 0;
1633 unsigned int chnl_prop;
1634 unsigned int dsp_addx;
1635 unsigned int active;
1636 bool code, yram;
1637
Takashi Iwai4e76a882014-02-25 12:21:03 +01001638 codec_dbg(codec, "-- dsp_dma_setup_common() -- Begin ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001639
1640 if (dma_chan >= DSPDMAC_DMA_CFG_CHANNEL_COUNT) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001641 codec_dbg(codec, "dma chan num invalid\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001642 return -EINVAL;
1643 }
1644
1645 if (dsp_is_dma_active(codec, dma_chan)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001646 codec_dbg(codec, "dma already active\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001647 return -EBUSY;
1648 }
1649
1650 dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram);
1651
1652 if (dsp_addx == INVALID_CHIP_ADDRESS) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001653 codec_dbg(codec, "invalid chip addr\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001654 return -ENXIO;
1655 }
1656
1657 chnl_prop = DSPDMAC_CHNLPROP_AC_MASK;
1658 active = 0;
1659
Takashi Iwai4e76a882014-02-25 12:21:03 +01001660 codec_dbg(codec, " dsp_dma_setup_common() start reg pgm\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001661
1662 if (ovly) {
1663 status = chipio_read(codec, DSPDMAC_CHNLPROP_INST_OFFSET,
1664 &chnl_prop);
1665
1666 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001667 codec_dbg(codec, "read CHNLPROP Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001668 return status;
1669 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001670 codec_dbg(codec, "dsp_dma_setup_common() Read CHNLPROP\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001671 }
1672
1673 if (!code)
1674 chnl_prop &= ~(1 << (DSPDMAC_CHNLPROP_MSPCE_LOBIT + dma_chan));
1675 else
1676 chnl_prop |= (1 << (DSPDMAC_CHNLPROP_MSPCE_LOBIT + dma_chan));
1677
1678 chnl_prop &= ~(1 << (DSPDMAC_CHNLPROP_DCON_LOBIT + dma_chan));
1679
1680 status = chipio_write(codec, DSPDMAC_CHNLPROP_INST_OFFSET, chnl_prop);
1681 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001682 codec_dbg(codec, "write CHNLPROP Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001683 return status;
1684 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001685 codec_dbg(codec, " dsp_dma_setup_common() Write CHNLPROP\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001686
1687 if (ovly) {
1688 status = chipio_read(codec, DSPDMAC_ACTIVE_INST_OFFSET,
1689 &active);
1690
1691 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001692 codec_dbg(codec, "read ACTIVE Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001693 return status;
1694 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001695 codec_dbg(codec, "dsp_dma_setup_common() Read ACTIVE\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001696 }
1697
1698 active &= (~(1 << (DSPDMAC_ACTIVE_AAR_LOBIT + dma_chan))) &
1699 DSPDMAC_ACTIVE_AAR_MASK;
1700
1701 status = chipio_write(codec, DSPDMAC_ACTIVE_INST_OFFSET, active);
1702 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001703 codec_dbg(codec, "write ACTIVE Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001704 return status;
1705 }
1706
Takashi Iwai4e76a882014-02-25 12:21:03 +01001707 codec_dbg(codec, " dsp_dma_setup_common() Write ACTIVE\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001708
1709 status = chipio_write(codec, DSPDMAC_AUDCHSEL_INST_OFFSET(dma_chan),
1710 port_map_mask);
1711 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001712 codec_dbg(codec, "write AUDCHSEL Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001713 return status;
1714 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001715 codec_dbg(codec, " dsp_dma_setup_common() Write AUDCHSEL\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001716
1717 status = chipio_write(codec, DSPDMAC_IRQCNT_INST_OFFSET(dma_chan),
1718 DSPDMAC_IRQCNT_BICNT_MASK | DSPDMAC_IRQCNT_CICNT_MASK);
1719 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001720 codec_dbg(codec, "write IRQCNT Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001721 return status;
1722 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001723 codec_dbg(codec, " dsp_dma_setup_common() Write IRQCNT\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001724
Takashi Iwai4e76a882014-02-25 12:21:03 +01001725 codec_dbg(codec,
Ian Minett01ef7db2012-09-20 20:29:16 -07001726 "ChipA=0x%x,DspA=0x%x,dmaCh=%u, "
1727 "CHSEL=0x%x,CHPROP=0x%x,Active=0x%x\n",
1728 chip_addx, dsp_addx, dma_chan,
1729 port_map_mask, chnl_prop, active);
1730
Takashi Iwai4e76a882014-02-25 12:21:03 +01001731 codec_dbg(codec, "-- dsp_dma_setup_common() -- Complete ------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001732
1733 return 0;
1734}
1735
Ian Minettd5c21b82012-09-20 20:29:18 -07001736/*
1737 * Setup the DSP DMA per-transfer-specific registers
1738 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001739static int dsp_dma_setup(struct hda_codec *codec,
1740 unsigned int chip_addx,
1741 unsigned int count,
1742 unsigned int dma_chan)
1743{
1744 int status = 0;
1745 bool code, yram;
1746 unsigned int dsp_addx;
1747 unsigned int addr_field;
1748 unsigned int incr_field;
1749 unsigned int base_cnt;
1750 unsigned int cur_cnt;
1751 unsigned int dma_cfg = 0;
1752 unsigned int adr_ofs = 0;
1753 unsigned int xfr_cnt = 0;
1754 const unsigned int max_dma_count = 1 << (DSPDMAC_XFRCNT_BCNT_HIBIT -
1755 DSPDMAC_XFRCNT_BCNT_LOBIT + 1);
1756
Takashi Iwai4e76a882014-02-25 12:21:03 +01001757 codec_dbg(codec, "-- dsp_dma_setup() -- Begin ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001758
1759 if (count > max_dma_count) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001760 codec_dbg(codec, "count too big\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001761 return -EINVAL;
1762 }
1763
1764 dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram);
1765 if (dsp_addx == INVALID_CHIP_ADDRESS) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001766 codec_dbg(codec, "invalid chip addr\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001767 return -ENXIO;
1768 }
1769
Takashi Iwai4e76a882014-02-25 12:21:03 +01001770 codec_dbg(codec, " dsp_dma_setup() start reg pgm\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001771
1772 addr_field = dsp_addx << DSPDMAC_DMACFG_DBADR_LOBIT;
1773 incr_field = 0;
1774
1775 if (!code) {
1776 addr_field <<= 1;
1777 if (yram)
1778 addr_field |= (1 << DSPDMAC_DMACFG_DBADR_LOBIT);
1779
1780 incr_field = (1 << DSPDMAC_DMACFG_AINCR_LOBIT);
1781 }
1782
1783 dma_cfg = addr_field + incr_field;
1784 status = chipio_write(codec, DSPDMAC_DMACFG_INST_OFFSET(dma_chan),
1785 dma_cfg);
1786 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001787 codec_dbg(codec, "write DMACFG Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001788 return status;
1789 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001790 codec_dbg(codec, " dsp_dma_setup() Write DMACFG\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001791
1792 adr_ofs = (count - 1) << (DSPDMAC_DSPADROFS_BOFS_LOBIT +
1793 (code ? 0 : 1));
1794
1795 status = chipio_write(codec, DSPDMAC_DSPADROFS_INST_OFFSET(dma_chan),
1796 adr_ofs);
1797 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001798 codec_dbg(codec, "write DSPADROFS Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001799 return status;
1800 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001801 codec_dbg(codec, " dsp_dma_setup() Write DSPADROFS\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001802
1803 base_cnt = (count - 1) << DSPDMAC_XFRCNT_BCNT_LOBIT;
1804
1805 cur_cnt = (count - 1) << DSPDMAC_XFRCNT_CCNT_LOBIT;
1806
1807 xfr_cnt = base_cnt | cur_cnt;
1808
1809 status = chipio_write(codec,
1810 DSPDMAC_XFRCNT_INST_OFFSET(dma_chan), xfr_cnt);
1811 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001812 codec_dbg(codec, "write XFRCNT Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001813 return status;
1814 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001815 codec_dbg(codec, " dsp_dma_setup() Write XFRCNT\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001816
Takashi Iwai4e76a882014-02-25 12:21:03 +01001817 codec_dbg(codec,
Ian Minett01ef7db2012-09-20 20:29:16 -07001818 "ChipA=0x%x, cnt=0x%x, DMACFG=0x%x, "
1819 "ADROFS=0x%x, XFRCNT=0x%x\n",
1820 chip_addx, count, dma_cfg, adr_ofs, xfr_cnt);
1821
Takashi Iwai4e76a882014-02-25 12:21:03 +01001822 codec_dbg(codec, "-- dsp_dma_setup() -- Complete ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001823
1824 return 0;
1825}
1826
Ian Minettd5c21b82012-09-20 20:29:18 -07001827/*
1828 * Start the DSP DMA
1829 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001830static int dsp_dma_start(struct hda_codec *codec,
1831 unsigned int dma_chan, bool ovly)
1832{
1833 unsigned int reg = 0;
1834 int status = 0;
1835
Takashi Iwai4e76a882014-02-25 12:21:03 +01001836 codec_dbg(codec, "-- dsp_dma_start() -- Begin ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001837
1838 if (ovly) {
1839 status = chipio_read(codec,
1840 DSPDMAC_CHNLSTART_INST_OFFSET, &reg);
1841
1842 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001843 codec_dbg(codec, "read CHNLSTART reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001844 return status;
1845 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001846 codec_dbg(codec, "-- dsp_dma_start() Read CHNLSTART\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001847
1848 reg &= ~(DSPDMAC_CHNLSTART_EN_MASK |
1849 DSPDMAC_CHNLSTART_DIS_MASK);
1850 }
1851
1852 status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET,
1853 reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_EN_LOBIT)));
1854 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001855 codec_dbg(codec, "write CHNLSTART reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001856 return status;
1857 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001858 codec_dbg(codec, "-- dsp_dma_start() -- Complete ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001859
1860 return status;
1861}
1862
Ian Minettd5c21b82012-09-20 20:29:18 -07001863/*
1864 * Stop the DSP DMA
1865 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001866static int dsp_dma_stop(struct hda_codec *codec,
1867 unsigned int dma_chan, bool ovly)
1868{
1869 unsigned int reg = 0;
1870 int status = 0;
1871
Takashi Iwai4e76a882014-02-25 12:21:03 +01001872 codec_dbg(codec, "-- dsp_dma_stop() -- Begin ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001873
1874 if (ovly) {
1875 status = chipio_read(codec,
1876 DSPDMAC_CHNLSTART_INST_OFFSET, &reg);
1877
1878 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001879 codec_dbg(codec, "read CHNLSTART reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001880 return status;
1881 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001882 codec_dbg(codec, "-- dsp_dma_stop() Read CHNLSTART\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001883 reg &= ~(DSPDMAC_CHNLSTART_EN_MASK |
1884 DSPDMAC_CHNLSTART_DIS_MASK);
1885 }
1886
1887 status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET,
1888 reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_DIS_LOBIT)));
1889 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001890 codec_dbg(codec, "write CHNLSTART reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001891 return status;
1892 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001893 codec_dbg(codec, "-- dsp_dma_stop() -- Complete ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001894
1895 return status;
1896}
1897
Ian Minettd5c21b82012-09-20 20:29:18 -07001898/**
1899 * Allocate router ports
1900 *
1901 * @codec: the HDA codec
1902 * @num_chans: number of channels in the stream
1903 * @ports_per_channel: number of ports per channel
1904 * @start_device: start device
1905 * @port_map: pointer to the port list to hold the allocated ports
1906 *
1907 * Returns zero or a negative error code.
1908 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001909static int dsp_allocate_router_ports(struct hda_codec *codec,
1910 unsigned int num_chans,
1911 unsigned int ports_per_channel,
1912 unsigned int start_device,
1913 unsigned int *port_map)
1914{
1915 int status = 0;
1916 int res;
1917 u8 val;
1918
1919 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
1920 if (status < 0)
1921 return status;
1922
1923 val = start_device << 6;
1924 val |= (ports_per_channel - 1) << 4;
1925 val |= num_chans - 1;
1926
1927 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1928 VENDOR_CHIPIO_PORT_ALLOC_CONFIG_SET,
1929 val);
1930
1931 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1932 VENDOR_CHIPIO_PORT_ALLOC_SET,
1933 MEM_CONNID_DSP);
1934
1935 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
1936 if (status < 0)
1937 return status;
1938
1939 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0,
1940 VENDOR_CHIPIO_PORT_ALLOC_GET, 0);
1941
1942 *port_map = res;
1943
1944 return (res < 0) ? res : 0;
1945}
1946
Ian Minettd5c21b82012-09-20 20:29:18 -07001947/*
1948 * Free router ports
1949 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001950static int dsp_free_router_ports(struct hda_codec *codec)
1951{
1952 int status = 0;
1953
1954 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
1955 if (status < 0)
1956 return status;
1957
1958 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1959 VENDOR_CHIPIO_PORT_FREE_SET,
1960 MEM_CONNID_DSP);
1961
1962 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
1963
1964 return status;
1965}
1966
Ian Minettd5c21b82012-09-20 20:29:18 -07001967/*
1968 * Allocate DSP ports for the download stream
1969 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001970static int dsp_allocate_ports(struct hda_codec *codec,
1971 unsigned int num_chans,
1972 unsigned int rate_multi, unsigned int *port_map)
1973{
1974 int status;
1975
Takashi Iwai4e76a882014-02-25 12:21:03 +01001976 codec_dbg(codec, " dsp_allocate_ports() -- begin\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001977
1978 if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001979 codec_dbg(codec, "bad rate multiple\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001980 return -EINVAL;
1981 }
1982
1983 status = dsp_allocate_router_ports(codec, num_chans,
1984 rate_multi, 0, port_map);
1985
Takashi Iwai4e76a882014-02-25 12:21:03 +01001986 codec_dbg(codec, " dsp_allocate_ports() -- complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001987
1988 return status;
1989}
1990
Ian Minett01ef7db2012-09-20 20:29:16 -07001991static int dsp_allocate_ports_format(struct hda_codec *codec,
1992 const unsigned short fmt,
1993 unsigned int *port_map)
1994{
1995 int status;
1996 unsigned int num_chans;
1997
1998 unsigned int sample_rate_div = ((get_hdafmt_rate(fmt) >> 0) & 3) + 1;
1999 unsigned int sample_rate_mul = ((get_hdafmt_rate(fmt) >> 3) & 3) + 1;
2000 unsigned int rate_multi = sample_rate_mul / sample_rate_div;
2001
2002 if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002003 codec_dbg(codec, "bad rate multiple\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002004 return -EINVAL;
2005 }
2006
2007 num_chans = get_hdafmt_chs(fmt) + 1;
2008
2009 status = dsp_allocate_ports(codec, num_chans, rate_multi, port_map);
2010
2011 return status;
2012}
2013
2014/*
Ian Minettd5c21b82012-09-20 20:29:18 -07002015 * free DSP ports
2016 */
2017static int dsp_free_ports(struct hda_codec *codec)
2018{
2019 int status;
2020
Takashi Iwai4e76a882014-02-25 12:21:03 +01002021 codec_dbg(codec, " dsp_free_ports() -- begin\n");
Ian Minettd5c21b82012-09-20 20:29:18 -07002022
2023 status = dsp_free_router_ports(codec);
2024 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002025 codec_dbg(codec, "free router ports fail\n");
Ian Minettd5c21b82012-09-20 20:29:18 -07002026 return status;
2027 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01002028 codec_dbg(codec, " dsp_free_ports() -- complete\n");
Ian Minettd5c21b82012-09-20 20:29:18 -07002029
2030 return status;
2031}
2032
2033/*
Ian Minett01ef7db2012-09-20 20:29:16 -07002034 * HDA DMA engine stuffs for DSP code download
2035 */
2036struct dma_engine {
2037 struct hda_codec *codec;
2038 unsigned short m_converter_format;
2039 struct snd_dma_buffer *dmab;
2040 unsigned int buf_size;
2041};
2042
2043
2044enum dma_state {
2045 DMA_STATE_STOP = 0,
2046 DMA_STATE_RUN = 1
2047};
2048
Takashi Iwai6194b992014-06-06 18:12:16 +02002049static int dma_convert_to_hda_format(struct hda_codec *codec,
Ian Minette97249d2012-09-20 20:29:21 -07002050 unsigned int sample_rate,
2051 unsigned short channels,
Ian Minett01ef7db2012-09-20 20:29:16 -07002052 unsigned short *hda_format)
2053{
2054 unsigned int format_val;
2055
Takashi Iwai6194b992014-06-06 18:12:16 +02002056 format_val = snd_hda_calc_stream_format(codec,
Ian Minette97249d2012-09-20 20:29:21 -07002057 sample_rate,
2058 channels,
Ian Minett01ef7db2012-09-20 20:29:16 -07002059 SNDRV_PCM_FORMAT_S32_LE,
Ian Minette97249d2012-09-20 20:29:21 -07002060 32, 0);
Ian Minett01ef7db2012-09-20 20:29:16 -07002061
2062 if (hda_format)
2063 *hda_format = (unsigned short)format_val;
2064
2065 return 0;
2066}
2067
Ian Minettd5c21b82012-09-20 20:29:18 -07002068/*
2069 * Reset DMA for DSP download
2070 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002071static int dma_reset(struct dma_engine *dma)
2072{
2073 struct hda_codec *codec = dma->codec;
2074 struct ca0132_spec *spec = codec->spec;
2075 int status;
2076
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002077 if (dma->dmab->area)
Ian Minett01ef7db2012-09-20 20:29:16 -07002078 snd_hda_codec_load_dsp_cleanup(codec, dma->dmab);
2079
2080 status = snd_hda_codec_load_dsp_prepare(codec,
2081 dma->m_converter_format,
2082 dma->buf_size,
2083 dma->dmab);
2084 if (status < 0)
2085 return status;
2086 spec->dsp_stream_id = status;
2087 return 0;
2088}
2089
2090static int dma_set_state(struct dma_engine *dma, enum dma_state state)
2091{
2092 bool cmd;
2093
Ian Minett01ef7db2012-09-20 20:29:16 -07002094 switch (state) {
2095 case DMA_STATE_STOP:
2096 cmd = false;
2097 break;
2098 case DMA_STATE_RUN:
2099 cmd = true;
2100 break;
2101 default:
2102 return 0;
2103 }
2104
2105 snd_hda_codec_load_dsp_trigger(dma->codec, cmd);
2106 return 0;
2107}
2108
2109static unsigned int dma_get_buffer_size(struct dma_engine *dma)
2110{
2111 return dma->dmab->bytes;
2112}
2113
2114static unsigned char *dma_get_buffer_addr(struct dma_engine *dma)
2115{
2116 return dma->dmab->area;
2117}
2118
2119static int dma_xfer(struct dma_engine *dma,
2120 const unsigned int *data,
2121 unsigned int count)
2122{
2123 memcpy(dma->dmab->area, data, count);
2124 return 0;
2125}
2126
2127static void dma_get_converter_format(
2128 struct dma_engine *dma,
2129 unsigned short *format)
2130{
2131 if (format)
2132 *format = dma->m_converter_format;
2133}
2134
2135static unsigned int dma_get_stream_id(struct dma_engine *dma)
2136{
2137 struct ca0132_spec *spec = dma->codec->spec;
2138
2139 return spec->dsp_stream_id;
2140}
2141
2142struct dsp_image_seg {
2143 u32 magic;
2144 u32 chip_addr;
2145 u32 count;
2146 u32 data[0];
2147};
2148
2149static const u32 g_magic_value = 0x4c46584d;
2150static const u32 g_chip_addr_magic_value = 0xFFFFFF01;
2151
2152static bool is_valid(const struct dsp_image_seg *p)
2153{
2154 return p->magic == g_magic_value;
2155}
2156
2157static bool is_hci_prog_list_seg(const struct dsp_image_seg *p)
2158{
2159 return g_chip_addr_magic_value == p->chip_addr;
2160}
2161
2162static bool is_last(const struct dsp_image_seg *p)
2163{
2164 return p->count == 0;
2165}
2166
2167static size_t dsp_sizeof(const struct dsp_image_seg *p)
2168{
2169 return sizeof(*p) + p->count*sizeof(u32);
2170}
2171
2172static const struct dsp_image_seg *get_next_seg_ptr(
2173 const struct dsp_image_seg *p)
2174{
2175 return (struct dsp_image_seg *)((unsigned char *)(p) + dsp_sizeof(p));
2176}
2177
2178/*
2179 * CA0132 chip DSP transfer stuffs. For DSP download.
2180 */
Takashi Iwai8ae3124b2013-01-15 17:43:09 +01002181#define INVALID_DMA_CHANNEL (~0U)
Ian Minett01ef7db2012-09-20 20:29:16 -07002182
Ian Minettd5c21b82012-09-20 20:29:18 -07002183/*
2184 * Program a list of address/data pairs via the ChipIO widget.
2185 * The segment data is in the format of successive pairs of words.
2186 * These are repeated as indicated by the segment's count field.
2187 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002188static int dspxfr_hci_write(struct hda_codec *codec,
2189 const struct dsp_image_seg *fls)
2190{
2191 int status;
2192 const u32 *data;
2193 unsigned int count;
2194
2195 if (fls == NULL || fls->chip_addr != g_chip_addr_magic_value) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002196 codec_dbg(codec, "hci_write invalid params\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002197 return -EINVAL;
2198 }
2199
2200 count = fls->count;
2201 data = (u32 *)(fls->data);
2202 while (count >= 2) {
2203 status = chipio_write(codec, data[0], data[1]);
2204 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002205 codec_dbg(codec, "hci_write chipio failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002206 return status;
2207 }
2208 count -= 2;
2209 data += 2;
2210 }
2211 return 0;
2212}
2213
Ian Minettd5c21b82012-09-20 20:29:18 -07002214/**
2215 * Write a block of data into DSP code or data RAM using pre-allocated
2216 * DMA engine.
2217 *
2218 * @codec: the HDA codec
2219 * @fls: pointer to a fast load image
2220 * @reloc: Relocation address for loading single-segment overlays, or 0 for
2221 * no relocation
2222 * @dma_engine: pointer to DMA engine to be used for DSP download
2223 * @dma_chan: The number of DMA channels used for DSP download
2224 * @port_map_mask: port mapping
2225 * @ovly: TRUE if overlay format is required
2226 *
2227 * Returns zero or a negative error code.
2228 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002229static int dspxfr_one_seg(struct hda_codec *codec,
2230 const struct dsp_image_seg *fls,
2231 unsigned int reloc,
2232 struct dma_engine *dma_engine,
2233 unsigned int dma_chan,
2234 unsigned int port_map_mask,
2235 bool ovly)
2236{
Ian Minett406261c2012-12-20 18:53:41 -08002237 int status = 0;
Ian Minett01ef7db2012-09-20 20:29:16 -07002238 bool comm_dma_setup_done = false;
2239 const unsigned int *data;
2240 unsigned int chip_addx;
2241 unsigned int words_to_write;
2242 unsigned int buffer_size_words;
2243 unsigned char *buffer_addx;
2244 unsigned short hda_format;
2245 unsigned int sample_rate_div;
2246 unsigned int sample_rate_mul;
2247 unsigned int num_chans;
2248 unsigned int hda_frame_size_words;
2249 unsigned int remainder_words;
2250 const u32 *data_remainder;
2251 u32 chip_addx_remainder;
2252 unsigned int run_size_words;
2253 const struct dsp_image_seg *hci_write = NULL;
Ian Minett6d675302013-02-08 18:31:43 -08002254 unsigned long timeout;
2255 bool dma_active;
Ian Minett01ef7db2012-09-20 20:29:16 -07002256
2257 if (fls == NULL)
2258 return -EINVAL;
2259 if (is_hci_prog_list_seg(fls)) {
2260 hci_write = fls;
2261 fls = get_next_seg_ptr(fls);
2262 }
2263
2264 if (hci_write && (!fls || is_last(fls))) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002265 codec_dbg(codec, "hci_write\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002266 return dspxfr_hci_write(codec, hci_write);
2267 }
2268
2269 if (fls == NULL || dma_engine == NULL || port_map_mask == 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002270 codec_dbg(codec, "Invalid Params\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002271 return -EINVAL;
2272 }
2273
2274 data = fls->data;
2275 chip_addx = fls->chip_addr,
2276 words_to_write = fls->count;
2277
2278 if (!words_to_write)
2279 return hci_write ? dspxfr_hci_write(codec, hci_write) : 0;
2280 if (reloc)
2281 chip_addx = (chip_addx & (0xFFFF0000 << 2)) + (reloc << 2);
2282
2283 if (!UC_RANGE(chip_addx, words_to_write) &&
2284 !X_RANGE_ALL(chip_addx, words_to_write) &&
2285 !Y_RANGE_ALL(chip_addx, words_to_write)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002286 codec_dbg(codec, "Invalid chip_addx Params\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002287 return -EINVAL;
2288 }
2289
2290 buffer_size_words = (unsigned int)dma_get_buffer_size(dma_engine) /
2291 sizeof(u32);
2292
2293 buffer_addx = dma_get_buffer_addr(dma_engine);
2294
2295 if (buffer_addx == NULL) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002296 codec_dbg(codec, "dma_engine buffer NULL\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002297 return -EINVAL;
2298 }
2299
2300 dma_get_converter_format(dma_engine, &hda_format);
2301 sample_rate_div = ((get_hdafmt_rate(hda_format) >> 0) & 3) + 1;
2302 sample_rate_mul = ((get_hdafmt_rate(hda_format) >> 3) & 3) + 1;
2303 num_chans = get_hdafmt_chs(hda_format) + 1;
2304
2305 hda_frame_size_words = ((sample_rate_div == 0) ? 0 :
2306 (num_chans * sample_rate_mul / sample_rate_div));
2307
Xi Wang3bc085a2013-03-07 00:13:51 -05002308 if (hda_frame_size_words == 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002309 codec_dbg(codec, "frmsz zero\n");
Xi Wang3bc085a2013-03-07 00:13:51 -05002310 return -EINVAL;
2311 }
2312
Ian Minett01ef7db2012-09-20 20:29:16 -07002313 buffer_size_words = min(buffer_size_words,
2314 (unsigned int)(UC_RANGE(chip_addx, 1) ?
2315 65536 : 32768));
2316 buffer_size_words -= buffer_size_words % hda_frame_size_words;
Takashi Iwai4e76a882014-02-25 12:21:03 +01002317 codec_dbg(codec,
Ian Minett01ef7db2012-09-20 20:29:16 -07002318 "chpadr=0x%08x frmsz=%u nchan=%u "
2319 "rate_mul=%u div=%u bufsz=%u\n",
2320 chip_addx, hda_frame_size_words, num_chans,
2321 sample_rate_mul, sample_rate_div, buffer_size_words);
2322
Xi Wang3bc085a2013-03-07 00:13:51 -05002323 if (buffer_size_words < hda_frame_size_words) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002324 codec_dbg(codec, "dspxfr_one_seg:failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002325 return -EINVAL;
2326 }
2327
2328 remainder_words = words_to_write % hda_frame_size_words;
2329 data_remainder = data;
2330 chip_addx_remainder = chip_addx;
2331
2332 data += remainder_words;
2333 chip_addx += remainder_words*sizeof(u32);
2334 words_to_write -= remainder_words;
2335
2336 while (words_to_write != 0) {
2337 run_size_words = min(buffer_size_words, words_to_write);
Takashi Iwai4e76a882014-02-25 12:21:03 +01002338 codec_dbg(codec, "dspxfr (seg loop)cnt=%u rs=%u remainder=%u\n",
Ian Minett01ef7db2012-09-20 20:29:16 -07002339 words_to_write, run_size_words, remainder_words);
2340 dma_xfer(dma_engine, data, run_size_words*sizeof(u32));
2341 if (!comm_dma_setup_done) {
2342 status = dsp_dma_stop(codec, dma_chan, ovly);
2343 if (status < 0)
Takashi Iwai425a7882013-01-15 17:41:21 +01002344 return status;
Ian Minett01ef7db2012-09-20 20:29:16 -07002345 status = dsp_dma_setup_common(codec, chip_addx,
2346 dma_chan, port_map_mask, ovly);
2347 if (status < 0)
2348 return status;
2349 comm_dma_setup_done = true;
2350 }
2351
2352 status = dsp_dma_setup(codec, chip_addx,
2353 run_size_words, dma_chan);
2354 if (status < 0)
2355 return status;
2356 status = dsp_dma_start(codec, dma_chan, ovly);
2357 if (status < 0)
2358 return status;
2359 if (!dsp_is_dma_active(codec, dma_chan)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002360 codec_dbg(codec, "dspxfr:DMA did not start\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002361 return -EIO;
2362 }
2363 status = dma_set_state(dma_engine, DMA_STATE_RUN);
2364 if (status < 0)
2365 return status;
2366 if (remainder_words != 0) {
2367 status = chipio_write_multiple(codec,
2368 chip_addx_remainder,
2369 data_remainder,
2370 remainder_words);
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002371 if (status < 0)
2372 return status;
Ian Minett01ef7db2012-09-20 20:29:16 -07002373 remainder_words = 0;
2374 }
2375 if (hci_write) {
2376 status = dspxfr_hci_write(codec, hci_write);
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002377 if (status < 0)
2378 return status;
Ian Minett01ef7db2012-09-20 20:29:16 -07002379 hci_write = NULL;
2380 }
Ian Minett6d675302013-02-08 18:31:43 -08002381
2382 timeout = jiffies + msecs_to_jiffies(2000);
2383 do {
2384 dma_active = dsp_is_dma_active(codec, dma_chan);
2385 if (!dma_active)
Ian Minett01ef7db2012-09-20 20:29:16 -07002386 break;
Ian Minett6d675302013-02-08 18:31:43 -08002387 msleep(20);
2388 } while (time_before(jiffies, timeout));
2389 if (dma_active)
2390 break;
2391
Takashi Iwai4e76a882014-02-25 12:21:03 +01002392 codec_dbg(codec, "+++++ DMA complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002393 dma_set_state(dma_engine, DMA_STATE_STOP);
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002394 status = dma_reset(dma_engine);
Ian Minett01ef7db2012-09-20 20:29:16 -07002395
2396 if (status < 0)
2397 return status;
2398
2399 data += run_size_words;
2400 chip_addx += run_size_words*sizeof(u32);
2401 words_to_write -= run_size_words;
2402 }
2403
2404 if (remainder_words != 0) {
2405 status = chipio_write_multiple(codec, chip_addx_remainder,
2406 data_remainder, remainder_words);
2407 }
2408
2409 return status;
2410}
2411
Ian Minettd5c21b82012-09-20 20:29:18 -07002412/**
2413 * Write the entire DSP image of a DSP code/data overlay to DSP memories
2414 *
2415 * @codec: the HDA codec
2416 * @fls_data: pointer to a fast load image
2417 * @reloc: Relocation address for loading single-segment overlays, or 0 for
2418 * no relocation
Ian Minette97249d2012-09-20 20:29:21 -07002419 * @sample_rate: sampling rate of the stream used for DSP download
Takashi Iwaie60b2c72014-11-10 16:47:26 +01002420 * @channels: channels of the stream used for DSP download
Ian Minettd5c21b82012-09-20 20:29:18 -07002421 * @ovly: TRUE if overlay format is required
2422 *
2423 * Returns zero or a negative error code.
2424 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002425static int dspxfr_image(struct hda_codec *codec,
2426 const struct dsp_image_seg *fls_data,
Ian Minette97249d2012-09-20 20:29:21 -07002427 unsigned int reloc,
2428 unsigned int sample_rate,
2429 unsigned short channels,
Ian Minett01ef7db2012-09-20 20:29:16 -07002430 bool ovly)
2431{
2432 struct ca0132_spec *spec = codec->spec;
2433 int status;
2434 unsigned short hda_format = 0;
2435 unsigned int response;
2436 unsigned char stream_id = 0;
2437 struct dma_engine *dma_engine;
2438 unsigned int dma_chan;
2439 unsigned int port_map_mask;
2440
2441 if (fls_data == NULL)
2442 return -EINVAL;
2443
2444 dma_engine = kzalloc(sizeof(*dma_engine), GFP_KERNEL);
Takashi Iwai549e8292013-01-15 17:42:15 +01002445 if (!dma_engine)
2446 return -ENOMEM;
Ian Minett01ef7db2012-09-20 20:29:16 -07002447
2448 dma_engine->dmab = kzalloc(sizeof(*dma_engine->dmab), GFP_KERNEL);
2449 if (!dma_engine->dmab) {
Takashi Iwai549e8292013-01-15 17:42:15 +01002450 kfree(dma_engine);
2451 return -ENOMEM;
Ian Minett01ef7db2012-09-20 20:29:16 -07002452 }
2453
2454 dma_engine->codec = codec;
Takashi Iwai6194b992014-06-06 18:12:16 +02002455 dma_convert_to_hda_format(codec, sample_rate, channels, &hda_format);
Ian Minett01ef7db2012-09-20 20:29:16 -07002456 dma_engine->m_converter_format = hda_format;
2457 dma_engine->buf_size = (ovly ? DSP_DMA_WRITE_BUFLEN_OVLY :
2458 DSP_DMA_WRITE_BUFLEN_INIT) * 2;
2459
Takashi Iwai8ae3124b2013-01-15 17:43:09 +01002460 dma_chan = ovly ? INVALID_DMA_CHANNEL : 0;
Ian Minett01ef7db2012-09-20 20:29:16 -07002461
2462 status = codec_set_converter_format(codec, WIDGET_CHIP_CTRL,
2463 hda_format, &response);
2464
2465 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002466 codec_dbg(codec, "set converter format fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002467 goto exit;
2468 }
2469
2470 status = snd_hda_codec_load_dsp_prepare(codec,
2471 dma_engine->m_converter_format,
2472 dma_engine->buf_size,
2473 dma_engine->dmab);
2474 if (status < 0)
2475 goto exit;
2476 spec->dsp_stream_id = status;
2477
2478 if (ovly) {
2479 status = dspio_alloc_dma_chan(codec, &dma_chan);
2480 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002481 codec_dbg(codec, "alloc dmachan fail\n");
Takashi Iwai8ae3124b2013-01-15 17:43:09 +01002482 dma_chan = INVALID_DMA_CHANNEL;
Ian Minett01ef7db2012-09-20 20:29:16 -07002483 goto exit;
2484 }
2485 }
2486
2487 port_map_mask = 0;
2488 status = dsp_allocate_ports_format(codec, hda_format,
2489 &port_map_mask);
2490 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002491 codec_dbg(codec, "alloc ports fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002492 goto exit;
2493 }
2494
2495 stream_id = dma_get_stream_id(dma_engine);
2496 status = codec_set_converter_stream_channel(codec,
2497 WIDGET_CHIP_CTRL, stream_id, 0, &response);
2498 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002499 codec_dbg(codec, "set stream chan fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002500 goto exit;
2501 }
2502
2503 while ((fls_data != NULL) && !is_last(fls_data)) {
2504 if (!is_valid(fls_data)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002505 codec_dbg(codec, "FLS check fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002506 status = -EINVAL;
2507 goto exit;
2508 }
2509 status = dspxfr_one_seg(codec, fls_data, reloc,
2510 dma_engine, dma_chan,
2511 port_map_mask, ovly);
2512 if (status < 0)
2513 break;
2514
2515 if (is_hci_prog_list_seg(fls_data))
2516 fls_data = get_next_seg_ptr(fls_data);
2517
2518 if ((fls_data != NULL) && !is_last(fls_data))
2519 fls_data = get_next_seg_ptr(fls_data);
2520 }
2521
2522 if (port_map_mask != 0)
2523 status = dsp_free_ports(codec);
2524
2525 if (status < 0)
2526 goto exit;
2527
2528 status = codec_set_converter_stream_channel(codec,
2529 WIDGET_CHIP_CTRL, 0, 0, &response);
2530
2531exit:
2532 if (ovly && (dma_chan != INVALID_DMA_CHANNEL))
2533 dspio_free_dma_chan(codec, dma_chan);
2534
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002535 if (dma_engine->dmab->area)
Ian Minett01ef7db2012-09-20 20:29:16 -07002536 snd_hda_codec_load_dsp_cleanup(codec, dma_engine->dmab);
2537 kfree(dma_engine->dmab);
2538 kfree(dma_engine);
2539
2540 return status;
2541}
2542
2543/*
2544 * CA0132 DSP download stuffs.
2545 */
2546static void dspload_post_setup(struct hda_codec *codec)
2547{
Takashi Iwai4e76a882014-02-25 12:21:03 +01002548 codec_dbg(codec, "---- dspload_post_setup ------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002549
2550 /*set DSP speaker to 2.0 configuration*/
2551 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x18), 0x08080080);
2552 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x19), 0x3f800000);
2553
2554 /*update write pointer*/
2555 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x29), 0x00000002);
2556}
2557
Ian Minettd5c21b82012-09-20 20:29:18 -07002558/**
Takashi Iwaie60b2c72014-11-10 16:47:26 +01002559 * dspload_image - Download DSP from a DSP Image Fast Load structure.
Ian Minettd5c21b82012-09-20 20:29:18 -07002560 *
2561 * @codec: the HDA codec
2562 * @fls: pointer to a fast load image
2563 * @ovly: TRUE if overlay format is required
2564 * @reloc: Relocation address for loading single-segment overlays, or 0 for
2565 * no relocation
2566 * @autostart: TRUE if DSP starts after loading; ignored if ovly is TRUE
2567 * @router_chans: number of audio router channels to be allocated (0 means use
2568 * internal defaults; max is 32)
2569 *
Takashi Iwaie60b2c72014-11-10 16:47:26 +01002570 * Download DSP from a DSP Image Fast Load structure. This structure is a
2571 * linear, non-constant sized element array of structures, each of which
2572 * contain the count of the data to be loaded, the data itself, and the
2573 * corresponding starting chip address of the starting data location.
Ian Minettd5c21b82012-09-20 20:29:18 -07002574 * Returns zero or a negative error code.
2575 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002576static int dspload_image(struct hda_codec *codec,
2577 const struct dsp_image_seg *fls,
2578 bool ovly,
2579 unsigned int reloc,
2580 bool autostart,
2581 int router_chans)
2582{
2583 int status = 0;
Ian Minette97249d2012-09-20 20:29:21 -07002584 unsigned int sample_rate;
2585 unsigned short channels;
Ian Minett01ef7db2012-09-20 20:29:16 -07002586
Takashi Iwai4e76a882014-02-25 12:21:03 +01002587 codec_dbg(codec, "---- dspload_image begin ------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002588 if (router_chans == 0) {
2589 if (!ovly)
2590 router_chans = DMA_TRANSFER_FRAME_SIZE_NWORDS;
2591 else
2592 router_chans = DMA_OVERLAY_FRAME_SIZE_NWORDS;
2593 }
2594
Ian Minette97249d2012-09-20 20:29:21 -07002595 sample_rate = 48000;
2596 channels = (unsigned short)router_chans;
Ian Minett01ef7db2012-09-20 20:29:16 -07002597
Ian Minette97249d2012-09-20 20:29:21 -07002598 while (channels > 16) {
2599 sample_rate *= 2;
2600 channels /= 2;
Ian Minett01ef7db2012-09-20 20:29:16 -07002601 }
2602
Ian Minett01ef7db2012-09-20 20:29:16 -07002603 do {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002604 codec_dbg(codec, "Ready to program DMA\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002605 if (!ovly)
2606 status = dsp_reset(codec);
2607
2608 if (status < 0)
2609 break;
2610
Takashi Iwai4e76a882014-02-25 12:21:03 +01002611 codec_dbg(codec, "dsp_reset() complete\n");
Ian Minette97249d2012-09-20 20:29:21 -07002612 status = dspxfr_image(codec, fls, reloc, sample_rate, channels,
2613 ovly);
Ian Minett01ef7db2012-09-20 20:29:16 -07002614
2615 if (status < 0)
2616 break;
2617
Takashi Iwai4e76a882014-02-25 12:21:03 +01002618 codec_dbg(codec, "dspxfr_image() complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002619 if (autostart && !ovly) {
2620 dspload_post_setup(codec);
2621 status = dsp_set_run_state(codec);
2622 }
2623
Takashi Iwai4e76a882014-02-25 12:21:03 +01002624 codec_dbg(codec, "LOAD FINISHED\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002625 } while (0);
2626
2627 return status;
2628}
2629
Takashi Iwaif6644172013-02-11 14:18:29 +01002630#ifdef CONFIG_SND_HDA_CODEC_CA0132_DSP
Ian Minett01ef7db2012-09-20 20:29:16 -07002631static bool dspload_is_loaded(struct hda_codec *codec)
2632{
2633 unsigned int data = 0;
2634 int status = 0;
2635
2636 status = chipio_read(codec, 0x40004, &data);
2637 if ((status < 0) || (data != 1))
2638 return false;
2639
2640 return true;
2641}
Takashi Iwaif6644172013-02-11 14:18:29 +01002642#else
2643#define dspload_is_loaded(codec) false
2644#endif
Ian Minett01ef7db2012-09-20 20:29:16 -07002645
2646static bool dspload_wait_loaded(struct hda_codec *codec)
2647{
Ian Minett6d675302013-02-08 18:31:43 -08002648 unsigned long timeout = jiffies + msecs_to_jiffies(2000);
Ian Minett01ef7db2012-09-20 20:29:16 -07002649
2650 do {
Ian Minett01ef7db2012-09-20 20:29:16 -07002651 if (dspload_is_loaded(codec)) {
2652 pr_info("ca0132 DOWNLOAD OK :-) DSP IS RUNNING.\n");
2653 return true;
2654 }
Ian Minett6d675302013-02-08 18:31:43 -08002655 msleep(20);
2656 } while (time_before(jiffies, timeout));
Ian Minett01ef7db2012-09-20 20:29:16 -07002657
2658 pr_err("ca0132 DOWNLOAD FAILED!!! DSP IS NOT RUNNING.\n");
2659 return false;
2660}
2661
Ian Minett5aaca442012-12-20 18:53:34 -08002662/*
Ian Minett825315b2012-12-20 18:53:36 -08002663 * PCM callbacks
2664 */
Ian Minett95c6e9c2011-06-15 15:35:17 -07002665static int ca0132_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
2666 struct hda_codec *codec,
2667 unsigned int stream_tag,
2668 unsigned int format,
2669 struct snd_pcm_substream *substream)
2670{
2671 struct ca0132_spec *spec = codec->spec;
Ian Minett825315b2012-12-20 18:53:36 -08002672
Hsin-Yu Chao28fba952014-02-19 14:27:07 +08002673 snd_hda_codec_setup_stream(codec, spec->dacs[0], stream_tag, 0, format);
Ian Minett825315b2012-12-20 18:53:36 -08002674
2675 return 0;
Ian Minett95c6e9c2011-06-15 15:35:17 -07002676}
2677
2678static int ca0132_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
2679 struct hda_codec *codec,
2680 struct snd_pcm_substream *substream)
2681{
2682 struct ca0132_spec *spec = codec->spec;
Ian Minett825315b2012-12-20 18:53:36 -08002683
2684 if (spec->dsp_state == DSP_DOWNLOADING)
2685 return 0;
2686
2687 /*If Playback effects are on, allow stream some time to flush
2688 *effects tail*/
2689 if (spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID])
2690 msleep(50);
2691
Hsin-Yu Chao28fba952014-02-19 14:27:07 +08002692 snd_hda_codec_cleanup_stream(codec, spec->dacs[0]);
Ian Minett825315b2012-12-20 18:53:36 -08002693
2694 return 0;
Ian Minett95c6e9c2011-06-15 15:35:17 -07002695}
2696
Dylan Reide8412ca2013-04-04 13:55:09 -07002697static unsigned int ca0132_playback_pcm_delay(struct hda_pcm_stream *info,
2698 struct hda_codec *codec,
2699 struct snd_pcm_substream *substream)
2700{
2701 struct ca0132_spec *spec = codec->spec;
2702 unsigned int latency = DSP_PLAYBACK_INIT_LATENCY;
2703 struct snd_pcm_runtime *runtime = substream->runtime;
2704
2705 if (spec->dsp_state != DSP_DOWNLOADED)
2706 return 0;
2707
2708 /* Add latency if playback enhancement and either effect is enabled. */
2709 if (spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]) {
2710 if ((spec->effects_switch[SURROUND - EFFECT_START_NID]) ||
2711 (spec->effects_switch[DIALOG_PLUS - EFFECT_START_NID]))
2712 latency += DSP_PLAY_ENHANCEMENT_LATENCY;
2713 }
2714
2715 /* Applying Speaker EQ adds latency as well. */
2716 if (spec->cur_out_type == SPEAKER_OUT)
2717 latency += DSP_SPEAKER_OUT_LATENCY;
2718
2719 return (latency * runtime->rate) / 1000;
2720}
2721
Ian Minett95c6e9c2011-06-15 15:35:17 -07002722/*
2723 * Digital out
2724 */
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002725static int ca0132_dig_playback_pcm_open(struct hda_pcm_stream *hinfo,
2726 struct hda_codec *codec,
2727 struct snd_pcm_substream *substream)
2728{
2729 struct ca0132_spec *spec = codec->spec;
2730 return snd_hda_multi_out_dig_open(codec, &spec->multiout);
2731}
2732
Ian Minett95c6e9c2011-06-15 15:35:17 -07002733static int ca0132_dig_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
2734 struct hda_codec *codec,
2735 unsigned int stream_tag,
2736 unsigned int format,
2737 struct snd_pcm_substream *substream)
2738{
2739 struct ca0132_spec *spec = codec->spec;
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002740 return snd_hda_multi_out_dig_prepare(codec, &spec->multiout,
2741 stream_tag, format, substream);
Ian Minett95c6e9c2011-06-15 15:35:17 -07002742}
2743
2744static int ca0132_dig_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
2745 struct hda_codec *codec,
2746 struct snd_pcm_substream *substream)
2747{
2748 struct ca0132_spec *spec = codec->spec;
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002749 return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout);
Ian Minett95c6e9c2011-06-15 15:35:17 -07002750}
2751
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002752static int ca0132_dig_playback_pcm_close(struct hda_pcm_stream *hinfo,
2753 struct hda_codec *codec,
2754 struct snd_pcm_substream *substream)
Ian Minett95c6e9c2011-06-15 15:35:17 -07002755{
2756 struct ca0132_spec *spec = codec->spec;
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002757 return snd_hda_multi_out_dig_close(codec, &spec->multiout);
Ian Minett95c6e9c2011-06-15 15:35:17 -07002758}
2759
2760/*
Ian Minett825315b2012-12-20 18:53:36 -08002761 * Analog capture
2762 */
2763static int ca0132_capture_pcm_prepare(struct hda_pcm_stream *hinfo,
2764 struct hda_codec *codec,
2765 unsigned int stream_tag,
2766 unsigned int format,
2767 struct snd_pcm_substream *substream)
2768{
Hsin-Yu Chao13c12db2014-02-19 14:30:35 +08002769 snd_hda_codec_setup_stream(codec, hinfo->nid,
Hsin-Yu Chao28fba952014-02-19 14:27:07 +08002770 stream_tag, 0, format);
Ian Minett825315b2012-12-20 18:53:36 -08002771
2772 return 0;
2773}
2774
2775static int ca0132_capture_pcm_cleanup(struct hda_pcm_stream *hinfo,
2776 struct hda_codec *codec,
2777 struct snd_pcm_substream *substream)
2778{
2779 struct ca0132_spec *spec = codec->spec;
2780
2781 if (spec->dsp_state == DSP_DOWNLOADING)
2782 return 0;
2783
Hsin-Yu Chao28fba952014-02-19 14:27:07 +08002784 snd_hda_codec_cleanup_stream(codec, hinfo->nid);
Ian Minett825315b2012-12-20 18:53:36 -08002785 return 0;
2786}
2787
Dylan Reide8412ca2013-04-04 13:55:09 -07002788static unsigned int ca0132_capture_pcm_delay(struct hda_pcm_stream *info,
2789 struct hda_codec *codec,
2790 struct snd_pcm_substream *substream)
2791{
2792 struct ca0132_spec *spec = codec->spec;
2793 unsigned int latency = DSP_CAPTURE_INIT_LATENCY;
2794 struct snd_pcm_runtime *runtime = substream->runtime;
2795
2796 if (spec->dsp_state != DSP_DOWNLOADED)
2797 return 0;
2798
2799 if (spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID])
2800 latency += DSP_CRYSTAL_VOICE_LATENCY;
2801
2802 return (latency * runtime->rate) / 1000;
2803}
2804
Ian Minette90f29e2012-12-20 18:53:39 -08002805/*
2806 * Controls stuffs.
2807 */
2808
2809/*
2810 * Mixer controls helpers.
2811 */
2812#define CA0132_CODEC_VOL_MONO(xname, nid, channel, dir) \
2813 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2814 .name = xname, \
2815 .subdevice = HDA_SUBDEV_AMP_FLAG, \
2816 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | \
2817 SNDRV_CTL_ELEM_ACCESS_TLV_READ | \
2818 SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK, \
2819 .info = ca0132_volume_info, \
2820 .get = ca0132_volume_get, \
2821 .put = ca0132_volume_put, \
2822 .tlv = { .c = ca0132_volume_tlv }, \
2823 .private_value = HDA_COMPOSE_AMP_VAL(nid, channel, 0, dir) }
2824
2825#define CA0132_CODEC_MUTE_MONO(xname, nid, channel, dir) \
2826 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2827 .name = xname, \
2828 .subdevice = HDA_SUBDEV_AMP_FLAG, \
2829 .info = snd_hda_mixer_amp_switch_info, \
2830 .get = ca0132_switch_get, \
2831 .put = ca0132_switch_put, \
2832 .private_value = HDA_COMPOSE_AMP_VAL(nid, channel, 0, dir) }
2833
2834/* stereo */
2835#define CA0132_CODEC_VOL(xname, nid, dir) \
2836 CA0132_CODEC_VOL_MONO(xname, nid, 3, dir)
2837#define CA0132_CODEC_MUTE(xname, nid, dir) \
2838 CA0132_CODEC_MUTE_MONO(xname, nid, 3, dir)
2839
Ian Minett44f0c972012-12-20 18:53:38 -08002840/* The followings are for tuning of products */
2841#ifdef ENABLE_TUNING_CONTROLS
2842
2843static unsigned int voice_focus_vals_lookup[] = {
28440x41A00000, 0x41A80000, 0x41B00000, 0x41B80000, 0x41C00000, 0x41C80000,
28450x41D00000, 0x41D80000, 0x41E00000, 0x41E80000, 0x41F00000, 0x41F80000,
28460x42000000, 0x42040000, 0x42080000, 0x420C0000, 0x42100000, 0x42140000,
28470x42180000, 0x421C0000, 0x42200000, 0x42240000, 0x42280000, 0x422C0000,
28480x42300000, 0x42340000, 0x42380000, 0x423C0000, 0x42400000, 0x42440000,
28490x42480000, 0x424C0000, 0x42500000, 0x42540000, 0x42580000, 0x425C0000,
28500x42600000, 0x42640000, 0x42680000, 0x426C0000, 0x42700000, 0x42740000,
28510x42780000, 0x427C0000, 0x42800000, 0x42820000, 0x42840000, 0x42860000,
28520x42880000, 0x428A0000, 0x428C0000, 0x428E0000, 0x42900000, 0x42920000,
28530x42940000, 0x42960000, 0x42980000, 0x429A0000, 0x429C0000, 0x429E0000,
28540x42A00000, 0x42A20000, 0x42A40000, 0x42A60000, 0x42A80000, 0x42AA0000,
28550x42AC0000, 0x42AE0000, 0x42B00000, 0x42B20000, 0x42B40000, 0x42B60000,
28560x42B80000, 0x42BA0000, 0x42BC0000, 0x42BE0000, 0x42C00000, 0x42C20000,
28570x42C40000, 0x42C60000, 0x42C80000, 0x42CA0000, 0x42CC0000, 0x42CE0000,
28580x42D00000, 0x42D20000, 0x42D40000, 0x42D60000, 0x42D80000, 0x42DA0000,
28590x42DC0000, 0x42DE0000, 0x42E00000, 0x42E20000, 0x42E40000, 0x42E60000,
28600x42E80000, 0x42EA0000, 0x42EC0000, 0x42EE0000, 0x42F00000, 0x42F20000,
28610x42F40000, 0x42F60000, 0x42F80000, 0x42FA0000, 0x42FC0000, 0x42FE0000,
28620x43000000, 0x43010000, 0x43020000, 0x43030000, 0x43040000, 0x43050000,
28630x43060000, 0x43070000, 0x43080000, 0x43090000, 0x430A0000, 0x430B0000,
28640x430C0000, 0x430D0000, 0x430E0000, 0x430F0000, 0x43100000, 0x43110000,
28650x43120000, 0x43130000, 0x43140000, 0x43150000, 0x43160000, 0x43170000,
28660x43180000, 0x43190000, 0x431A0000, 0x431B0000, 0x431C0000, 0x431D0000,
28670x431E0000, 0x431F0000, 0x43200000, 0x43210000, 0x43220000, 0x43230000,
28680x43240000, 0x43250000, 0x43260000, 0x43270000, 0x43280000, 0x43290000,
28690x432A0000, 0x432B0000, 0x432C0000, 0x432D0000, 0x432E0000, 0x432F0000,
28700x43300000, 0x43310000, 0x43320000, 0x43330000, 0x43340000
2871};
2872
2873static unsigned int mic_svm_vals_lookup[] = {
28740x00000000, 0x3C23D70A, 0x3CA3D70A, 0x3CF5C28F, 0x3D23D70A, 0x3D4CCCCD,
28750x3D75C28F, 0x3D8F5C29, 0x3DA3D70A, 0x3DB851EC, 0x3DCCCCCD, 0x3DE147AE,
28760x3DF5C28F, 0x3E051EB8, 0x3E0F5C29, 0x3E19999A, 0x3E23D70A, 0x3E2E147B,
28770x3E3851EC, 0x3E428F5C, 0x3E4CCCCD, 0x3E570A3D, 0x3E6147AE, 0x3E6B851F,
28780x3E75C28F, 0x3E800000, 0x3E851EB8, 0x3E8A3D71, 0x3E8F5C29, 0x3E947AE1,
28790x3E99999A, 0x3E9EB852, 0x3EA3D70A, 0x3EA8F5C3, 0x3EAE147B, 0x3EB33333,
28800x3EB851EC, 0x3EBD70A4, 0x3EC28F5C, 0x3EC7AE14, 0x3ECCCCCD, 0x3ED1EB85,
28810x3ED70A3D, 0x3EDC28F6, 0x3EE147AE, 0x3EE66666, 0x3EEB851F, 0x3EF0A3D7,
28820x3EF5C28F, 0x3EFAE148, 0x3F000000, 0x3F028F5C, 0x3F051EB8, 0x3F07AE14,
28830x3F0A3D71, 0x3F0CCCCD, 0x3F0F5C29, 0x3F11EB85, 0x3F147AE1, 0x3F170A3D,
28840x3F19999A, 0x3F1C28F6, 0x3F1EB852, 0x3F2147AE, 0x3F23D70A, 0x3F266666,
28850x3F28F5C3, 0x3F2B851F, 0x3F2E147B, 0x3F30A3D7, 0x3F333333, 0x3F35C28F,
28860x3F3851EC, 0x3F3AE148, 0x3F3D70A4, 0x3F400000, 0x3F428F5C, 0x3F451EB8,
28870x3F47AE14, 0x3F4A3D71, 0x3F4CCCCD, 0x3F4F5C29, 0x3F51EB85, 0x3F547AE1,
28880x3F570A3D, 0x3F59999A, 0x3F5C28F6, 0x3F5EB852, 0x3F6147AE, 0x3F63D70A,
28890x3F666666, 0x3F68F5C3, 0x3F6B851F, 0x3F6E147B, 0x3F70A3D7, 0x3F733333,
28900x3F75C28F, 0x3F7851EC, 0x3F7AE148, 0x3F7D70A4, 0x3F800000
2891};
2892
2893static unsigned int equalizer_vals_lookup[] = {
28940xC1C00000, 0xC1B80000, 0xC1B00000, 0xC1A80000, 0xC1A00000, 0xC1980000,
28950xC1900000, 0xC1880000, 0xC1800000, 0xC1700000, 0xC1600000, 0xC1500000,
28960xC1400000, 0xC1300000, 0xC1200000, 0xC1100000, 0xC1000000, 0xC0E00000,
28970xC0C00000, 0xC0A00000, 0xC0800000, 0xC0400000, 0xC0000000, 0xBF800000,
28980x00000000, 0x3F800000, 0x40000000, 0x40400000, 0x40800000, 0x40A00000,
28990x40C00000, 0x40E00000, 0x41000000, 0x41100000, 0x41200000, 0x41300000,
29000x41400000, 0x41500000, 0x41600000, 0x41700000, 0x41800000, 0x41880000,
29010x41900000, 0x41980000, 0x41A00000, 0x41A80000, 0x41B00000, 0x41B80000,
29020x41C00000
2903};
2904
2905static int tuning_ctl_set(struct hda_codec *codec, hda_nid_t nid,
2906 unsigned int *lookup, int idx)
2907{
2908 int i = 0;
2909
2910 for (i = 0; i < TUNING_CTLS_COUNT; i++)
2911 if (nid == ca0132_tuning_ctls[i].nid)
2912 break;
2913
2914 snd_hda_power_up(codec);
2915 dspio_set_param(codec, ca0132_tuning_ctls[i].mid,
2916 ca0132_tuning_ctls[i].req,
2917 &(lookup[idx]), sizeof(unsigned int));
2918 snd_hda_power_down(codec);
2919
2920 return 1;
2921}
2922
2923static int tuning_ctl_get(struct snd_kcontrol *kcontrol,
2924 struct snd_ctl_elem_value *ucontrol)
2925{
2926 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2927 struct ca0132_spec *spec = codec->spec;
2928 hda_nid_t nid = get_amp_nid(kcontrol);
2929 long *valp = ucontrol->value.integer.value;
2930 int idx = nid - TUNING_CTL_START_NID;
2931
2932 *valp = spec->cur_ctl_vals[idx];
2933 return 0;
2934}
2935
2936static int voice_focus_ctl_info(struct snd_kcontrol *kcontrol,
2937 struct snd_ctl_elem_info *uinfo)
2938{
2939 int chs = get_amp_channels(kcontrol);
2940 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
2941 uinfo->count = chs == 3 ? 2 : 1;
2942 uinfo->value.integer.min = 20;
2943 uinfo->value.integer.max = 180;
2944 uinfo->value.integer.step = 1;
2945
2946 return 0;
2947}
2948
2949static int voice_focus_ctl_put(struct snd_kcontrol *kcontrol,
2950 struct snd_ctl_elem_value *ucontrol)
2951{
2952 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2953 struct ca0132_spec *spec = codec->spec;
2954 hda_nid_t nid = get_amp_nid(kcontrol);
2955 long *valp = ucontrol->value.integer.value;
2956 int idx;
2957
2958 idx = nid - TUNING_CTL_START_NID;
2959 /* any change? */
2960 if (spec->cur_ctl_vals[idx] == *valp)
2961 return 0;
2962
2963 spec->cur_ctl_vals[idx] = *valp;
2964
2965 idx = *valp - 20;
2966 tuning_ctl_set(codec, nid, voice_focus_vals_lookup, idx);
2967
2968 return 1;
2969}
2970
2971static int mic_svm_ctl_info(struct snd_kcontrol *kcontrol,
2972 struct snd_ctl_elem_info *uinfo)
2973{
2974 int chs = get_amp_channels(kcontrol);
2975 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
2976 uinfo->count = chs == 3 ? 2 : 1;
2977 uinfo->value.integer.min = 0;
2978 uinfo->value.integer.max = 100;
2979 uinfo->value.integer.step = 1;
2980
2981 return 0;
2982}
2983
2984static int mic_svm_ctl_put(struct snd_kcontrol *kcontrol,
2985 struct snd_ctl_elem_value *ucontrol)
2986{
2987 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2988 struct ca0132_spec *spec = codec->spec;
2989 hda_nid_t nid = get_amp_nid(kcontrol);
2990 long *valp = ucontrol->value.integer.value;
2991 int idx;
2992
2993 idx = nid - TUNING_CTL_START_NID;
2994 /* any change? */
2995 if (spec->cur_ctl_vals[idx] == *valp)
2996 return 0;
2997
2998 spec->cur_ctl_vals[idx] = *valp;
2999
3000 idx = *valp;
3001 tuning_ctl_set(codec, nid, mic_svm_vals_lookup, idx);
3002
3003 return 0;
3004}
3005
3006static int equalizer_ctl_info(struct snd_kcontrol *kcontrol,
3007 struct snd_ctl_elem_info *uinfo)
3008{
3009 int chs = get_amp_channels(kcontrol);
3010 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
3011 uinfo->count = chs == 3 ? 2 : 1;
3012 uinfo->value.integer.min = 0;
3013 uinfo->value.integer.max = 48;
3014 uinfo->value.integer.step = 1;
3015
3016 return 0;
3017}
3018
3019static int equalizer_ctl_put(struct snd_kcontrol *kcontrol,
3020 struct snd_ctl_elem_value *ucontrol)
3021{
3022 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3023 struct ca0132_spec *spec = codec->spec;
3024 hda_nid_t nid = get_amp_nid(kcontrol);
3025 long *valp = ucontrol->value.integer.value;
3026 int idx;
3027
3028 idx = nid - TUNING_CTL_START_NID;
3029 /* any change? */
3030 if (spec->cur_ctl_vals[idx] == *valp)
3031 return 0;
3032
3033 spec->cur_ctl_vals[idx] = *valp;
3034
3035 idx = *valp;
3036 tuning_ctl_set(codec, nid, equalizer_vals_lookup, idx);
3037
3038 return 1;
3039}
3040
3041static const DECLARE_TLV_DB_SCALE(voice_focus_db_scale, 2000, 100, 0);
3042static const DECLARE_TLV_DB_SCALE(eq_db_scale, -2400, 100, 0);
3043
3044static int add_tuning_control(struct hda_codec *codec,
3045 hda_nid_t pnid, hda_nid_t nid,
3046 const char *name, int dir)
3047{
Takashi Iwai975cc022013-06-28 11:56:49 +02003048 char namestr[SNDRV_CTL_ELEM_ID_NAME_MAXLEN];
Ian Minett44f0c972012-12-20 18:53:38 -08003049 int type = dir ? HDA_INPUT : HDA_OUTPUT;
3050 struct snd_kcontrol_new knew =
3051 HDA_CODEC_VOLUME_MONO(namestr, nid, 1, 0, type);
3052
3053 knew.access = SNDRV_CTL_ELEM_ACCESS_READWRITE |
3054 SNDRV_CTL_ELEM_ACCESS_TLV_READ;
3055 knew.tlv.c = 0;
3056 knew.tlv.p = 0;
3057 switch (pnid) {
3058 case VOICE_FOCUS:
3059 knew.info = voice_focus_ctl_info;
3060 knew.get = tuning_ctl_get;
3061 knew.put = voice_focus_ctl_put;
3062 knew.tlv.p = voice_focus_db_scale;
3063 break;
3064 case MIC_SVM:
3065 knew.info = mic_svm_ctl_info;
3066 knew.get = tuning_ctl_get;
3067 knew.put = mic_svm_ctl_put;
3068 break;
3069 case EQUALIZER:
3070 knew.info = equalizer_ctl_info;
3071 knew.get = tuning_ctl_get;
3072 knew.put = equalizer_ctl_put;
3073 knew.tlv.p = eq_db_scale;
3074 break;
3075 default:
3076 return 0;
3077 }
3078 knew.private_value =
3079 HDA_COMPOSE_AMP_VAL(nid, 1, 0, type);
3080 sprintf(namestr, "%s %s Volume", name, dirstr[dir]);
3081 return snd_hda_ctl_add(codec, nid, snd_ctl_new1(&knew, codec));
3082}
3083
3084static int add_tuning_ctls(struct hda_codec *codec)
3085{
3086 int i;
3087 int err;
3088
3089 for (i = 0; i < TUNING_CTLS_COUNT; i++) {
3090 err = add_tuning_control(codec,
3091 ca0132_tuning_ctls[i].parent_nid,
3092 ca0132_tuning_ctls[i].nid,
3093 ca0132_tuning_ctls[i].name,
3094 ca0132_tuning_ctls[i].direct);
3095 if (err < 0)
3096 return err;
3097 }
3098
3099 return 0;
3100}
3101
3102static void ca0132_init_tuning_defaults(struct hda_codec *codec)
3103{
3104 struct ca0132_spec *spec = codec->spec;
3105 int i;
3106
3107 /* Wedge Angle defaults to 30. 10 below is 30 - 20. 20 is min. */
3108 spec->cur_ctl_vals[WEDGE_ANGLE - TUNING_CTL_START_NID] = 10;
3109 /* SVM level defaults to 0.74. */
3110 spec->cur_ctl_vals[SVM_LEVEL - TUNING_CTL_START_NID] = 74;
3111
3112 /* EQ defaults to 0dB. */
3113 for (i = 2; i < TUNING_CTLS_COUNT; i++)
3114 spec->cur_ctl_vals[i] = 24;
3115}
3116#endif /*ENABLE_TUNING_CONTROLS*/
3117
Ian Minett825315b2012-12-20 18:53:36 -08003118/*
Ian Minett5aaca442012-12-20 18:53:34 -08003119 * Select the active output.
3120 * If autodetect is enabled, output will be selected based on jack detection.
3121 * If jack inserted, headphone will be selected, else built-in speakers
3122 * If autodetect is disabled, output will be selected based on selection.
3123 */
3124static int ca0132_select_out(struct hda_codec *codec)
3125{
3126 struct ca0132_spec *spec = codec->spec;
3127 unsigned int pin_ctl;
3128 int jack_present;
3129 int auto_jack;
3130 unsigned int tmp;
3131 int err;
3132
Takashi Iwai4e76a882014-02-25 12:21:03 +01003133 codec_dbg(codec, "ca0132_select_out\n");
Ian Minett5aaca442012-12-20 18:53:34 -08003134
3135 snd_hda_power_up(codec);
3136
3137 auto_jack = spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID];
3138
3139 if (auto_jack)
3140 jack_present = snd_hda_jack_detect(codec, spec->out_pins[1]);
3141 else
3142 jack_present =
3143 spec->vnode_lswitch[VNID_HP_SEL - VNODE_START_NID];
3144
3145 if (jack_present)
3146 spec->cur_out_type = HEADPHONE_OUT;
3147 else
3148 spec->cur_out_type = SPEAKER_OUT;
3149
3150 if (spec->cur_out_type == SPEAKER_OUT) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01003151 codec_dbg(codec, "ca0132_select_out speaker\n");
Ian Minett5aaca442012-12-20 18:53:34 -08003152 /*speaker out config*/
3153 tmp = FLOAT_ONE;
3154 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp);
3155 if (err < 0)
3156 goto exit;
3157 /*enable speaker EQ*/
3158 tmp = FLOAT_ONE;
3159 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp);
3160 if (err < 0)
3161 goto exit;
3162
3163 /* Setup EAPD */
3164 snd_hda_codec_write(codec, spec->out_pins[1], 0,
3165 VENDOR_CHIPIO_EAPD_SEL_SET, 0x02);
3166 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3167 AC_VERB_SET_EAPD_BTLENABLE, 0x00);
3168 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3169 VENDOR_CHIPIO_EAPD_SEL_SET, 0x00);
3170 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3171 AC_VERB_SET_EAPD_BTLENABLE, 0x02);
3172
3173 /* disable headphone node */
3174 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0,
3175 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
Takashi Iwaia0c041c2013-01-15 17:13:31 +01003176 snd_hda_set_pin_ctl(codec, spec->out_pins[1],
3177 pin_ctl & ~PIN_HP);
Ian Minett5aaca442012-12-20 18:53:34 -08003178 /* enable speaker node */
3179 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0,
3180 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
Takashi Iwaia0c041c2013-01-15 17:13:31 +01003181 snd_hda_set_pin_ctl(codec, spec->out_pins[0],
3182 pin_ctl | PIN_OUT);
Ian Minett5aaca442012-12-20 18:53:34 -08003183 } else {
Takashi Iwai4e76a882014-02-25 12:21:03 +01003184 codec_dbg(codec, "ca0132_select_out hp\n");
Ian Minett5aaca442012-12-20 18:53:34 -08003185 /*headphone out config*/
3186 tmp = FLOAT_ZERO;
3187 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp);
3188 if (err < 0)
3189 goto exit;
3190 /*disable speaker EQ*/
3191 tmp = FLOAT_ZERO;
3192 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp);
3193 if (err < 0)
3194 goto exit;
3195
3196 /* Setup EAPD */
3197 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3198 VENDOR_CHIPIO_EAPD_SEL_SET, 0x00);
3199 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3200 AC_VERB_SET_EAPD_BTLENABLE, 0x00);
3201 snd_hda_codec_write(codec, spec->out_pins[1], 0,
3202 VENDOR_CHIPIO_EAPD_SEL_SET, 0x02);
3203 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3204 AC_VERB_SET_EAPD_BTLENABLE, 0x02);
3205
3206 /* disable speaker*/
3207 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0,
3208 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
Takashi Iwaia0c041c2013-01-15 17:13:31 +01003209 snd_hda_set_pin_ctl(codec, spec->out_pins[0],
3210 pin_ctl & ~PIN_HP);
Ian Minett5aaca442012-12-20 18:53:34 -08003211 /* enable headphone*/
3212 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0,
3213 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
Takashi Iwaia0c041c2013-01-15 17:13:31 +01003214 snd_hda_set_pin_ctl(codec, spec->out_pins[1],
3215 pin_ctl | PIN_HP);
Ian Minett5aaca442012-12-20 18:53:34 -08003216 }
3217
3218exit:
3219 snd_hda_power_down(codec);
3220
3221 return err < 0 ? err : 0;
3222}
3223
Chih-Chung Chang993884f2013-03-25 10:39:23 -07003224static void ca0132_unsol_hp_delayed(struct work_struct *work)
3225{
3226 struct ca0132_spec *spec = container_of(
3227 to_delayed_work(work), struct ca0132_spec, unsol_hp_work);
Takashi Iwaif8fb1172014-09-11 15:53:26 +02003228 struct hda_jack_tbl *jack;
3229
Chih-Chung Chang993884f2013-03-25 10:39:23 -07003230 ca0132_select_out(spec->codec);
Takashi Iwaif8fb1172014-09-11 15:53:26 +02003231 jack = snd_hda_jack_tbl_get(spec->codec, UNSOL_TAG_HP);
3232 if (jack) {
3233 jack->block_report = 0;
3234 snd_hda_jack_report_sync(spec->codec);
3235 }
Chih-Chung Chang993884f2013-03-25 10:39:23 -07003236}
3237
Ian Minett5aaca442012-12-20 18:53:34 -08003238static void ca0132_set_dmic(struct hda_codec *codec, int enable);
3239static int ca0132_mic_boost_set(struct hda_codec *codec, long val);
3240static int ca0132_effects_set(struct hda_codec *codec, hda_nid_t nid, long val);
3241
3242/*
3243 * Select the active VIP source
3244 */
3245static int ca0132_set_vipsource(struct hda_codec *codec, int val)
3246{
3247 struct ca0132_spec *spec = codec->spec;
3248 unsigned int tmp;
3249
Dylan Reide8f1bd52013-03-14 17:27:45 -07003250 if (spec->dsp_state != DSP_DOWNLOADED)
Ian Minett5aaca442012-12-20 18:53:34 -08003251 return 0;
3252
3253 /* if CrystalVoice if off, vipsource should be 0 */
3254 if (!spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] ||
3255 (val == 0)) {
3256 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, 0);
3257 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000);
3258 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000);
3259 if (spec->cur_mic_type == DIGITAL_MIC)
3260 tmp = FLOAT_TWO;
3261 else
3262 tmp = FLOAT_ONE;
3263 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
3264 tmp = FLOAT_ZERO;
3265 dspio_set_uint_param(codec, 0x80, 0x05, tmp);
3266 } else {
3267 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_16_000);
3268 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_16_000);
3269 if (spec->cur_mic_type == DIGITAL_MIC)
3270 tmp = FLOAT_TWO;
3271 else
3272 tmp = FLOAT_ONE;
3273 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
3274 tmp = FLOAT_ONE;
3275 dspio_set_uint_param(codec, 0x80, 0x05, tmp);
3276 msleep(20);
3277 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, val);
3278 }
3279
3280 return 1;
3281}
3282
3283/*
3284 * Select the active microphone.
3285 * If autodetect is enabled, mic will be selected based on jack detection.
3286 * If jack inserted, ext.mic will be selected, else built-in mic
3287 * If autodetect is disabled, mic will be selected based on selection.
3288 */
3289static int ca0132_select_mic(struct hda_codec *codec)
3290{
3291 struct ca0132_spec *spec = codec->spec;
3292 int jack_present;
3293 int auto_jack;
3294
Takashi Iwai4e76a882014-02-25 12:21:03 +01003295 codec_dbg(codec, "ca0132_select_mic\n");
Ian Minett5aaca442012-12-20 18:53:34 -08003296
3297 snd_hda_power_up(codec);
3298
3299 auto_jack = spec->vnode_lswitch[VNID_AMIC1_ASEL - VNODE_START_NID];
3300
3301 if (auto_jack)
3302 jack_present = snd_hda_jack_detect(codec, spec->input_pins[0]);
3303 else
3304 jack_present =
3305 spec->vnode_lswitch[VNID_AMIC1_SEL - VNODE_START_NID];
3306
3307 if (jack_present)
3308 spec->cur_mic_type = LINE_MIC_IN;
3309 else
3310 spec->cur_mic_type = DIGITAL_MIC;
3311
3312 if (spec->cur_mic_type == DIGITAL_MIC) {
3313 /* enable digital Mic */
3314 chipio_set_conn_rate(codec, MEM_CONNID_DMIC, SR_32_000);
3315 ca0132_set_dmic(codec, 1);
3316 ca0132_mic_boost_set(codec, 0);
3317 /* set voice focus */
3318 ca0132_effects_set(codec, VOICE_FOCUS,
3319 spec->effects_switch
3320 [VOICE_FOCUS - EFFECT_START_NID]);
3321 } else {
3322 /* disable digital Mic */
3323 chipio_set_conn_rate(codec, MEM_CONNID_DMIC, SR_96_000);
3324 ca0132_set_dmic(codec, 0);
3325 ca0132_mic_boost_set(codec, spec->cur_mic_boost);
3326 /* disable voice focus */
3327 ca0132_effects_set(codec, VOICE_FOCUS, 0);
3328 }
3329
3330 snd_hda_power_down(codec);
3331
3332 return 0;
3333}
3334
3335/*
Ian Minetta7e76272012-12-20 18:53:35 -08003336 * Check if VNODE settings take effect immediately.
3337 */
3338static bool ca0132_is_vnode_effective(struct hda_codec *codec,
3339 hda_nid_t vnid,
3340 hda_nid_t *shared_nid)
3341{
3342 struct ca0132_spec *spec = codec->spec;
3343 hda_nid_t nid;
Ian Minetta7e76272012-12-20 18:53:35 -08003344
3345 switch (vnid) {
3346 case VNID_SPK:
3347 nid = spec->shared_out_nid;
Ian Minetta7e76272012-12-20 18:53:35 -08003348 break;
3349 case VNID_MIC:
3350 nid = spec->shared_mic_nid;
Ian Minetta7e76272012-12-20 18:53:35 -08003351 break;
3352 default:
Takashi Iwai9a0869f2013-02-07 12:41:40 +01003353 return false;
Ian Minetta7e76272012-12-20 18:53:35 -08003354 }
3355
Takashi Iwai9a0869f2013-02-07 12:41:40 +01003356 if (shared_nid)
Ian Minetta7e76272012-12-20 18:53:35 -08003357 *shared_nid = nid;
3358
Takashi Iwai9a0869f2013-02-07 12:41:40 +01003359 return true;
Ian Minetta7e76272012-12-20 18:53:35 -08003360}
3361
3362/*
3363* The following functions are control change helpers.
3364* They return 0 if no changed. Return 1 if changed.
3365*/
3366static int ca0132_voicefx_set(struct hda_codec *codec, int enable)
3367{
3368 struct ca0132_spec *spec = codec->spec;
3369 unsigned int tmp;
3370
3371 /* based on CrystalVoice state to enable VoiceFX. */
3372 if (enable) {
3373 tmp = spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] ?
3374 FLOAT_ONE : FLOAT_ZERO;
3375 } else {
3376 tmp = FLOAT_ZERO;
3377 }
3378
3379 dspio_set_uint_param(codec, ca0132_voicefx.mid,
3380 ca0132_voicefx.reqs[0], tmp);
3381
3382 return 1;
3383}
3384
3385/*
Ian Minett5aaca442012-12-20 18:53:34 -08003386 * Set the effects parameters
3387 */
3388static int ca0132_effects_set(struct hda_codec *codec, hda_nid_t nid, long val)
3389{
3390 struct ca0132_spec *spec = codec->spec;
3391 unsigned int on;
3392 int num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT;
3393 int err = 0;
3394 int idx = nid - EFFECT_START_NID;
3395
3396 if ((idx < 0) || (idx >= num_fx))
3397 return 0; /* no changed */
3398
3399 /* for out effect, qualify with PE */
3400 if ((nid >= OUT_EFFECT_START_NID) && (nid < OUT_EFFECT_END_NID)) {
3401 /* if PE if off, turn off out effects. */
3402 if (!spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID])
3403 val = 0;
3404 }
3405
3406 /* for in effect, qualify with CrystalVoice */
3407 if ((nid >= IN_EFFECT_START_NID) && (nid < IN_EFFECT_END_NID)) {
3408 /* if CrystalVoice if off, turn off in effects. */
3409 if (!spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID])
3410 val = 0;
3411
3412 /* Voice Focus applies to 2-ch Mic, Digital Mic */
3413 if ((nid == VOICE_FOCUS) && (spec->cur_mic_type != DIGITAL_MIC))
3414 val = 0;
3415 }
3416
Takashi Iwai4e76a882014-02-25 12:21:03 +01003417 codec_dbg(codec, "ca0132_effect_set: nid=0x%x, val=%ld\n",
Ian Minett5aaca442012-12-20 18:53:34 -08003418 nid, val);
3419
3420 on = (val == 0) ? FLOAT_ZERO : FLOAT_ONE;
3421 err = dspio_set_uint_param(codec, ca0132_effects[idx].mid,
3422 ca0132_effects[idx].reqs[0], on);
3423
3424 if (err < 0)
3425 return 0; /* no changed */
3426
3427 return 1;
3428}
3429
Ian Minetta7e76272012-12-20 18:53:35 -08003430/*
3431 * Turn on/off Playback Enhancements
3432 */
3433static int ca0132_pe_switch_set(struct hda_codec *codec)
3434{
3435 struct ca0132_spec *spec = codec->spec;
3436 hda_nid_t nid;
3437 int i, ret = 0;
3438
Takashi Iwai4e76a882014-02-25 12:21:03 +01003439 codec_dbg(codec, "ca0132_pe_switch_set: val=%ld\n",
Ian Minetta7e76272012-12-20 18:53:35 -08003440 spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]);
3441
3442 i = OUT_EFFECT_START_NID - EFFECT_START_NID;
3443 nid = OUT_EFFECT_START_NID;
3444 /* PE affects all out effects */
3445 for (; nid < OUT_EFFECT_END_NID; nid++, i++)
3446 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]);
3447
3448 return ret;
3449}
3450
Ian Minett5aaca442012-12-20 18:53:34 -08003451/* Check if Mic1 is streaming, if so, stop streaming */
3452static int stop_mic1(struct hda_codec *codec)
3453{
3454 struct ca0132_spec *spec = codec->spec;
3455 unsigned int oldval = snd_hda_codec_read(codec, spec->adcs[0], 0,
3456 AC_VERB_GET_CONV, 0);
3457 if (oldval != 0)
3458 snd_hda_codec_write(codec, spec->adcs[0], 0,
3459 AC_VERB_SET_CHANNEL_STREAMID,
3460 0);
3461 return oldval;
3462}
3463
3464/* Resume Mic1 streaming if it was stopped. */
3465static void resume_mic1(struct hda_codec *codec, unsigned int oldval)
3466{
3467 struct ca0132_spec *spec = codec->spec;
3468 /* Restore the previous stream and channel */
3469 if (oldval != 0)
3470 snd_hda_codec_write(codec, spec->adcs[0], 0,
3471 AC_VERB_SET_CHANNEL_STREAMID,
3472 oldval);
3473}
3474
3475/*
Ian Minetta7e76272012-12-20 18:53:35 -08003476 * Turn on/off CrystalVoice
Ian Minett5aaca442012-12-20 18:53:34 -08003477 */
Ian Minetta7e76272012-12-20 18:53:35 -08003478static int ca0132_cvoice_switch_set(struct hda_codec *codec)
3479{
3480 struct ca0132_spec *spec = codec->spec;
3481 hda_nid_t nid;
3482 int i, ret = 0;
3483 unsigned int oldval;
3484
Takashi Iwai4e76a882014-02-25 12:21:03 +01003485 codec_dbg(codec, "ca0132_cvoice_switch_set: val=%ld\n",
Ian Minetta7e76272012-12-20 18:53:35 -08003486 spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID]);
3487
3488 i = IN_EFFECT_START_NID - EFFECT_START_NID;
3489 nid = IN_EFFECT_START_NID;
3490 /* CrystalVoice affects all in effects */
3491 for (; nid < IN_EFFECT_END_NID; nid++, i++)
3492 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]);
3493
3494 /* including VoiceFX */
3495 ret |= ca0132_voicefx_set(codec, (spec->voicefx_val ? 1 : 0));
3496
3497 /* set correct vipsource */
3498 oldval = stop_mic1(codec);
3499 ret |= ca0132_set_vipsource(codec, 1);
3500 resume_mic1(codec, oldval);
3501 return ret;
3502}
3503
Ian Minett5aaca442012-12-20 18:53:34 -08003504static int ca0132_mic_boost_set(struct hda_codec *codec, long val)
3505{
3506 struct ca0132_spec *spec = codec->spec;
3507 int ret = 0;
3508
3509 if (val) /* on */
3510 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0,
3511 HDA_INPUT, 0, HDA_AMP_VOLMASK, 3);
3512 else /* off */
3513 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0,
3514 HDA_INPUT, 0, HDA_AMP_VOLMASK, 0);
3515
3516 return ret;
3517}
3518
Ian Minetta7e76272012-12-20 18:53:35 -08003519static int ca0132_vnode_switch_set(struct snd_kcontrol *kcontrol,
3520 struct snd_ctl_elem_value *ucontrol)
3521{
3522 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3523 hda_nid_t nid = get_amp_nid(kcontrol);
3524 hda_nid_t shared_nid = 0;
3525 bool effective;
3526 int ret = 0;
3527 struct ca0132_spec *spec = codec->spec;
3528 int auto_jack;
3529
3530 if (nid == VNID_HP_SEL) {
3531 auto_jack =
3532 spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID];
3533 if (!auto_jack)
3534 ca0132_select_out(codec);
3535 return 1;
3536 }
3537
3538 if (nid == VNID_AMIC1_SEL) {
3539 auto_jack =
3540 spec->vnode_lswitch[VNID_AMIC1_ASEL - VNODE_START_NID];
3541 if (!auto_jack)
3542 ca0132_select_mic(codec);
3543 return 1;
3544 }
3545
3546 if (nid == VNID_HP_ASEL) {
3547 ca0132_select_out(codec);
3548 return 1;
3549 }
3550
3551 if (nid == VNID_AMIC1_ASEL) {
3552 ca0132_select_mic(codec);
3553 return 1;
3554 }
3555
3556 /* if effective conditions, then update hw immediately. */
3557 effective = ca0132_is_vnode_effective(codec, nid, &shared_nid);
3558 if (effective) {
3559 int dir = get_amp_direction(kcontrol);
3560 int ch = get_amp_channels(kcontrol);
3561 unsigned long pval;
3562
3563 mutex_lock(&codec->control_mutex);
3564 pval = kcontrol->private_value;
3565 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(shared_nid, ch,
3566 0, dir);
3567 ret = snd_hda_mixer_amp_switch_put(kcontrol, ucontrol);
3568 kcontrol->private_value = pval;
3569 mutex_unlock(&codec->control_mutex);
3570 }
3571
3572 return ret;
3573}
3574/* End of control change helpers. */
3575
3576static int ca0132_voicefx_info(struct snd_kcontrol *kcontrol,
3577 struct snd_ctl_elem_info *uinfo)
3578{
3579 unsigned int items = sizeof(ca0132_voicefx_presets)
3580 / sizeof(struct ct_voicefx_preset);
3581
3582 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
3583 uinfo->count = 1;
3584 uinfo->value.enumerated.items = items;
3585 if (uinfo->value.enumerated.item >= items)
3586 uinfo->value.enumerated.item = items - 1;
3587 strcpy(uinfo->value.enumerated.name,
3588 ca0132_voicefx_presets[uinfo->value.enumerated.item].name);
3589 return 0;
3590}
3591
3592static int ca0132_voicefx_get(struct snd_kcontrol *kcontrol,
3593 struct snd_ctl_elem_value *ucontrol)
3594{
3595 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3596 struct ca0132_spec *spec = codec->spec;
3597
3598 ucontrol->value.enumerated.item[0] = spec->voicefx_val;
3599 return 0;
3600}
3601
3602static int ca0132_voicefx_put(struct snd_kcontrol *kcontrol,
3603 struct snd_ctl_elem_value *ucontrol)
3604{
3605 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3606 struct ca0132_spec *spec = codec->spec;
3607 int i, err = 0;
3608 int sel = ucontrol->value.enumerated.item[0];
3609 unsigned int items = sizeof(ca0132_voicefx_presets)
3610 / sizeof(struct ct_voicefx_preset);
3611
3612 if (sel >= items)
3613 return 0;
3614
Takashi Iwai4e76a882014-02-25 12:21:03 +01003615 codec_dbg(codec, "ca0132_voicefx_put: sel=%d, preset=%s\n",
Ian Minetta7e76272012-12-20 18:53:35 -08003616 sel, ca0132_voicefx_presets[sel].name);
3617
3618 /*
3619 * Idx 0 is default.
3620 * Default needs to qualify with CrystalVoice state.
3621 */
3622 for (i = 0; i < VOICEFX_MAX_PARAM_COUNT; i++) {
3623 err = dspio_set_uint_param(codec, ca0132_voicefx.mid,
3624 ca0132_voicefx.reqs[i],
3625 ca0132_voicefx_presets[sel].vals[i]);
3626 if (err < 0)
3627 break;
3628 }
3629
3630 if (err >= 0) {
3631 spec->voicefx_val = sel;
3632 /* enable voice fx */
3633 ca0132_voicefx_set(codec, (sel ? 1 : 0));
3634 }
3635
3636 return 1;
3637}
3638
3639static int ca0132_switch_get(struct snd_kcontrol *kcontrol,
3640 struct snd_ctl_elem_value *ucontrol)
3641{
3642 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3643 struct ca0132_spec *spec = codec->spec;
3644 hda_nid_t nid = get_amp_nid(kcontrol);
3645 int ch = get_amp_channels(kcontrol);
3646 long *valp = ucontrol->value.integer.value;
3647
3648 /* vnode */
3649 if ((nid >= VNODE_START_NID) && (nid < VNODE_END_NID)) {
3650 if (ch & 1) {
3651 *valp = spec->vnode_lswitch[nid - VNODE_START_NID];
3652 valp++;
3653 }
3654 if (ch & 2) {
3655 *valp = spec->vnode_rswitch[nid - VNODE_START_NID];
3656 valp++;
3657 }
3658 return 0;
3659 }
3660
3661 /* effects, include PE and CrystalVoice */
3662 if ((nid >= EFFECT_START_NID) && (nid < EFFECT_END_NID)) {
3663 *valp = spec->effects_switch[nid - EFFECT_START_NID];
3664 return 0;
3665 }
3666
3667 /* mic boost */
3668 if (nid == spec->input_pins[0]) {
3669 *valp = spec->cur_mic_boost;
3670 return 0;
3671 }
3672
3673 return 0;
3674}
3675
3676static int ca0132_switch_put(struct snd_kcontrol *kcontrol,
3677 struct snd_ctl_elem_value *ucontrol)
3678{
3679 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3680 struct ca0132_spec *spec = codec->spec;
3681 hda_nid_t nid = get_amp_nid(kcontrol);
3682 int ch = get_amp_channels(kcontrol);
3683 long *valp = ucontrol->value.integer.value;
3684 int changed = 1;
3685
Takashi Iwai4e76a882014-02-25 12:21:03 +01003686 codec_dbg(codec, "ca0132_switch_put: nid=0x%x, val=%ld\n",
Ian Minetta7e76272012-12-20 18:53:35 -08003687 nid, *valp);
3688
3689 snd_hda_power_up(codec);
3690 /* vnode */
3691 if ((nid >= VNODE_START_NID) && (nid < VNODE_END_NID)) {
3692 if (ch & 1) {
3693 spec->vnode_lswitch[nid - VNODE_START_NID] = *valp;
3694 valp++;
3695 }
3696 if (ch & 2) {
3697 spec->vnode_rswitch[nid - VNODE_START_NID] = *valp;
3698 valp++;
3699 }
3700 changed = ca0132_vnode_switch_set(kcontrol, ucontrol);
3701 goto exit;
3702 }
3703
3704 /* PE */
3705 if (nid == PLAY_ENHANCEMENT) {
3706 spec->effects_switch[nid - EFFECT_START_NID] = *valp;
3707 changed = ca0132_pe_switch_set(codec);
3708 goto exit;
3709 }
3710
3711 /* CrystalVoice */
3712 if (nid == CRYSTAL_VOICE) {
3713 spec->effects_switch[nid - EFFECT_START_NID] = *valp;
3714 changed = ca0132_cvoice_switch_set(codec);
3715 goto exit;
3716 }
3717
3718 /* out and in effects */
3719 if (((nid >= OUT_EFFECT_START_NID) && (nid < OUT_EFFECT_END_NID)) ||
3720 ((nid >= IN_EFFECT_START_NID) && (nid < IN_EFFECT_END_NID))) {
3721 spec->effects_switch[nid - EFFECT_START_NID] = *valp;
3722 changed = ca0132_effects_set(codec, nid, *valp);
3723 goto exit;
3724 }
3725
3726 /* mic boost */
3727 if (nid == spec->input_pins[0]) {
3728 spec->cur_mic_boost = *valp;
3729
3730 /* Mic boost does not apply to Digital Mic */
3731 if (spec->cur_mic_type != DIGITAL_MIC)
3732 changed = ca0132_mic_boost_set(codec, *valp);
3733 goto exit;
3734 }
3735
3736exit:
3737 snd_hda_power_down(codec);
3738 return changed;
3739}
3740
3741/*
3742 * Volume related
3743 */
3744static int ca0132_volume_info(struct snd_kcontrol *kcontrol,
3745 struct snd_ctl_elem_info *uinfo)
3746{
3747 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3748 struct ca0132_spec *spec = codec->spec;
3749 hda_nid_t nid = get_amp_nid(kcontrol);
3750 int ch = get_amp_channels(kcontrol);
3751 int dir = get_amp_direction(kcontrol);
3752 unsigned long pval;
3753 int err;
3754
3755 switch (nid) {
3756 case VNID_SPK:
3757 /* follow shared_out info */
3758 nid = spec->shared_out_nid;
3759 mutex_lock(&codec->control_mutex);
3760 pval = kcontrol->private_value;
3761 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir);
3762 err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo);
3763 kcontrol->private_value = pval;
3764 mutex_unlock(&codec->control_mutex);
3765 break;
3766 case VNID_MIC:
3767 /* follow shared_mic info */
3768 nid = spec->shared_mic_nid;
3769 mutex_lock(&codec->control_mutex);
3770 pval = kcontrol->private_value;
3771 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir);
3772 err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo);
3773 kcontrol->private_value = pval;
3774 mutex_unlock(&codec->control_mutex);
3775 break;
3776 default:
3777 err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo);
3778 }
3779 return err;
3780}
3781
3782static int ca0132_volume_get(struct snd_kcontrol *kcontrol,
3783 struct snd_ctl_elem_value *ucontrol)
3784{
3785 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3786 struct ca0132_spec *spec = codec->spec;
3787 hda_nid_t nid = get_amp_nid(kcontrol);
3788 int ch = get_amp_channels(kcontrol);
3789 long *valp = ucontrol->value.integer.value;
3790
3791 /* store the left and right volume */
3792 if (ch & 1) {
3793 *valp = spec->vnode_lvol[nid - VNODE_START_NID];
3794 valp++;
3795 }
3796 if (ch & 2) {
3797 *valp = spec->vnode_rvol[nid - VNODE_START_NID];
3798 valp++;
3799 }
3800 return 0;
3801}
3802
3803static int ca0132_volume_put(struct snd_kcontrol *kcontrol,
3804 struct snd_ctl_elem_value *ucontrol)
3805{
3806 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3807 struct ca0132_spec *spec = codec->spec;
3808 hda_nid_t nid = get_amp_nid(kcontrol);
3809 int ch = get_amp_channels(kcontrol);
3810 long *valp = ucontrol->value.integer.value;
3811 hda_nid_t shared_nid = 0;
3812 bool effective;
3813 int changed = 1;
3814
3815 /* store the left and right volume */
3816 if (ch & 1) {
3817 spec->vnode_lvol[nid - VNODE_START_NID] = *valp;
3818 valp++;
3819 }
3820 if (ch & 2) {
3821 spec->vnode_rvol[nid - VNODE_START_NID] = *valp;
3822 valp++;
3823 }
3824
3825 /* if effective conditions, then update hw immediately. */
3826 effective = ca0132_is_vnode_effective(codec, nid, &shared_nid);
3827 if (effective) {
3828 int dir = get_amp_direction(kcontrol);
3829 unsigned long pval;
3830
3831 snd_hda_power_up(codec);
3832 mutex_lock(&codec->control_mutex);
3833 pval = kcontrol->private_value;
3834 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(shared_nid, ch,
3835 0, dir);
3836 changed = snd_hda_mixer_amp_volume_put(kcontrol, ucontrol);
3837 kcontrol->private_value = pval;
3838 mutex_unlock(&codec->control_mutex);
3839 snd_hda_power_down(codec);
3840 }
3841
3842 return changed;
3843}
3844
3845static int ca0132_volume_tlv(struct snd_kcontrol *kcontrol, int op_flag,
3846 unsigned int size, unsigned int __user *tlv)
3847{
3848 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3849 struct ca0132_spec *spec = codec->spec;
3850 hda_nid_t nid = get_amp_nid(kcontrol);
3851 int ch = get_amp_channels(kcontrol);
3852 int dir = get_amp_direction(kcontrol);
3853 unsigned long pval;
3854 int err;
3855
3856 switch (nid) {
3857 case VNID_SPK:
3858 /* follow shared_out tlv */
3859 nid = spec->shared_out_nid;
3860 mutex_lock(&codec->control_mutex);
3861 pval = kcontrol->private_value;
3862 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir);
3863 err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv);
3864 kcontrol->private_value = pval;
3865 mutex_unlock(&codec->control_mutex);
3866 break;
3867 case VNID_MIC:
3868 /* follow shared_mic tlv */
3869 nid = spec->shared_mic_nid;
3870 mutex_lock(&codec->control_mutex);
3871 pval = kcontrol->private_value;
3872 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir);
3873 err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv);
3874 kcontrol->private_value = pval;
3875 mutex_unlock(&codec->control_mutex);
3876 break;
3877 default:
3878 err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv);
3879 }
3880 return err;
3881}
3882
3883static int add_fx_switch(struct hda_codec *codec, hda_nid_t nid,
3884 const char *pfx, int dir)
3885{
Takashi Iwai975cc022013-06-28 11:56:49 +02003886 char namestr[SNDRV_CTL_ELEM_ID_NAME_MAXLEN];
Ian Minetta7e76272012-12-20 18:53:35 -08003887 int type = dir ? HDA_INPUT : HDA_OUTPUT;
3888 struct snd_kcontrol_new knew =
3889 CA0132_CODEC_MUTE_MONO(namestr, nid, 1, type);
3890 sprintf(namestr, "%s %s Switch", pfx, dirstr[dir]);
3891 return snd_hda_ctl_add(codec, nid, snd_ctl_new1(&knew, codec));
3892}
3893
3894static int add_voicefx(struct hda_codec *codec)
3895{
3896 struct snd_kcontrol_new knew =
3897 HDA_CODEC_MUTE_MONO(ca0132_voicefx.name,
3898 VOICEFX, 1, 0, HDA_INPUT);
3899 knew.info = ca0132_voicefx_info;
3900 knew.get = ca0132_voicefx_get;
3901 knew.put = ca0132_voicefx_put;
3902 return snd_hda_ctl_add(codec, VOICEFX, snd_ctl_new1(&knew, codec));
3903}
3904
3905/*
3906 * When changing Node IDs for Mixer Controls below, make sure to update
3907 * Node IDs in ca0132_config() as well.
3908 */
3909static struct snd_kcontrol_new ca0132_mixer[] = {
3910 CA0132_CODEC_VOL("Master Playback Volume", VNID_SPK, HDA_OUTPUT),
3911 CA0132_CODEC_MUTE("Master Playback Switch", VNID_SPK, HDA_OUTPUT),
3912 CA0132_CODEC_VOL("Capture Volume", VNID_MIC, HDA_INPUT),
3913 CA0132_CODEC_MUTE("Capture Switch", VNID_MIC, HDA_INPUT),
3914 HDA_CODEC_VOLUME("Analog-Mic2 Capture Volume", 0x08, 0, HDA_INPUT),
3915 HDA_CODEC_MUTE("Analog-Mic2 Capture Switch", 0x08, 0, HDA_INPUT),
3916 HDA_CODEC_VOLUME("What U Hear Capture Volume", 0x0a, 0, HDA_INPUT),
3917 HDA_CODEC_MUTE("What U Hear Capture Switch", 0x0a, 0, HDA_INPUT),
3918 CA0132_CODEC_MUTE_MONO("Mic1-Boost (30dB) Capture Switch",
3919 0x12, 1, HDA_INPUT),
3920 CA0132_CODEC_MUTE_MONO("HP/Speaker Playback Switch",
3921 VNID_HP_SEL, 1, HDA_OUTPUT),
3922 CA0132_CODEC_MUTE_MONO("AMic1/DMic Capture Switch",
3923 VNID_AMIC1_SEL, 1, HDA_INPUT),
3924 CA0132_CODEC_MUTE_MONO("HP/Speaker Auto Detect Playback Switch",
3925 VNID_HP_ASEL, 1, HDA_OUTPUT),
3926 CA0132_CODEC_MUTE_MONO("AMic1/DMic Auto Detect Capture Switch",
3927 VNID_AMIC1_ASEL, 1, HDA_INPUT),
3928 { } /* end */
3929};
3930
Ian Minette90f29e2012-12-20 18:53:39 -08003931static int ca0132_build_controls(struct hda_codec *codec)
3932{
3933 struct ca0132_spec *spec = codec->spec;
3934 int i, num_fx;
3935 int err = 0;
3936
3937 /* Add Mixer controls */
3938 for (i = 0; i < spec->num_mixers; i++) {
3939 err = snd_hda_add_new_ctls(codec, spec->mixers[i]);
3940 if (err < 0)
3941 return err;
3942 }
3943
3944 /* Add in and out effects controls.
3945 * VoiceFX, PE and CrystalVoice are added separately.
3946 */
3947 num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT;
3948 for (i = 0; i < num_fx; i++) {
3949 err = add_fx_switch(codec, ca0132_effects[i].nid,
3950 ca0132_effects[i].name,
3951 ca0132_effects[i].direct);
3952 if (err < 0)
3953 return err;
3954 }
3955
3956 err = add_fx_switch(codec, PLAY_ENHANCEMENT, "PlayEnhancement", 0);
3957 if (err < 0)
3958 return err;
3959
3960 err = add_fx_switch(codec, CRYSTAL_VOICE, "CrystalVoice", 1);
3961 if (err < 0)
3962 return err;
3963
3964 add_voicefx(codec);
3965
3966#ifdef ENABLE_TUNING_CONTROLS
3967 add_tuning_ctls(codec);
3968#endif
3969
3970 err = snd_hda_jack_add_kctls(codec, &spec->autocfg);
3971 if (err < 0)
3972 return err;
3973
3974 if (spec->dig_out) {
3975 err = snd_hda_create_spdif_out_ctls(codec, spec->dig_out,
3976 spec->dig_out);
3977 if (err < 0)
3978 return err;
3979 err = snd_hda_create_spdif_share_sw(codec, &spec->multiout);
3980 if (err < 0)
3981 return err;
3982 /* spec->multiout.share_spdif = 1; */
3983 }
3984
3985 if (spec->dig_in) {
3986 err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in);
3987 if (err < 0)
3988 return err;
3989 }
3990 return 0;
3991}
3992
Ian Minett5aaca442012-12-20 18:53:34 -08003993/*
Ian Minette90f29e2012-12-20 18:53:39 -08003994 * PCM
Ian Minett95c6e9c2011-06-15 15:35:17 -07003995 */
3996static struct hda_pcm_stream ca0132_pcm_analog_playback = {
3997 .substreams = 1,
3998 .channels_min = 2,
Ian Minett825315b2012-12-20 18:53:36 -08003999 .channels_max = 6,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004000 .ops = {
4001 .prepare = ca0132_playback_pcm_prepare,
Dylan Reide8412ca2013-04-04 13:55:09 -07004002 .cleanup = ca0132_playback_pcm_cleanup,
4003 .get_delay = ca0132_playback_pcm_delay,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004004 },
4005};
4006
4007static struct hda_pcm_stream ca0132_pcm_analog_capture = {
4008 .substreams = 1,
4009 .channels_min = 2,
4010 .channels_max = 2,
Ian Minett825315b2012-12-20 18:53:36 -08004011 .ops = {
4012 .prepare = ca0132_capture_pcm_prepare,
Dylan Reide8412ca2013-04-04 13:55:09 -07004013 .cleanup = ca0132_capture_pcm_cleanup,
4014 .get_delay = ca0132_capture_pcm_delay,
Ian Minett825315b2012-12-20 18:53:36 -08004015 },
Ian Minett95c6e9c2011-06-15 15:35:17 -07004016};
4017
4018static struct hda_pcm_stream ca0132_pcm_digital_playback = {
4019 .substreams = 1,
4020 .channels_min = 2,
4021 .channels_max = 2,
4022 .ops = {
Takashi Iwai27ebeb02012-08-08 17:20:18 +02004023 .open = ca0132_dig_playback_pcm_open,
4024 .close = ca0132_dig_playback_pcm_close,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004025 .prepare = ca0132_dig_playback_pcm_prepare,
4026 .cleanup = ca0132_dig_playback_pcm_cleanup
4027 },
4028};
4029
4030static struct hda_pcm_stream ca0132_pcm_digital_capture = {
4031 .substreams = 1,
4032 .channels_min = 2,
4033 .channels_max = 2,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004034};
4035
4036static int ca0132_build_pcms(struct hda_codec *codec)
4037{
4038 struct ca0132_spec *spec = codec->spec;
4039 struct hda_pcm *info = spec->pcm_rec;
4040
4041 codec->pcm_info = info;
4042 codec->num_pcms = 0;
4043
4044 info->name = "CA0132 Analog";
4045 info->stream[SNDRV_PCM_STREAM_PLAYBACK] = ca0132_pcm_analog_playback;
4046 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dacs[0];
4047 info->stream[SNDRV_PCM_STREAM_PLAYBACK].channels_max =
4048 spec->multiout.max_channels;
4049 info->stream[SNDRV_PCM_STREAM_CAPTURE] = ca0132_pcm_analog_capture;
Ian Minett825315b2012-12-20 18:53:36 -08004050 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004051 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[0];
4052 codec->num_pcms++;
4053
Ian Minett825315b2012-12-20 18:53:36 -08004054 info++;
4055 info->name = "CA0132 Analog Mic-In2";
4056 info->stream[SNDRV_PCM_STREAM_CAPTURE] = ca0132_pcm_analog_capture;
4057 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1;
4058 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[1];
4059 codec->num_pcms++;
4060
4061 info++;
4062 info->name = "CA0132 What U Hear";
4063 info->stream[SNDRV_PCM_STREAM_CAPTURE] = ca0132_pcm_analog_capture;
4064 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1;
4065 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[2];
4066 codec->num_pcms++;
4067
Ian Minett95c6e9c2011-06-15 15:35:17 -07004068 if (!spec->dig_out && !spec->dig_in)
4069 return 0;
4070
4071 info++;
4072 info->name = "CA0132 Digital";
4073 info->pcm_type = HDA_PCM_TYPE_SPDIF;
4074 if (spec->dig_out) {
4075 info->stream[SNDRV_PCM_STREAM_PLAYBACK] =
4076 ca0132_pcm_digital_playback;
4077 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dig_out;
4078 }
4079 if (spec->dig_in) {
4080 info->stream[SNDRV_PCM_STREAM_CAPTURE] =
4081 ca0132_pcm_digital_capture;
4082 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->dig_in;
4083 }
4084 codec->num_pcms++;
4085
4086 return 0;
4087}
4088
Ian Minett441aa6a2012-12-20 18:53:40 -08004089static void init_output(struct hda_codec *codec, hda_nid_t pin, hda_nid_t dac)
4090{
4091 if (pin) {
Takashi Iwaia0c041c2013-01-15 17:13:31 +01004092 snd_hda_set_pin_ctl(codec, pin, PIN_HP);
Ian Minett441aa6a2012-12-20 18:53:40 -08004093 if (get_wcaps(codec, pin) & AC_WCAP_OUT_AMP)
4094 snd_hda_codec_write(codec, pin, 0,
4095 AC_VERB_SET_AMP_GAIN_MUTE,
4096 AMP_OUT_UNMUTE);
4097 }
4098 if (dac && (get_wcaps(codec, dac) & AC_WCAP_OUT_AMP))
4099 snd_hda_codec_write(codec, dac, 0,
4100 AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO);
4101}
4102
4103static void init_input(struct hda_codec *codec, hda_nid_t pin, hda_nid_t adc)
4104{
4105 if (pin) {
Takashi Iwaia0c041c2013-01-15 17:13:31 +01004106 snd_hda_set_pin_ctl(codec, pin, PIN_VREF80);
Ian Minett441aa6a2012-12-20 18:53:40 -08004107 if (get_wcaps(codec, pin) & AC_WCAP_IN_AMP)
4108 snd_hda_codec_write(codec, pin, 0,
4109 AC_VERB_SET_AMP_GAIN_MUTE,
4110 AMP_IN_UNMUTE(0));
4111 }
4112 if (adc && (get_wcaps(codec, adc) & AC_WCAP_IN_AMP)) {
4113 snd_hda_codec_write(codec, adc, 0, AC_VERB_SET_AMP_GAIN_MUTE,
4114 AMP_IN_UNMUTE(0));
4115
4116 /* init to 0 dB and unmute. */
4117 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0,
4118 HDA_AMP_VOLMASK, 0x5a);
4119 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0,
4120 HDA_AMP_MUTE, 0);
4121 }
4122}
4123
Ian Minett5aaca442012-12-20 18:53:34 -08004124static void refresh_amp_caps(struct hda_codec *codec, hda_nid_t nid, int dir)
4125{
4126 unsigned int caps;
4127
4128 caps = snd_hda_param_read(codec, nid, dir == HDA_OUTPUT ?
4129 AC_PAR_AMP_OUT_CAP : AC_PAR_AMP_IN_CAP);
4130 snd_hda_override_amp_caps(codec, nid, dir, caps);
4131}
4132
4133/*
4134 * Switch between Digital built-in mic and analog mic.
4135 */
4136static void ca0132_set_dmic(struct hda_codec *codec, int enable)
4137{
4138 struct ca0132_spec *spec = codec->spec;
4139 unsigned int tmp;
4140 u8 val;
4141 unsigned int oldval;
4142
Takashi Iwai4e76a882014-02-25 12:21:03 +01004143 codec_dbg(codec, "ca0132_set_dmic: enable=%d\n", enable);
Ian Minett5aaca442012-12-20 18:53:34 -08004144
4145 oldval = stop_mic1(codec);
4146 ca0132_set_vipsource(codec, 0);
4147 if (enable) {
4148 /* set DMic input as 2-ch */
4149 tmp = FLOAT_TWO;
4150 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
4151
4152 val = spec->dmic_ctl;
4153 val |= 0x80;
4154 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4155 VENDOR_CHIPIO_DMIC_CTL_SET, val);
4156
4157 if (!(spec->dmic_ctl & 0x20))
4158 chipio_set_control_flag(codec, CONTROL_FLAG_DMIC, 1);
4159 } else {
4160 /* set AMic input as mono */
4161 tmp = FLOAT_ONE;
4162 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
4163
4164 val = spec->dmic_ctl;
4165 /* clear bit7 and bit5 to disable dmic */
4166 val &= 0x5f;
4167 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4168 VENDOR_CHIPIO_DMIC_CTL_SET, val);
4169
4170 if (!(spec->dmic_ctl & 0x20))
4171 chipio_set_control_flag(codec, CONTROL_FLAG_DMIC, 0);
4172 }
4173 ca0132_set_vipsource(codec, 1);
4174 resume_mic1(codec, oldval);
4175}
4176
4177/*
4178 * Initialization for Digital Mic.
4179 */
4180static void ca0132_init_dmic(struct hda_codec *codec)
4181{
4182 struct ca0132_spec *spec = codec->spec;
4183 u8 val;
4184
4185 /* Setup Digital Mic here, but don't enable.
4186 * Enable based on jack detect.
4187 */
4188
4189 /* MCLK uses MPIO1, set to enable.
4190 * Bit 2-0: MPIO select
4191 * Bit 3: set to disable
4192 * Bit 7-4: reserved
4193 */
4194 val = 0x01;
4195 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4196 VENDOR_CHIPIO_DMIC_MCLK_SET, val);
4197
4198 /* Data1 uses MPIO3. Data2 not use
4199 * Bit 2-0: Data1 MPIO select
4200 * Bit 3: set disable Data1
4201 * Bit 6-4: Data2 MPIO select
4202 * Bit 7: set disable Data2
4203 */
4204 val = 0x83;
4205 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4206 VENDOR_CHIPIO_DMIC_PIN_SET, val);
4207
4208 /* Use Ch-0 and Ch-1. Rate is 48K, mode 1. Disable DMic first.
4209 * Bit 3-0: Channel mask
4210 * Bit 4: set for 48KHz, clear for 32KHz
4211 * Bit 5: mode
4212 * Bit 6: set to select Data2, clear for Data1
4213 * Bit 7: set to enable DMic, clear for AMic
4214 */
4215 val = 0x23;
4216 /* keep a copy of dmic ctl val for enable/disable dmic purpuse */
4217 spec->dmic_ctl = val;
4218 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4219 VENDOR_CHIPIO_DMIC_CTL_SET, val);
4220}
4221
4222/*
4223 * Initialization for Analog Mic 2
4224 */
4225static void ca0132_init_analog_mic2(struct hda_codec *codec)
4226{
4227 struct ca0132_spec *spec = codec->spec;
4228
4229 mutex_lock(&spec->chipio_mutex);
4230 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4231 VENDOR_CHIPIO_8051_ADDRESS_LOW, 0x20);
4232 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4233 VENDOR_CHIPIO_8051_ADDRESS_HIGH, 0x19);
4234 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4235 VENDOR_CHIPIO_8051_DATA_WRITE, 0x00);
4236 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4237 VENDOR_CHIPIO_8051_ADDRESS_LOW, 0x2D);
4238 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4239 VENDOR_CHIPIO_8051_ADDRESS_HIGH, 0x19);
4240 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4241 VENDOR_CHIPIO_8051_DATA_WRITE, 0x00);
4242 mutex_unlock(&spec->chipio_mutex);
4243}
4244
4245static void ca0132_refresh_widget_caps(struct hda_codec *codec)
4246{
4247 struct ca0132_spec *spec = codec->spec;
4248 int i;
4249 hda_nid_t nid;
4250
Takashi Iwai4e76a882014-02-25 12:21:03 +01004251 codec_dbg(codec, "ca0132_refresh_widget_caps.\n");
Ian Minett5aaca442012-12-20 18:53:34 -08004252 nid = codec->start_nid;
4253 for (i = 0; i < codec->num_nodes; i++, nid++)
4254 codec->wcaps[i] = snd_hda_param_read(codec, nid,
4255 AC_PAR_AUDIO_WIDGET_CAP);
4256
4257 for (i = 0; i < spec->multiout.num_dacs; i++)
4258 refresh_amp_caps(codec, spec->dacs[i], HDA_OUTPUT);
4259
4260 for (i = 0; i < spec->num_outputs; i++)
4261 refresh_amp_caps(codec, spec->out_pins[i], HDA_OUTPUT);
4262
4263 for (i = 0; i < spec->num_inputs; i++) {
4264 refresh_amp_caps(codec, spec->adcs[i], HDA_INPUT);
4265 refresh_amp_caps(codec, spec->input_pins[i], HDA_INPUT);
4266 }
4267}
4268
4269/*
4270 * Setup default parameters for DSP
4271 */
4272static void ca0132_setup_defaults(struct hda_codec *codec)
4273{
Dylan Reide8f1bd52013-03-14 17:27:45 -07004274 struct ca0132_spec *spec = codec->spec;
Ian Minett5aaca442012-12-20 18:53:34 -08004275 unsigned int tmp;
4276 int num_fx;
4277 int idx, i;
4278
Dylan Reide8f1bd52013-03-14 17:27:45 -07004279 if (spec->dsp_state != DSP_DOWNLOADED)
Ian Minett5aaca442012-12-20 18:53:34 -08004280 return;
4281
4282 /* out, in effects + voicefx */
4283 num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT + 1;
4284 for (idx = 0; idx < num_fx; idx++) {
4285 for (i = 0; i <= ca0132_effects[idx].params; i++) {
4286 dspio_set_uint_param(codec, ca0132_effects[idx].mid,
4287 ca0132_effects[idx].reqs[i],
4288 ca0132_effects[idx].def_vals[i]);
4289 }
4290 }
4291
4292 /*remove DSP headroom*/
4293 tmp = FLOAT_ZERO;
4294 dspio_set_uint_param(codec, 0x96, 0x3C, tmp);
4295
4296 /*set speaker EQ bypass attenuation*/
4297 dspio_set_uint_param(codec, 0x8f, 0x01, tmp);
4298
4299 /* set AMic1 and AMic2 as mono mic */
4300 tmp = FLOAT_ONE;
4301 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
4302 dspio_set_uint_param(codec, 0x80, 0x01, tmp);
4303
4304 /* set AMic1 as CrystalVoice input */
4305 tmp = FLOAT_ONE;
4306 dspio_set_uint_param(codec, 0x80, 0x05, tmp);
4307
4308 /* set WUH source */
4309 tmp = FLOAT_TWO;
4310 dspio_set_uint_param(codec, 0x31, 0x00, tmp);
4311}
4312
4313/*
4314 * Initialization of flags in chip
4315 */
4316static void ca0132_init_flags(struct hda_codec *codec)
4317{
4318 chipio_set_control_flag(codec, CONTROL_FLAG_IDLE_ENABLE, 0);
4319 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_A_COMMON_MODE, 0);
4320 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_D_COMMON_MODE, 0);
4321 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_A_10KOHM_LOAD, 0);
4322 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_D_10KOHM_LOAD, 0);
4323 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_C_HIGH_PASS, 1);
4324}
4325
4326/*
4327 * Initialization of parameters in chip
4328 */
4329static void ca0132_init_params(struct hda_codec *codec)
4330{
4331 chipio_set_control_param(codec, CONTROL_PARAM_PORTA_160OHM_GAIN, 6);
4332 chipio_set_control_param(codec, CONTROL_PARAM_PORTD_160OHM_GAIN, 6);
4333}
Ian Minett95c6e9c2011-06-15 15:35:17 -07004334
Ian Minette90f29e2012-12-20 18:53:39 -08004335static void ca0132_set_dsp_msr(struct hda_codec *codec, bool is96k)
4336{
4337 chipio_set_control_flag(codec, CONTROL_FLAG_DSP_96KHZ, is96k);
4338 chipio_set_control_flag(codec, CONTROL_FLAG_DAC_96KHZ, is96k);
4339 chipio_set_control_flag(codec, CONTROL_FLAG_SRC_RATE_96KHZ, is96k);
4340 chipio_set_control_flag(codec, CONTROL_FLAG_SRC_CLOCK_196MHZ, is96k);
4341 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_B_96KHZ, is96k);
4342 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_C_96KHZ, is96k);
4343
Ian Minett406261c2012-12-20 18:53:41 -08004344 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000);
4345 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000);
Ian Minette90f29e2012-12-20 18:53:39 -08004346 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000);
4347}
4348
4349static bool ca0132_download_dsp_images(struct hda_codec *codec)
4350{
4351 bool dsp_loaded = false;
4352 const struct dsp_image_seg *dsp_os_image;
Takashi Iwai15e4ba62013-01-15 17:08:38 +01004353 const struct firmware *fw_entry;
Ian Minette90f29e2012-12-20 18:53:39 -08004354
Takashi Iwai15e4ba62013-01-15 17:08:38 +01004355 if (request_firmware(&fw_entry, EFX_FILE, codec->bus->card->dev) != 0)
Ian Minette90f29e2012-12-20 18:53:39 -08004356 return false;
4357
Takashi Iwai15e4ba62013-01-15 17:08:38 +01004358 dsp_os_image = (struct dsp_image_seg *)(fw_entry->data);
Dylan Reidd1d28502013-03-14 17:27:44 -07004359 if (dspload_image(codec, dsp_os_image, 0, 0, true, 0)) {
4360 pr_err("ca0132 dspload_image failed.\n");
4361 goto exit_download;
4362 }
4363
Ian Minette90f29e2012-12-20 18:53:39 -08004364 dsp_loaded = dspload_wait_loaded(codec);
4365
Dylan Reidd1d28502013-03-14 17:27:44 -07004366exit_download:
Takashi Iwai15e4ba62013-01-15 17:08:38 +01004367 release_firmware(fw_entry);
4368
Ian Minette90f29e2012-12-20 18:53:39 -08004369 return dsp_loaded;
4370}
4371
4372static void ca0132_download_dsp(struct hda_codec *codec)
4373{
4374 struct ca0132_spec *spec = codec->spec;
4375
Takashi Iwai9a0869f2013-02-07 12:41:40 +01004376#ifndef CONFIG_SND_HDA_CODEC_CA0132_DSP
4377 return; /* NOP */
4378#endif
Ian Minette90f29e2012-12-20 18:53:39 -08004379
Takashi Iwaie24aa0a2014-08-10 13:30:08 +02004380 if (spec->dsp_state == DSP_DOWNLOAD_FAILED)
4381 return; /* don't retry failures */
4382
Dylan Reidb714a712013-03-14 17:27:46 -07004383 chipio_enable_clocks(codec);
4384 spec->dsp_state = DSP_DOWNLOADING;
4385 if (!ca0132_download_dsp_images(codec))
4386 spec->dsp_state = DSP_DOWNLOAD_FAILED;
4387 else
4388 spec->dsp_state = DSP_DOWNLOADED;
Ian Minette90f29e2012-12-20 18:53:39 -08004389
4390 if (spec->dsp_state == DSP_DOWNLOADED)
4391 ca0132_set_dsp_msr(codec, true);
4392}
4393
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004394static void ca0132_process_dsp_response(struct hda_codec *codec,
4395 struct hda_jack_callback *callback)
Ian Minette90f29e2012-12-20 18:53:39 -08004396{
4397 struct ca0132_spec *spec = codec->spec;
4398
Takashi Iwai4e76a882014-02-25 12:21:03 +01004399 codec_dbg(codec, "ca0132_process_dsp_response\n");
Ian Minette90f29e2012-12-20 18:53:39 -08004400 if (spec->wait_scp) {
4401 if (dspio_get_response_data(codec) >= 0)
4402 spec->wait_scp = 0;
4403 }
4404
4405 dspio_clear_response_queue(codec);
4406}
4407
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004408static void hp_callback(struct hda_codec *codec, struct hda_jack_callback *cb)
Ian Minette90f29e2012-12-20 18:53:39 -08004409{
Chih-Chung Chang993884f2013-03-25 10:39:23 -07004410 struct ca0132_spec *spec = codec->spec;
Ian Minette90f29e2012-12-20 18:53:39 -08004411
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004412 /* Delay enabling the HP amp, to let the mic-detection
4413 * state machine run.
4414 */
4415 cancel_delayed_work_sync(&spec->unsol_hp_work);
4416 queue_delayed_work(codec->bus->workq, &spec->unsol_hp_work,
4417 msecs_to_jiffies(500));
4418 cb->tbl->block_report = 1;
4419}
Ian Minette90f29e2012-12-20 18:53:39 -08004420
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004421static void amic_callback(struct hda_codec *codec, struct hda_jack_callback *cb)
4422{
4423 ca0132_select_mic(codec);
4424}
4425
4426static void ca0132_init_unsol(struct hda_codec *codec)
4427{
4428 snd_hda_jack_detect_enable_callback(codec, UNSOL_TAG_HP, hp_callback);
4429 snd_hda_jack_detect_enable_callback(codec, UNSOL_TAG_AMIC1,
4430 amic_callback);
4431 snd_hda_jack_detect_enable_callback(codec, UNSOL_TAG_DSP,
4432 ca0132_process_dsp_response);
Ian Minette90f29e2012-12-20 18:53:39 -08004433}
4434
Ian Minett5aaca442012-12-20 18:53:34 -08004435/*
4436 * Verbs tables.
4437 */
4438
4439/* Sends before DSP download. */
4440static struct hda_verb ca0132_base_init_verbs[] = {
4441 /*enable ct extension*/
4442 {0x15, VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE, 0x1},
Ian Minett5aaca442012-12-20 18:53:34 -08004443 {}
4444};
4445
4446/* Send at exit. */
4447static struct hda_verb ca0132_base_exit_verbs[] = {
4448 /*set afg to D3*/
4449 {0x01, AC_VERB_SET_POWER_STATE, 0x03},
4450 /*disable ct extension*/
4451 {0x15, VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE, 0},
4452 {}
4453};
4454
4455/* Other verbs tables. Sends after DSP download. */
4456static struct hda_verb ca0132_init_verbs0[] = {
4457 /* chip init verbs */
4458 {0x15, 0x70D, 0xF0},
4459 {0x15, 0x70E, 0xFE},
4460 {0x15, 0x707, 0x75},
4461 {0x15, 0x707, 0xD3},
4462 {0x15, 0x707, 0x09},
4463 {0x15, 0x707, 0x53},
4464 {0x15, 0x707, 0xD4},
4465 {0x15, 0x707, 0xEF},
4466 {0x15, 0x707, 0x75},
4467 {0x15, 0x707, 0xD3},
4468 {0x15, 0x707, 0x09},
4469 {0x15, 0x707, 0x02},
4470 {0x15, 0x707, 0x37},
4471 {0x15, 0x707, 0x78},
4472 {0x15, 0x53C, 0xCE},
4473 {0x15, 0x575, 0xC9},
4474 {0x15, 0x53D, 0xCE},
4475 {0x15, 0x5B7, 0xC9},
4476 {0x15, 0x70D, 0xE8},
4477 {0x15, 0x70E, 0xFE},
4478 {0x15, 0x707, 0x02},
4479 {0x15, 0x707, 0x68},
4480 {0x15, 0x707, 0x62},
4481 {0x15, 0x53A, 0xCE},
4482 {0x15, 0x546, 0xC9},
4483 {0x15, 0x53B, 0xCE},
4484 {0x15, 0x5E8, 0xC9},
4485 {0x15, 0x717, 0x0D},
4486 {0x15, 0x718, 0x20},
4487 {}
4488};
4489
4490static struct hda_verb ca0132_init_verbs1[] = {
4491 {0x10, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | UNSOL_TAG_HP},
4492 {0x12, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | UNSOL_TAG_AMIC1},
4493 /* config EAPD */
4494 {0x0b, 0x78D, 0x00},
4495 /*{0x0b, AC_VERB_SET_EAPD_BTLENABLE, 0x02},*/
4496 /*{0x10, 0x78D, 0x02},*/
4497 /*{0x10, AC_VERB_SET_EAPD_BTLENABLE, 0x02},*/
4498 {}
4499};
4500
Ian Minett95c6e9c2011-06-15 15:35:17 -07004501static void ca0132_init_chip(struct hda_codec *codec)
4502{
4503 struct ca0132_spec *spec = codec->spec;
Ian Minett5aaca442012-12-20 18:53:34 -08004504 int num_fx;
4505 int i;
4506 unsigned int on;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004507
4508 mutex_init(&spec->chipio_mutex);
Ian Minett5aaca442012-12-20 18:53:34 -08004509
4510 spec->cur_out_type = SPEAKER_OUT;
4511 spec->cur_mic_type = DIGITAL_MIC;
4512 spec->cur_mic_boost = 0;
4513
4514 for (i = 0; i < VNODES_COUNT; i++) {
4515 spec->vnode_lvol[i] = 0x5a;
4516 spec->vnode_rvol[i] = 0x5a;
4517 spec->vnode_lswitch[i] = 0;
4518 spec->vnode_rswitch[i] = 0;
4519 }
4520
4521 /*
4522 * Default states for effects are in ca0132_effects[].
4523 */
4524 num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT;
4525 for (i = 0; i < num_fx; i++) {
4526 on = (unsigned int)ca0132_effects[i].reqs[0];
4527 spec->effects_switch[i] = on ? 1 : 0;
4528 }
4529
4530 spec->voicefx_val = 0;
4531 spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID] = 1;
4532 spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] = 0;
4533
Ian Minett44f0c972012-12-20 18:53:38 -08004534#ifdef ENABLE_TUNING_CONTROLS
4535 ca0132_init_tuning_defaults(codec);
4536#endif
Ian Minett95c6e9c2011-06-15 15:35:17 -07004537}
4538
4539static void ca0132_exit_chip(struct hda_codec *codec)
4540{
4541 /* put any chip cleanup stuffs here. */
Ian Minett5aaca442012-12-20 18:53:34 -08004542
4543 if (dspload_is_loaded(codec))
4544 dsp_reset(codec);
Ian Minett95c6e9c2011-06-15 15:35:17 -07004545}
4546
4547static int ca0132_init(struct hda_codec *codec)
4548{
4549 struct ca0132_spec *spec = codec->spec;
4550 struct auto_pin_cfg *cfg = &spec->autocfg;
4551 int i;
4552
Takashi Iwaie24aa0a2014-08-10 13:30:08 +02004553 if (spec->dsp_state != DSP_DOWNLOAD_FAILED)
4554 spec->dsp_state = DSP_DOWNLOAD_INIT;
Takashi Iwai4a8b89f2013-02-12 10:15:15 +01004555 spec->curr_chip_addx = INVALID_CHIP_ADDRESS;
Ian Minett5aaca442012-12-20 18:53:34 -08004556
4557 snd_hda_power_up(codec);
4558
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004559 ca0132_init_unsol(codec);
4560
Ian Minett5aaca442012-12-20 18:53:34 -08004561 ca0132_init_params(codec);
4562 ca0132_init_flags(codec);
4563 snd_hda_sequence_write(codec, spec->base_init_verbs);
Ian Minett01ef7db2012-09-20 20:29:16 -07004564 ca0132_download_dsp(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08004565 ca0132_refresh_widget_caps(codec);
4566 ca0132_setup_defaults(codec);
4567 ca0132_init_analog_mic2(codec);
4568 ca0132_init_dmic(codec);
Ian Minett01ef7db2012-09-20 20:29:16 -07004569
Ian Minett5aaca442012-12-20 18:53:34 -08004570 for (i = 0; i < spec->num_outputs; i++)
4571 init_output(codec, spec->out_pins[i], spec->dacs[0]);
4572
Ian Minett95c6e9c2011-06-15 15:35:17 -07004573 init_output(codec, cfg->dig_out_pins[0], spec->dig_out);
4574
4575 for (i = 0; i < spec->num_inputs; i++)
4576 init_input(codec, spec->input_pins[i], spec->adcs[i]);
4577
4578 init_input(codec, cfg->dig_in_pin, spec->dig_in);
4579
Ian Minett5aaca442012-12-20 18:53:34 -08004580 for (i = 0; i < spec->num_init_verbs; i++)
4581 snd_hda_sequence_write(codec, spec->init_verbs[i]);
4582
4583 ca0132_select_out(codec);
4584 ca0132_select_mic(codec);
4585
Ian Minetta73d5112012-12-20 18:53:37 -08004586 snd_hda_jack_report_sync(codec);
4587
Ian Minett5aaca442012-12-20 18:53:34 -08004588 snd_hda_power_down(codec);
Ian Minett95c6e9c2011-06-15 15:35:17 -07004589
4590 return 0;
4591}
4592
Ian Minett95c6e9c2011-06-15 15:35:17 -07004593static void ca0132_free(struct hda_codec *codec)
4594{
Ian Minett5aaca442012-12-20 18:53:34 -08004595 struct ca0132_spec *spec = codec->spec;
4596
Chih-Chung Chang993884f2013-03-25 10:39:23 -07004597 cancel_delayed_work_sync(&spec->unsol_hp_work);
Ian Minett5aaca442012-12-20 18:53:34 -08004598 snd_hda_power_up(codec);
4599 snd_hda_sequence_write(codec, spec->base_exit_verbs);
Ian Minett95c6e9c2011-06-15 15:35:17 -07004600 ca0132_exit_chip(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08004601 snd_hda_power_down(codec);
Ian Minett95c6e9c2011-06-15 15:35:17 -07004602 kfree(codec->spec);
4603}
4604
4605static struct hda_codec_ops ca0132_patch_ops = {
4606 .build_controls = ca0132_build_controls,
4607 .build_pcms = ca0132_build_pcms,
4608 .init = ca0132_init,
4609 .free = ca0132_free,
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004610 .unsol_event = snd_hda_jack_unsol_event,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004611};
4612
Ian Minett441aa6a2012-12-20 18:53:40 -08004613static void ca0132_config(struct hda_codec *codec)
4614{
4615 struct ca0132_spec *spec = codec->spec;
4616 struct auto_pin_cfg *cfg = &spec->autocfg;
4617
4618 spec->dacs[0] = 0x2;
4619 spec->dacs[1] = 0x3;
4620 spec->dacs[2] = 0x4;
4621
4622 spec->multiout.dac_nids = spec->dacs;
4623 spec->multiout.num_dacs = 3;
4624 spec->multiout.max_channels = 2;
4625
4626 spec->num_outputs = 2;
4627 spec->out_pins[0] = 0x0b; /* speaker out */
4628 spec->out_pins[1] = 0x10; /* headphone out */
4629 spec->shared_out_nid = 0x2;
4630
4631 spec->num_inputs = 3;
4632 spec->adcs[0] = 0x7; /* digital mic / analog mic1 */
4633 spec->adcs[1] = 0x8; /* analog mic2 */
4634 spec->adcs[2] = 0xa; /* what u hear */
4635 spec->shared_mic_nid = 0x7;
4636
4637 spec->input_pins[0] = 0x12;
4638 spec->input_pins[1] = 0x11;
4639 spec->input_pins[2] = 0x13;
4640
4641 /* SPDIF I/O */
4642 spec->dig_out = 0x05;
4643 spec->multiout.dig_out_nid = spec->dig_out;
4644 cfg->dig_out_pins[0] = 0x0c;
4645 cfg->dig_outs = 1;
4646 cfg->dig_out_type[0] = HDA_PCM_TYPE_SPDIF;
4647 spec->dig_in = 0x09;
4648 cfg->dig_in_pin = 0x0e;
4649 cfg->dig_in_type = HDA_PCM_TYPE_SPDIF;
4650}
4651
Ian Minett95c6e9c2011-06-15 15:35:17 -07004652static int patch_ca0132(struct hda_codec *codec)
4653{
4654 struct ca0132_spec *spec;
Ian Minetta73d5112012-12-20 18:53:37 -08004655 int err;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004656
Takashi Iwai4e76a882014-02-25 12:21:03 +01004657 codec_dbg(codec, "patch_ca0132\n");
Ian Minett95c6e9c2011-06-15 15:35:17 -07004658
4659 spec = kzalloc(sizeof(*spec), GFP_KERNEL);
4660 if (!spec)
4661 return -ENOMEM;
4662 codec->spec = spec;
Chih-Chung Chang993884f2013-03-25 10:39:23 -07004663 spec->codec = codec;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004664
Takashi Iwaie24aa0a2014-08-10 13:30:08 +02004665 spec->dsp_state = DSP_DOWNLOAD_INIT;
Ian Minetta7e76272012-12-20 18:53:35 -08004666 spec->num_mixers = 1;
4667 spec->mixers[0] = ca0132_mixer;
4668
Ian Minett5aaca442012-12-20 18:53:34 -08004669 spec->base_init_verbs = ca0132_base_init_verbs;
4670 spec->base_exit_verbs = ca0132_base_exit_verbs;
4671 spec->init_verbs[0] = ca0132_init_verbs0;
4672 spec->init_verbs[1] = ca0132_init_verbs1;
4673 spec->num_init_verbs = 2;
4674
Chih-Chung Chang993884f2013-03-25 10:39:23 -07004675 INIT_DELAYED_WORK(&spec->unsol_hp_work, ca0132_unsol_hp_delayed);
4676
Ian Minett95c6e9c2011-06-15 15:35:17 -07004677 ca0132_init_chip(codec);
4678
4679 ca0132_config(codec);
4680
Ian Minetta73d5112012-12-20 18:53:37 -08004681 err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, NULL);
4682 if (err < 0)
4683 return err;
4684
Ian Minett95c6e9c2011-06-15 15:35:17 -07004685 codec->patch_ops = ca0132_patch_ops;
Hsin-Yu Chao28fba952014-02-19 14:27:07 +08004686 codec->pcm_format_first = 1;
4687 codec->no_sticky_stream = 1;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004688
4689 return 0;
4690}
4691
4692/*
4693 * patch entries
4694 */
4695static struct hda_codec_preset snd_hda_preset_ca0132[] = {
4696 { .id = 0x11020011, .name = "CA0132", .patch = patch_ca0132 },
4697 {} /* terminator */
4698};
4699
4700MODULE_ALIAS("snd-hda-codec-id:11020011");
4701
4702MODULE_LICENSE("GPL");
Ian Minett406261c2012-12-20 18:53:41 -08004703MODULE_DESCRIPTION("Creative Sound Core3D codec");
Ian Minett95c6e9c2011-06-15 15:35:17 -07004704
4705static struct hda_codec_preset_list ca0132_list = {
4706 .preset = snd_hda_preset_ca0132,
4707 .owner = THIS_MODULE,
4708};
4709
4710static int __init patch_ca0132_init(void)
4711{
4712 return snd_hda_add_codec_preset(&ca0132_list);
4713}
4714
4715static void __exit patch_ca0132_exit(void)
4716{
Ian Minett95c6e9c2011-06-15 15:35:17 -07004717 snd_hda_delete_codec_preset(&ca0132_list);
4718}
4719
4720module_init(patch_ca0132_init)
4721module_exit(patch_ca0132_exit)