blob: 3e73d5c6ccfc95155d79557d0a5292f865afe777 [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
Ian Minettef6b2ea2012-12-20 18:53:33 -080046#define UNSOL_TAG_DSP 0x16
47
Ian Minett4aa3bb02012-09-20 20:29:15 -070048#define DSP_DMA_WRITE_BUFLEN_INIT (1UL<<18)
49#define DSP_DMA_WRITE_BUFLEN_OVLY (1UL<<15)
50
51#define DMA_TRANSFER_FRAME_SIZE_NWORDS 8
52#define DMA_TRANSFER_MAX_FRAME_SIZE_NWORDS 32
53#define DMA_OVERLAY_FRAME_SIZE_NWORDS 2
54
55#define MASTERCONTROL 0x80
Ian Minettef6b2ea2012-12-20 18:53:33 -080056#define MASTERCONTROL_ALLOC_DMA_CHAN 10
57#define MASTERCONTROL_QUERY_SPEAKER_EQ_ADDRESS 60
Ian Minett4aa3bb02012-09-20 20:29:15 -070058
Ian Minett95c6e9c2011-06-15 15:35:17 -070059#define WIDGET_CHIP_CTRL 0x15
60#define WIDGET_DSP_CTRL 0x16
61
Ian Minett4aa3bb02012-09-20 20:29:15 -070062#define MEM_CONNID_MICIN1 3
63#define MEM_CONNID_MICIN2 5
64#define MEM_CONNID_MICOUT1 12
65#define MEM_CONNID_MICOUT2 14
66#define MEM_CONNID_WUH 10
67#define MEM_CONNID_DSP 16
68#define MEM_CONNID_DMIC 100
69
70#define SCP_SET 0
71#define SCP_GET 1
72
Ian Minett01ef7db2012-09-20 20:29:16 -070073#define EFX_FILE "ctefx.bin"
74
Takashi Iwai24f3ced2013-02-04 18:25:51 +010075#ifdef CONFIG_SND_HDA_CODEC_CA0132_DSP
Ian Minett01ef7db2012-09-20 20:29:16 -070076MODULE_FIRMWARE(EFX_FILE);
Takashi Iwai7a527ed2013-01-15 17:44:20 +010077#endif
Ian Minett01ef7db2012-09-20 20:29:16 -070078
Ian Minettef6b2ea2012-12-20 18:53:33 -080079static char *dirstr[2] = { "Playback", "Capture" };
80
81enum {
82 SPEAKER_OUT,
83 HEADPHONE_OUT
84};
85
86enum {
87 DIGITAL_MIC,
88 LINE_MIC_IN
89};
90
91enum {
92#define VNODE_START_NID 0x80
93 VNID_SPK = VNODE_START_NID, /* Speaker vnid */
94 VNID_MIC,
95 VNID_HP_SEL,
96 VNID_AMIC1_SEL,
97 VNID_HP_ASEL,
98 VNID_AMIC1_ASEL,
99 VNODE_END_NID,
100#define VNODES_COUNT (VNODE_END_NID - VNODE_START_NID)
101
102#define EFFECT_START_NID 0x90
103#define OUT_EFFECT_START_NID EFFECT_START_NID
104 SURROUND = OUT_EFFECT_START_NID,
105 CRYSTALIZER,
106 DIALOG_PLUS,
107 SMART_VOLUME,
108 X_BASS,
109 EQUALIZER,
110 OUT_EFFECT_END_NID,
111#define OUT_EFFECTS_COUNT (OUT_EFFECT_END_NID - OUT_EFFECT_START_NID)
112
113#define IN_EFFECT_START_NID OUT_EFFECT_END_NID
114 ECHO_CANCELLATION = IN_EFFECT_START_NID,
115 VOICE_FOCUS,
116 MIC_SVM,
117 NOISE_REDUCTION,
118 IN_EFFECT_END_NID,
119#define IN_EFFECTS_COUNT (IN_EFFECT_END_NID - IN_EFFECT_START_NID)
120
121 VOICEFX = IN_EFFECT_END_NID,
122 PLAY_ENHANCEMENT,
123 CRYSTAL_VOICE,
124 EFFECT_END_NID
125#define EFFECTS_COUNT (EFFECT_END_NID - EFFECT_START_NID)
126};
127
128/* Effects values size*/
129#define EFFECT_VALS_MAX_COUNT 12
130
Dylan Reide8412ca2013-04-04 13:55:09 -0700131/* Latency introduced by DSP blocks in milliseconds. */
132#define DSP_CAPTURE_INIT_LATENCY 0
133#define DSP_CRYSTAL_VOICE_LATENCY 124
134#define DSP_PLAYBACK_INIT_LATENCY 13
135#define DSP_PLAY_ENHANCEMENT_LATENCY 30
136#define DSP_SPEAKER_OUT_LATENCY 7
137
Ian Minettef6b2ea2012-12-20 18:53:33 -0800138struct ct_effect {
Takashi Iwai975cc022013-06-28 11:56:49 +0200139 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN];
Ian Minettef6b2ea2012-12-20 18:53:33 -0800140 hda_nid_t nid;
141 int mid; /*effect module ID*/
142 int reqs[EFFECT_VALS_MAX_COUNT]; /*effect module request*/
143 int direct; /* 0:output; 1:input*/
144 int params; /* number of default non-on/off params */
145 /*effect default values, 1st is on/off. */
146 unsigned int def_vals[EFFECT_VALS_MAX_COUNT];
147};
148
149#define EFX_DIR_OUT 0
150#define EFX_DIR_IN 1
151
152static struct ct_effect ca0132_effects[EFFECTS_COUNT] = {
153 { .name = "Surround",
154 .nid = SURROUND,
155 .mid = 0x96,
156 .reqs = {0, 1},
157 .direct = EFX_DIR_OUT,
158 .params = 1,
159 .def_vals = {0x3F800000, 0x3F2B851F}
160 },
161 { .name = "Crystalizer",
162 .nid = CRYSTALIZER,
163 .mid = 0x96,
164 .reqs = {7, 8},
165 .direct = EFX_DIR_OUT,
166 .params = 1,
167 .def_vals = {0x3F800000, 0x3F266666}
168 },
169 { .name = "Dialog Plus",
170 .nid = DIALOG_PLUS,
171 .mid = 0x96,
172 .reqs = {2, 3},
173 .direct = EFX_DIR_OUT,
174 .params = 1,
175 .def_vals = {0x00000000, 0x3F000000}
176 },
177 { .name = "Smart Volume",
178 .nid = SMART_VOLUME,
179 .mid = 0x96,
180 .reqs = {4, 5, 6},
181 .direct = EFX_DIR_OUT,
182 .params = 2,
183 .def_vals = {0x3F800000, 0x3F3D70A4, 0x00000000}
184 },
185 { .name = "X-Bass",
186 .nid = X_BASS,
187 .mid = 0x96,
188 .reqs = {24, 23, 25},
189 .direct = EFX_DIR_OUT,
190 .params = 2,
191 .def_vals = {0x3F800000, 0x42A00000, 0x3F000000}
192 },
193 { .name = "Equalizer",
194 .nid = EQUALIZER,
195 .mid = 0x96,
196 .reqs = {9, 10, 11, 12, 13, 14,
197 15, 16, 17, 18, 19, 20},
198 .direct = EFX_DIR_OUT,
199 .params = 11,
200 .def_vals = {0x00000000, 0x00000000, 0x00000000, 0x00000000,
201 0x00000000, 0x00000000, 0x00000000, 0x00000000,
202 0x00000000, 0x00000000, 0x00000000, 0x00000000}
203 },
204 { .name = "Echo Cancellation",
205 .nid = ECHO_CANCELLATION,
206 .mid = 0x95,
207 .reqs = {0, 1, 2, 3},
208 .direct = EFX_DIR_IN,
209 .params = 3,
210 .def_vals = {0x00000000, 0x3F3A9692, 0x00000000, 0x00000000}
211 },
212 { .name = "Voice Focus",
213 .nid = VOICE_FOCUS,
214 .mid = 0x95,
215 .reqs = {6, 7, 8, 9},
216 .direct = EFX_DIR_IN,
217 .params = 3,
218 .def_vals = {0x3F800000, 0x3D7DF3B6, 0x41F00000, 0x41F00000}
219 },
220 { .name = "Mic SVM",
221 .nid = MIC_SVM,
222 .mid = 0x95,
223 .reqs = {44, 45},
224 .direct = EFX_DIR_IN,
225 .params = 1,
226 .def_vals = {0x00000000, 0x3F3D70A4}
227 },
228 { .name = "Noise Reduction",
229 .nid = NOISE_REDUCTION,
230 .mid = 0x95,
231 .reqs = {4, 5},
232 .direct = EFX_DIR_IN,
233 .params = 1,
234 .def_vals = {0x3F800000, 0x3F000000}
235 },
236 { .name = "VoiceFX",
237 .nid = VOICEFX,
238 .mid = 0x95,
239 .reqs = {10, 11, 12, 13, 14, 15, 16, 17, 18},
240 .direct = EFX_DIR_IN,
241 .params = 8,
242 .def_vals = {0x00000000, 0x43C80000, 0x44AF0000, 0x44FA0000,
243 0x3F800000, 0x3F800000, 0x3F800000, 0x00000000,
244 0x00000000}
245 }
246};
247
248/* Tuning controls */
249#ifdef ENABLE_TUNING_CONTROLS
250
251enum {
252#define TUNING_CTL_START_NID 0xC0
253 WEDGE_ANGLE = TUNING_CTL_START_NID,
254 SVM_LEVEL,
255 EQUALIZER_BAND_0,
256 EQUALIZER_BAND_1,
257 EQUALIZER_BAND_2,
258 EQUALIZER_BAND_3,
259 EQUALIZER_BAND_4,
260 EQUALIZER_BAND_5,
261 EQUALIZER_BAND_6,
262 EQUALIZER_BAND_7,
263 EQUALIZER_BAND_8,
264 EQUALIZER_BAND_9,
265 TUNING_CTL_END_NID
266#define TUNING_CTLS_COUNT (TUNING_CTL_END_NID - TUNING_CTL_START_NID)
267};
268
269struct ct_tuning_ctl {
Takashi Iwai975cc022013-06-28 11:56:49 +0200270 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN];
Ian Minettef6b2ea2012-12-20 18:53:33 -0800271 hda_nid_t parent_nid;
272 hda_nid_t nid;
273 int mid; /*effect module ID*/
274 int req; /*effect module request*/
275 int direct; /* 0:output; 1:input*/
276 unsigned int def_val;/*effect default values*/
277};
278
279static struct ct_tuning_ctl ca0132_tuning_ctls[] = {
280 { .name = "Wedge Angle",
281 .parent_nid = VOICE_FOCUS,
282 .nid = WEDGE_ANGLE,
283 .mid = 0x95,
284 .req = 8,
285 .direct = EFX_DIR_IN,
286 .def_val = 0x41F00000
287 },
288 { .name = "SVM Level",
289 .parent_nid = MIC_SVM,
290 .nid = SVM_LEVEL,
291 .mid = 0x95,
292 .req = 45,
293 .direct = EFX_DIR_IN,
294 .def_val = 0x3F3D70A4
295 },
296 { .name = "EQ Band0",
297 .parent_nid = EQUALIZER,
298 .nid = EQUALIZER_BAND_0,
299 .mid = 0x96,
300 .req = 11,
301 .direct = EFX_DIR_OUT,
302 .def_val = 0x00000000
303 },
304 { .name = "EQ Band1",
305 .parent_nid = EQUALIZER,
306 .nid = EQUALIZER_BAND_1,
307 .mid = 0x96,
308 .req = 12,
309 .direct = EFX_DIR_OUT,
310 .def_val = 0x00000000
311 },
312 { .name = "EQ Band2",
313 .parent_nid = EQUALIZER,
314 .nid = EQUALIZER_BAND_2,
315 .mid = 0x96,
316 .req = 13,
317 .direct = EFX_DIR_OUT,
318 .def_val = 0x00000000
319 },
320 { .name = "EQ Band3",
321 .parent_nid = EQUALIZER,
322 .nid = EQUALIZER_BAND_3,
323 .mid = 0x96,
324 .req = 14,
325 .direct = EFX_DIR_OUT,
326 .def_val = 0x00000000
327 },
328 { .name = "EQ Band4",
329 .parent_nid = EQUALIZER,
330 .nid = EQUALIZER_BAND_4,
331 .mid = 0x96,
332 .req = 15,
333 .direct = EFX_DIR_OUT,
334 .def_val = 0x00000000
335 },
336 { .name = "EQ Band5",
337 .parent_nid = EQUALIZER,
338 .nid = EQUALIZER_BAND_5,
339 .mid = 0x96,
340 .req = 16,
341 .direct = EFX_DIR_OUT,
342 .def_val = 0x00000000
343 },
344 { .name = "EQ Band6",
345 .parent_nid = EQUALIZER,
346 .nid = EQUALIZER_BAND_6,
347 .mid = 0x96,
348 .req = 17,
349 .direct = EFX_DIR_OUT,
350 .def_val = 0x00000000
351 },
352 { .name = "EQ Band7",
353 .parent_nid = EQUALIZER,
354 .nid = EQUALIZER_BAND_7,
355 .mid = 0x96,
356 .req = 18,
357 .direct = EFX_DIR_OUT,
358 .def_val = 0x00000000
359 },
360 { .name = "EQ Band8",
361 .parent_nid = EQUALIZER,
362 .nid = EQUALIZER_BAND_8,
363 .mid = 0x96,
364 .req = 19,
365 .direct = EFX_DIR_OUT,
366 .def_val = 0x00000000
367 },
368 { .name = "EQ Band9",
369 .parent_nid = EQUALIZER,
370 .nid = EQUALIZER_BAND_9,
371 .mid = 0x96,
372 .req = 20,
373 .direct = EFX_DIR_OUT,
374 .def_val = 0x00000000
375 }
376};
377#endif
378
379/* Voice FX Presets */
380#define VOICEFX_MAX_PARAM_COUNT 9
381
382struct ct_voicefx {
383 char *name;
384 hda_nid_t nid;
385 int mid;
386 int reqs[VOICEFX_MAX_PARAM_COUNT]; /*effect module request*/
387};
388
389struct ct_voicefx_preset {
390 char *name; /*preset name*/
391 unsigned int vals[VOICEFX_MAX_PARAM_COUNT];
392};
393
Takashi Iwaiccd7bd32013-01-16 09:32:54 +0800394static struct ct_voicefx ca0132_voicefx = {
Ian Minettef6b2ea2012-12-20 18:53:33 -0800395 .name = "VoiceFX Capture Switch",
396 .nid = VOICEFX,
397 .mid = 0x95,
398 .reqs = {10, 11, 12, 13, 14, 15, 16, 17, 18}
399};
400
Takashi Iwaiccd7bd32013-01-16 09:32:54 +0800401static struct ct_voicefx_preset ca0132_voicefx_presets[] = {
Ian Minettef6b2ea2012-12-20 18:53:33 -0800402 { .name = "Neutral",
403 .vals = { 0x00000000, 0x43C80000, 0x44AF0000,
404 0x44FA0000, 0x3F800000, 0x3F800000,
405 0x3F800000, 0x00000000, 0x00000000 }
406 },
407 { .name = "Female2Male",
408 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
409 0x44FA0000, 0x3F19999A, 0x3F866666,
410 0x3F800000, 0x00000000, 0x00000000 }
411 },
412 { .name = "Male2Female",
413 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
414 0x450AC000, 0x4017AE14, 0x3F6B851F,
415 0x3F800000, 0x00000000, 0x00000000 }
416 },
417 { .name = "ScrappyKid",
418 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
419 0x44FA0000, 0x40400000, 0x3F28F5C3,
420 0x3F800000, 0x00000000, 0x00000000 }
421 },
422 { .name = "Elderly",
423 .vals = { 0x3F800000, 0x44324000, 0x44BB8000,
424 0x44E10000, 0x3FB33333, 0x3FB9999A,
425 0x3F800000, 0x3E3A2E43, 0x00000000 }
426 },
427 { .name = "Orc",
428 .vals = { 0x3F800000, 0x43EA0000, 0x44A52000,
429 0x45098000, 0x3F266666, 0x3FC00000,
430 0x3F800000, 0x00000000, 0x00000000 }
431 },
432 { .name = "Elf",
433 .vals = { 0x3F800000, 0x43C70000, 0x44AE6000,
434 0x45193000, 0x3F8E147B, 0x3F75C28F,
435 0x3F800000, 0x00000000, 0x00000000 }
436 },
437 { .name = "Dwarf",
438 .vals = { 0x3F800000, 0x43930000, 0x44BEE000,
439 0x45007000, 0x3F451EB8, 0x3F7851EC,
440 0x3F800000, 0x00000000, 0x00000000 }
441 },
442 { .name = "AlienBrute",
443 .vals = { 0x3F800000, 0x43BFC5AC, 0x44B28FDF,
444 0x451F6000, 0x3F266666, 0x3FA7D945,
445 0x3F800000, 0x3CF5C28F, 0x00000000 }
446 },
447 { .name = "Robot",
448 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
449 0x44FA0000, 0x3FB2718B, 0x3F800000,
450 0xBC07010E, 0x00000000, 0x00000000 }
451 },
452 { .name = "Marine",
453 .vals = { 0x3F800000, 0x43C20000, 0x44906000,
454 0x44E70000, 0x3F4CCCCD, 0x3F8A3D71,
455 0x3F0A3D71, 0x00000000, 0x00000000 }
456 },
457 { .name = "Emo",
458 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
459 0x44FA0000, 0x3F800000, 0x3F800000,
460 0x3E4CCCCD, 0x00000000, 0x00000000 }
461 },
462 { .name = "DeepVoice",
463 .vals = { 0x3F800000, 0x43A9C5AC, 0x44AA4FDF,
464 0x44FFC000, 0x3EDBB56F, 0x3F99C4CA,
465 0x3F800000, 0x00000000, 0x00000000 }
466 },
467 { .name = "Munchkin",
468 .vals = { 0x3F800000, 0x43C80000, 0x44AF0000,
469 0x44FA0000, 0x3F800000, 0x3F1A043C,
470 0x3F800000, 0x00000000, 0x00000000 }
471 }
472};
473
Ian Minett95c6e9c2011-06-15 15:35:17 -0700474enum hda_cmd_vendor_io {
475 /* for DspIO node */
476 VENDOR_DSPIO_SCP_WRITE_DATA_LOW = 0x000,
477 VENDOR_DSPIO_SCP_WRITE_DATA_HIGH = 0x100,
478
479 VENDOR_DSPIO_STATUS = 0xF01,
480 VENDOR_DSPIO_SCP_POST_READ_DATA = 0x702,
481 VENDOR_DSPIO_SCP_READ_DATA = 0xF02,
482 VENDOR_DSPIO_DSP_INIT = 0x703,
483 VENDOR_DSPIO_SCP_POST_COUNT_QUERY = 0x704,
484 VENDOR_DSPIO_SCP_READ_COUNT = 0xF04,
485
486 /* for ChipIO node */
487 VENDOR_CHIPIO_ADDRESS_LOW = 0x000,
488 VENDOR_CHIPIO_ADDRESS_HIGH = 0x100,
489 VENDOR_CHIPIO_STREAM_FORMAT = 0x200,
490 VENDOR_CHIPIO_DATA_LOW = 0x300,
491 VENDOR_CHIPIO_DATA_HIGH = 0x400,
492
493 VENDOR_CHIPIO_GET_PARAMETER = 0xF00,
494 VENDOR_CHIPIO_STATUS = 0xF01,
495 VENDOR_CHIPIO_HIC_POST_READ = 0x702,
496 VENDOR_CHIPIO_HIC_READ_DATA = 0xF03,
497
Ian Minett4aa3bb02012-09-20 20:29:15 -0700498 VENDOR_CHIPIO_8051_DATA_WRITE = 0x707,
499 VENDOR_CHIPIO_8051_DATA_READ = 0xF07,
500
Ian Minett95c6e9c2011-06-15 15:35:17 -0700501 VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE = 0x70A,
Ian Minett4aa3bb02012-09-20 20:29:15 -0700502 VENDOR_CHIPIO_CT_EXTENSIONS_GET = 0xF0A,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700503
504 VENDOR_CHIPIO_PLL_PMU_WRITE = 0x70C,
505 VENDOR_CHIPIO_PLL_PMU_READ = 0xF0C,
506 VENDOR_CHIPIO_8051_ADDRESS_LOW = 0x70D,
507 VENDOR_CHIPIO_8051_ADDRESS_HIGH = 0x70E,
508 VENDOR_CHIPIO_FLAG_SET = 0x70F,
509 VENDOR_CHIPIO_FLAGS_GET = 0xF0F,
Ian Minett4aa3bb02012-09-20 20:29:15 -0700510 VENDOR_CHIPIO_PARAM_SET = 0x710,
511 VENDOR_CHIPIO_PARAM_GET = 0xF10,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700512
513 VENDOR_CHIPIO_PORT_ALLOC_CONFIG_SET = 0x711,
514 VENDOR_CHIPIO_PORT_ALLOC_SET = 0x712,
515 VENDOR_CHIPIO_PORT_ALLOC_GET = 0xF12,
516 VENDOR_CHIPIO_PORT_FREE_SET = 0x713,
517
Ian Minett4aa3bb02012-09-20 20:29:15 -0700518 VENDOR_CHIPIO_PARAM_EX_ID_GET = 0xF17,
519 VENDOR_CHIPIO_PARAM_EX_ID_SET = 0x717,
520 VENDOR_CHIPIO_PARAM_EX_VALUE_GET = 0xF18,
521 VENDOR_CHIPIO_PARAM_EX_VALUE_SET = 0x718,
522
523 VENDOR_CHIPIO_DMIC_CTL_SET = 0x788,
524 VENDOR_CHIPIO_DMIC_CTL_GET = 0xF88,
525 VENDOR_CHIPIO_DMIC_PIN_SET = 0x789,
526 VENDOR_CHIPIO_DMIC_PIN_GET = 0xF89,
527 VENDOR_CHIPIO_DMIC_MCLK_SET = 0x78A,
528 VENDOR_CHIPIO_DMIC_MCLK_GET = 0xF8A,
529
530 VENDOR_CHIPIO_EAPD_SEL_SET = 0x78D
Ian Minett95c6e9c2011-06-15 15:35:17 -0700531};
532
533/*
534 * Control flag IDs
535 */
536enum control_flag_id {
537 /* Connection manager stream setup is bypassed/enabled */
538 CONTROL_FLAG_C_MGR = 0,
539 /* DSP DMA is bypassed/enabled */
540 CONTROL_FLAG_DMA = 1,
541 /* 8051 'idle' mode is disabled/enabled */
542 CONTROL_FLAG_IDLE_ENABLE = 2,
543 /* Tracker for the SPDIF-in path is bypassed/enabled */
544 CONTROL_FLAG_TRACKER = 3,
545 /* DigitalOut to Spdif2Out connection is disabled/enabled */
546 CONTROL_FLAG_SPDIF2OUT = 4,
547 /* Digital Microphone is disabled/enabled */
548 CONTROL_FLAG_DMIC = 5,
549 /* ADC_B rate is 48 kHz/96 kHz */
550 CONTROL_FLAG_ADC_B_96KHZ = 6,
551 /* ADC_C rate is 48 kHz/96 kHz */
552 CONTROL_FLAG_ADC_C_96KHZ = 7,
553 /* DAC rate is 48 kHz/96 kHz (affects all DACs) */
554 CONTROL_FLAG_DAC_96KHZ = 8,
555 /* DSP rate is 48 kHz/96 kHz */
556 CONTROL_FLAG_DSP_96KHZ = 9,
557 /* SRC clock is 98 MHz/196 MHz (196 MHz forces rate to 96 KHz) */
558 CONTROL_FLAG_SRC_CLOCK_196MHZ = 10,
559 /* SRC rate is 48 kHz/96 kHz (48 kHz disabled when clock is 196 MHz) */
560 CONTROL_FLAG_SRC_RATE_96KHZ = 11,
561 /* Decode Loop (DSP->SRC->DSP) is disabled/enabled */
562 CONTROL_FLAG_DECODE_LOOP = 12,
563 /* De-emphasis filter on DAC-1 disabled/enabled */
564 CONTROL_FLAG_DAC1_DEEMPHASIS = 13,
565 /* De-emphasis filter on DAC-2 disabled/enabled */
566 CONTROL_FLAG_DAC2_DEEMPHASIS = 14,
567 /* De-emphasis filter on DAC-3 disabled/enabled */
568 CONTROL_FLAG_DAC3_DEEMPHASIS = 15,
569 /* High-pass filter on ADC_B disabled/enabled */
570 CONTROL_FLAG_ADC_B_HIGH_PASS = 16,
571 /* High-pass filter on ADC_C disabled/enabled */
572 CONTROL_FLAG_ADC_C_HIGH_PASS = 17,
573 /* Common mode on Port_A disabled/enabled */
574 CONTROL_FLAG_PORT_A_COMMON_MODE = 18,
575 /* Common mode on Port_D disabled/enabled */
576 CONTROL_FLAG_PORT_D_COMMON_MODE = 19,
577 /* Impedance for ramp generator on Port_A 16 Ohm/10K Ohm */
578 CONTROL_FLAG_PORT_A_10KOHM_LOAD = 20,
579 /* Impedance for ramp generator on Port_D, 16 Ohm/10K Ohm */
Ian Minett4aa3bb02012-09-20 20:29:15 -0700580 CONTROL_FLAG_PORT_D_10KOHM_LOAD = 21,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700581 /* ASI rate is 48kHz/96kHz */
582 CONTROL_FLAG_ASI_96KHZ = 22,
583 /* DAC power settings able to control attached ports no/yes */
584 CONTROL_FLAG_DACS_CONTROL_PORTS = 23,
585 /* Clock Stop OK reporting is disabled/enabled */
586 CONTROL_FLAG_CONTROL_STOP_OK_ENABLE = 24,
587 /* Number of control flags */
588 CONTROL_FLAGS_MAX = (CONTROL_FLAG_CONTROL_STOP_OK_ENABLE+1)
589};
590
591/*
592 * Control parameter IDs
593 */
Ian Minett4aa3bb02012-09-20 20:29:15 -0700594enum control_param_id {
Ian Minettef6b2ea2012-12-20 18:53:33 -0800595 /* 0: None, 1: Mic1In*/
596 CONTROL_PARAM_VIP_SOURCE = 1,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700597 /* 0: force HDA, 1: allow DSP if HDA Spdif1Out stream is idle */
598 CONTROL_PARAM_SPDIF1_SOURCE = 2,
Ian Minettef6b2ea2012-12-20 18:53:33 -0800599 /* Port A output stage gain setting to use when 16 Ohm output
600 * impedance is selected*/
601 CONTROL_PARAM_PORTA_160OHM_GAIN = 8,
602 /* Port D output stage gain setting to use when 16 Ohm output
603 * impedance is selected*/
604 CONTROL_PARAM_PORTD_160OHM_GAIN = 10,
Ian Minett95c6e9c2011-06-15 15:35:17 -0700605
606 /* Stream Control */
607
608 /* Select stream with the given ID */
609 CONTROL_PARAM_STREAM_ID = 24,
610 /* Source connection point for the selected stream */
611 CONTROL_PARAM_STREAM_SOURCE_CONN_POINT = 25,
612 /* Destination connection point for the selected stream */
613 CONTROL_PARAM_STREAM_DEST_CONN_POINT = 26,
614 /* Number of audio channels in the selected stream */
615 CONTROL_PARAM_STREAMS_CHANNELS = 27,
616 /*Enable control for the selected stream */
617 CONTROL_PARAM_STREAM_CONTROL = 28,
618
619 /* Connection Point Control */
620
621 /* Select connection point with the given ID */
622 CONTROL_PARAM_CONN_POINT_ID = 29,
623 /* Connection point sample rate */
624 CONTROL_PARAM_CONN_POINT_SAMPLE_RATE = 30,
625
626 /* Node Control */
627
628 /* Select HDA node with the given ID */
629 CONTROL_PARAM_NODE_ID = 31
630};
631
632/*
633 * Dsp Io Status codes
634 */
635enum hda_vendor_status_dspio {
636 /* Success */
637 VENDOR_STATUS_DSPIO_OK = 0x00,
638 /* Busy, unable to accept new command, the host must retry */
639 VENDOR_STATUS_DSPIO_BUSY = 0x01,
640 /* SCP command queue is full */
641 VENDOR_STATUS_DSPIO_SCP_COMMAND_QUEUE_FULL = 0x02,
642 /* SCP response queue is empty */
643 VENDOR_STATUS_DSPIO_SCP_RESPONSE_QUEUE_EMPTY = 0x03
644};
645
646/*
647 * Chip Io Status codes
648 */
649enum hda_vendor_status_chipio {
650 /* Success */
651 VENDOR_STATUS_CHIPIO_OK = 0x00,
652 /* Busy, unable to accept new command, the host must retry */
653 VENDOR_STATUS_CHIPIO_BUSY = 0x01
654};
655
656/*
657 * CA0132 sample rate
658 */
659enum ca0132_sample_rate {
660 SR_6_000 = 0x00,
661 SR_8_000 = 0x01,
662 SR_9_600 = 0x02,
663 SR_11_025 = 0x03,
664 SR_16_000 = 0x04,
665 SR_22_050 = 0x05,
666 SR_24_000 = 0x06,
667 SR_32_000 = 0x07,
668 SR_44_100 = 0x08,
669 SR_48_000 = 0x09,
670 SR_88_200 = 0x0A,
671 SR_96_000 = 0x0B,
672 SR_144_000 = 0x0C,
673 SR_176_400 = 0x0D,
674 SR_192_000 = 0x0E,
675 SR_384_000 = 0x0F,
676
677 SR_COUNT = 0x10,
678
679 SR_RATE_UNKNOWN = 0x1F
680};
681
Ian Minett01ef7db2012-09-20 20:29:16 -0700682enum dsp_download_state {
683 DSP_DOWNLOAD_FAILED = -1,
684 DSP_DOWNLOAD_INIT = 0,
685 DSP_DOWNLOADING = 1,
686 DSP_DOWNLOADED = 2
687};
688
Ian Minett01ef7db2012-09-20 20:29:16 -0700689/* retrieve parameters from hda format */
690#define get_hdafmt_chs(fmt) (fmt & 0xf)
691#define get_hdafmt_bits(fmt) ((fmt >> 4) & 0x7)
692#define get_hdafmt_rate(fmt) ((fmt >> 8) & 0x7f)
693#define get_hdafmt_type(fmt) ((fmt >> 15) & 0x1)
Ian Minett95c6e9c2011-06-15 15:35:17 -0700694
695/*
696 * CA0132 specific
697 */
698
699struct ca0132_spec {
Ian Minetta7e76272012-12-20 18:53:35 -0800700 struct snd_kcontrol_new *mixers[5];
701 unsigned int num_mixers;
Ian Minett5aaca442012-12-20 18:53:34 -0800702 const struct hda_verb *base_init_verbs;
703 const struct hda_verb *base_exit_verbs;
Gabriele Martinod5c016b2015-05-18 21:15:13 +0200704 const struct hda_verb *chip_init_verbs;
705 struct hda_verb *spec_init_verbs;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700706 struct auto_pin_cfg autocfg;
Ian Minett5aaca442012-12-20 18:53:34 -0800707
708 /* Nodes configurations */
Ian Minett95c6e9c2011-06-15 15:35:17 -0700709 struct hda_multi_out multiout;
710 hda_nid_t out_pins[AUTO_CFG_MAX_OUTS];
711 hda_nid_t dacs[AUTO_CFG_MAX_OUTS];
Ian Minett5aaca442012-12-20 18:53:34 -0800712 unsigned int num_outputs;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700713 hda_nid_t input_pins[AUTO_PIN_LAST];
714 hda_nid_t adcs[AUTO_PIN_LAST];
715 hda_nid_t dig_out;
716 hda_nid_t dig_in;
717 unsigned int num_inputs;
Ian Minetta7e76272012-12-20 18:53:35 -0800718 hda_nid_t shared_mic_nid;
719 hda_nid_t shared_out_nid;
Gabriele Martinod5c016b2015-05-18 21:15:13 +0200720 hda_nid_t unsol_tag_hp;
721 hda_nid_t unsol_tag_amic1;
Ian Minett01ef7db2012-09-20 20:29:16 -0700722
723 /* chip access */
724 struct mutex chipio_mutex; /* chip access mutex */
725 u32 curr_chip_addx;
726
727 /* DSP download related */
728 enum dsp_download_state dsp_state;
729 unsigned int dsp_stream_id;
730 unsigned int wait_scp;
731 unsigned int wait_scp_header;
732 unsigned int wait_num_data;
733 unsigned int scp_resp_header;
734 unsigned int scp_resp_data[4];
735 unsigned int scp_resp_count;
Ian Minett5aaca442012-12-20 18:53:34 -0800736
737 /* mixer and effects related */
738 unsigned char dmic_ctl;
739 int cur_out_type;
740 int cur_mic_type;
741 long vnode_lvol[VNODES_COUNT];
742 long vnode_rvol[VNODES_COUNT];
743 long vnode_lswitch[VNODES_COUNT];
744 long vnode_rswitch[VNODES_COUNT];
745 long effects_switch[EFFECTS_COUNT];
746 long voicefx_val;
747 long cur_mic_boost;
Ian Minett44f0c972012-12-20 18:53:38 -0800748
Chih-Chung Chang993884f2013-03-25 10:39:23 -0700749 struct hda_codec *codec;
750 struct delayed_work unsol_hp_work;
Gabriele Martinod5c016b2015-05-18 21:15:13 +0200751 int quirk;
Chih-Chung Chang993884f2013-03-25 10:39:23 -0700752
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/*
Gabriele Martinod5c016b2015-05-18 21:15:13 +0200759 * CA0132 quirks table
760 */
761enum {
762 QUIRK_NONE,
763 QUIRK_ALIENWARE,
764};
765
Takashi Iwaife14f392015-08-10 16:53:32 +0200766static const struct hda_pintbl alienware_pincfgs[] = {
767 { 0x0b, 0x90170110 }, /* Builtin Speaker */
768 { 0x0c, 0x411111f0 }, /* N/A */
769 { 0x0d, 0x411111f0 }, /* N/A */
770 { 0x0e, 0x411111f0 }, /* N/A */
771 { 0x0f, 0x0321101f }, /* HP */
772 { 0x10, 0x411111f0 }, /* Headset? disabled for now */
773 { 0x11, 0x03a11021 }, /* Mic */
774 { 0x12, 0xd5a30140 }, /* Builtin Mic */
775 { 0x13, 0x411111f0 }, /* N/A */
776 { 0x18, 0x411111f0 }, /* N/A */
777 {}
778};
779
Gabriele Martinod5c016b2015-05-18 21:15:13 +0200780static const struct snd_pci_quirk ca0132_quirks[] = {
Gabriele Martino5328e1e2015-12-09 17:05:58 +0100781 SND_PCI_QUIRK(0x1028, 0x0685, "Alienware 15 2015", QUIRK_ALIENWARE),
782 SND_PCI_QUIRK(0x1028, 0x0688, "Alienware 17 2015", QUIRK_ALIENWARE),
Sven Hahneb5337cf2016-11-25 14:16:43 +0100783 SND_PCI_QUIRK(0x1028, 0x0708, "Alienware 15 R2 2016", QUIRK_ALIENWARE),
Gabriele Martinod5c016b2015-05-18 21:15:13 +0200784 {}
785};
786
787/*
Ian Minett01ef7db2012-09-20 20:29:16 -0700788 * CA0132 codec access
789 */
Sachin Kamat399ae722013-09-13 15:14:22 +0530790static unsigned int codec_send_command(struct hda_codec *codec, hda_nid_t nid,
Ian Minett01ef7db2012-09-20 20:29:16 -0700791 unsigned int verb, unsigned int parm, unsigned int *res)
792{
793 unsigned int response;
794 response = snd_hda_codec_read(codec, nid, 0, verb, parm);
795 *res = response;
796
797 return ((response == -1) ? -1 : 0);
798}
799
800static int codec_set_converter_format(struct hda_codec *codec, hda_nid_t nid,
801 unsigned short converter_format, unsigned int *res)
802{
803 return codec_send_command(codec, nid, VENDOR_CHIPIO_STREAM_FORMAT,
804 converter_format & 0xffff, res);
805}
806
807static int codec_set_converter_stream_channel(struct hda_codec *codec,
808 hda_nid_t nid, unsigned char stream,
809 unsigned char channel, unsigned int *res)
810{
811 unsigned char converter_stream_channel = 0;
812
813 converter_stream_channel = (stream << 4) | (channel & 0x0f);
814 return codec_send_command(codec, nid, AC_VERB_SET_CHANNEL_STREAMID,
815 converter_stream_channel, res);
816}
817
Ian Minett95c6e9c2011-06-15 15:35:17 -0700818/* Chip access helper function */
819static int chipio_send(struct hda_codec *codec,
820 unsigned int reg,
821 unsigned int data)
822{
823 unsigned int res;
Ian Minett6d675302013-02-08 18:31:43 -0800824 unsigned long timeout = jiffies + msecs_to_jiffies(1000);
Ian Minett95c6e9c2011-06-15 15:35:17 -0700825
826 /* send bits of data specified by reg */
827 do {
828 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0,
829 reg, data);
830 if (res == VENDOR_STATUS_CHIPIO_OK)
831 return 0;
Ian Minett6d675302013-02-08 18:31:43 -0800832 msleep(20);
833 } while (time_before(jiffies, timeout));
834
Ian Minett95c6e9c2011-06-15 15:35:17 -0700835 return -EIO;
836}
837
838/*
839 * Write chip address through the vendor widget -- NOT protected by the Mutex!
840 */
841static int chipio_write_address(struct hda_codec *codec,
842 unsigned int chip_addx)
843{
Ian Minett4861af82012-09-20 20:29:20 -0700844 struct ca0132_spec *spec = codec->spec;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700845 int res;
846
Ian Minett4861af82012-09-20 20:29:20 -0700847 if (spec->curr_chip_addx == chip_addx)
848 return 0;
849
Ian Minett95c6e9c2011-06-15 15:35:17 -0700850 /* send low 16 bits of the address */
851 res = chipio_send(codec, VENDOR_CHIPIO_ADDRESS_LOW,
852 chip_addx & 0xffff);
853
854 if (res != -EIO) {
855 /* send high 16 bits of the address */
856 res = chipio_send(codec, VENDOR_CHIPIO_ADDRESS_HIGH,
857 chip_addx >> 16);
858 }
859
Matthias Kaehlcked1600402017-03-31 18:00:04 -0700860 spec->curr_chip_addx = (res < 0) ? ~0U : chip_addx;
Ian Minett4861af82012-09-20 20:29:20 -0700861
Ian Minett95c6e9c2011-06-15 15:35:17 -0700862 return res;
863}
864
865/*
866 * Write data through the vendor widget -- NOT protected by the Mutex!
867 */
Ian Minett95c6e9c2011-06-15 15:35:17 -0700868static int chipio_write_data(struct hda_codec *codec, unsigned int data)
869{
Ian Minett5aaca442012-12-20 18:53:34 -0800870 struct ca0132_spec *spec = codec->spec;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700871 int res;
872
873 /* send low 16 bits of the data */
874 res = chipio_send(codec, VENDOR_CHIPIO_DATA_LOW, data & 0xffff);
875
876 if (res != -EIO) {
877 /* send high 16 bits of the data */
878 res = chipio_send(codec, VENDOR_CHIPIO_DATA_HIGH,
879 data >> 16);
880 }
881
Ian Minett5aaca442012-12-20 18:53:34 -0800882 /*If no error encountered, automatically increment the address
883 as per chip behaviour*/
884 spec->curr_chip_addx = (res != -EIO) ?
Matthias Kaehlcked1600402017-03-31 18:00:04 -0700885 (spec->curr_chip_addx + 4) : ~0U;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700886 return res;
887}
888
Ian Minettd5c21b82012-09-20 20:29:18 -0700889/*
890 * Write multiple data through the vendor widget -- NOT protected by the Mutex!
891 */
Ian Minett01ef7db2012-09-20 20:29:16 -0700892static int chipio_write_data_multiple(struct hda_codec *codec,
893 const u32 *data,
894 unsigned int count)
895{
896 int status = 0;
897
898 if (data == NULL) {
Takashi Iwai4e76a882014-02-25 12:21:03 +0100899 codec_dbg(codec, "chipio_write_data null ptr\n");
Ian Minett01ef7db2012-09-20 20:29:16 -0700900 return -EINVAL;
901 }
902
903 while ((count-- != 0) && (status == 0))
904 status = chipio_write_data(codec, *data++);
905
906 return status;
907}
908
909
Ian Minett95c6e9c2011-06-15 15:35:17 -0700910/*
911 * Read data through the vendor widget -- NOT protected by the Mutex!
912 */
913static int chipio_read_data(struct hda_codec *codec, unsigned int *data)
914{
Ian Minett5aaca442012-12-20 18:53:34 -0800915 struct ca0132_spec *spec = codec->spec;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700916 int res;
917
918 /* post read */
919 res = chipio_send(codec, VENDOR_CHIPIO_HIC_POST_READ, 0);
920
921 if (res != -EIO) {
922 /* read status */
923 res = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
924 }
925
926 if (res != -EIO) {
927 /* read data */
928 *data = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0,
929 VENDOR_CHIPIO_HIC_READ_DATA,
930 0);
931 }
932
Ian Minett5aaca442012-12-20 18:53:34 -0800933 /*If no error encountered, automatically increment the address
934 as per chip behaviour*/
935 spec->curr_chip_addx = (res != -EIO) ?
Matthias Kaehlcked1600402017-03-31 18:00:04 -0700936 (spec->curr_chip_addx + 4) : ~0U;
Ian Minett95c6e9c2011-06-15 15:35:17 -0700937 return res;
938}
939
940/*
941 * Write given value to the given address through the chip I/O widget.
942 * protected by the Mutex
943 */
944static int chipio_write(struct hda_codec *codec,
945 unsigned int chip_addx, const unsigned int data)
946{
947 struct ca0132_spec *spec = codec->spec;
948 int err;
949
950 mutex_lock(&spec->chipio_mutex);
951
952 /* write the address, and if successful proceed to write data */
953 err = chipio_write_address(codec, chip_addx);
954 if (err < 0)
955 goto exit;
956
957 err = chipio_write_data(codec, data);
958 if (err < 0)
959 goto exit;
960
961exit:
962 mutex_unlock(&spec->chipio_mutex);
963 return err;
964}
965
Ian Minettd5c21b82012-09-20 20:29:18 -0700966/*
967 * Write multiple values to the given address through the chip I/O widget.
968 * protected by the Mutex
969 */
Ian Minett01ef7db2012-09-20 20:29:16 -0700970static int chipio_write_multiple(struct hda_codec *codec,
971 u32 chip_addx,
972 const u32 *data,
973 unsigned int count)
974{
975 struct ca0132_spec *spec = codec->spec;
976 int status;
977
978 mutex_lock(&spec->chipio_mutex);
Ian Minett4861af82012-09-20 20:29:20 -0700979 status = chipio_write_address(codec, chip_addx);
Ian Minett01ef7db2012-09-20 20:29:16 -0700980 if (status < 0)
981 goto error;
982
983 status = chipio_write_data_multiple(codec, data, count);
984error:
985 mutex_unlock(&spec->chipio_mutex);
986
987 return status;
988}
989
Ian Minett95c6e9c2011-06-15 15:35:17 -0700990/*
991 * Read the given address through the chip I/O widget
992 * protected by the Mutex
993 */
994static int chipio_read(struct hda_codec *codec,
995 unsigned int chip_addx, unsigned int *data)
996{
997 struct ca0132_spec *spec = codec->spec;
998 int err;
999
1000 mutex_lock(&spec->chipio_mutex);
1001
1002 /* write the address, and if successful proceed to write data */
1003 err = chipio_write_address(codec, chip_addx);
1004 if (err < 0)
1005 goto exit;
1006
1007 err = chipio_read_data(codec, data);
1008 if (err < 0)
1009 goto exit;
1010
1011exit:
1012 mutex_unlock(&spec->chipio_mutex);
1013 return err;
1014}
1015
Ian Minettd5c21b82012-09-20 20:29:18 -07001016/*
1017 * Set chip control flags through the chip I/O widget.
1018 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001019static void chipio_set_control_flag(struct hda_codec *codec,
1020 enum control_flag_id flag_id,
1021 bool flag_state)
1022{
1023 unsigned int val;
1024 unsigned int flag_bit;
1025
1026 flag_bit = (flag_state ? 1 : 0);
1027 val = (flag_bit << 7) | (flag_id);
1028 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1029 VENDOR_CHIPIO_FLAG_SET, val);
1030}
1031
Ian Minettd5c21b82012-09-20 20:29:18 -07001032/*
1033 * Set chip parameters through the chip I/O widget.
1034 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001035static void chipio_set_control_param(struct hda_codec *codec,
1036 enum control_param_id param_id, int param_val)
1037{
1038 struct ca0132_spec *spec = codec->spec;
1039 int val;
1040
1041 if ((param_id < 32) && (param_val < 8)) {
1042 val = (param_val << 5) | (param_id);
1043 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1044 VENDOR_CHIPIO_PARAM_SET, val);
1045 } else {
1046 mutex_lock(&spec->chipio_mutex);
1047 if (chipio_send(codec, VENDOR_CHIPIO_STATUS, 0) == 0) {
1048 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1049 VENDOR_CHIPIO_PARAM_EX_ID_SET,
1050 param_id);
1051 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1052 VENDOR_CHIPIO_PARAM_EX_VALUE_SET,
1053 param_val);
1054 }
1055 mutex_unlock(&spec->chipio_mutex);
1056 }
1057}
1058
Ian Minettd5c21b82012-09-20 20:29:18 -07001059/*
1060 * Set sampling rate of the connection point.
1061 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001062static void chipio_set_conn_rate(struct hda_codec *codec,
1063 int connid, enum ca0132_sample_rate rate)
1064{
1065 chipio_set_control_param(codec, CONTROL_PARAM_CONN_POINT_ID, connid);
1066 chipio_set_control_param(codec, CONTROL_PARAM_CONN_POINT_SAMPLE_RATE,
1067 rate);
1068}
1069
Ian Minettd5c21b82012-09-20 20:29:18 -07001070/*
1071 * Enable clocks.
1072 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001073static void chipio_enable_clocks(struct hda_codec *codec)
1074{
1075 struct ca0132_spec *spec = codec->spec;
1076
1077 mutex_lock(&spec->chipio_mutex);
1078 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1079 VENDOR_CHIPIO_8051_ADDRESS_LOW, 0);
1080 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1081 VENDOR_CHIPIO_PLL_PMU_WRITE, 0xff);
1082 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1083 VENDOR_CHIPIO_8051_ADDRESS_LOW, 5);
1084 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1085 VENDOR_CHIPIO_PLL_PMU_WRITE, 0x0b);
1086 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1087 VENDOR_CHIPIO_8051_ADDRESS_LOW, 6);
1088 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1089 VENDOR_CHIPIO_PLL_PMU_WRITE, 0xff);
1090 mutex_unlock(&spec->chipio_mutex);
1091}
1092
1093/*
1094 * CA0132 DSP IO stuffs
1095 */
1096static int dspio_send(struct hda_codec *codec, unsigned int reg,
1097 unsigned int data)
1098{
Takashi Iwaib645d792013-01-15 17:39:29 +01001099 int res;
Ian Minett6d675302013-02-08 18:31:43 -08001100 unsigned long timeout = jiffies + msecs_to_jiffies(1000);
Ian Minett01ef7db2012-09-20 20:29:16 -07001101
1102 /* send bits of data specified by reg to dsp */
1103 do {
1104 res = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, reg, data);
1105 if ((res >= 0) && (res != VENDOR_STATUS_DSPIO_BUSY))
1106 return res;
Ian Minett6d675302013-02-08 18:31:43 -08001107 msleep(20);
1108 } while (time_before(jiffies, timeout));
Ian Minett01ef7db2012-09-20 20:29:16 -07001109
1110 return -EIO;
1111}
1112
Ian Minettd5c21b82012-09-20 20:29:18 -07001113/*
1114 * Wait for DSP to be ready for commands
1115 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001116static void dspio_write_wait(struct hda_codec *codec)
1117{
Ian Minett4861af82012-09-20 20:29:20 -07001118 int status;
1119 unsigned long timeout = jiffies + msecs_to_jiffies(1000);
Ian Minett01ef7db2012-09-20 20:29:16 -07001120
Ian Minett01ef7db2012-09-20 20:29:16 -07001121 do {
Ian Minett4861af82012-09-20 20:29:20 -07001122 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0,
1123 VENDOR_DSPIO_STATUS, 0);
1124 if ((status == VENDOR_STATUS_DSPIO_OK) ||
1125 (status == VENDOR_STATUS_DSPIO_SCP_RESPONSE_QUEUE_EMPTY))
1126 break;
1127 msleep(1);
1128 } while (time_before(jiffies, timeout));
Ian Minett01ef7db2012-09-20 20:29:16 -07001129}
1130
Ian Minettd5c21b82012-09-20 20:29:18 -07001131/*
1132 * Write SCP data to DSP
1133 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001134static int dspio_write(struct hda_codec *codec, unsigned int scp_data)
1135{
1136 struct ca0132_spec *spec = codec->spec;
1137 int status;
1138
1139 dspio_write_wait(codec);
1140
1141 mutex_lock(&spec->chipio_mutex);
1142 status = dspio_send(codec, VENDOR_DSPIO_SCP_WRITE_DATA_LOW,
1143 scp_data & 0xffff);
1144 if (status < 0)
1145 goto error;
1146
1147 status = dspio_send(codec, VENDOR_DSPIO_SCP_WRITE_DATA_HIGH,
1148 scp_data >> 16);
1149 if (status < 0)
1150 goto error;
1151
1152 /* OK, now check if the write itself has executed*/
1153 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0,
1154 VENDOR_DSPIO_STATUS, 0);
1155error:
1156 mutex_unlock(&spec->chipio_mutex);
1157
1158 return (status == VENDOR_STATUS_DSPIO_SCP_COMMAND_QUEUE_FULL) ?
1159 -EIO : 0;
1160}
1161
Ian Minettd5c21b82012-09-20 20:29:18 -07001162/*
1163 * Write multiple SCP data to DSP
1164 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001165static int dspio_write_multiple(struct hda_codec *codec,
1166 unsigned int *buffer, unsigned int size)
1167{
1168 int status = 0;
1169 unsigned int count;
1170
Matthias Kaehlckea16fbb82017-03-15 15:41:23 -07001171 if (buffer == NULL)
Ian Minett01ef7db2012-09-20 20:29:16 -07001172 return -EINVAL;
1173
1174 count = 0;
1175 while (count < size) {
1176 status = dspio_write(codec, *buffer++);
1177 if (status != 0)
1178 break;
1179 count++;
1180 }
1181
1182 return status;
1183}
1184
Ian Minetta73d5112012-12-20 18:53:37 -08001185static int dspio_read(struct hda_codec *codec, unsigned int *data)
1186{
1187 int status;
1188
1189 status = dspio_send(codec, VENDOR_DSPIO_SCP_POST_READ_DATA, 0);
1190 if (status == -EIO)
1191 return status;
1192
1193 status = dspio_send(codec, VENDOR_DSPIO_STATUS, 0);
1194 if (status == -EIO ||
1195 status == VENDOR_STATUS_DSPIO_SCP_RESPONSE_QUEUE_EMPTY)
1196 return -EIO;
1197
1198 *data = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0,
1199 VENDOR_DSPIO_SCP_READ_DATA, 0);
1200
1201 return 0;
1202}
1203
1204static int dspio_read_multiple(struct hda_codec *codec, unsigned int *buffer,
1205 unsigned int *buf_size, unsigned int size_count)
1206{
1207 int status = 0;
1208 unsigned int size = *buf_size;
1209 unsigned int count;
1210 unsigned int skip_count;
1211 unsigned int dummy;
1212
Matthias Kaehlckea16fbb82017-03-15 15:41:23 -07001213 if (buffer == NULL)
Ian Minetta73d5112012-12-20 18:53:37 -08001214 return -1;
1215
1216 count = 0;
1217 while (count < size && count < size_count) {
1218 status = dspio_read(codec, buffer++);
1219 if (status != 0)
1220 break;
1221 count++;
1222 }
1223
1224 skip_count = count;
1225 if (status == 0) {
1226 while (skip_count < size) {
1227 status = dspio_read(codec, &dummy);
1228 if (status != 0)
1229 break;
1230 skip_count++;
1231 }
1232 }
1233 *buf_size = count;
1234
1235 return status;
1236}
1237
Ian Minettd5c21b82012-09-20 20:29:18 -07001238/*
1239 * Construct the SCP header using corresponding fields
1240 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001241static inline unsigned int
1242make_scp_header(unsigned int target_id, unsigned int source_id,
1243 unsigned int get_flag, unsigned int req,
1244 unsigned int device_flag, unsigned int resp_flag,
1245 unsigned int error_flag, unsigned int data_size)
1246{
1247 unsigned int header = 0;
1248
1249 header = (data_size & 0x1f) << 27;
1250 header |= (error_flag & 0x01) << 26;
1251 header |= (resp_flag & 0x01) << 25;
1252 header |= (device_flag & 0x01) << 24;
1253 header |= (req & 0x7f) << 17;
1254 header |= (get_flag & 0x01) << 16;
1255 header |= (source_id & 0xff) << 8;
1256 header |= target_id & 0xff;
1257
1258 return header;
1259}
1260
Ian Minettd5c21b82012-09-20 20:29:18 -07001261/*
1262 * Extract corresponding fields from SCP header
1263 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001264static inline void
1265extract_scp_header(unsigned int header,
1266 unsigned int *target_id, unsigned int *source_id,
1267 unsigned int *get_flag, unsigned int *req,
1268 unsigned int *device_flag, unsigned int *resp_flag,
1269 unsigned int *error_flag, unsigned int *data_size)
1270{
1271 if (data_size)
1272 *data_size = (header >> 27) & 0x1f;
1273 if (error_flag)
1274 *error_flag = (header >> 26) & 0x01;
1275 if (resp_flag)
1276 *resp_flag = (header >> 25) & 0x01;
1277 if (device_flag)
1278 *device_flag = (header >> 24) & 0x01;
1279 if (req)
1280 *req = (header >> 17) & 0x7f;
1281 if (get_flag)
1282 *get_flag = (header >> 16) & 0x01;
1283 if (source_id)
1284 *source_id = (header >> 8) & 0xff;
1285 if (target_id)
1286 *target_id = header & 0xff;
1287}
1288
1289#define SCP_MAX_DATA_WORDS (16)
1290
1291/* Structure to contain any SCP message */
1292struct scp_msg {
1293 unsigned int hdr;
1294 unsigned int data[SCP_MAX_DATA_WORDS];
1295};
1296
Ian Minetta73d5112012-12-20 18:53:37 -08001297static void dspio_clear_response_queue(struct hda_codec *codec)
1298{
1299 unsigned int dummy = 0;
1300 int status = -1;
1301
1302 /* clear all from the response queue */
1303 do {
1304 status = dspio_read(codec, &dummy);
1305 } while (status == 0);
1306}
1307
1308static int dspio_get_response_data(struct hda_codec *codec)
1309{
1310 struct ca0132_spec *spec = codec->spec;
1311 unsigned int data = 0;
1312 unsigned int count;
1313
1314 if (dspio_read(codec, &data) < 0)
1315 return -EIO;
1316
1317 if ((data & 0x00ffffff) == spec->wait_scp_header) {
1318 spec->scp_resp_header = data;
1319 spec->scp_resp_count = data >> 27;
1320 count = spec->wait_num_data;
1321 dspio_read_multiple(codec, spec->scp_resp_data,
1322 &spec->scp_resp_count, count);
1323 return 0;
1324 }
1325
1326 return -EIO;
1327}
1328
Ian Minettd5c21b82012-09-20 20:29:18 -07001329/*
1330 * Send SCP message to DSP
1331 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001332static int dspio_send_scp_message(struct hda_codec *codec,
1333 unsigned char *send_buf,
1334 unsigned int send_buf_size,
1335 unsigned char *return_buf,
1336 unsigned int return_buf_size,
1337 unsigned int *bytes_returned)
1338{
1339 struct ca0132_spec *spec = codec->spec;
Ian Minett01ef7db2012-09-20 20:29:16 -07001340 int status = -1;
1341 unsigned int scp_send_size = 0;
1342 unsigned int total_size;
1343 bool waiting_for_resp = false;
1344 unsigned int header;
1345 struct scp_msg *ret_msg;
1346 unsigned int resp_src_id, resp_target_id;
1347 unsigned int data_size, src_id, target_id, get_flag, device_flag;
1348
1349 if (bytes_returned)
1350 *bytes_returned = 0;
1351
1352 /* get scp header from buffer */
1353 header = *((unsigned int *)send_buf);
1354 extract_scp_header(header, &target_id, &src_id, &get_flag, NULL,
1355 &device_flag, NULL, NULL, &data_size);
1356 scp_send_size = data_size + 1;
1357 total_size = (scp_send_size * 4);
1358
1359 if (send_buf_size < total_size)
1360 return -EINVAL;
1361
1362 if (get_flag || device_flag) {
1363 if (!return_buf || return_buf_size < 4 || !bytes_returned)
1364 return -EINVAL;
1365
1366 spec->wait_scp_header = *((unsigned int *)send_buf);
1367
1368 /* swap source id with target id */
1369 resp_target_id = src_id;
1370 resp_src_id = target_id;
1371 spec->wait_scp_header &= 0xffff0000;
1372 spec->wait_scp_header |= (resp_src_id << 8) | (resp_target_id);
1373 spec->wait_num_data = return_buf_size/sizeof(unsigned int) - 1;
1374 spec->wait_scp = 1;
1375 waiting_for_resp = true;
1376 }
1377
1378 status = dspio_write_multiple(codec, (unsigned int *)send_buf,
1379 scp_send_size);
1380 if (status < 0) {
1381 spec->wait_scp = 0;
1382 return status;
1383 }
1384
1385 if (waiting_for_resp) {
Ian Minett6d675302013-02-08 18:31:43 -08001386 unsigned long timeout = jiffies + msecs_to_jiffies(1000);
Ian Minett01ef7db2012-09-20 20:29:16 -07001387 memset(return_buf, 0, return_buf_size);
Ian Minett01ef7db2012-09-20 20:29:16 -07001388 do {
1389 msleep(20);
Ian Minett6d675302013-02-08 18:31:43 -08001390 } while (spec->wait_scp && time_before(jiffies, timeout));
Ian Minett01ef7db2012-09-20 20:29:16 -07001391 waiting_for_resp = false;
Ian Minett6d675302013-02-08 18:31:43 -08001392 if (!spec->wait_scp) {
Ian Minett01ef7db2012-09-20 20:29:16 -07001393 ret_msg = (struct scp_msg *)return_buf;
1394 memcpy(&ret_msg->hdr, &spec->scp_resp_header, 4);
1395 memcpy(&ret_msg->data, spec->scp_resp_data,
1396 spec->wait_num_data);
1397 *bytes_returned = (spec->scp_resp_count + 1) * 4;
1398 status = 0;
1399 } else {
1400 status = -EIO;
1401 }
1402 spec->wait_scp = 0;
1403 }
1404
1405 return status;
1406}
1407
Ian Minettd5c21b82012-09-20 20:29:18 -07001408/**
1409 * Prepare and send the SCP message to DSP
1410 * @codec: the HDA codec
1411 * @mod_id: ID of the DSP module to send the command
1412 * @req: ID of request to send to the DSP module
1413 * @dir: SET or GET
1414 * @data: pointer to the data to send with the request, request specific
1415 * @len: length of the data, in bytes
1416 * @reply: point to the buffer to hold data returned for a reply
1417 * @reply_len: length of the reply buffer returned from GET
1418 *
1419 * Returns zero or a negative error code.
1420 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001421static int dspio_scp(struct hda_codec *codec,
1422 int mod_id, int req, int dir, void *data, unsigned int len,
1423 void *reply, unsigned int *reply_len)
1424{
1425 int status = 0;
1426 struct scp_msg scp_send, scp_reply;
1427 unsigned int ret_bytes, send_size, ret_size;
1428 unsigned int send_get_flag, reply_resp_flag, reply_error_flag;
1429 unsigned int reply_data_size;
1430
1431 memset(&scp_send, 0, sizeof(scp_send));
1432 memset(&scp_reply, 0, sizeof(scp_reply));
1433
1434 if ((len != 0 && data == NULL) || (len > SCP_MAX_DATA_WORDS))
1435 return -EINVAL;
1436
1437 if (dir == SCP_GET && reply == NULL) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001438 codec_dbg(codec, "dspio_scp get but has no buffer\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001439 return -EINVAL;
1440 }
1441
1442 if (reply != NULL && (reply_len == NULL || (*reply_len == 0))) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001443 codec_dbg(codec, "dspio_scp bad resp buf len parms\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001444 return -EINVAL;
1445 }
1446
1447 scp_send.hdr = make_scp_header(mod_id, 0x20, (dir == SCP_GET), req,
1448 0, 0, 0, len/sizeof(unsigned int));
1449 if (data != NULL && len > 0) {
1450 len = min((unsigned int)(sizeof(scp_send.data)), len);
1451 memcpy(scp_send.data, data, len);
1452 }
1453
1454 ret_bytes = 0;
1455 send_size = sizeof(unsigned int) + len;
1456 status = dspio_send_scp_message(codec, (unsigned char *)&scp_send,
1457 send_size, (unsigned char *)&scp_reply,
1458 sizeof(scp_reply), &ret_bytes);
1459
1460 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001461 codec_dbg(codec, "dspio_scp: send scp msg failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001462 return status;
1463 }
1464
1465 /* extract send and reply headers members */
1466 extract_scp_header(scp_send.hdr, NULL, NULL, &send_get_flag,
1467 NULL, NULL, NULL, NULL, NULL);
1468 extract_scp_header(scp_reply.hdr, NULL, NULL, NULL, NULL, NULL,
1469 &reply_resp_flag, &reply_error_flag,
1470 &reply_data_size);
1471
1472 if (!send_get_flag)
1473 return 0;
1474
1475 if (reply_resp_flag && !reply_error_flag) {
1476 ret_size = (ret_bytes - sizeof(scp_reply.hdr))
1477 / sizeof(unsigned int);
1478
1479 if (*reply_len < ret_size*sizeof(unsigned int)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001480 codec_dbg(codec, "reply too long for buf\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001481 return -EINVAL;
1482 } else if (ret_size != reply_data_size) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001483 codec_dbg(codec, "RetLen and HdrLen .NE.\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001484 return -EINVAL;
Arnd Bergmann46a049d2017-01-11 14:39:44 +01001485 } else if (!reply) {
1486 codec_dbg(codec, "NULL reply\n");
1487 return -EINVAL;
Ian Minett01ef7db2012-09-20 20:29:16 -07001488 } else {
1489 *reply_len = ret_size*sizeof(unsigned int);
1490 memcpy(reply, scp_reply.data, *reply_len);
1491 }
1492 } else {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001493 codec_dbg(codec, "reply ill-formed or errflag set\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001494 return -EIO;
1495 }
1496
1497 return status;
1498}
1499
Ian Minettd5c21b82012-09-20 20:29:18 -07001500/*
Ian Minett5aaca442012-12-20 18:53:34 -08001501 * Set DSP parameters
1502 */
1503static int dspio_set_param(struct hda_codec *codec, int mod_id,
1504 int req, void *data, unsigned int len)
1505{
1506 return dspio_scp(codec, mod_id, req, SCP_SET, data, len, NULL, NULL);
1507}
1508
1509static int dspio_set_uint_param(struct hda_codec *codec, int mod_id,
1510 int req, unsigned int data)
1511{
1512 return dspio_set_param(codec, mod_id, req, &data, sizeof(unsigned int));
1513}
1514
1515/*
Ian Minettd5c21b82012-09-20 20:29:18 -07001516 * Allocate a DSP DMA channel via an SCP message
1517 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001518static int dspio_alloc_dma_chan(struct hda_codec *codec, unsigned int *dma_chan)
1519{
1520 int status = 0;
1521 unsigned int size = sizeof(dma_chan);
1522
Takashi Iwai4e76a882014-02-25 12:21:03 +01001523 codec_dbg(codec, " dspio_alloc_dma_chan() -- begin\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001524 status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN,
1525 SCP_GET, NULL, 0, dma_chan, &size);
1526
1527 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001528 codec_dbg(codec, "dspio_alloc_dma_chan: SCP Failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001529 return status;
1530 }
1531
1532 if ((*dma_chan + 1) == 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001533 codec_dbg(codec, "no free dma channels to allocate\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001534 return -EBUSY;
1535 }
1536
Takashi Iwai4e76a882014-02-25 12:21:03 +01001537 codec_dbg(codec, "dspio_alloc_dma_chan: chan=%d\n", *dma_chan);
1538 codec_dbg(codec, " dspio_alloc_dma_chan() -- complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001539
1540 return status;
1541}
1542
Ian Minettd5c21b82012-09-20 20:29:18 -07001543/*
1544 * Free a DSP DMA via an SCP message
1545 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001546static int dspio_free_dma_chan(struct hda_codec *codec, unsigned int dma_chan)
1547{
1548 int status = 0;
1549 unsigned int dummy = 0;
1550
Takashi Iwai4e76a882014-02-25 12:21:03 +01001551 codec_dbg(codec, " dspio_free_dma_chan() -- begin\n");
1552 codec_dbg(codec, "dspio_free_dma_chan: chan=%d\n", dma_chan);
Ian Minett01ef7db2012-09-20 20:29:16 -07001553
1554 status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN,
1555 SCP_SET, &dma_chan, sizeof(dma_chan), NULL, &dummy);
1556
1557 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001558 codec_dbg(codec, "dspio_free_dma_chan: SCP Failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001559 return status;
1560 }
1561
Takashi Iwai4e76a882014-02-25 12:21:03 +01001562 codec_dbg(codec, " dspio_free_dma_chan() -- complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001563
1564 return status;
1565}
1566
1567/*
Ian Minettd5c21b82012-09-20 20:29:18 -07001568 * (Re)start the DSP
Ian Minett01ef7db2012-09-20 20:29:16 -07001569 */
1570static int dsp_set_run_state(struct hda_codec *codec)
1571{
1572 unsigned int dbg_ctrl_reg;
1573 unsigned int halt_state;
1574 int err;
1575
1576 err = chipio_read(codec, DSP_DBGCNTL_INST_OFFSET, &dbg_ctrl_reg);
1577 if (err < 0)
1578 return err;
1579
1580 halt_state = (dbg_ctrl_reg & DSP_DBGCNTL_STATE_MASK) >>
1581 DSP_DBGCNTL_STATE_LOBIT;
1582
1583 if (halt_state != 0) {
1584 dbg_ctrl_reg &= ~((halt_state << DSP_DBGCNTL_SS_LOBIT) &
1585 DSP_DBGCNTL_SS_MASK);
1586 err = chipio_write(codec, DSP_DBGCNTL_INST_OFFSET,
1587 dbg_ctrl_reg);
1588 if (err < 0)
1589 return err;
1590
1591 dbg_ctrl_reg |= (halt_state << DSP_DBGCNTL_EXEC_LOBIT) &
1592 DSP_DBGCNTL_EXEC_MASK;
1593 err = chipio_write(codec, DSP_DBGCNTL_INST_OFFSET,
1594 dbg_ctrl_reg);
1595 if (err < 0)
1596 return err;
1597 }
1598
1599 return 0;
1600}
1601
Ian Minettd5c21b82012-09-20 20:29:18 -07001602/*
1603 * Reset the DSP
1604 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001605static int dsp_reset(struct hda_codec *codec)
1606{
1607 unsigned int res;
1608 int retry = 20;
1609
Takashi Iwai4e76a882014-02-25 12:21:03 +01001610 codec_dbg(codec, "dsp_reset\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001611 do {
1612 res = dspio_send(codec, VENDOR_DSPIO_DSP_INIT, 0);
1613 retry--;
1614 } while (res == -EIO && retry);
1615
1616 if (!retry) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001617 codec_dbg(codec, "dsp_reset timeout\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001618 return -EIO;
1619 }
1620
1621 return 0;
1622}
1623
Ian Minettd5c21b82012-09-20 20:29:18 -07001624/*
1625 * Convert chip address to DSP address
1626 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001627static unsigned int dsp_chip_to_dsp_addx(unsigned int chip_addx,
1628 bool *code, bool *yram)
1629{
1630 *code = *yram = false;
1631
1632 if (UC_RANGE(chip_addx, 1)) {
1633 *code = true;
1634 return UC_OFF(chip_addx);
1635 } else if (X_RANGE_ALL(chip_addx, 1)) {
1636 return X_OFF(chip_addx);
1637 } else if (Y_RANGE_ALL(chip_addx, 1)) {
1638 *yram = true;
1639 return Y_OFF(chip_addx);
1640 }
1641
Takashi Iwai4a8b89f2013-02-12 10:15:15 +01001642 return INVALID_CHIP_ADDRESS;
Ian Minett01ef7db2012-09-20 20:29:16 -07001643}
1644
Ian Minettd5c21b82012-09-20 20:29:18 -07001645/*
1646 * Check if the DSP DMA is active
1647 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001648static bool dsp_is_dma_active(struct hda_codec *codec, unsigned int dma_chan)
1649{
1650 unsigned int dma_chnlstart_reg;
1651
1652 chipio_read(codec, DSPDMAC_CHNLSTART_INST_OFFSET, &dma_chnlstart_reg);
1653
1654 return ((dma_chnlstart_reg & (1 <<
1655 (DSPDMAC_CHNLSTART_EN_LOBIT + dma_chan))) != 0);
1656}
1657
1658static int dsp_dma_setup_common(struct hda_codec *codec,
1659 unsigned int chip_addx,
1660 unsigned int dma_chan,
1661 unsigned int port_map_mask,
1662 bool ovly)
1663{
1664 int status = 0;
1665 unsigned int chnl_prop;
1666 unsigned int dsp_addx;
1667 unsigned int active;
1668 bool code, yram;
1669
Takashi Iwai4e76a882014-02-25 12:21:03 +01001670 codec_dbg(codec, "-- dsp_dma_setup_common() -- Begin ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001671
1672 if (dma_chan >= DSPDMAC_DMA_CFG_CHANNEL_COUNT) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001673 codec_dbg(codec, "dma chan num invalid\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001674 return -EINVAL;
1675 }
1676
1677 if (dsp_is_dma_active(codec, dma_chan)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001678 codec_dbg(codec, "dma already active\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001679 return -EBUSY;
1680 }
1681
1682 dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram);
1683
1684 if (dsp_addx == INVALID_CHIP_ADDRESS) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001685 codec_dbg(codec, "invalid chip addr\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001686 return -ENXIO;
1687 }
1688
1689 chnl_prop = DSPDMAC_CHNLPROP_AC_MASK;
1690 active = 0;
1691
Takashi Iwai4e76a882014-02-25 12:21:03 +01001692 codec_dbg(codec, " dsp_dma_setup_common() start reg pgm\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001693
1694 if (ovly) {
1695 status = chipio_read(codec, DSPDMAC_CHNLPROP_INST_OFFSET,
1696 &chnl_prop);
1697
1698 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001699 codec_dbg(codec, "read CHNLPROP Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001700 return status;
1701 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001702 codec_dbg(codec, "dsp_dma_setup_common() Read CHNLPROP\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001703 }
1704
1705 if (!code)
1706 chnl_prop &= ~(1 << (DSPDMAC_CHNLPROP_MSPCE_LOBIT + dma_chan));
1707 else
1708 chnl_prop |= (1 << (DSPDMAC_CHNLPROP_MSPCE_LOBIT + dma_chan));
1709
1710 chnl_prop &= ~(1 << (DSPDMAC_CHNLPROP_DCON_LOBIT + dma_chan));
1711
1712 status = chipio_write(codec, DSPDMAC_CHNLPROP_INST_OFFSET, chnl_prop);
1713 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001714 codec_dbg(codec, "write CHNLPROP Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001715 return status;
1716 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001717 codec_dbg(codec, " dsp_dma_setup_common() Write CHNLPROP\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001718
1719 if (ovly) {
1720 status = chipio_read(codec, DSPDMAC_ACTIVE_INST_OFFSET,
1721 &active);
1722
1723 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001724 codec_dbg(codec, "read ACTIVE Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001725 return status;
1726 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001727 codec_dbg(codec, "dsp_dma_setup_common() Read ACTIVE\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001728 }
1729
1730 active &= (~(1 << (DSPDMAC_ACTIVE_AAR_LOBIT + dma_chan))) &
1731 DSPDMAC_ACTIVE_AAR_MASK;
1732
1733 status = chipio_write(codec, DSPDMAC_ACTIVE_INST_OFFSET, active);
1734 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001735 codec_dbg(codec, "write ACTIVE Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001736 return status;
1737 }
1738
Takashi Iwai4e76a882014-02-25 12:21:03 +01001739 codec_dbg(codec, " dsp_dma_setup_common() Write ACTIVE\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001740
1741 status = chipio_write(codec, DSPDMAC_AUDCHSEL_INST_OFFSET(dma_chan),
1742 port_map_mask);
1743 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001744 codec_dbg(codec, "write AUDCHSEL Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001745 return status;
1746 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001747 codec_dbg(codec, " dsp_dma_setup_common() Write AUDCHSEL\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001748
1749 status = chipio_write(codec, DSPDMAC_IRQCNT_INST_OFFSET(dma_chan),
1750 DSPDMAC_IRQCNT_BICNT_MASK | DSPDMAC_IRQCNT_CICNT_MASK);
1751 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001752 codec_dbg(codec, "write IRQCNT Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001753 return status;
1754 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001755 codec_dbg(codec, " dsp_dma_setup_common() Write IRQCNT\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001756
Takashi Iwai4e76a882014-02-25 12:21:03 +01001757 codec_dbg(codec,
Ian Minett01ef7db2012-09-20 20:29:16 -07001758 "ChipA=0x%x,DspA=0x%x,dmaCh=%u, "
1759 "CHSEL=0x%x,CHPROP=0x%x,Active=0x%x\n",
1760 chip_addx, dsp_addx, dma_chan,
1761 port_map_mask, chnl_prop, active);
1762
Takashi Iwai4e76a882014-02-25 12:21:03 +01001763 codec_dbg(codec, "-- dsp_dma_setup_common() -- Complete ------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001764
1765 return 0;
1766}
1767
Ian Minettd5c21b82012-09-20 20:29:18 -07001768/*
1769 * Setup the DSP DMA per-transfer-specific registers
1770 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001771static int dsp_dma_setup(struct hda_codec *codec,
1772 unsigned int chip_addx,
1773 unsigned int count,
1774 unsigned int dma_chan)
1775{
1776 int status = 0;
1777 bool code, yram;
1778 unsigned int dsp_addx;
1779 unsigned int addr_field;
1780 unsigned int incr_field;
1781 unsigned int base_cnt;
1782 unsigned int cur_cnt;
1783 unsigned int dma_cfg = 0;
1784 unsigned int adr_ofs = 0;
1785 unsigned int xfr_cnt = 0;
1786 const unsigned int max_dma_count = 1 << (DSPDMAC_XFRCNT_BCNT_HIBIT -
1787 DSPDMAC_XFRCNT_BCNT_LOBIT + 1);
1788
Takashi Iwai4e76a882014-02-25 12:21:03 +01001789 codec_dbg(codec, "-- dsp_dma_setup() -- Begin ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001790
1791 if (count > max_dma_count) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001792 codec_dbg(codec, "count too big\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001793 return -EINVAL;
1794 }
1795
1796 dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram);
1797 if (dsp_addx == INVALID_CHIP_ADDRESS) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001798 codec_dbg(codec, "invalid chip addr\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001799 return -ENXIO;
1800 }
1801
Takashi Iwai4e76a882014-02-25 12:21:03 +01001802 codec_dbg(codec, " dsp_dma_setup() start reg pgm\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001803
1804 addr_field = dsp_addx << DSPDMAC_DMACFG_DBADR_LOBIT;
1805 incr_field = 0;
1806
1807 if (!code) {
1808 addr_field <<= 1;
1809 if (yram)
1810 addr_field |= (1 << DSPDMAC_DMACFG_DBADR_LOBIT);
1811
1812 incr_field = (1 << DSPDMAC_DMACFG_AINCR_LOBIT);
1813 }
1814
1815 dma_cfg = addr_field + incr_field;
1816 status = chipio_write(codec, DSPDMAC_DMACFG_INST_OFFSET(dma_chan),
1817 dma_cfg);
1818 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001819 codec_dbg(codec, "write DMACFG Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001820 return status;
1821 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001822 codec_dbg(codec, " dsp_dma_setup() Write DMACFG\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001823
1824 adr_ofs = (count - 1) << (DSPDMAC_DSPADROFS_BOFS_LOBIT +
1825 (code ? 0 : 1));
1826
1827 status = chipio_write(codec, DSPDMAC_DSPADROFS_INST_OFFSET(dma_chan),
1828 adr_ofs);
1829 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001830 codec_dbg(codec, "write DSPADROFS Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001831 return status;
1832 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001833 codec_dbg(codec, " dsp_dma_setup() Write DSPADROFS\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001834
1835 base_cnt = (count - 1) << DSPDMAC_XFRCNT_BCNT_LOBIT;
1836
1837 cur_cnt = (count - 1) << DSPDMAC_XFRCNT_CCNT_LOBIT;
1838
1839 xfr_cnt = base_cnt | cur_cnt;
1840
1841 status = chipio_write(codec,
1842 DSPDMAC_XFRCNT_INST_OFFSET(dma_chan), xfr_cnt);
1843 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001844 codec_dbg(codec, "write XFRCNT Reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001845 return status;
1846 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001847 codec_dbg(codec, " dsp_dma_setup() Write XFRCNT\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001848
Takashi Iwai4e76a882014-02-25 12:21:03 +01001849 codec_dbg(codec,
Ian Minett01ef7db2012-09-20 20:29:16 -07001850 "ChipA=0x%x, cnt=0x%x, DMACFG=0x%x, "
1851 "ADROFS=0x%x, XFRCNT=0x%x\n",
1852 chip_addx, count, dma_cfg, adr_ofs, xfr_cnt);
1853
Takashi Iwai4e76a882014-02-25 12:21:03 +01001854 codec_dbg(codec, "-- dsp_dma_setup() -- Complete ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001855
1856 return 0;
1857}
1858
Ian Minettd5c21b82012-09-20 20:29:18 -07001859/*
1860 * Start the DSP DMA
1861 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001862static int dsp_dma_start(struct hda_codec *codec,
1863 unsigned int dma_chan, bool ovly)
1864{
1865 unsigned int reg = 0;
1866 int status = 0;
1867
Takashi Iwai4e76a882014-02-25 12:21:03 +01001868 codec_dbg(codec, "-- dsp_dma_start() -- Begin ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001869
1870 if (ovly) {
1871 status = chipio_read(codec,
1872 DSPDMAC_CHNLSTART_INST_OFFSET, &reg);
1873
1874 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001875 codec_dbg(codec, "read CHNLSTART reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001876 return status;
1877 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001878 codec_dbg(codec, "-- dsp_dma_start() Read CHNLSTART\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001879
1880 reg &= ~(DSPDMAC_CHNLSTART_EN_MASK |
1881 DSPDMAC_CHNLSTART_DIS_MASK);
1882 }
1883
1884 status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET,
1885 reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_EN_LOBIT)));
1886 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001887 codec_dbg(codec, "write CHNLSTART reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001888 return status;
1889 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001890 codec_dbg(codec, "-- dsp_dma_start() -- Complete ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001891
1892 return status;
1893}
1894
Ian Minettd5c21b82012-09-20 20:29:18 -07001895/*
1896 * Stop the DSP DMA
1897 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001898static int dsp_dma_stop(struct hda_codec *codec,
1899 unsigned int dma_chan, bool ovly)
1900{
1901 unsigned int reg = 0;
1902 int status = 0;
1903
Takashi Iwai4e76a882014-02-25 12:21:03 +01001904 codec_dbg(codec, "-- dsp_dma_stop() -- Begin ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001905
1906 if (ovly) {
1907 status = chipio_read(codec,
1908 DSPDMAC_CHNLSTART_INST_OFFSET, &reg);
1909
1910 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001911 codec_dbg(codec, "read CHNLSTART reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001912 return status;
1913 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001914 codec_dbg(codec, "-- dsp_dma_stop() Read CHNLSTART\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001915 reg &= ~(DSPDMAC_CHNLSTART_EN_MASK |
1916 DSPDMAC_CHNLSTART_DIS_MASK);
1917 }
1918
1919 status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET,
1920 reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_DIS_LOBIT)));
1921 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01001922 codec_dbg(codec, "write CHNLSTART reg fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001923 return status;
1924 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01001925 codec_dbg(codec, "-- dsp_dma_stop() -- Complete ---------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07001926
1927 return status;
1928}
1929
Ian Minettd5c21b82012-09-20 20:29:18 -07001930/**
1931 * Allocate router ports
1932 *
1933 * @codec: the HDA codec
1934 * @num_chans: number of channels in the stream
1935 * @ports_per_channel: number of ports per channel
1936 * @start_device: start device
1937 * @port_map: pointer to the port list to hold the allocated ports
1938 *
1939 * Returns zero or a negative error code.
1940 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001941static int dsp_allocate_router_ports(struct hda_codec *codec,
1942 unsigned int num_chans,
1943 unsigned int ports_per_channel,
1944 unsigned int start_device,
1945 unsigned int *port_map)
1946{
1947 int status = 0;
1948 int res;
1949 u8 val;
1950
1951 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
1952 if (status < 0)
1953 return status;
1954
1955 val = start_device << 6;
1956 val |= (ports_per_channel - 1) << 4;
1957 val |= num_chans - 1;
1958
1959 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1960 VENDOR_CHIPIO_PORT_ALLOC_CONFIG_SET,
1961 val);
1962
1963 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1964 VENDOR_CHIPIO_PORT_ALLOC_SET,
1965 MEM_CONNID_DSP);
1966
1967 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
1968 if (status < 0)
1969 return status;
1970
1971 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0,
1972 VENDOR_CHIPIO_PORT_ALLOC_GET, 0);
1973
1974 *port_map = res;
1975
1976 return (res < 0) ? res : 0;
1977}
1978
Ian Minettd5c21b82012-09-20 20:29:18 -07001979/*
1980 * Free router ports
1981 */
Ian Minett01ef7db2012-09-20 20:29:16 -07001982static int dsp_free_router_ports(struct hda_codec *codec)
1983{
1984 int status = 0;
1985
1986 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
1987 if (status < 0)
1988 return status;
1989
1990 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
1991 VENDOR_CHIPIO_PORT_FREE_SET,
1992 MEM_CONNID_DSP);
1993
1994 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0);
1995
1996 return status;
1997}
1998
Ian Minettd5c21b82012-09-20 20:29:18 -07001999/*
2000 * Allocate DSP ports for the download stream
2001 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002002static int dsp_allocate_ports(struct hda_codec *codec,
2003 unsigned int num_chans,
2004 unsigned int rate_multi, unsigned int *port_map)
2005{
2006 int status;
2007
Takashi Iwai4e76a882014-02-25 12:21:03 +01002008 codec_dbg(codec, " dsp_allocate_ports() -- begin\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002009
2010 if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002011 codec_dbg(codec, "bad rate multiple\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002012 return -EINVAL;
2013 }
2014
2015 status = dsp_allocate_router_ports(codec, num_chans,
2016 rate_multi, 0, port_map);
2017
Takashi Iwai4e76a882014-02-25 12:21:03 +01002018 codec_dbg(codec, " dsp_allocate_ports() -- complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002019
2020 return status;
2021}
2022
Ian Minett01ef7db2012-09-20 20:29:16 -07002023static int dsp_allocate_ports_format(struct hda_codec *codec,
2024 const unsigned short fmt,
2025 unsigned int *port_map)
2026{
2027 int status;
2028 unsigned int num_chans;
2029
2030 unsigned int sample_rate_div = ((get_hdafmt_rate(fmt) >> 0) & 3) + 1;
2031 unsigned int sample_rate_mul = ((get_hdafmt_rate(fmt) >> 3) & 3) + 1;
2032 unsigned int rate_multi = sample_rate_mul / sample_rate_div;
2033
2034 if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002035 codec_dbg(codec, "bad rate multiple\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002036 return -EINVAL;
2037 }
2038
2039 num_chans = get_hdafmt_chs(fmt) + 1;
2040
2041 status = dsp_allocate_ports(codec, num_chans, rate_multi, port_map);
2042
2043 return status;
2044}
2045
2046/*
Ian Minettd5c21b82012-09-20 20:29:18 -07002047 * free DSP ports
2048 */
2049static int dsp_free_ports(struct hda_codec *codec)
2050{
2051 int status;
2052
Takashi Iwai4e76a882014-02-25 12:21:03 +01002053 codec_dbg(codec, " dsp_free_ports() -- begin\n");
Ian Minettd5c21b82012-09-20 20:29:18 -07002054
2055 status = dsp_free_router_ports(codec);
2056 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002057 codec_dbg(codec, "free router ports fail\n");
Ian Minettd5c21b82012-09-20 20:29:18 -07002058 return status;
2059 }
Takashi Iwai4e76a882014-02-25 12:21:03 +01002060 codec_dbg(codec, " dsp_free_ports() -- complete\n");
Ian Minettd5c21b82012-09-20 20:29:18 -07002061
2062 return status;
2063}
2064
2065/*
Ian Minett01ef7db2012-09-20 20:29:16 -07002066 * HDA DMA engine stuffs for DSP code download
2067 */
2068struct dma_engine {
2069 struct hda_codec *codec;
2070 unsigned short m_converter_format;
2071 struct snd_dma_buffer *dmab;
2072 unsigned int buf_size;
2073};
2074
2075
2076enum dma_state {
2077 DMA_STATE_STOP = 0,
2078 DMA_STATE_RUN = 1
2079};
2080
Takashi Iwai6194b992014-06-06 18:12:16 +02002081static int dma_convert_to_hda_format(struct hda_codec *codec,
Ian Minette97249d2012-09-20 20:29:21 -07002082 unsigned int sample_rate,
2083 unsigned short channels,
Ian Minett01ef7db2012-09-20 20:29:16 -07002084 unsigned short *hda_format)
2085{
2086 unsigned int format_val;
2087
Takashi Iwaib7d023e2015-04-16 08:19:06 +02002088 format_val = snd_hdac_calc_stream_format(sample_rate,
2089 channels, SNDRV_PCM_FORMAT_S32_LE, 32, 0);
Ian Minett01ef7db2012-09-20 20:29:16 -07002090
2091 if (hda_format)
2092 *hda_format = (unsigned short)format_val;
2093
2094 return 0;
2095}
2096
Ian Minettd5c21b82012-09-20 20:29:18 -07002097/*
2098 * Reset DMA for DSP download
2099 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002100static int dma_reset(struct dma_engine *dma)
2101{
2102 struct hda_codec *codec = dma->codec;
2103 struct ca0132_spec *spec = codec->spec;
2104 int status;
2105
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002106 if (dma->dmab->area)
Ian Minett01ef7db2012-09-20 20:29:16 -07002107 snd_hda_codec_load_dsp_cleanup(codec, dma->dmab);
2108
2109 status = snd_hda_codec_load_dsp_prepare(codec,
2110 dma->m_converter_format,
2111 dma->buf_size,
2112 dma->dmab);
2113 if (status < 0)
2114 return status;
2115 spec->dsp_stream_id = status;
2116 return 0;
2117}
2118
2119static int dma_set_state(struct dma_engine *dma, enum dma_state state)
2120{
2121 bool cmd;
2122
Ian Minett01ef7db2012-09-20 20:29:16 -07002123 switch (state) {
2124 case DMA_STATE_STOP:
2125 cmd = false;
2126 break;
2127 case DMA_STATE_RUN:
2128 cmd = true;
2129 break;
2130 default:
2131 return 0;
2132 }
2133
2134 snd_hda_codec_load_dsp_trigger(dma->codec, cmd);
2135 return 0;
2136}
2137
2138static unsigned int dma_get_buffer_size(struct dma_engine *dma)
2139{
2140 return dma->dmab->bytes;
2141}
2142
2143static unsigned char *dma_get_buffer_addr(struct dma_engine *dma)
2144{
2145 return dma->dmab->area;
2146}
2147
2148static int dma_xfer(struct dma_engine *dma,
2149 const unsigned int *data,
2150 unsigned int count)
2151{
2152 memcpy(dma->dmab->area, data, count);
2153 return 0;
2154}
2155
2156static void dma_get_converter_format(
2157 struct dma_engine *dma,
2158 unsigned short *format)
2159{
2160 if (format)
2161 *format = dma->m_converter_format;
2162}
2163
2164static unsigned int dma_get_stream_id(struct dma_engine *dma)
2165{
2166 struct ca0132_spec *spec = dma->codec->spec;
2167
2168 return spec->dsp_stream_id;
2169}
2170
2171struct dsp_image_seg {
2172 u32 magic;
2173 u32 chip_addr;
2174 u32 count;
2175 u32 data[0];
2176};
2177
2178static const u32 g_magic_value = 0x4c46584d;
2179static const u32 g_chip_addr_magic_value = 0xFFFFFF01;
2180
2181static bool is_valid(const struct dsp_image_seg *p)
2182{
2183 return p->magic == g_magic_value;
2184}
2185
2186static bool is_hci_prog_list_seg(const struct dsp_image_seg *p)
2187{
2188 return g_chip_addr_magic_value == p->chip_addr;
2189}
2190
2191static bool is_last(const struct dsp_image_seg *p)
2192{
2193 return p->count == 0;
2194}
2195
2196static size_t dsp_sizeof(const struct dsp_image_seg *p)
2197{
2198 return sizeof(*p) + p->count*sizeof(u32);
2199}
2200
2201static const struct dsp_image_seg *get_next_seg_ptr(
2202 const struct dsp_image_seg *p)
2203{
2204 return (struct dsp_image_seg *)((unsigned char *)(p) + dsp_sizeof(p));
2205}
2206
2207/*
2208 * CA0132 chip DSP transfer stuffs. For DSP download.
2209 */
Takashi Iwai8ae3124b2013-01-15 17:43:09 +01002210#define INVALID_DMA_CHANNEL (~0U)
Ian Minett01ef7db2012-09-20 20:29:16 -07002211
Ian Minettd5c21b82012-09-20 20:29:18 -07002212/*
2213 * Program a list of address/data pairs via the ChipIO widget.
2214 * The segment data is in the format of successive pairs of words.
2215 * These are repeated as indicated by the segment's count field.
2216 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002217static int dspxfr_hci_write(struct hda_codec *codec,
2218 const struct dsp_image_seg *fls)
2219{
2220 int status;
2221 const u32 *data;
2222 unsigned int count;
2223
2224 if (fls == NULL || fls->chip_addr != g_chip_addr_magic_value) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002225 codec_dbg(codec, "hci_write invalid params\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002226 return -EINVAL;
2227 }
2228
2229 count = fls->count;
2230 data = (u32 *)(fls->data);
2231 while (count >= 2) {
2232 status = chipio_write(codec, data[0], data[1]);
2233 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002234 codec_dbg(codec, "hci_write chipio failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002235 return status;
2236 }
2237 count -= 2;
2238 data += 2;
2239 }
2240 return 0;
2241}
2242
Ian Minettd5c21b82012-09-20 20:29:18 -07002243/**
2244 * Write a block of data into DSP code or data RAM using pre-allocated
2245 * DMA engine.
2246 *
2247 * @codec: the HDA codec
2248 * @fls: pointer to a fast load image
2249 * @reloc: Relocation address for loading single-segment overlays, or 0 for
2250 * no relocation
2251 * @dma_engine: pointer to DMA engine to be used for DSP download
2252 * @dma_chan: The number of DMA channels used for DSP download
2253 * @port_map_mask: port mapping
2254 * @ovly: TRUE if overlay format is required
2255 *
2256 * Returns zero or a negative error code.
2257 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002258static int dspxfr_one_seg(struct hda_codec *codec,
2259 const struct dsp_image_seg *fls,
2260 unsigned int reloc,
2261 struct dma_engine *dma_engine,
2262 unsigned int dma_chan,
2263 unsigned int port_map_mask,
2264 bool ovly)
2265{
Ian Minett406261c2012-12-20 18:53:41 -08002266 int status = 0;
Ian Minett01ef7db2012-09-20 20:29:16 -07002267 bool comm_dma_setup_done = false;
2268 const unsigned int *data;
2269 unsigned int chip_addx;
2270 unsigned int words_to_write;
2271 unsigned int buffer_size_words;
2272 unsigned char *buffer_addx;
2273 unsigned short hda_format;
2274 unsigned int sample_rate_div;
2275 unsigned int sample_rate_mul;
2276 unsigned int num_chans;
2277 unsigned int hda_frame_size_words;
2278 unsigned int remainder_words;
2279 const u32 *data_remainder;
2280 u32 chip_addx_remainder;
2281 unsigned int run_size_words;
2282 const struct dsp_image_seg *hci_write = NULL;
Ian Minett6d675302013-02-08 18:31:43 -08002283 unsigned long timeout;
2284 bool dma_active;
Ian Minett01ef7db2012-09-20 20:29:16 -07002285
2286 if (fls == NULL)
2287 return -EINVAL;
2288 if (is_hci_prog_list_seg(fls)) {
2289 hci_write = fls;
2290 fls = get_next_seg_ptr(fls);
2291 }
2292
2293 if (hci_write && (!fls || is_last(fls))) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002294 codec_dbg(codec, "hci_write\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002295 return dspxfr_hci_write(codec, hci_write);
2296 }
2297
2298 if (fls == NULL || dma_engine == NULL || port_map_mask == 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002299 codec_dbg(codec, "Invalid Params\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002300 return -EINVAL;
2301 }
2302
2303 data = fls->data;
2304 chip_addx = fls->chip_addr,
2305 words_to_write = fls->count;
2306
2307 if (!words_to_write)
2308 return hci_write ? dspxfr_hci_write(codec, hci_write) : 0;
2309 if (reloc)
2310 chip_addx = (chip_addx & (0xFFFF0000 << 2)) + (reloc << 2);
2311
2312 if (!UC_RANGE(chip_addx, words_to_write) &&
2313 !X_RANGE_ALL(chip_addx, words_to_write) &&
2314 !Y_RANGE_ALL(chip_addx, words_to_write)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002315 codec_dbg(codec, "Invalid chip_addx Params\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002316 return -EINVAL;
2317 }
2318
2319 buffer_size_words = (unsigned int)dma_get_buffer_size(dma_engine) /
2320 sizeof(u32);
2321
2322 buffer_addx = dma_get_buffer_addr(dma_engine);
2323
2324 if (buffer_addx == NULL) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002325 codec_dbg(codec, "dma_engine buffer NULL\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002326 return -EINVAL;
2327 }
2328
2329 dma_get_converter_format(dma_engine, &hda_format);
2330 sample_rate_div = ((get_hdafmt_rate(hda_format) >> 0) & 3) + 1;
2331 sample_rate_mul = ((get_hdafmt_rate(hda_format) >> 3) & 3) + 1;
2332 num_chans = get_hdafmt_chs(hda_format) + 1;
2333
2334 hda_frame_size_words = ((sample_rate_div == 0) ? 0 :
2335 (num_chans * sample_rate_mul / sample_rate_div));
2336
Xi Wang3bc085a2013-03-07 00:13:51 -05002337 if (hda_frame_size_words == 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002338 codec_dbg(codec, "frmsz zero\n");
Xi Wang3bc085a2013-03-07 00:13:51 -05002339 return -EINVAL;
2340 }
2341
Ian Minett01ef7db2012-09-20 20:29:16 -07002342 buffer_size_words = min(buffer_size_words,
2343 (unsigned int)(UC_RANGE(chip_addx, 1) ?
2344 65536 : 32768));
2345 buffer_size_words -= buffer_size_words % hda_frame_size_words;
Takashi Iwai4e76a882014-02-25 12:21:03 +01002346 codec_dbg(codec,
Ian Minett01ef7db2012-09-20 20:29:16 -07002347 "chpadr=0x%08x frmsz=%u nchan=%u "
2348 "rate_mul=%u div=%u bufsz=%u\n",
2349 chip_addx, hda_frame_size_words, num_chans,
2350 sample_rate_mul, sample_rate_div, buffer_size_words);
2351
Xi Wang3bc085a2013-03-07 00:13:51 -05002352 if (buffer_size_words < hda_frame_size_words) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002353 codec_dbg(codec, "dspxfr_one_seg:failed\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002354 return -EINVAL;
2355 }
2356
2357 remainder_words = words_to_write % hda_frame_size_words;
2358 data_remainder = data;
2359 chip_addx_remainder = chip_addx;
2360
2361 data += remainder_words;
2362 chip_addx += remainder_words*sizeof(u32);
2363 words_to_write -= remainder_words;
2364
2365 while (words_to_write != 0) {
2366 run_size_words = min(buffer_size_words, words_to_write);
Takashi Iwai4e76a882014-02-25 12:21:03 +01002367 codec_dbg(codec, "dspxfr (seg loop)cnt=%u rs=%u remainder=%u\n",
Ian Minett01ef7db2012-09-20 20:29:16 -07002368 words_to_write, run_size_words, remainder_words);
2369 dma_xfer(dma_engine, data, run_size_words*sizeof(u32));
2370 if (!comm_dma_setup_done) {
2371 status = dsp_dma_stop(codec, dma_chan, ovly);
2372 if (status < 0)
Takashi Iwai425a7882013-01-15 17:41:21 +01002373 return status;
Ian Minett01ef7db2012-09-20 20:29:16 -07002374 status = dsp_dma_setup_common(codec, chip_addx,
2375 dma_chan, port_map_mask, ovly);
2376 if (status < 0)
2377 return status;
2378 comm_dma_setup_done = true;
2379 }
2380
2381 status = dsp_dma_setup(codec, chip_addx,
2382 run_size_words, dma_chan);
2383 if (status < 0)
2384 return status;
2385 status = dsp_dma_start(codec, dma_chan, ovly);
2386 if (status < 0)
2387 return status;
2388 if (!dsp_is_dma_active(codec, dma_chan)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002389 codec_dbg(codec, "dspxfr:DMA did not start\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002390 return -EIO;
2391 }
2392 status = dma_set_state(dma_engine, DMA_STATE_RUN);
2393 if (status < 0)
2394 return status;
2395 if (remainder_words != 0) {
2396 status = chipio_write_multiple(codec,
2397 chip_addx_remainder,
2398 data_remainder,
2399 remainder_words);
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002400 if (status < 0)
2401 return status;
Ian Minett01ef7db2012-09-20 20:29:16 -07002402 remainder_words = 0;
2403 }
2404 if (hci_write) {
2405 status = dspxfr_hci_write(codec, hci_write);
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002406 if (status < 0)
2407 return status;
Ian Minett01ef7db2012-09-20 20:29:16 -07002408 hci_write = NULL;
2409 }
Ian Minett6d675302013-02-08 18:31:43 -08002410
2411 timeout = jiffies + msecs_to_jiffies(2000);
2412 do {
2413 dma_active = dsp_is_dma_active(codec, dma_chan);
2414 if (!dma_active)
Ian Minett01ef7db2012-09-20 20:29:16 -07002415 break;
Ian Minett6d675302013-02-08 18:31:43 -08002416 msleep(20);
2417 } while (time_before(jiffies, timeout));
2418 if (dma_active)
2419 break;
2420
Takashi Iwai4e76a882014-02-25 12:21:03 +01002421 codec_dbg(codec, "+++++ DMA complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002422 dma_set_state(dma_engine, DMA_STATE_STOP);
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002423 status = dma_reset(dma_engine);
Ian Minett01ef7db2012-09-20 20:29:16 -07002424
2425 if (status < 0)
2426 return status;
2427
2428 data += run_size_words;
2429 chip_addx += run_size_words*sizeof(u32);
2430 words_to_write -= run_size_words;
2431 }
2432
2433 if (remainder_words != 0) {
2434 status = chipio_write_multiple(codec, chip_addx_remainder,
2435 data_remainder, remainder_words);
2436 }
2437
2438 return status;
2439}
2440
Ian Minettd5c21b82012-09-20 20:29:18 -07002441/**
2442 * Write the entire DSP image of a DSP code/data overlay to DSP memories
2443 *
2444 * @codec: the HDA codec
2445 * @fls_data: pointer to a fast load image
2446 * @reloc: Relocation address for loading single-segment overlays, or 0 for
2447 * no relocation
Ian Minette97249d2012-09-20 20:29:21 -07002448 * @sample_rate: sampling rate of the stream used for DSP download
Takashi Iwaie60b2c72014-11-10 16:47:26 +01002449 * @channels: channels of the stream used for DSP download
Ian Minettd5c21b82012-09-20 20:29:18 -07002450 * @ovly: TRUE if overlay format is required
2451 *
2452 * Returns zero or a negative error code.
2453 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002454static int dspxfr_image(struct hda_codec *codec,
2455 const struct dsp_image_seg *fls_data,
Ian Minette97249d2012-09-20 20:29:21 -07002456 unsigned int reloc,
2457 unsigned int sample_rate,
2458 unsigned short channels,
Ian Minett01ef7db2012-09-20 20:29:16 -07002459 bool ovly)
2460{
2461 struct ca0132_spec *spec = codec->spec;
2462 int status;
2463 unsigned short hda_format = 0;
2464 unsigned int response;
2465 unsigned char stream_id = 0;
2466 struct dma_engine *dma_engine;
2467 unsigned int dma_chan;
2468 unsigned int port_map_mask;
2469
2470 if (fls_data == NULL)
2471 return -EINVAL;
2472
2473 dma_engine = kzalloc(sizeof(*dma_engine), GFP_KERNEL);
Takashi Iwai549e8292013-01-15 17:42:15 +01002474 if (!dma_engine)
2475 return -ENOMEM;
Ian Minett01ef7db2012-09-20 20:29:16 -07002476
2477 dma_engine->dmab = kzalloc(sizeof(*dma_engine->dmab), GFP_KERNEL);
2478 if (!dma_engine->dmab) {
Takashi Iwai549e8292013-01-15 17:42:15 +01002479 kfree(dma_engine);
2480 return -ENOMEM;
Ian Minett01ef7db2012-09-20 20:29:16 -07002481 }
2482
2483 dma_engine->codec = codec;
Takashi Iwai6194b992014-06-06 18:12:16 +02002484 dma_convert_to_hda_format(codec, sample_rate, channels, &hda_format);
Ian Minett01ef7db2012-09-20 20:29:16 -07002485 dma_engine->m_converter_format = hda_format;
2486 dma_engine->buf_size = (ovly ? DSP_DMA_WRITE_BUFLEN_OVLY :
2487 DSP_DMA_WRITE_BUFLEN_INIT) * 2;
2488
Takashi Iwai8ae3124b2013-01-15 17:43:09 +01002489 dma_chan = ovly ? INVALID_DMA_CHANNEL : 0;
Ian Minett01ef7db2012-09-20 20:29:16 -07002490
2491 status = codec_set_converter_format(codec, WIDGET_CHIP_CTRL,
2492 hda_format, &response);
2493
2494 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002495 codec_dbg(codec, "set converter format fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002496 goto exit;
2497 }
2498
2499 status = snd_hda_codec_load_dsp_prepare(codec,
2500 dma_engine->m_converter_format,
2501 dma_engine->buf_size,
2502 dma_engine->dmab);
2503 if (status < 0)
2504 goto exit;
2505 spec->dsp_stream_id = status;
2506
2507 if (ovly) {
2508 status = dspio_alloc_dma_chan(codec, &dma_chan);
2509 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002510 codec_dbg(codec, "alloc dmachan fail\n");
Takashi Iwai8ae3124b2013-01-15 17:43:09 +01002511 dma_chan = INVALID_DMA_CHANNEL;
Ian Minett01ef7db2012-09-20 20:29:16 -07002512 goto exit;
2513 }
2514 }
2515
2516 port_map_mask = 0;
2517 status = dsp_allocate_ports_format(codec, hda_format,
2518 &port_map_mask);
2519 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002520 codec_dbg(codec, "alloc ports fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002521 goto exit;
2522 }
2523
2524 stream_id = dma_get_stream_id(dma_engine);
2525 status = codec_set_converter_stream_channel(codec,
2526 WIDGET_CHIP_CTRL, stream_id, 0, &response);
2527 if (status < 0) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002528 codec_dbg(codec, "set stream chan fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002529 goto exit;
2530 }
2531
2532 while ((fls_data != NULL) && !is_last(fls_data)) {
2533 if (!is_valid(fls_data)) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002534 codec_dbg(codec, "FLS check fail\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002535 status = -EINVAL;
2536 goto exit;
2537 }
2538 status = dspxfr_one_seg(codec, fls_data, reloc,
2539 dma_engine, dma_chan,
2540 port_map_mask, ovly);
2541 if (status < 0)
2542 break;
2543
2544 if (is_hci_prog_list_seg(fls_data))
2545 fls_data = get_next_seg_ptr(fls_data);
2546
2547 if ((fls_data != NULL) && !is_last(fls_data))
2548 fls_data = get_next_seg_ptr(fls_data);
2549 }
2550
2551 if (port_map_mask != 0)
2552 status = dsp_free_ports(codec);
2553
2554 if (status < 0)
2555 goto exit;
2556
2557 status = codec_set_converter_stream_channel(codec,
2558 WIDGET_CHIP_CTRL, 0, 0, &response);
2559
2560exit:
2561 if (ovly && (dma_chan != INVALID_DMA_CHANNEL))
2562 dspio_free_dma_chan(codec, dma_chan);
2563
Takashi Iwaib3667bd2013-02-10 11:58:40 +01002564 if (dma_engine->dmab->area)
Ian Minett01ef7db2012-09-20 20:29:16 -07002565 snd_hda_codec_load_dsp_cleanup(codec, dma_engine->dmab);
2566 kfree(dma_engine->dmab);
2567 kfree(dma_engine);
2568
2569 return status;
2570}
2571
2572/*
2573 * CA0132 DSP download stuffs.
2574 */
2575static void dspload_post_setup(struct hda_codec *codec)
2576{
Takashi Iwai4e76a882014-02-25 12:21:03 +01002577 codec_dbg(codec, "---- dspload_post_setup ------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002578
2579 /*set DSP speaker to 2.0 configuration*/
2580 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x18), 0x08080080);
2581 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x19), 0x3f800000);
2582
2583 /*update write pointer*/
2584 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x29), 0x00000002);
2585}
2586
Ian Minettd5c21b82012-09-20 20:29:18 -07002587/**
Takashi Iwaie60b2c72014-11-10 16:47:26 +01002588 * dspload_image - Download DSP from a DSP Image Fast Load structure.
Ian Minettd5c21b82012-09-20 20:29:18 -07002589 *
2590 * @codec: the HDA codec
2591 * @fls: pointer to a fast load image
2592 * @ovly: TRUE if overlay format is required
2593 * @reloc: Relocation address for loading single-segment overlays, or 0 for
2594 * no relocation
2595 * @autostart: TRUE if DSP starts after loading; ignored if ovly is TRUE
2596 * @router_chans: number of audio router channels to be allocated (0 means use
2597 * internal defaults; max is 32)
2598 *
Takashi Iwaie60b2c72014-11-10 16:47:26 +01002599 * Download DSP from a DSP Image Fast Load structure. This structure is a
2600 * linear, non-constant sized element array of structures, each of which
2601 * contain the count of the data to be loaded, the data itself, and the
2602 * corresponding starting chip address of the starting data location.
Ian Minettd5c21b82012-09-20 20:29:18 -07002603 * Returns zero or a negative error code.
2604 */
Ian Minett01ef7db2012-09-20 20:29:16 -07002605static int dspload_image(struct hda_codec *codec,
2606 const struct dsp_image_seg *fls,
2607 bool ovly,
2608 unsigned int reloc,
2609 bool autostart,
2610 int router_chans)
2611{
2612 int status = 0;
Ian Minette97249d2012-09-20 20:29:21 -07002613 unsigned int sample_rate;
2614 unsigned short channels;
Ian Minett01ef7db2012-09-20 20:29:16 -07002615
Takashi Iwai4e76a882014-02-25 12:21:03 +01002616 codec_dbg(codec, "---- dspload_image begin ------\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002617 if (router_chans == 0) {
2618 if (!ovly)
2619 router_chans = DMA_TRANSFER_FRAME_SIZE_NWORDS;
2620 else
2621 router_chans = DMA_OVERLAY_FRAME_SIZE_NWORDS;
2622 }
2623
Ian Minette97249d2012-09-20 20:29:21 -07002624 sample_rate = 48000;
2625 channels = (unsigned short)router_chans;
Ian Minett01ef7db2012-09-20 20:29:16 -07002626
Ian Minette97249d2012-09-20 20:29:21 -07002627 while (channels > 16) {
2628 sample_rate *= 2;
2629 channels /= 2;
Ian Minett01ef7db2012-09-20 20:29:16 -07002630 }
2631
Ian Minett01ef7db2012-09-20 20:29:16 -07002632 do {
Takashi Iwai4e76a882014-02-25 12:21:03 +01002633 codec_dbg(codec, "Ready to program DMA\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002634 if (!ovly)
2635 status = dsp_reset(codec);
2636
2637 if (status < 0)
2638 break;
2639
Takashi Iwai4e76a882014-02-25 12:21:03 +01002640 codec_dbg(codec, "dsp_reset() complete\n");
Ian Minette97249d2012-09-20 20:29:21 -07002641 status = dspxfr_image(codec, fls, reloc, sample_rate, channels,
2642 ovly);
Ian Minett01ef7db2012-09-20 20:29:16 -07002643
2644 if (status < 0)
2645 break;
2646
Takashi Iwai4e76a882014-02-25 12:21:03 +01002647 codec_dbg(codec, "dspxfr_image() complete\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002648 if (autostart && !ovly) {
2649 dspload_post_setup(codec);
2650 status = dsp_set_run_state(codec);
2651 }
2652
Takashi Iwai4e76a882014-02-25 12:21:03 +01002653 codec_dbg(codec, "LOAD FINISHED\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002654 } while (0);
2655
2656 return status;
2657}
2658
Takashi Iwaif6644172013-02-11 14:18:29 +01002659#ifdef CONFIG_SND_HDA_CODEC_CA0132_DSP
Ian Minett01ef7db2012-09-20 20:29:16 -07002660static bool dspload_is_loaded(struct hda_codec *codec)
2661{
2662 unsigned int data = 0;
2663 int status = 0;
2664
2665 status = chipio_read(codec, 0x40004, &data);
2666 if ((status < 0) || (data != 1))
2667 return false;
2668
2669 return true;
2670}
Takashi Iwaif6644172013-02-11 14:18:29 +01002671#else
2672#define dspload_is_loaded(codec) false
2673#endif
Ian Minett01ef7db2012-09-20 20:29:16 -07002674
2675static bool dspload_wait_loaded(struct hda_codec *codec)
2676{
Ian Minett6d675302013-02-08 18:31:43 -08002677 unsigned long timeout = jiffies + msecs_to_jiffies(2000);
Ian Minett01ef7db2012-09-20 20:29:16 -07002678
2679 do {
Ian Minett01ef7db2012-09-20 20:29:16 -07002680 if (dspload_is_loaded(codec)) {
Takashi Iwaid9684bb2015-10-26 16:54:16 +01002681 codec_info(codec, "ca0132 DSP downloaded and running\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002682 return true;
2683 }
Ian Minett6d675302013-02-08 18:31:43 -08002684 msleep(20);
2685 } while (time_before(jiffies, timeout));
Ian Minett01ef7db2012-09-20 20:29:16 -07002686
Takashi Iwaid9684bb2015-10-26 16:54:16 +01002687 codec_err(codec, "ca0132 failed to download DSP\n");
Ian Minett01ef7db2012-09-20 20:29:16 -07002688 return false;
2689}
2690
Ian Minett5aaca442012-12-20 18:53:34 -08002691/*
Ian Minett825315b2012-12-20 18:53:36 -08002692 * PCM callbacks
2693 */
Ian Minett95c6e9c2011-06-15 15:35:17 -07002694static int ca0132_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
2695 struct hda_codec *codec,
2696 unsigned int stream_tag,
2697 unsigned int format,
2698 struct snd_pcm_substream *substream)
2699{
2700 struct ca0132_spec *spec = codec->spec;
Ian Minett825315b2012-12-20 18:53:36 -08002701
Hsin-Yu Chao28fba952014-02-19 14:27:07 +08002702 snd_hda_codec_setup_stream(codec, spec->dacs[0], stream_tag, 0, format);
Ian Minett825315b2012-12-20 18:53:36 -08002703
2704 return 0;
Ian Minett95c6e9c2011-06-15 15:35:17 -07002705}
2706
2707static int ca0132_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
2708 struct hda_codec *codec,
2709 struct snd_pcm_substream *substream)
2710{
2711 struct ca0132_spec *spec = codec->spec;
Ian Minett825315b2012-12-20 18:53:36 -08002712
2713 if (spec->dsp_state == DSP_DOWNLOADING)
2714 return 0;
2715
2716 /*If Playback effects are on, allow stream some time to flush
2717 *effects tail*/
2718 if (spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID])
2719 msleep(50);
2720
Hsin-Yu Chao28fba952014-02-19 14:27:07 +08002721 snd_hda_codec_cleanup_stream(codec, spec->dacs[0]);
Ian Minett825315b2012-12-20 18:53:36 -08002722
2723 return 0;
Ian Minett95c6e9c2011-06-15 15:35:17 -07002724}
2725
Dylan Reide8412ca2013-04-04 13:55:09 -07002726static unsigned int ca0132_playback_pcm_delay(struct hda_pcm_stream *info,
2727 struct hda_codec *codec,
2728 struct snd_pcm_substream *substream)
2729{
2730 struct ca0132_spec *spec = codec->spec;
2731 unsigned int latency = DSP_PLAYBACK_INIT_LATENCY;
2732 struct snd_pcm_runtime *runtime = substream->runtime;
2733
2734 if (spec->dsp_state != DSP_DOWNLOADED)
2735 return 0;
2736
2737 /* Add latency if playback enhancement and either effect is enabled. */
2738 if (spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]) {
2739 if ((spec->effects_switch[SURROUND - EFFECT_START_NID]) ||
2740 (spec->effects_switch[DIALOG_PLUS - EFFECT_START_NID]))
2741 latency += DSP_PLAY_ENHANCEMENT_LATENCY;
2742 }
2743
2744 /* Applying Speaker EQ adds latency as well. */
2745 if (spec->cur_out_type == SPEAKER_OUT)
2746 latency += DSP_SPEAKER_OUT_LATENCY;
2747
2748 return (latency * runtime->rate) / 1000;
2749}
2750
Ian Minett95c6e9c2011-06-15 15:35:17 -07002751/*
2752 * Digital out
2753 */
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002754static int ca0132_dig_playback_pcm_open(struct hda_pcm_stream *hinfo,
2755 struct hda_codec *codec,
2756 struct snd_pcm_substream *substream)
2757{
2758 struct ca0132_spec *spec = codec->spec;
2759 return snd_hda_multi_out_dig_open(codec, &spec->multiout);
2760}
2761
Ian Minett95c6e9c2011-06-15 15:35:17 -07002762static int ca0132_dig_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
2763 struct hda_codec *codec,
2764 unsigned int stream_tag,
2765 unsigned int format,
2766 struct snd_pcm_substream *substream)
2767{
2768 struct ca0132_spec *spec = codec->spec;
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002769 return snd_hda_multi_out_dig_prepare(codec, &spec->multiout,
2770 stream_tag, format, substream);
Ian Minett95c6e9c2011-06-15 15:35:17 -07002771}
2772
2773static int ca0132_dig_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
2774 struct hda_codec *codec,
2775 struct snd_pcm_substream *substream)
2776{
2777 struct ca0132_spec *spec = codec->spec;
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002778 return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout);
Ian Minett95c6e9c2011-06-15 15:35:17 -07002779}
2780
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002781static int ca0132_dig_playback_pcm_close(struct hda_pcm_stream *hinfo,
2782 struct hda_codec *codec,
2783 struct snd_pcm_substream *substream)
Ian Minett95c6e9c2011-06-15 15:35:17 -07002784{
2785 struct ca0132_spec *spec = codec->spec;
Takashi Iwai27ebeb02012-08-08 17:20:18 +02002786 return snd_hda_multi_out_dig_close(codec, &spec->multiout);
Ian Minett95c6e9c2011-06-15 15:35:17 -07002787}
2788
2789/*
Ian Minett825315b2012-12-20 18:53:36 -08002790 * Analog capture
2791 */
2792static int ca0132_capture_pcm_prepare(struct hda_pcm_stream *hinfo,
2793 struct hda_codec *codec,
2794 unsigned int stream_tag,
2795 unsigned int format,
2796 struct snd_pcm_substream *substream)
2797{
Hsin-Yu Chao13c12db2014-02-19 14:30:35 +08002798 snd_hda_codec_setup_stream(codec, hinfo->nid,
Hsin-Yu Chao28fba952014-02-19 14:27:07 +08002799 stream_tag, 0, format);
Ian Minett825315b2012-12-20 18:53:36 -08002800
2801 return 0;
2802}
2803
2804static int ca0132_capture_pcm_cleanup(struct hda_pcm_stream *hinfo,
2805 struct hda_codec *codec,
2806 struct snd_pcm_substream *substream)
2807{
2808 struct ca0132_spec *spec = codec->spec;
2809
2810 if (spec->dsp_state == DSP_DOWNLOADING)
2811 return 0;
2812
Hsin-Yu Chao28fba952014-02-19 14:27:07 +08002813 snd_hda_codec_cleanup_stream(codec, hinfo->nid);
Ian Minett825315b2012-12-20 18:53:36 -08002814 return 0;
2815}
2816
Dylan Reide8412ca2013-04-04 13:55:09 -07002817static unsigned int ca0132_capture_pcm_delay(struct hda_pcm_stream *info,
2818 struct hda_codec *codec,
2819 struct snd_pcm_substream *substream)
2820{
2821 struct ca0132_spec *spec = codec->spec;
2822 unsigned int latency = DSP_CAPTURE_INIT_LATENCY;
2823 struct snd_pcm_runtime *runtime = substream->runtime;
2824
2825 if (spec->dsp_state != DSP_DOWNLOADED)
2826 return 0;
2827
2828 if (spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID])
2829 latency += DSP_CRYSTAL_VOICE_LATENCY;
2830
2831 return (latency * runtime->rate) / 1000;
2832}
2833
Ian Minette90f29e2012-12-20 18:53:39 -08002834/*
2835 * Controls stuffs.
2836 */
2837
2838/*
2839 * Mixer controls helpers.
2840 */
2841#define CA0132_CODEC_VOL_MONO(xname, nid, channel, dir) \
2842 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2843 .name = xname, \
2844 .subdevice = HDA_SUBDEV_AMP_FLAG, \
2845 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | \
2846 SNDRV_CTL_ELEM_ACCESS_TLV_READ | \
2847 SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK, \
2848 .info = ca0132_volume_info, \
2849 .get = ca0132_volume_get, \
2850 .put = ca0132_volume_put, \
2851 .tlv = { .c = ca0132_volume_tlv }, \
2852 .private_value = HDA_COMPOSE_AMP_VAL(nid, channel, 0, dir) }
2853
2854#define CA0132_CODEC_MUTE_MONO(xname, nid, channel, dir) \
2855 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2856 .name = xname, \
2857 .subdevice = HDA_SUBDEV_AMP_FLAG, \
2858 .info = snd_hda_mixer_amp_switch_info, \
2859 .get = ca0132_switch_get, \
2860 .put = ca0132_switch_put, \
2861 .private_value = HDA_COMPOSE_AMP_VAL(nid, channel, 0, dir) }
2862
2863/* stereo */
2864#define CA0132_CODEC_VOL(xname, nid, dir) \
2865 CA0132_CODEC_VOL_MONO(xname, nid, 3, dir)
2866#define CA0132_CODEC_MUTE(xname, nid, dir) \
2867 CA0132_CODEC_MUTE_MONO(xname, nid, 3, dir)
2868
Masahiro Yamada4091fb92017-02-27 14:29:56 -08002869/* The following are for tuning of products */
Ian Minett44f0c972012-12-20 18:53:38 -08002870#ifdef ENABLE_TUNING_CONTROLS
2871
2872static unsigned int voice_focus_vals_lookup[] = {
28730x41A00000, 0x41A80000, 0x41B00000, 0x41B80000, 0x41C00000, 0x41C80000,
28740x41D00000, 0x41D80000, 0x41E00000, 0x41E80000, 0x41F00000, 0x41F80000,
28750x42000000, 0x42040000, 0x42080000, 0x420C0000, 0x42100000, 0x42140000,
28760x42180000, 0x421C0000, 0x42200000, 0x42240000, 0x42280000, 0x422C0000,
28770x42300000, 0x42340000, 0x42380000, 0x423C0000, 0x42400000, 0x42440000,
28780x42480000, 0x424C0000, 0x42500000, 0x42540000, 0x42580000, 0x425C0000,
28790x42600000, 0x42640000, 0x42680000, 0x426C0000, 0x42700000, 0x42740000,
28800x42780000, 0x427C0000, 0x42800000, 0x42820000, 0x42840000, 0x42860000,
28810x42880000, 0x428A0000, 0x428C0000, 0x428E0000, 0x42900000, 0x42920000,
28820x42940000, 0x42960000, 0x42980000, 0x429A0000, 0x429C0000, 0x429E0000,
28830x42A00000, 0x42A20000, 0x42A40000, 0x42A60000, 0x42A80000, 0x42AA0000,
28840x42AC0000, 0x42AE0000, 0x42B00000, 0x42B20000, 0x42B40000, 0x42B60000,
28850x42B80000, 0x42BA0000, 0x42BC0000, 0x42BE0000, 0x42C00000, 0x42C20000,
28860x42C40000, 0x42C60000, 0x42C80000, 0x42CA0000, 0x42CC0000, 0x42CE0000,
28870x42D00000, 0x42D20000, 0x42D40000, 0x42D60000, 0x42D80000, 0x42DA0000,
28880x42DC0000, 0x42DE0000, 0x42E00000, 0x42E20000, 0x42E40000, 0x42E60000,
28890x42E80000, 0x42EA0000, 0x42EC0000, 0x42EE0000, 0x42F00000, 0x42F20000,
28900x42F40000, 0x42F60000, 0x42F80000, 0x42FA0000, 0x42FC0000, 0x42FE0000,
28910x43000000, 0x43010000, 0x43020000, 0x43030000, 0x43040000, 0x43050000,
28920x43060000, 0x43070000, 0x43080000, 0x43090000, 0x430A0000, 0x430B0000,
28930x430C0000, 0x430D0000, 0x430E0000, 0x430F0000, 0x43100000, 0x43110000,
28940x43120000, 0x43130000, 0x43140000, 0x43150000, 0x43160000, 0x43170000,
28950x43180000, 0x43190000, 0x431A0000, 0x431B0000, 0x431C0000, 0x431D0000,
28960x431E0000, 0x431F0000, 0x43200000, 0x43210000, 0x43220000, 0x43230000,
28970x43240000, 0x43250000, 0x43260000, 0x43270000, 0x43280000, 0x43290000,
28980x432A0000, 0x432B0000, 0x432C0000, 0x432D0000, 0x432E0000, 0x432F0000,
28990x43300000, 0x43310000, 0x43320000, 0x43330000, 0x43340000
2900};
2901
2902static unsigned int mic_svm_vals_lookup[] = {
29030x00000000, 0x3C23D70A, 0x3CA3D70A, 0x3CF5C28F, 0x3D23D70A, 0x3D4CCCCD,
29040x3D75C28F, 0x3D8F5C29, 0x3DA3D70A, 0x3DB851EC, 0x3DCCCCCD, 0x3DE147AE,
29050x3DF5C28F, 0x3E051EB8, 0x3E0F5C29, 0x3E19999A, 0x3E23D70A, 0x3E2E147B,
29060x3E3851EC, 0x3E428F5C, 0x3E4CCCCD, 0x3E570A3D, 0x3E6147AE, 0x3E6B851F,
29070x3E75C28F, 0x3E800000, 0x3E851EB8, 0x3E8A3D71, 0x3E8F5C29, 0x3E947AE1,
29080x3E99999A, 0x3E9EB852, 0x3EA3D70A, 0x3EA8F5C3, 0x3EAE147B, 0x3EB33333,
29090x3EB851EC, 0x3EBD70A4, 0x3EC28F5C, 0x3EC7AE14, 0x3ECCCCCD, 0x3ED1EB85,
29100x3ED70A3D, 0x3EDC28F6, 0x3EE147AE, 0x3EE66666, 0x3EEB851F, 0x3EF0A3D7,
29110x3EF5C28F, 0x3EFAE148, 0x3F000000, 0x3F028F5C, 0x3F051EB8, 0x3F07AE14,
29120x3F0A3D71, 0x3F0CCCCD, 0x3F0F5C29, 0x3F11EB85, 0x3F147AE1, 0x3F170A3D,
29130x3F19999A, 0x3F1C28F6, 0x3F1EB852, 0x3F2147AE, 0x3F23D70A, 0x3F266666,
29140x3F28F5C3, 0x3F2B851F, 0x3F2E147B, 0x3F30A3D7, 0x3F333333, 0x3F35C28F,
29150x3F3851EC, 0x3F3AE148, 0x3F3D70A4, 0x3F400000, 0x3F428F5C, 0x3F451EB8,
29160x3F47AE14, 0x3F4A3D71, 0x3F4CCCCD, 0x3F4F5C29, 0x3F51EB85, 0x3F547AE1,
29170x3F570A3D, 0x3F59999A, 0x3F5C28F6, 0x3F5EB852, 0x3F6147AE, 0x3F63D70A,
29180x3F666666, 0x3F68F5C3, 0x3F6B851F, 0x3F6E147B, 0x3F70A3D7, 0x3F733333,
29190x3F75C28F, 0x3F7851EC, 0x3F7AE148, 0x3F7D70A4, 0x3F800000
2920};
2921
2922static unsigned int equalizer_vals_lookup[] = {
29230xC1C00000, 0xC1B80000, 0xC1B00000, 0xC1A80000, 0xC1A00000, 0xC1980000,
29240xC1900000, 0xC1880000, 0xC1800000, 0xC1700000, 0xC1600000, 0xC1500000,
29250xC1400000, 0xC1300000, 0xC1200000, 0xC1100000, 0xC1000000, 0xC0E00000,
29260xC0C00000, 0xC0A00000, 0xC0800000, 0xC0400000, 0xC0000000, 0xBF800000,
29270x00000000, 0x3F800000, 0x40000000, 0x40400000, 0x40800000, 0x40A00000,
29280x40C00000, 0x40E00000, 0x41000000, 0x41100000, 0x41200000, 0x41300000,
29290x41400000, 0x41500000, 0x41600000, 0x41700000, 0x41800000, 0x41880000,
29300x41900000, 0x41980000, 0x41A00000, 0x41A80000, 0x41B00000, 0x41B80000,
29310x41C00000
2932};
2933
2934static int tuning_ctl_set(struct hda_codec *codec, hda_nid_t nid,
2935 unsigned int *lookup, int idx)
2936{
2937 int i = 0;
2938
2939 for (i = 0; i < TUNING_CTLS_COUNT; i++)
2940 if (nid == ca0132_tuning_ctls[i].nid)
2941 break;
2942
2943 snd_hda_power_up(codec);
2944 dspio_set_param(codec, ca0132_tuning_ctls[i].mid,
2945 ca0132_tuning_ctls[i].req,
2946 &(lookup[idx]), sizeof(unsigned int));
2947 snd_hda_power_down(codec);
2948
2949 return 1;
2950}
2951
2952static int tuning_ctl_get(struct snd_kcontrol *kcontrol,
2953 struct snd_ctl_elem_value *ucontrol)
2954{
2955 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2956 struct ca0132_spec *spec = codec->spec;
2957 hda_nid_t nid = get_amp_nid(kcontrol);
2958 long *valp = ucontrol->value.integer.value;
2959 int idx = nid - TUNING_CTL_START_NID;
2960
2961 *valp = spec->cur_ctl_vals[idx];
2962 return 0;
2963}
2964
2965static int voice_focus_ctl_info(struct snd_kcontrol *kcontrol,
2966 struct snd_ctl_elem_info *uinfo)
2967{
2968 int chs = get_amp_channels(kcontrol);
2969 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
2970 uinfo->count = chs == 3 ? 2 : 1;
2971 uinfo->value.integer.min = 20;
2972 uinfo->value.integer.max = 180;
2973 uinfo->value.integer.step = 1;
2974
2975 return 0;
2976}
2977
2978static int voice_focus_ctl_put(struct snd_kcontrol *kcontrol,
2979 struct snd_ctl_elem_value *ucontrol)
2980{
2981 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2982 struct ca0132_spec *spec = codec->spec;
2983 hda_nid_t nid = get_amp_nid(kcontrol);
2984 long *valp = ucontrol->value.integer.value;
2985 int idx;
2986
2987 idx = nid - TUNING_CTL_START_NID;
2988 /* any change? */
2989 if (spec->cur_ctl_vals[idx] == *valp)
2990 return 0;
2991
2992 spec->cur_ctl_vals[idx] = *valp;
2993
2994 idx = *valp - 20;
2995 tuning_ctl_set(codec, nid, voice_focus_vals_lookup, idx);
2996
2997 return 1;
2998}
2999
3000static int mic_svm_ctl_info(struct snd_kcontrol *kcontrol,
3001 struct snd_ctl_elem_info *uinfo)
3002{
3003 int chs = get_amp_channels(kcontrol);
3004 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
3005 uinfo->count = chs == 3 ? 2 : 1;
3006 uinfo->value.integer.min = 0;
3007 uinfo->value.integer.max = 100;
3008 uinfo->value.integer.step = 1;
3009
3010 return 0;
3011}
3012
3013static int mic_svm_ctl_put(struct snd_kcontrol *kcontrol,
3014 struct snd_ctl_elem_value *ucontrol)
3015{
3016 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3017 struct ca0132_spec *spec = codec->spec;
3018 hda_nid_t nid = get_amp_nid(kcontrol);
3019 long *valp = ucontrol->value.integer.value;
3020 int idx;
3021
3022 idx = nid - TUNING_CTL_START_NID;
3023 /* any change? */
3024 if (spec->cur_ctl_vals[idx] == *valp)
3025 return 0;
3026
3027 spec->cur_ctl_vals[idx] = *valp;
3028
3029 idx = *valp;
3030 tuning_ctl_set(codec, nid, mic_svm_vals_lookup, idx);
3031
3032 return 0;
3033}
3034
3035static int equalizer_ctl_info(struct snd_kcontrol *kcontrol,
3036 struct snd_ctl_elem_info *uinfo)
3037{
3038 int chs = get_amp_channels(kcontrol);
3039 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
3040 uinfo->count = chs == 3 ? 2 : 1;
3041 uinfo->value.integer.min = 0;
3042 uinfo->value.integer.max = 48;
3043 uinfo->value.integer.step = 1;
3044
3045 return 0;
3046}
3047
3048static int equalizer_ctl_put(struct snd_kcontrol *kcontrol,
3049 struct snd_ctl_elem_value *ucontrol)
3050{
3051 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3052 struct ca0132_spec *spec = codec->spec;
3053 hda_nid_t nid = get_amp_nid(kcontrol);
3054 long *valp = ucontrol->value.integer.value;
3055 int idx;
3056
3057 idx = nid - TUNING_CTL_START_NID;
3058 /* any change? */
3059 if (spec->cur_ctl_vals[idx] == *valp)
3060 return 0;
3061
3062 spec->cur_ctl_vals[idx] = *valp;
3063
3064 idx = *valp;
3065 tuning_ctl_set(codec, nid, equalizer_vals_lookup, idx);
3066
3067 return 1;
3068}
3069
3070static const DECLARE_TLV_DB_SCALE(voice_focus_db_scale, 2000, 100, 0);
3071static const DECLARE_TLV_DB_SCALE(eq_db_scale, -2400, 100, 0);
3072
3073static int add_tuning_control(struct hda_codec *codec,
3074 hda_nid_t pnid, hda_nid_t nid,
3075 const char *name, int dir)
3076{
Takashi Iwai975cc022013-06-28 11:56:49 +02003077 char namestr[SNDRV_CTL_ELEM_ID_NAME_MAXLEN];
Ian Minett44f0c972012-12-20 18:53:38 -08003078 int type = dir ? HDA_INPUT : HDA_OUTPUT;
3079 struct snd_kcontrol_new knew =
3080 HDA_CODEC_VOLUME_MONO(namestr, nid, 1, 0, type);
3081
3082 knew.access = SNDRV_CTL_ELEM_ACCESS_READWRITE |
3083 SNDRV_CTL_ELEM_ACCESS_TLV_READ;
3084 knew.tlv.c = 0;
3085 knew.tlv.p = 0;
3086 switch (pnid) {
3087 case VOICE_FOCUS:
3088 knew.info = voice_focus_ctl_info;
3089 knew.get = tuning_ctl_get;
3090 knew.put = voice_focus_ctl_put;
3091 knew.tlv.p = voice_focus_db_scale;
3092 break;
3093 case MIC_SVM:
3094 knew.info = mic_svm_ctl_info;
3095 knew.get = tuning_ctl_get;
3096 knew.put = mic_svm_ctl_put;
3097 break;
3098 case EQUALIZER:
3099 knew.info = equalizer_ctl_info;
3100 knew.get = tuning_ctl_get;
3101 knew.put = equalizer_ctl_put;
3102 knew.tlv.p = eq_db_scale;
3103 break;
3104 default:
3105 return 0;
3106 }
3107 knew.private_value =
3108 HDA_COMPOSE_AMP_VAL(nid, 1, 0, type);
3109 sprintf(namestr, "%s %s Volume", name, dirstr[dir]);
3110 return snd_hda_ctl_add(codec, nid, snd_ctl_new1(&knew, codec));
3111}
3112
3113static int add_tuning_ctls(struct hda_codec *codec)
3114{
3115 int i;
3116 int err;
3117
3118 for (i = 0; i < TUNING_CTLS_COUNT; i++) {
3119 err = add_tuning_control(codec,
3120 ca0132_tuning_ctls[i].parent_nid,
3121 ca0132_tuning_ctls[i].nid,
3122 ca0132_tuning_ctls[i].name,
3123 ca0132_tuning_ctls[i].direct);
3124 if (err < 0)
3125 return err;
3126 }
3127
3128 return 0;
3129}
3130
3131static void ca0132_init_tuning_defaults(struct hda_codec *codec)
3132{
3133 struct ca0132_spec *spec = codec->spec;
3134 int i;
3135
3136 /* Wedge Angle defaults to 30. 10 below is 30 - 20. 20 is min. */
3137 spec->cur_ctl_vals[WEDGE_ANGLE - TUNING_CTL_START_NID] = 10;
3138 /* SVM level defaults to 0.74. */
3139 spec->cur_ctl_vals[SVM_LEVEL - TUNING_CTL_START_NID] = 74;
3140
3141 /* EQ defaults to 0dB. */
3142 for (i = 2; i < TUNING_CTLS_COUNT; i++)
3143 spec->cur_ctl_vals[i] = 24;
3144}
3145#endif /*ENABLE_TUNING_CONTROLS*/
3146
Ian Minett825315b2012-12-20 18:53:36 -08003147/*
Ian Minett5aaca442012-12-20 18:53:34 -08003148 * Select the active output.
3149 * If autodetect is enabled, output will be selected based on jack detection.
3150 * If jack inserted, headphone will be selected, else built-in speakers
3151 * If autodetect is disabled, output will be selected based on selection.
3152 */
3153static int ca0132_select_out(struct hda_codec *codec)
3154{
3155 struct ca0132_spec *spec = codec->spec;
3156 unsigned int pin_ctl;
3157 int jack_present;
3158 int auto_jack;
3159 unsigned int tmp;
3160 int err;
3161
Takashi Iwai4e76a882014-02-25 12:21:03 +01003162 codec_dbg(codec, "ca0132_select_out\n");
Ian Minett5aaca442012-12-20 18:53:34 -08003163
Takashi Iwai664c7152015-04-08 11:43:14 +02003164 snd_hda_power_up_pm(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08003165
3166 auto_jack = spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID];
3167
3168 if (auto_jack)
Takashi Iwaife14f392015-08-10 16:53:32 +02003169 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_hp);
Ian Minett5aaca442012-12-20 18:53:34 -08003170 else
3171 jack_present =
3172 spec->vnode_lswitch[VNID_HP_SEL - VNODE_START_NID];
3173
3174 if (jack_present)
3175 spec->cur_out_type = HEADPHONE_OUT;
3176 else
3177 spec->cur_out_type = SPEAKER_OUT;
3178
3179 if (spec->cur_out_type == SPEAKER_OUT) {
Takashi Iwai4e76a882014-02-25 12:21:03 +01003180 codec_dbg(codec, "ca0132_select_out speaker\n");
Ian Minett5aaca442012-12-20 18:53:34 -08003181 /*speaker out config*/
3182 tmp = FLOAT_ONE;
3183 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp);
3184 if (err < 0)
3185 goto exit;
3186 /*enable speaker EQ*/
3187 tmp = FLOAT_ONE;
3188 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp);
3189 if (err < 0)
3190 goto exit;
3191
3192 /* Setup EAPD */
3193 snd_hda_codec_write(codec, spec->out_pins[1], 0,
3194 VENDOR_CHIPIO_EAPD_SEL_SET, 0x02);
3195 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3196 AC_VERB_SET_EAPD_BTLENABLE, 0x00);
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, 0x02);
3201
3202 /* disable headphone node */
3203 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0,
3204 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
Takashi Iwaia0c041c2013-01-15 17:13:31 +01003205 snd_hda_set_pin_ctl(codec, spec->out_pins[1],
3206 pin_ctl & ~PIN_HP);
Ian Minett5aaca442012-12-20 18:53:34 -08003207 /* enable speaker node */
3208 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0,
3209 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
Takashi Iwaia0c041c2013-01-15 17:13:31 +01003210 snd_hda_set_pin_ctl(codec, spec->out_pins[0],
3211 pin_ctl | PIN_OUT);
Ian Minett5aaca442012-12-20 18:53:34 -08003212 } else {
Takashi Iwai4e76a882014-02-25 12:21:03 +01003213 codec_dbg(codec, "ca0132_select_out hp\n");
Ian Minett5aaca442012-12-20 18:53:34 -08003214 /*headphone out config*/
3215 tmp = FLOAT_ZERO;
3216 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp);
3217 if (err < 0)
3218 goto exit;
3219 /*disable speaker EQ*/
3220 tmp = FLOAT_ZERO;
3221 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp);
3222 if (err < 0)
3223 goto exit;
3224
3225 /* Setup EAPD */
3226 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3227 VENDOR_CHIPIO_EAPD_SEL_SET, 0x00);
3228 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3229 AC_VERB_SET_EAPD_BTLENABLE, 0x00);
3230 snd_hda_codec_write(codec, spec->out_pins[1], 0,
3231 VENDOR_CHIPIO_EAPD_SEL_SET, 0x02);
3232 snd_hda_codec_write(codec, spec->out_pins[0], 0,
3233 AC_VERB_SET_EAPD_BTLENABLE, 0x02);
3234
3235 /* disable speaker*/
3236 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0,
3237 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
Takashi Iwaia0c041c2013-01-15 17:13:31 +01003238 snd_hda_set_pin_ctl(codec, spec->out_pins[0],
3239 pin_ctl & ~PIN_HP);
Ian Minett5aaca442012-12-20 18:53:34 -08003240 /* enable headphone*/
3241 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0,
3242 AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
Takashi Iwaia0c041c2013-01-15 17:13:31 +01003243 snd_hda_set_pin_ctl(codec, spec->out_pins[1],
3244 pin_ctl | PIN_HP);
Ian Minett5aaca442012-12-20 18:53:34 -08003245 }
3246
3247exit:
Takashi Iwai664c7152015-04-08 11:43:14 +02003248 snd_hda_power_down_pm(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08003249
3250 return err < 0 ? err : 0;
3251}
3252
Chih-Chung Chang993884f2013-03-25 10:39:23 -07003253static void ca0132_unsol_hp_delayed(struct work_struct *work)
3254{
3255 struct ca0132_spec *spec = container_of(
3256 to_delayed_work(work), struct ca0132_spec, unsol_hp_work);
Takashi Iwaif8fb1172014-09-11 15:53:26 +02003257 struct hda_jack_tbl *jack;
3258
Chih-Chung Chang993884f2013-03-25 10:39:23 -07003259 ca0132_select_out(spec->codec);
Gabriele Martinod5c016b2015-05-18 21:15:13 +02003260 jack = snd_hda_jack_tbl_get(spec->codec, spec->unsol_tag_hp);
Takashi Iwaif8fb1172014-09-11 15:53:26 +02003261 if (jack) {
3262 jack->block_report = 0;
3263 snd_hda_jack_report_sync(spec->codec);
3264 }
Chih-Chung Chang993884f2013-03-25 10:39:23 -07003265}
3266
Ian Minett5aaca442012-12-20 18:53:34 -08003267static void ca0132_set_dmic(struct hda_codec *codec, int enable);
3268static int ca0132_mic_boost_set(struct hda_codec *codec, long val);
3269static int ca0132_effects_set(struct hda_codec *codec, hda_nid_t nid, long val);
3270
3271/*
3272 * Select the active VIP source
3273 */
3274static int ca0132_set_vipsource(struct hda_codec *codec, int val)
3275{
3276 struct ca0132_spec *spec = codec->spec;
3277 unsigned int tmp;
3278
Dylan Reide8f1bd52013-03-14 17:27:45 -07003279 if (spec->dsp_state != DSP_DOWNLOADED)
Ian Minett5aaca442012-12-20 18:53:34 -08003280 return 0;
3281
3282 /* if CrystalVoice if off, vipsource should be 0 */
3283 if (!spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] ||
3284 (val == 0)) {
3285 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, 0);
3286 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000);
3287 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000);
3288 if (spec->cur_mic_type == DIGITAL_MIC)
3289 tmp = FLOAT_TWO;
3290 else
3291 tmp = FLOAT_ONE;
3292 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
3293 tmp = FLOAT_ZERO;
3294 dspio_set_uint_param(codec, 0x80, 0x05, tmp);
3295 } else {
3296 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_16_000);
3297 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_16_000);
3298 if (spec->cur_mic_type == DIGITAL_MIC)
3299 tmp = FLOAT_TWO;
3300 else
3301 tmp = FLOAT_ONE;
3302 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
3303 tmp = FLOAT_ONE;
3304 dspio_set_uint_param(codec, 0x80, 0x05, tmp);
3305 msleep(20);
3306 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, val);
3307 }
3308
3309 return 1;
3310}
3311
3312/*
3313 * Select the active microphone.
3314 * If autodetect is enabled, mic will be selected based on jack detection.
3315 * If jack inserted, ext.mic will be selected, else built-in mic
3316 * If autodetect is disabled, mic will be selected based on selection.
3317 */
3318static int ca0132_select_mic(struct hda_codec *codec)
3319{
3320 struct ca0132_spec *spec = codec->spec;
3321 int jack_present;
3322 int auto_jack;
3323
Takashi Iwai4e76a882014-02-25 12:21:03 +01003324 codec_dbg(codec, "ca0132_select_mic\n");
Ian Minett5aaca442012-12-20 18:53:34 -08003325
Takashi Iwai664c7152015-04-08 11:43:14 +02003326 snd_hda_power_up_pm(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08003327
3328 auto_jack = spec->vnode_lswitch[VNID_AMIC1_ASEL - VNODE_START_NID];
3329
3330 if (auto_jack)
Takashi Iwaife14f392015-08-10 16:53:32 +02003331 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_amic1);
Ian Minett5aaca442012-12-20 18:53:34 -08003332 else
3333 jack_present =
3334 spec->vnode_lswitch[VNID_AMIC1_SEL - VNODE_START_NID];
3335
3336 if (jack_present)
3337 spec->cur_mic_type = LINE_MIC_IN;
3338 else
3339 spec->cur_mic_type = DIGITAL_MIC;
3340
3341 if (spec->cur_mic_type == DIGITAL_MIC) {
3342 /* enable digital Mic */
3343 chipio_set_conn_rate(codec, MEM_CONNID_DMIC, SR_32_000);
3344 ca0132_set_dmic(codec, 1);
3345 ca0132_mic_boost_set(codec, 0);
3346 /* set voice focus */
3347 ca0132_effects_set(codec, VOICE_FOCUS,
3348 spec->effects_switch
3349 [VOICE_FOCUS - EFFECT_START_NID]);
3350 } else {
3351 /* disable digital Mic */
3352 chipio_set_conn_rate(codec, MEM_CONNID_DMIC, SR_96_000);
3353 ca0132_set_dmic(codec, 0);
3354 ca0132_mic_boost_set(codec, spec->cur_mic_boost);
3355 /* disable voice focus */
3356 ca0132_effects_set(codec, VOICE_FOCUS, 0);
3357 }
3358
Takashi Iwai664c7152015-04-08 11:43:14 +02003359 snd_hda_power_down_pm(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08003360
3361 return 0;
3362}
3363
3364/*
Ian Minetta7e76272012-12-20 18:53:35 -08003365 * Check if VNODE settings take effect immediately.
3366 */
3367static bool ca0132_is_vnode_effective(struct hda_codec *codec,
3368 hda_nid_t vnid,
3369 hda_nid_t *shared_nid)
3370{
3371 struct ca0132_spec *spec = codec->spec;
3372 hda_nid_t nid;
Ian Minetta7e76272012-12-20 18:53:35 -08003373
3374 switch (vnid) {
3375 case VNID_SPK:
3376 nid = spec->shared_out_nid;
Ian Minetta7e76272012-12-20 18:53:35 -08003377 break;
3378 case VNID_MIC:
3379 nid = spec->shared_mic_nid;
Ian Minetta7e76272012-12-20 18:53:35 -08003380 break;
3381 default:
Takashi Iwai9a0869f2013-02-07 12:41:40 +01003382 return false;
Ian Minetta7e76272012-12-20 18:53:35 -08003383 }
3384
Takashi Iwai9a0869f2013-02-07 12:41:40 +01003385 if (shared_nid)
Ian Minetta7e76272012-12-20 18:53:35 -08003386 *shared_nid = nid;
3387
Takashi Iwai9a0869f2013-02-07 12:41:40 +01003388 return true;
Ian Minetta7e76272012-12-20 18:53:35 -08003389}
3390
3391/*
3392* The following functions are control change helpers.
3393* They return 0 if no changed. Return 1 if changed.
3394*/
3395static int ca0132_voicefx_set(struct hda_codec *codec, int enable)
3396{
3397 struct ca0132_spec *spec = codec->spec;
3398 unsigned int tmp;
3399
3400 /* based on CrystalVoice state to enable VoiceFX. */
3401 if (enable) {
3402 tmp = spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] ?
3403 FLOAT_ONE : FLOAT_ZERO;
3404 } else {
3405 tmp = FLOAT_ZERO;
3406 }
3407
3408 dspio_set_uint_param(codec, ca0132_voicefx.mid,
3409 ca0132_voicefx.reqs[0], tmp);
3410
3411 return 1;
3412}
3413
3414/*
Ian Minett5aaca442012-12-20 18:53:34 -08003415 * Set the effects parameters
3416 */
3417static int ca0132_effects_set(struct hda_codec *codec, hda_nid_t nid, long val)
3418{
3419 struct ca0132_spec *spec = codec->spec;
3420 unsigned int on;
3421 int num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT;
3422 int err = 0;
3423 int idx = nid - EFFECT_START_NID;
3424
3425 if ((idx < 0) || (idx >= num_fx))
3426 return 0; /* no changed */
3427
3428 /* for out effect, qualify with PE */
3429 if ((nid >= OUT_EFFECT_START_NID) && (nid < OUT_EFFECT_END_NID)) {
3430 /* if PE if off, turn off out effects. */
3431 if (!spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID])
3432 val = 0;
3433 }
3434
3435 /* for in effect, qualify with CrystalVoice */
3436 if ((nid >= IN_EFFECT_START_NID) && (nid < IN_EFFECT_END_NID)) {
3437 /* if CrystalVoice if off, turn off in effects. */
3438 if (!spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID])
3439 val = 0;
3440
3441 /* Voice Focus applies to 2-ch Mic, Digital Mic */
3442 if ((nid == VOICE_FOCUS) && (spec->cur_mic_type != DIGITAL_MIC))
3443 val = 0;
3444 }
3445
Takashi Iwai4e76a882014-02-25 12:21:03 +01003446 codec_dbg(codec, "ca0132_effect_set: nid=0x%x, val=%ld\n",
Ian Minett5aaca442012-12-20 18:53:34 -08003447 nid, val);
3448
3449 on = (val == 0) ? FLOAT_ZERO : FLOAT_ONE;
3450 err = dspio_set_uint_param(codec, ca0132_effects[idx].mid,
3451 ca0132_effects[idx].reqs[0], on);
3452
3453 if (err < 0)
3454 return 0; /* no changed */
3455
3456 return 1;
3457}
3458
Ian Minetta7e76272012-12-20 18:53:35 -08003459/*
3460 * Turn on/off Playback Enhancements
3461 */
3462static int ca0132_pe_switch_set(struct hda_codec *codec)
3463{
3464 struct ca0132_spec *spec = codec->spec;
3465 hda_nid_t nid;
3466 int i, ret = 0;
3467
Takashi Iwai4e76a882014-02-25 12:21:03 +01003468 codec_dbg(codec, "ca0132_pe_switch_set: val=%ld\n",
Ian Minetta7e76272012-12-20 18:53:35 -08003469 spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]);
3470
3471 i = OUT_EFFECT_START_NID - EFFECT_START_NID;
3472 nid = OUT_EFFECT_START_NID;
3473 /* PE affects all out effects */
3474 for (; nid < OUT_EFFECT_END_NID; nid++, i++)
3475 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]);
3476
3477 return ret;
3478}
3479
Ian Minett5aaca442012-12-20 18:53:34 -08003480/* Check if Mic1 is streaming, if so, stop streaming */
3481static int stop_mic1(struct hda_codec *codec)
3482{
3483 struct ca0132_spec *spec = codec->spec;
3484 unsigned int oldval = snd_hda_codec_read(codec, spec->adcs[0], 0,
3485 AC_VERB_GET_CONV, 0);
3486 if (oldval != 0)
3487 snd_hda_codec_write(codec, spec->adcs[0], 0,
3488 AC_VERB_SET_CHANNEL_STREAMID,
3489 0);
3490 return oldval;
3491}
3492
3493/* Resume Mic1 streaming if it was stopped. */
3494static void resume_mic1(struct hda_codec *codec, unsigned int oldval)
3495{
3496 struct ca0132_spec *spec = codec->spec;
3497 /* Restore the previous stream and channel */
3498 if (oldval != 0)
3499 snd_hda_codec_write(codec, spec->adcs[0], 0,
3500 AC_VERB_SET_CHANNEL_STREAMID,
3501 oldval);
3502}
3503
3504/*
Ian Minetta7e76272012-12-20 18:53:35 -08003505 * Turn on/off CrystalVoice
Ian Minett5aaca442012-12-20 18:53:34 -08003506 */
Ian Minetta7e76272012-12-20 18:53:35 -08003507static int ca0132_cvoice_switch_set(struct hda_codec *codec)
3508{
3509 struct ca0132_spec *spec = codec->spec;
3510 hda_nid_t nid;
3511 int i, ret = 0;
3512 unsigned int oldval;
3513
Takashi Iwai4e76a882014-02-25 12:21:03 +01003514 codec_dbg(codec, "ca0132_cvoice_switch_set: val=%ld\n",
Ian Minetta7e76272012-12-20 18:53:35 -08003515 spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID]);
3516
3517 i = IN_EFFECT_START_NID - EFFECT_START_NID;
3518 nid = IN_EFFECT_START_NID;
3519 /* CrystalVoice affects all in effects */
3520 for (; nid < IN_EFFECT_END_NID; nid++, i++)
3521 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]);
3522
3523 /* including VoiceFX */
3524 ret |= ca0132_voicefx_set(codec, (spec->voicefx_val ? 1 : 0));
3525
3526 /* set correct vipsource */
3527 oldval = stop_mic1(codec);
3528 ret |= ca0132_set_vipsource(codec, 1);
3529 resume_mic1(codec, oldval);
3530 return ret;
3531}
3532
Ian Minett5aaca442012-12-20 18:53:34 -08003533static int ca0132_mic_boost_set(struct hda_codec *codec, long val)
3534{
3535 struct ca0132_spec *spec = codec->spec;
3536 int ret = 0;
3537
3538 if (val) /* on */
3539 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0,
3540 HDA_INPUT, 0, HDA_AMP_VOLMASK, 3);
3541 else /* off */
3542 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0,
3543 HDA_INPUT, 0, HDA_AMP_VOLMASK, 0);
3544
3545 return ret;
3546}
3547
Ian Minetta7e76272012-12-20 18:53:35 -08003548static int ca0132_vnode_switch_set(struct snd_kcontrol *kcontrol,
3549 struct snd_ctl_elem_value *ucontrol)
3550{
3551 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3552 hda_nid_t nid = get_amp_nid(kcontrol);
3553 hda_nid_t shared_nid = 0;
3554 bool effective;
3555 int ret = 0;
3556 struct ca0132_spec *spec = codec->spec;
3557 int auto_jack;
3558
3559 if (nid == VNID_HP_SEL) {
3560 auto_jack =
3561 spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID];
3562 if (!auto_jack)
3563 ca0132_select_out(codec);
3564 return 1;
3565 }
3566
3567 if (nid == VNID_AMIC1_SEL) {
3568 auto_jack =
3569 spec->vnode_lswitch[VNID_AMIC1_ASEL - VNODE_START_NID];
3570 if (!auto_jack)
3571 ca0132_select_mic(codec);
3572 return 1;
3573 }
3574
3575 if (nid == VNID_HP_ASEL) {
3576 ca0132_select_out(codec);
3577 return 1;
3578 }
3579
3580 if (nid == VNID_AMIC1_ASEL) {
3581 ca0132_select_mic(codec);
3582 return 1;
3583 }
3584
3585 /* if effective conditions, then update hw immediately. */
3586 effective = ca0132_is_vnode_effective(codec, nid, &shared_nid);
3587 if (effective) {
3588 int dir = get_amp_direction(kcontrol);
3589 int ch = get_amp_channels(kcontrol);
3590 unsigned long pval;
3591
3592 mutex_lock(&codec->control_mutex);
3593 pval = kcontrol->private_value;
3594 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(shared_nid, ch,
3595 0, dir);
3596 ret = snd_hda_mixer_amp_switch_put(kcontrol, ucontrol);
3597 kcontrol->private_value = pval;
3598 mutex_unlock(&codec->control_mutex);
3599 }
3600
3601 return ret;
3602}
3603/* End of control change helpers. */
3604
3605static int ca0132_voicefx_info(struct snd_kcontrol *kcontrol,
3606 struct snd_ctl_elem_info *uinfo)
3607{
3608 unsigned int items = sizeof(ca0132_voicefx_presets)
3609 / sizeof(struct ct_voicefx_preset);
3610
3611 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
3612 uinfo->count = 1;
3613 uinfo->value.enumerated.items = items;
3614 if (uinfo->value.enumerated.item >= items)
3615 uinfo->value.enumerated.item = items - 1;
3616 strcpy(uinfo->value.enumerated.name,
3617 ca0132_voicefx_presets[uinfo->value.enumerated.item].name);
3618 return 0;
3619}
3620
3621static int ca0132_voicefx_get(struct snd_kcontrol *kcontrol,
3622 struct snd_ctl_elem_value *ucontrol)
3623{
3624 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3625 struct ca0132_spec *spec = codec->spec;
3626
3627 ucontrol->value.enumerated.item[0] = spec->voicefx_val;
3628 return 0;
3629}
3630
3631static int ca0132_voicefx_put(struct snd_kcontrol *kcontrol,
3632 struct snd_ctl_elem_value *ucontrol)
3633{
3634 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3635 struct ca0132_spec *spec = codec->spec;
3636 int i, err = 0;
3637 int sel = ucontrol->value.enumerated.item[0];
3638 unsigned int items = sizeof(ca0132_voicefx_presets)
3639 / sizeof(struct ct_voicefx_preset);
3640
3641 if (sel >= items)
3642 return 0;
3643
Takashi Iwai4e76a882014-02-25 12:21:03 +01003644 codec_dbg(codec, "ca0132_voicefx_put: sel=%d, preset=%s\n",
Ian Minetta7e76272012-12-20 18:53:35 -08003645 sel, ca0132_voicefx_presets[sel].name);
3646
3647 /*
3648 * Idx 0 is default.
3649 * Default needs to qualify with CrystalVoice state.
3650 */
3651 for (i = 0; i < VOICEFX_MAX_PARAM_COUNT; i++) {
3652 err = dspio_set_uint_param(codec, ca0132_voicefx.mid,
3653 ca0132_voicefx.reqs[i],
3654 ca0132_voicefx_presets[sel].vals[i]);
3655 if (err < 0)
3656 break;
3657 }
3658
3659 if (err >= 0) {
3660 spec->voicefx_val = sel;
3661 /* enable voice fx */
3662 ca0132_voicefx_set(codec, (sel ? 1 : 0));
3663 }
3664
3665 return 1;
3666}
3667
3668static int ca0132_switch_get(struct snd_kcontrol *kcontrol,
3669 struct snd_ctl_elem_value *ucontrol)
3670{
3671 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3672 struct ca0132_spec *spec = codec->spec;
3673 hda_nid_t nid = get_amp_nid(kcontrol);
3674 int ch = get_amp_channels(kcontrol);
3675 long *valp = ucontrol->value.integer.value;
3676
3677 /* vnode */
3678 if ((nid >= VNODE_START_NID) && (nid < VNODE_END_NID)) {
3679 if (ch & 1) {
3680 *valp = spec->vnode_lswitch[nid - VNODE_START_NID];
3681 valp++;
3682 }
3683 if (ch & 2) {
3684 *valp = spec->vnode_rswitch[nid - VNODE_START_NID];
3685 valp++;
3686 }
3687 return 0;
3688 }
3689
3690 /* effects, include PE and CrystalVoice */
3691 if ((nid >= EFFECT_START_NID) && (nid < EFFECT_END_NID)) {
3692 *valp = spec->effects_switch[nid - EFFECT_START_NID];
3693 return 0;
3694 }
3695
3696 /* mic boost */
3697 if (nid == spec->input_pins[0]) {
3698 *valp = spec->cur_mic_boost;
3699 return 0;
3700 }
3701
3702 return 0;
3703}
3704
3705static int ca0132_switch_put(struct snd_kcontrol *kcontrol,
3706 struct snd_ctl_elem_value *ucontrol)
3707{
3708 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3709 struct ca0132_spec *spec = codec->spec;
3710 hda_nid_t nid = get_amp_nid(kcontrol);
3711 int ch = get_amp_channels(kcontrol);
3712 long *valp = ucontrol->value.integer.value;
3713 int changed = 1;
3714
Takashi Iwai4e76a882014-02-25 12:21:03 +01003715 codec_dbg(codec, "ca0132_switch_put: nid=0x%x, val=%ld\n",
Ian Minetta7e76272012-12-20 18:53:35 -08003716 nid, *valp);
3717
3718 snd_hda_power_up(codec);
3719 /* vnode */
3720 if ((nid >= VNODE_START_NID) && (nid < VNODE_END_NID)) {
3721 if (ch & 1) {
3722 spec->vnode_lswitch[nid - VNODE_START_NID] = *valp;
3723 valp++;
3724 }
3725 if (ch & 2) {
3726 spec->vnode_rswitch[nid - VNODE_START_NID] = *valp;
3727 valp++;
3728 }
3729 changed = ca0132_vnode_switch_set(kcontrol, ucontrol);
3730 goto exit;
3731 }
3732
3733 /* PE */
3734 if (nid == PLAY_ENHANCEMENT) {
3735 spec->effects_switch[nid - EFFECT_START_NID] = *valp;
3736 changed = ca0132_pe_switch_set(codec);
3737 goto exit;
3738 }
3739
3740 /* CrystalVoice */
3741 if (nid == CRYSTAL_VOICE) {
3742 spec->effects_switch[nid - EFFECT_START_NID] = *valp;
3743 changed = ca0132_cvoice_switch_set(codec);
3744 goto exit;
3745 }
3746
3747 /* out and in effects */
3748 if (((nid >= OUT_EFFECT_START_NID) && (nid < OUT_EFFECT_END_NID)) ||
3749 ((nid >= IN_EFFECT_START_NID) && (nid < IN_EFFECT_END_NID))) {
3750 spec->effects_switch[nid - EFFECT_START_NID] = *valp;
3751 changed = ca0132_effects_set(codec, nid, *valp);
3752 goto exit;
3753 }
3754
3755 /* mic boost */
3756 if (nid == spec->input_pins[0]) {
3757 spec->cur_mic_boost = *valp;
3758
3759 /* Mic boost does not apply to Digital Mic */
3760 if (spec->cur_mic_type != DIGITAL_MIC)
3761 changed = ca0132_mic_boost_set(codec, *valp);
3762 goto exit;
3763 }
3764
3765exit:
3766 snd_hda_power_down(codec);
3767 return changed;
3768}
3769
3770/*
3771 * Volume related
3772 */
3773static int ca0132_volume_info(struct snd_kcontrol *kcontrol,
3774 struct snd_ctl_elem_info *uinfo)
3775{
3776 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3777 struct ca0132_spec *spec = codec->spec;
3778 hda_nid_t nid = get_amp_nid(kcontrol);
3779 int ch = get_amp_channels(kcontrol);
3780 int dir = get_amp_direction(kcontrol);
3781 unsigned long pval;
3782 int err;
3783
3784 switch (nid) {
3785 case VNID_SPK:
3786 /* follow shared_out info */
3787 nid = spec->shared_out_nid;
3788 mutex_lock(&codec->control_mutex);
3789 pval = kcontrol->private_value;
3790 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir);
3791 err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo);
3792 kcontrol->private_value = pval;
3793 mutex_unlock(&codec->control_mutex);
3794 break;
3795 case VNID_MIC:
3796 /* follow shared_mic info */
3797 nid = spec->shared_mic_nid;
3798 mutex_lock(&codec->control_mutex);
3799 pval = kcontrol->private_value;
3800 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir);
3801 err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo);
3802 kcontrol->private_value = pval;
3803 mutex_unlock(&codec->control_mutex);
3804 break;
3805 default:
3806 err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo);
3807 }
3808 return err;
3809}
3810
3811static int ca0132_volume_get(struct snd_kcontrol *kcontrol,
3812 struct snd_ctl_elem_value *ucontrol)
3813{
3814 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3815 struct ca0132_spec *spec = codec->spec;
3816 hda_nid_t nid = get_amp_nid(kcontrol);
3817 int ch = get_amp_channels(kcontrol);
3818 long *valp = ucontrol->value.integer.value;
3819
3820 /* store the left and right volume */
3821 if (ch & 1) {
3822 *valp = spec->vnode_lvol[nid - VNODE_START_NID];
3823 valp++;
3824 }
3825 if (ch & 2) {
3826 *valp = spec->vnode_rvol[nid - VNODE_START_NID];
3827 valp++;
3828 }
3829 return 0;
3830}
3831
3832static int ca0132_volume_put(struct snd_kcontrol *kcontrol,
3833 struct snd_ctl_elem_value *ucontrol)
3834{
3835 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3836 struct ca0132_spec *spec = codec->spec;
3837 hda_nid_t nid = get_amp_nid(kcontrol);
3838 int ch = get_amp_channels(kcontrol);
3839 long *valp = ucontrol->value.integer.value;
3840 hda_nid_t shared_nid = 0;
3841 bool effective;
3842 int changed = 1;
3843
3844 /* store the left and right volume */
3845 if (ch & 1) {
3846 spec->vnode_lvol[nid - VNODE_START_NID] = *valp;
3847 valp++;
3848 }
3849 if (ch & 2) {
3850 spec->vnode_rvol[nid - VNODE_START_NID] = *valp;
3851 valp++;
3852 }
3853
3854 /* if effective conditions, then update hw immediately. */
3855 effective = ca0132_is_vnode_effective(codec, nid, &shared_nid);
3856 if (effective) {
3857 int dir = get_amp_direction(kcontrol);
3858 unsigned long pval;
3859
3860 snd_hda_power_up(codec);
3861 mutex_lock(&codec->control_mutex);
3862 pval = kcontrol->private_value;
3863 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(shared_nid, ch,
3864 0, dir);
3865 changed = snd_hda_mixer_amp_volume_put(kcontrol, ucontrol);
3866 kcontrol->private_value = pval;
3867 mutex_unlock(&codec->control_mutex);
3868 snd_hda_power_down(codec);
3869 }
3870
3871 return changed;
3872}
3873
3874static int ca0132_volume_tlv(struct snd_kcontrol *kcontrol, int op_flag,
3875 unsigned int size, unsigned int __user *tlv)
3876{
3877 struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3878 struct ca0132_spec *spec = codec->spec;
3879 hda_nid_t nid = get_amp_nid(kcontrol);
3880 int ch = get_amp_channels(kcontrol);
3881 int dir = get_amp_direction(kcontrol);
3882 unsigned long pval;
3883 int err;
3884
3885 switch (nid) {
3886 case VNID_SPK:
3887 /* follow shared_out tlv */
3888 nid = spec->shared_out_nid;
3889 mutex_lock(&codec->control_mutex);
3890 pval = kcontrol->private_value;
3891 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir);
3892 err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv);
3893 kcontrol->private_value = pval;
3894 mutex_unlock(&codec->control_mutex);
3895 break;
3896 case VNID_MIC:
3897 /* follow shared_mic tlv */
3898 nid = spec->shared_mic_nid;
3899 mutex_lock(&codec->control_mutex);
3900 pval = kcontrol->private_value;
3901 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir);
3902 err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv);
3903 kcontrol->private_value = pval;
3904 mutex_unlock(&codec->control_mutex);
3905 break;
3906 default:
3907 err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv);
3908 }
3909 return err;
3910}
3911
3912static int add_fx_switch(struct hda_codec *codec, hda_nid_t nid,
3913 const char *pfx, int dir)
3914{
Takashi Iwai975cc022013-06-28 11:56:49 +02003915 char namestr[SNDRV_CTL_ELEM_ID_NAME_MAXLEN];
Ian Minetta7e76272012-12-20 18:53:35 -08003916 int type = dir ? HDA_INPUT : HDA_OUTPUT;
3917 struct snd_kcontrol_new knew =
3918 CA0132_CODEC_MUTE_MONO(namestr, nid, 1, type);
3919 sprintf(namestr, "%s %s Switch", pfx, dirstr[dir]);
3920 return snd_hda_ctl_add(codec, nid, snd_ctl_new1(&knew, codec));
3921}
3922
3923static int add_voicefx(struct hda_codec *codec)
3924{
3925 struct snd_kcontrol_new knew =
3926 HDA_CODEC_MUTE_MONO(ca0132_voicefx.name,
3927 VOICEFX, 1, 0, HDA_INPUT);
3928 knew.info = ca0132_voicefx_info;
3929 knew.get = ca0132_voicefx_get;
3930 knew.put = ca0132_voicefx_put;
3931 return snd_hda_ctl_add(codec, VOICEFX, snd_ctl_new1(&knew, codec));
3932}
3933
3934/*
3935 * When changing Node IDs for Mixer Controls below, make sure to update
3936 * Node IDs in ca0132_config() as well.
3937 */
3938static struct snd_kcontrol_new ca0132_mixer[] = {
3939 CA0132_CODEC_VOL("Master Playback Volume", VNID_SPK, HDA_OUTPUT),
3940 CA0132_CODEC_MUTE("Master Playback Switch", VNID_SPK, HDA_OUTPUT),
3941 CA0132_CODEC_VOL("Capture Volume", VNID_MIC, HDA_INPUT),
3942 CA0132_CODEC_MUTE("Capture Switch", VNID_MIC, HDA_INPUT),
3943 HDA_CODEC_VOLUME("Analog-Mic2 Capture Volume", 0x08, 0, HDA_INPUT),
3944 HDA_CODEC_MUTE("Analog-Mic2 Capture Switch", 0x08, 0, HDA_INPUT),
3945 HDA_CODEC_VOLUME("What U Hear Capture Volume", 0x0a, 0, HDA_INPUT),
3946 HDA_CODEC_MUTE("What U Hear Capture Switch", 0x0a, 0, HDA_INPUT),
3947 CA0132_CODEC_MUTE_MONO("Mic1-Boost (30dB) Capture Switch",
3948 0x12, 1, HDA_INPUT),
3949 CA0132_CODEC_MUTE_MONO("HP/Speaker Playback Switch",
3950 VNID_HP_SEL, 1, HDA_OUTPUT),
3951 CA0132_CODEC_MUTE_MONO("AMic1/DMic Capture Switch",
3952 VNID_AMIC1_SEL, 1, HDA_INPUT),
3953 CA0132_CODEC_MUTE_MONO("HP/Speaker Auto Detect Playback Switch",
3954 VNID_HP_ASEL, 1, HDA_OUTPUT),
3955 CA0132_CODEC_MUTE_MONO("AMic1/DMic Auto Detect Capture Switch",
3956 VNID_AMIC1_ASEL, 1, HDA_INPUT),
3957 { } /* end */
3958};
3959
Ian Minette90f29e2012-12-20 18:53:39 -08003960static int ca0132_build_controls(struct hda_codec *codec)
3961{
3962 struct ca0132_spec *spec = codec->spec;
3963 int i, num_fx;
3964 int err = 0;
3965
3966 /* Add Mixer controls */
3967 for (i = 0; i < spec->num_mixers; i++) {
3968 err = snd_hda_add_new_ctls(codec, spec->mixers[i]);
3969 if (err < 0)
3970 return err;
3971 }
3972
3973 /* Add in and out effects controls.
3974 * VoiceFX, PE and CrystalVoice are added separately.
3975 */
3976 num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT;
3977 for (i = 0; i < num_fx; i++) {
3978 err = add_fx_switch(codec, ca0132_effects[i].nid,
3979 ca0132_effects[i].name,
3980 ca0132_effects[i].direct);
3981 if (err < 0)
3982 return err;
3983 }
3984
3985 err = add_fx_switch(codec, PLAY_ENHANCEMENT, "PlayEnhancement", 0);
3986 if (err < 0)
3987 return err;
3988
3989 err = add_fx_switch(codec, CRYSTAL_VOICE, "CrystalVoice", 1);
3990 if (err < 0)
3991 return err;
3992
3993 add_voicefx(codec);
3994
3995#ifdef ENABLE_TUNING_CONTROLS
3996 add_tuning_ctls(codec);
3997#endif
3998
3999 err = snd_hda_jack_add_kctls(codec, &spec->autocfg);
4000 if (err < 0)
4001 return err;
4002
4003 if (spec->dig_out) {
4004 err = snd_hda_create_spdif_out_ctls(codec, spec->dig_out,
4005 spec->dig_out);
4006 if (err < 0)
4007 return err;
4008 err = snd_hda_create_spdif_share_sw(codec, &spec->multiout);
4009 if (err < 0)
4010 return err;
4011 /* spec->multiout.share_spdif = 1; */
4012 }
4013
4014 if (spec->dig_in) {
4015 err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in);
4016 if (err < 0)
4017 return err;
4018 }
4019 return 0;
4020}
4021
Ian Minett5aaca442012-12-20 18:53:34 -08004022/*
Ian Minette90f29e2012-12-20 18:53:39 -08004023 * PCM
Ian Minett95c6e9c2011-06-15 15:35:17 -07004024 */
Julia Lawall071f1342016-09-11 15:05:43 +02004025static const struct hda_pcm_stream ca0132_pcm_analog_playback = {
Ian Minett95c6e9c2011-06-15 15:35:17 -07004026 .substreams = 1,
4027 .channels_min = 2,
Ian Minett825315b2012-12-20 18:53:36 -08004028 .channels_max = 6,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004029 .ops = {
4030 .prepare = ca0132_playback_pcm_prepare,
Dylan Reide8412ca2013-04-04 13:55:09 -07004031 .cleanup = ca0132_playback_pcm_cleanup,
4032 .get_delay = ca0132_playback_pcm_delay,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004033 },
4034};
4035
Julia Lawall071f1342016-09-11 15:05:43 +02004036static const struct hda_pcm_stream ca0132_pcm_analog_capture = {
Ian Minett95c6e9c2011-06-15 15:35:17 -07004037 .substreams = 1,
4038 .channels_min = 2,
4039 .channels_max = 2,
Ian Minett825315b2012-12-20 18:53:36 -08004040 .ops = {
4041 .prepare = ca0132_capture_pcm_prepare,
Dylan Reide8412ca2013-04-04 13:55:09 -07004042 .cleanup = ca0132_capture_pcm_cleanup,
4043 .get_delay = ca0132_capture_pcm_delay,
Ian Minett825315b2012-12-20 18:53:36 -08004044 },
Ian Minett95c6e9c2011-06-15 15:35:17 -07004045};
4046
Julia Lawall071f1342016-09-11 15:05:43 +02004047static const struct hda_pcm_stream ca0132_pcm_digital_playback = {
Ian Minett95c6e9c2011-06-15 15:35:17 -07004048 .substreams = 1,
4049 .channels_min = 2,
4050 .channels_max = 2,
4051 .ops = {
Takashi Iwai27ebeb02012-08-08 17:20:18 +02004052 .open = ca0132_dig_playback_pcm_open,
4053 .close = ca0132_dig_playback_pcm_close,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004054 .prepare = ca0132_dig_playback_pcm_prepare,
4055 .cleanup = ca0132_dig_playback_pcm_cleanup
4056 },
4057};
4058
Julia Lawall071f1342016-09-11 15:05:43 +02004059static const struct hda_pcm_stream ca0132_pcm_digital_capture = {
Ian Minett95c6e9c2011-06-15 15:35:17 -07004060 .substreams = 1,
4061 .channels_min = 2,
4062 .channels_max = 2,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004063};
4064
4065static int ca0132_build_pcms(struct hda_codec *codec)
4066{
4067 struct ca0132_spec *spec = codec->spec;
Takashi Iwaibbbc7e82015-02-27 17:43:19 +01004068 struct hda_pcm *info;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004069
Takashi Iwaibbbc7e82015-02-27 17:43:19 +01004070 info = snd_hda_codec_pcm_new(codec, "CA0132 Analog");
4071 if (!info)
4072 return -ENOMEM;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004073 info->stream[SNDRV_PCM_STREAM_PLAYBACK] = ca0132_pcm_analog_playback;
4074 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dacs[0];
4075 info->stream[SNDRV_PCM_STREAM_PLAYBACK].channels_max =
4076 spec->multiout.max_channels;
4077 info->stream[SNDRV_PCM_STREAM_CAPTURE] = ca0132_pcm_analog_capture;
Ian Minett825315b2012-12-20 18:53:36 -08004078 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004079 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[0];
Ian Minett95c6e9c2011-06-15 15:35:17 -07004080
Takashi Iwaibbbc7e82015-02-27 17:43:19 +01004081 info = snd_hda_codec_pcm_new(codec, "CA0132 Analog Mic-In2");
4082 if (!info)
4083 return -ENOMEM;
Ian Minett825315b2012-12-20 18:53:36 -08004084 info->stream[SNDRV_PCM_STREAM_CAPTURE] = ca0132_pcm_analog_capture;
4085 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1;
4086 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[1];
Ian Minett825315b2012-12-20 18:53:36 -08004087
Takashi Iwaibbbc7e82015-02-27 17:43:19 +01004088 info = snd_hda_codec_pcm_new(codec, "CA0132 What U Hear");
4089 if (!info)
4090 return -ENOMEM;
Ian Minett825315b2012-12-20 18:53:36 -08004091 info->stream[SNDRV_PCM_STREAM_CAPTURE] = ca0132_pcm_analog_capture;
4092 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1;
4093 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[2];
Ian Minett825315b2012-12-20 18:53:36 -08004094
Ian Minett95c6e9c2011-06-15 15:35:17 -07004095 if (!spec->dig_out && !spec->dig_in)
4096 return 0;
4097
Takashi Iwaibbbc7e82015-02-27 17:43:19 +01004098 info = snd_hda_codec_pcm_new(codec, "CA0132 Digital");
4099 if (!info)
4100 return -ENOMEM;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004101 info->pcm_type = HDA_PCM_TYPE_SPDIF;
4102 if (spec->dig_out) {
4103 info->stream[SNDRV_PCM_STREAM_PLAYBACK] =
4104 ca0132_pcm_digital_playback;
4105 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dig_out;
4106 }
4107 if (spec->dig_in) {
4108 info->stream[SNDRV_PCM_STREAM_CAPTURE] =
4109 ca0132_pcm_digital_capture;
4110 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->dig_in;
4111 }
Ian Minett95c6e9c2011-06-15 15:35:17 -07004112
4113 return 0;
4114}
4115
Ian Minett441aa6a2012-12-20 18:53:40 -08004116static void init_output(struct hda_codec *codec, hda_nid_t pin, hda_nid_t dac)
4117{
4118 if (pin) {
Takashi Iwaia0c041c2013-01-15 17:13:31 +01004119 snd_hda_set_pin_ctl(codec, pin, PIN_HP);
Ian Minett441aa6a2012-12-20 18:53:40 -08004120 if (get_wcaps(codec, pin) & AC_WCAP_OUT_AMP)
4121 snd_hda_codec_write(codec, pin, 0,
4122 AC_VERB_SET_AMP_GAIN_MUTE,
4123 AMP_OUT_UNMUTE);
4124 }
4125 if (dac && (get_wcaps(codec, dac) & AC_WCAP_OUT_AMP))
4126 snd_hda_codec_write(codec, dac, 0,
4127 AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO);
4128}
4129
4130static void init_input(struct hda_codec *codec, hda_nid_t pin, hda_nid_t adc)
4131{
4132 if (pin) {
Takashi Iwaia0c041c2013-01-15 17:13:31 +01004133 snd_hda_set_pin_ctl(codec, pin, PIN_VREF80);
Ian Minett441aa6a2012-12-20 18:53:40 -08004134 if (get_wcaps(codec, pin) & AC_WCAP_IN_AMP)
4135 snd_hda_codec_write(codec, pin, 0,
4136 AC_VERB_SET_AMP_GAIN_MUTE,
4137 AMP_IN_UNMUTE(0));
4138 }
4139 if (adc && (get_wcaps(codec, adc) & AC_WCAP_IN_AMP)) {
4140 snd_hda_codec_write(codec, adc, 0, AC_VERB_SET_AMP_GAIN_MUTE,
4141 AMP_IN_UNMUTE(0));
4142
4143 /* init to 0 dB and unmute. */
4144 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0,
4145 HDA_AMP_VOLMASK, 0x5a);
4146 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0,
4147 HDA_AMP_MUTE, 0);
4148 }
4149}
4150
Ian Minett5aaca442012-12-20 18:53:34 -08004151static void refresh_amp_caps(struct hda_codec *codec, hda_nid_t nid, int dir)
4152{
4153 unsigned int caps;
4154
4155 caps = snd_hda_param_read(codec, nid, dir == HDA_OUTPUT ?
4156 AC_PAR_AMP_OUT_CAP : AC_PAR_AMP_IN_CAP);
4157 snd_hda_override_amp_caps(codec, nid, dir, caps);
4158}
4159
4160/*
4161 * Switch between Digital built-in mic and analog mic.
4162 */
4163static void ca0132_set_dmic(struct hda_codec *codec, int enable)
4164{
4165 struct ca0132_spec *spec = codec->spec;
4166 unsigned int tmp;
4167 u8 val;
4168 unsigned int oldval;
4169
Takashi Iwai4e76a882014-02-25 12:21:03 +01004170 codec_dbg(codec, "ca0132_set_dmic: enable=%d\n", enable);
Ian Minett5aaca442012-12-20 18:53:34 -08004171
4172 oldval = stop_mic1(codec);
4173 ca0132_set_vipsource(codec, 0);
4174 if (enable) {
4175 /* set DMic input as 2-ch */
4176 tmp = FLOAT_TWO;
4177 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
4178
4179 val = spec->dmic_ctl;
4180 val |= 0x80;
4181 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4182 VENDOR_CHIPIO_DMIC_CTL_SET, val);
4183
4184 if (!(spec->dmic_ctl & 0x20))
4185 chipio_set_control_flag(codec, CONTROL_FLAG_DMIC, 1);
4186 } else {
4187 /* set AMic input as mono */
4188 tmp = FLOAT_ONE;
4189 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
4190
4191 val = spec->dmic_ctl;
4192 /* clear bit7 and bit5 to disable dmic */
4193 val &= 0x5f;
4194 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4195 VENDOR_CHIPIO_DMIC_CTL_SET, val);
4196
4197 if (!(spec->dmic_ctl & 0x20))
4198 chipio_set_control_flag(codec, CONTROL_FLAG_DMIC, 0);
4199 }
4200 ca0132_set_vipsource(codec, 1);
4201 resume_mic1(codec, oldval);
4202}
4203
4204/*
4205 * Initialization for Digital Mic.
4206 */
4207static void ca0132_init_dmic(struct hda_codec *codec)
4208{
4209 struct ca0132_spec *spec = codec->spec;
4210 u8 val;
4211
4212 /* Setup Digital Mic here, but don't enable.
4213 * Enable based on jack detect.
4214 */
4215
4216 /* MCLK uses MPIO1, set to enable.
4217 * Bit 2-0: MPIO select
4218 * Bit 3: set to disable
4219 * Bit 7-4: reserved
4220 */
4221 val = 0x01;
4222 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4223 VENDOR_CHIPIO_DMIC_MCLK_SET, val);
4224
4225 /* Data1 uses MPIO3. Data2 not use
4226 * Bit 2-0: Data1 MPIO select
4227 * Bit 3: set disable Data1
4228 * Bit 6-4: Data2 MPIO select
4229 * Bit 7: set disable Data2
4230 */
4231 val = 0x83;
4232 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4233 VENDOR_CHIPIO_DMIC_PIN_SET, val);
4234
4235 /* Use Ch-0 and Ch-1. Rate is 48K, mode 1. Disable DMic first.
4236 * Bit 3-0: Channel mask
4237 * Bit 4: set for 48KHz, clear for 32KHz
4238 * Bit 5: mode
4239 * Bit 6: set to select Data2, clear for Data1
4240 * Bit 7: set to enable DMic, clear for AMic
4241 */
4242 val = 0x23;
4243 /* keep a copy of dmic ctl val for enable/disable dmic purpuse */
4244 spec->dmic_ctl = val;
4245 snd_hda_codec_write(codec, spec->input_pins[0], 0,
4246 VENDOR_CHIPIO_DMIC_CTL_SET, val);
4247}
4248
4249/*
4250 * Initialization for Analog Mic 2
4251 */
4252static void ca0132_init_analog_mic2(struct hda_codec *codec)
4253{
4254 struct ca0132_spec *spec = codec->spec;
4255
4256 mutex_lock(&spec->chipio_mutex);
4257 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4258 VENDOR_CHIPIO_8051_ADDRESS_LOW, 0x20);
4259 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4260 VENDOR_CHIPIO_8051_ADDRESS_HIGH, 0x19);
4261 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4262 VENDOR_CHIPIO_8051_DATA_WRITE, 0x00);
4263 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4264 VENDOR_CHIPIO_8051_ADDRESS_LOW, 0x2D);
4265 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4266 VENDOR_CHIPIO_8051_ADDRESS_HIGH, 0x19);
4267 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0,
4268 VENDOR_CHIPIO_8051_DATA_WRITE, 0x00);
4269 mutex_unlock(&spec->chipio_mutex);
4270}
4271
4272static void ca0132_refresh_widget_caps(struct hda_codec *codec)
4273{
4274 struct ca0132_spec *spec = codec->spec;
4275 int i;
Ian Minett5aaca442012-12-20 18:53:34 -08004276
Takashi Iwai4e76a882014-02-25 12:21:03 +01004277 codec_dbg(codec, "ca0132_refresh_widget_caps.\n");
Takashi Iwai7639a062015-03-03 10:07:24 +01004278 snd_hda_codec_update_widgets(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08004279
4280 for (i = 0; i < spec->multiout.num_dacs; i++)
4281 refresh_amp_caps(codec, spec->dacs[i], HDA_OUTPUT);
4282
4283 for (i = 0; i < spec->num_outputs; i++)
4284 refresh_amp_caps(codec, spec->out_pins[i], HDA_OUTPUT);
4285
4286 for (i = 0; i < spec->num_inputs; i++) {
4287 refresh_amp_caps(codec, spec->adcs[i], HDA_INPUT);
4288 refresh_amp_caps(codec, spec->input_pins[i], HDA_INPUT);
4289 }
4290}
4291
4292/*
4293 * Setup default parameters for DSP
4294 */
4295static void ca0132_setup_defaults(struct hda_codec *codec)
4296{
Dylan Reide8f1bd52013-03-14 17:27:45 -07004297 struct ca0132_spec *spec = codec->spec;
Ian Minett5aaca442012-12-20 18:53:34 -08004298 unsigned int tmp;
4299 int num_fx;
4300 int idx, i;
4301
Dylan Reide8f1bd52013-03-14 17:27:45 -07004302 if (spec->dsp_state != DSP_DOWNLOADED)
Ian Minett5aaca442012-12-20 18:53:34 -08004303 return;
4304
4305 /* out, in effects + voicefx */
4306 num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT + 1;
4307 for (idx = 0; idx < num_fx; idx++) {
4308 for (i = 0; i <= ca0132_effects[idx].params; i++) {
4309 dspio_set_uint_param(codec, ca0132_effects[idx].mid,
4310 ca0132_effects[idx].reqs[i],
4311 ca0132_effects[idx].def_vals[i]);
4312 }
4313 }
4314
4315 /*remove DSP headroom*/
4316 tmp = FLOAT_ZERO;
4317 dspio_set_uint_param(codec, 0x96, 0x3C, tmp);
4318
4319 /*set speaker EQ bypass attenuation*/
4320 dspio_set_uint_param(codec, 0x8f, 0x01, tmp);
4321
4322 /* set AMic1 and AMic2 as mono mic */
4323 tmp = FLOAT_ONE;
4324 dspio_set_uint_param(codec, 0x80, 0x00, tmp);
4325 dspio_set_uint_param(codec, 0x80, 0x01, tmp);
4326
4327 /* set AMic1 as CrystalVoice input */
4328 tmp = FLOAT_ONE;
4329 dspio_set_uint_param(codec, 0x80, 0x05, tmp);
4330
4331 /* set WUH source */
4332 tmp = FLOAT_TWO;
4333 dspio_set_uint_param(codec, 0x31, 0x00, tmp);
4334}
4335
4336/*
4337 * Initialization of flags in chip
4338 */
4339static void ca0132_init_flags(struct hda_codec *codec)
4340{
4341 chipio_set_control_flag(codec, CONTROL_FLAG_IDLE_ENABLE, 0);
4342 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_A_COMMON_MODE, 0);
4343 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_D_COMMON_MODE, 0);
4344 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_A_10KOHM_LOAD, 0);
4345 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_D_10KOHM_LOAD, 0);
4346 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_C_HIGH_PASS, 1);
4347}
4348
4349/*
4350 * Initialization of parameters in chip
4351 */
4352static void ca0132_init_params(struct hda_codec *codec)
4353{
4354 chipio_set_control_param(codec, CONTROL_PARAM_PORTA_160OHM_GAIN, 6);
4355 chipio_set_control_param(codec, CONTROL_PARAM_PORTD_160OHM_GAIN, 6);
4356}
Ian Minett95c6e9c2011-06-15 15:35:17 -07004357
Ian Minette90f29e2012-12-20 18:53:39 -08004358static void ca0132_set_dsp_msr(struct hda_codec *codec, bool is96k)
4359{
4360 chipio_set_control_flag(codec, CONTROL_FLAG_DSP_96KHZ, is96k);
4361 chipio_set_control_flag(codec, CONTROL_FLAG_DAC_96KHZ, is96k);
4362 chipio_set_control_flag(codec, CONTROL_FLAG_SRC_RATE_96KHZ, is96k);
4363 chipio_set_control_flag(codec, CONTROL_FLAG_SRC_CLOCK_196MHZ, is96k);
4364 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_B_96KHZ, is96k);
4365 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_C_96KHZ, is96k);
4366
Ian Minett406261c2012-12-20 18:53:41 -08004367 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000);
4368 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000);
Ian Minette90f29e2012-12-20 18:53:39 -08004369 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000);
4370}
4371
4372static bool ca0132_download_dsp_images(struct hda_codec *codec)
4373{
4374 bool dsp_loaded = false;
4375 const struct dsp_image_seg *dsp_os_image;
Takashi Iwai15e4ba62013-01-15 17:08:38 +01004376 const struct firmware *fw_entry;
Ian Minette90f29e2012-12-20 18:53:39 -08004377
Takashi Iwai6efdd852015-02-27 16:09:22 +01004378 if (request_firmware(&fw_entry, EFX_FILE, codec->card->dev) != 0)
Ian Minette90f29e2012-12-20 18:53:39 -08004379 return false;
4380
Takashi Iwai15e4ba62013-01-15 17:08:38 +01004381 dsp_os_image = (struct dsp_image_seg *)(fw_entry->data);
Dylan Reidd1d28502013-03-14 17:27:44 -07004382 if (dspload_image(codec, dsp_os_image, 0, 0, true, 0)) {
Takashi Iwaid9684bb2015-10-26 16:54:16 +01004383 codec_err(codec, "ca0132 DSP load image failed\n");
Dylan Reidd1d28502013-03-14 17:27:44 -07004384 goto exit_download;
4385 }
4386
Ian Minette90f29e2012-12-20 18:53:39 -08004387 dsp_loaded = dspload_wait_loaded(codec);
4388
Dylan Reidd1d28502013-03-14 17:27:44 -07004389exit_download:
Takashi Iwai15e4ba62013-01-15 17:08:38 +01004390 release_firmware(fw_entry);
4391
Ian Minette90f29e2012-12-20 18:53:39 -08004392 return dsp_loaded;
4393}
4394
4395static void ca0132_download_dsp(struct hda_codec *codec)
4396{
4397 struct ca0132_spec *spec = codec->spec;
4398
Takashi Iwai9a0869f2013-02-07 12:41:40 +01004399#ifndef CONFIG_SND_HDA_CODEC_CA0132_DSP
4400 return; /* NOP */
4401#endif
Ian Minette90f29e2012-12-20 18:53:39 -08004402
Takashi Iwaie24aa0a2014-08-10 13:30:08 +02004403 if (spec->dsp_state == DSP_DOWNLOAD_FAILED)
4404 return; /* don't retry failures */
4405
Dylan Reidb714a712013-03-14 17:27:46 -07004406 chipio_enable_clocks(codec);
4407 spec->dsp_state = DSP_DOWNLOADING;
4408 if (!ca0132_download_dsp_images(codec))
4409 spec->dsp_state = DSP_DOWNLOAD_FAILED;
4410 else
4411 spec->dsp_state = DSP_DOWNLOADED;
Ian Minette90f29e2012-12-20 18:53:39 -08004412
4413 if (spec->dsp_state == DSP_DOWNLOADED)
4414 ca0132_set_dsp_msr(codec, true);
4415}
4416
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004417static void ca0132_process_dsp_response(struct hda_codec *codec,
4418 struct hda_jack_callback *callback)
Ian Minette90f29e2012-12-20 18:53:39 -08004419{
4420 struct ca0132_spec *spec = codec->spec;
4421
Takashi Iwai4e76a882014-02-25 12:21:03 +01004422 codec_dbg(codec, "ca0132_process_dsp_response\n");
Ian Minette90f29e2012-12-20 18:53:39 -08004423 if (spec->wait_scp) {
4424 if (dspio_get_response_data(codec) >= 0)
4425 spec->wait_scp = 0;
4426 }
4427
4428 dspio_clear_response_queue(codec);
4429}
4430
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004431static void hp_callback(struct hda_codec *codec, struct hda_jack_callback *cb)
Ian Minette90f29e2012-12-20 18:53:39 -08004432{
Chih-Chung Chang993884f2013-03-25 10:39:23 -07004433 struct ca0132_spec *spec = codec->spec;
Takashi Iwai2ebab402016-02-09 10:23:52 +01004434 struct hda_jack_tbl *tbl;
Ian Minette90f29e2012-12-20 18:53:39 -08004435
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004436 /* Delay enabling the HP amp, to let the mic-detection
4437 * state machine run.
4438 */
4439 cancel_delayed_work_sync(&spec->unsol_hp_work);
Takashi Iwai2f35c632015-02-27 22:43:26 +01004440 schedule_delayed_work(&spec->unsol_hp_work, msecs_to_jiffies(500));
Takashi Iwai2ebab402016-02-09 10:23:52 +01004441 tbl = snd_hda_jack_tbl_get(codec, cb->nid);
4442 if (tbl)
4443 tbl->block_report = 1;
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004444}
Ian Minette90f29e2012-12-20 18:53:39 -08004445
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004446static void amic_callback(struct hda_codec *codec, struct hda_jack_callback *cb)
4447{
4448 ca0132_select_mic(codec);
4449}
4450
4451static void ca0132_init_unsol(struct hda_codec *codec)
4452{
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004453 struct ca0132_spec *spec = codec->spec;
4454 snd_hda_jack_detect_enable_callback(codec, spec->unsol_tag_hp, hp_callback);
4455 snd_hda_jack_detect_enable_callback(codec, spec->unsol_tag_amic1,
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004456 amic_callback);
4457 snd_hda_jack_detect_enable_callback(codec, UNSOL_TAG_DSP,
4458 ca0132_process_dsp_response);
Ian Minette90f29e2012-12-20 18:53:39 -08004459}
4460
Ian Minett5aaca442012-12-20 18:53:34 -08004461/*
4462 * Verbs tables.
4463 */
4464
4465/* Sends before DSP download. */
4466static struct hda_verb ca0132_base_init_verbs[] = {
4467 /*enable ct extension*/
4468 {0x15, VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE, 0x1},
Ian Minett5aaca442012-12-20 18:53:34 -08004469 {}
4470};
4471
4472/* Send at exit. */
4473static struct hda_verb ca0132_base_exit_verbs[] = {
4474 /*set afg to D3*/
4475 {0x01, AC_VERB_SET_POWER_STATE, 0x03},
4476 /*disable ct extension*/
4477 {0x15, VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE, 0},
4478 {}
4479};
4480
4481/* Other verbs tables. Sends after DSP download. */
4482static struct hda_verb ca0132_init_verbs0[] = {
4483 /* chip init verbs */
4484 {0x15, 0x70D, 0xF0},
4485 {0x15, 0x70E, 0xFE},
4486 {0x15, 0x707, 0x75},
4487 {0x15, 0x707, 0xD3},
4488 {0x15, 0x707, 0x09},
4489 {0x15, 0x707, 0x53},
4490 {0x15, 0x707, 0xD4},
4491 {0x15, 0x707, 0xEF},
4492 {0x15, 0x707, 0x75},
4493 {0x15, 0x707, 0xD3},
4494 {0x15, 0x707, 0x09},
4495 {0x15, 0x707, 0x02},
4496 {0x15, 0x707, 0x37},
4497 {0x15, 0x707, 0x78},
4498 {0x15, 0x53C, 0xCE},
4499 {0x15, 0x575, 0xC9},
4500 {0x15, 0x53D, 0xCE},
4501 {0x15, 0x5B7, 0xC9},
4502 {0x15, 0x70D, 0xE8},
4503 {0x15, 0x70E, 0xFE},
4504 {0x15, 0x707, 0x02},
4505 {0x15, 0x707, 0x68},
4506 {0x15, 0x707, 0x62},
4507 {0x15, 0x53A, 0xCE},
4508 {0x15, 0x546, 0xC9},
4509 {0x15, 0x53B, 0xCE},
4510 {0x15, 0x5E8, 0xC9},
4511 {0x15, 0x717, 0x0D},
4512 {0x15, 0x718, 0x20},
4513 {}
4514};
4515
Ian Minett95c6e9c2011-06-15 15:35:17 -07004516static void ca0132_init_chip(struct hda_codec *codec)
4517{
4518 struct ca0132_spec *spec = codec->spec;
Ian Minett5aaca442012-12-20 18:53:34 -08004519 int num_fx;
4520 int i;
4521 unsigned int on;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004522
4523 mutex_init(&spec->chipio_mutex);
Ian Minett5aaca442012-12-20 18:53:34 -08004524
4525 spec->cur_out_type = SPEAKER_OUT;
4526 spec->cur_mic_type = DIGITAL_MIC;
4527 spec->cur_mic_boost = 0;
4528
4529 for (i = 0; i < VNODES_COUNT; i++) {
4530 spec->vnode_lvol[i] = 0x5a;
4531 spec->vnode_rvol[i] = 0x5a;
4532 spec->vnode_lswitch[i] = 0;
4533 spec->vnode_rswitch[i] = 0;
4534 }
4535
4536 /*
4537 * Default states for effects are in ca0132_effects[].
4538 */
4539 num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT;
4540 for (i = 0; i < num_fx; i++) {
4541 on = (unsigned int)ca0132_effects[i].reqs[0];
4542 spec->effects_switch[i] = on ? 1 : 0;
4543 }
4544
4545 spec->voicefx_val = 0;
4546 spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID] = 1;
4547 spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] = 0;
4548
Ian Minett44f0c972012-12-20 18:53:38 -08004549#ifdef ENABLE_TUNING_CONTROLS
4550 ca0132_init_tuning_defaults(codec);
4551#endif
Ian Minett95c6e9c2011-06-15 15:35:17 -07004552}
4553
4554static void ca0132_exit_chip(struct hda_codec *codec)
4555{
4556 /* put any chip cleanup stuffs here. */
Ian Minett5aaca442012-12-20 18:53:34 -08004557
4558 if (dspload_is_loaded(codec))
4559 dsp_reset(codec);
Ian Minett95c6e9c2011-06-15 15:35:17 -07004560}
4561
4562static int ca0132_init(struct hda_codec *codec)
4563{
4564 struct ca0132_spec *spec = codec->spec;
4565 struct auto_pin_cfg *cfg = &spec->autocfg;
4566 int i;
4567
Takashi Iwaie24aa0a2014-08-10 13:30:08 +02004568 if (spec->dsp_state != DSP_DOWNLOAD_FAILED)
4569 spec->dsp_state = DSP_DOWNLOAD_INIT;
Takashi Iwai4a8b89f2013-02-12 10:15:15 +01004570 spec->curr_chip_addx = INVALID_CHIP_ADDRESS;
Ian Minett5aaca442012-12-20 18:53:34 -08004571
Takashi Iwai664c7152015-04-08 11:43:14 +02004572 snd_hda_power_up_pm(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08004573
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004574 ca0132_init_unsol(codec);
4575
Ian Minett5aaca442012-12-20 18:53:34 -08004576 ca0132_init_params(codec);
4577 ca0132_init_flags(codec);
4578 snd_hda_sequence_write(codec, spec->base_init_verbs);
Ian Minett01ef7db2012-09-20 20:29:16 -07004579 ca0132_download_dsp(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08004580 ca0132_refresh_widget_caps(codec);
4581 ca0132_setup_defaults(codec);
4582 ca0132_init_analog_mic2(codec);
4583 ca0132_init_dmic(codec);
Ian Minett01ef7db2012-09-20 20:29:16 -07004584
Ian Minett5aaca442012-12-20 18:53:34 -08004585 for (i = 0; i < spec->num_outputs; i++)
4586 init_output(codec, spec->out_pins[i], spec->dacs[0]);
4587
Ian Minett95c6e9c2011-06-15 15:35:17 -07004588 init_output(codec, cfg->dig_out_pins[0], spec->dig_out);
4589
4590 for (i = 0; i < spec->num_inputs; i++)
4591 init_input(codec, spec->input_pins[i], spec->adcs[i]);
4592
4593 init_input(codec, cfg->dig_in_pin, spec->dig_in);
4594
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004595 snd_hda_sequence_write(codec, spec->chip_init_verbs);
4596 snd_hda_sequence_write(codec, spec->spec_init_verbs);
Ian Minett5aaca442012-12-20 18:53:34 -08004597
4598 ca0132_select_out(codec);
4599 ca0132_select_mic(codec);
4600
Ian Minetta73d5112012-12-20 18:53:37 -08004601 snd_hda_jack_report_sync(codec);
4602
Takashi Iwai664c7152015-04-08 11:43:14 +02004603 snd_hda_power_down_pm(codec);
Ian Minett95c6e9c2011-06-15 15:35:17 -07004604
4605 return 0;
4606}
4607
Ian Minett95c6e9c2011-06-15 15:35:17 -07004608static void ca0132_free(struct hda_codec *codec)
4609{
Ian Minett5aaca442012-12-20 18:53:34 -08004610 struct ca0132_spec *spec = codec->spec;
4611
Chih-Chung Chang993884f2013-03-25 10:39:23 -07004612 cancel_delayed_work_sync(&spec->unsol_hp_work);
Ian Minett5aaca442012-12-20 18:53:34 -08004613 snd_hda_power_up(codec);
4614 snd_hda_sequence_write(codec, spec->base_exit_verbs);
Ian Minett95c6e9c2011-06-15 15:35:17 -07004615 ca0132_exit_chip(codec);
Ian Minett5aaca442012-12-20 18:53:34 -08004616 snd_hda_power_down(codec);
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004617 kfree(spec->spec_init_verbs);
Ian Minett95c6e9c2011-06-15 15:35:17 -07004618 kfree(codec->spec);
4619}
4620
Julia Lawall071f1342016-09-11 15:05:43 +02004621static const struct hda_codec_ops ca0132_patch_ops = {
Ian Minett95c6e9c2011-06-15 15:35:17 -07004622 .build_controls = ca0132_build_controls,
4623 .build_pcms = ca0132_build_pcms,
4624 .init = ca0132_init,
4625 .free = ca0132_free,
Takashi Iwaif8fb1172014-09-11 15:53:26 +02004626 .unsol_event = snd_hda_jack_unsol_event,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004627};
4628
Ian Minett441aa6a2012-12-20 18:53:40 -08004629static void ca0132_config(struct hda_codec *codec)
4630{
4631 struct ca0132_spec *spec = codec->spec;
4632 struct auto_pin_cfg *cfg = &spec->autocfg;
4633
4634 spec->dacs[0] = 0x2;
4635 spec->dacs[1] = 0x3;
4636 spec->dacs[2] = 0x4;
4637
4638 spec->multiout.dac_nids = spec->dacs;
4639 spec->multiout.num_dacs = 3;
4640 spec->multiout.max_channels = 2;
4641
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004642 if (spec->quirk == QUIRK_ALIENWARE) {
4643 codec_dbg(codec, "ca0132_config: QUIRK_ALIENWARE applied.\n");
Takashi Iwaife14f392015-08-10 16:53:32 +02004644 snd_hda_apply_pincfgs(codec, alienware_pincfgs);
4645
4646 spec->num_outputs = 2;
4647 spec->out_pins[0] = 0x0b; /* speaker out */
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004648 spec->out_pins[1] = 0x0f;
Takashi Iwaife14f392015-08-10 16:53:32 +02004649 spec->shared_out_nid = 0x2;
4650 spec->unsol_tag_hp = 0x0f;
4651
4652 spec->adcs[0] = 0x7; /* digital mic / analog mic1 */
4653 spec->adcs[1] = 0x8; /* analog mic2 */
4654 spec->adcs[2] = 0xa; /* what u hear */
4655
4656 spec->num_inputs = 3;
4657 spec->input_pins[0] = 0x12;
4658 spec->input_pins[1] = 0x11;
4659 spec->input_pins[2] = 0x13;
4660 spec->shared_mic_nid = 0x7;
4661 spec->unsol_tag_amic1 = 0x11;
4662 } else {
4663 spec->num_outputs = 2;
4664 spec->out_pins[0] = 0x0b; /* speaker out */
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004665 spec->out_pins[1] = 0x10; /* headphone out */
Takashi Iwaife14f392015-08-10 16:53:32 +02004666 spec->shared_out_nid = 0x2;
4667 spec->unsol_tag_hp = spec->out_pins[1];
4668
4669 spec->adcs[0] = 0x7; /* digital mic / analog mic1 */
4670 spec->adcs[1] = 0x8; /* analog mic2 */
4671 spec->adcs[2] = 0xa; /* what u hear */
4672
4673 spec->num_inputs = 3;
4674 spec->input_pins[0] = 0x12;
4675 spec->input_pins[1] = 0x11;
4676 spec->input_pins[2] = 0x13;
4677 spec->shared_mic_nid = 0x7;
4678 spec->unsol_tag_amic1 = spec->input_pins[0];
4679
4680 /* SPDIF I/O */
4681 spec->dig_out = 0x05;
4682 spec->multiout.dig_out_nid = spec->dig_out;
4683 cfg->dig_out_pins[0] = 0x0c;
4684 cfg->dig_outs = 1;
4685 cfg->dig_out_type[0] = HDA_PCM_TYPE_SPDIF;
4686 spec->dig_in = 0x09;
4687 cfg->dig_in_pin = 0x0e;
4688 cfg->dig_in_type = HDA_PCM_TYPE_SPDIF;
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004689 }
Ian Minett441aa6a2012-12-20 18:53:40 -08004690}
4691
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004692static int ca0132_prepare_verbs(struct hda_codec *codec)
4693{
4694/* Verbs + terminator (an empty element) */
4695#define NUM_SPEC_VERBS 4
4696 struct ca0132_spec *spec = codec->spec;
4697
4698 spec->chip_init_verbs = ca0132_init_verbs0;
4699 spec->spec_init_verbs = kzalloc(sizeof(struct hda_verb) * NUM_SPEC_VERBS, GFP_KERNEL);
4700 if (!spec->spec_init_verbs)
4701 return -ENOMEM;
4702
4703 /* HP jack autodetection */
4704 spec->spec_init_verbs[0].nid = spec->unsol_tag_hp;
4705 spec->spec_init_verbs[0].param = AC_VERB_SET_UNSOLICITED_ENABLE;
4706 spec->spec_init_verbs[0].verb = AC_USRSP_EN | spec->unsol_tag_hp;
4707
4708 /* MIC1 jack autodetection */
4709 spec->spec_init_verbs[1].nid = spec->unsol_tag_amic1;
4710 spec->spec_init_verbs[1].param = AC_VERB_SET_UNSOLICITED_ENABLE;
4711 spec->spec_init_verbs[1].verb = AC_USRSP_EN | spec->unsol_tag_amic1;
4712
4713 /* config EAPD */
4714 spec->spec_init_verbs[2].nid = 0x0b;
4715 spec->spec_init_verbs[2].param = 0x78D;
4716 spec->spec_init_verbs[2].verb = 0x00;
4717
4718 /* Previously commented configuration */
4719 /*
4720 spec->spec_init_verbs[3].nid = 0x0b;
4721 spec->spec_init_verbs[3].param = AC_VERB_SET_EAPD_BTLENABLE;
4722 spec->spec_init_verbs[3].verb = 0x02;
4723
4724 spec->spec_init_verbs[4].nid = 0x10;
4725 spec->spec_init_verbs[4].param = 0x78D;
4726 spec->spec_init_verbs[4].verb = 0x02;
4727
4728 spec->spec_init_verbs[5].nid = 0x10;
4729 spec->spec_init_verbs[5].param = AC_VERB_SET_EAPD_BTLENABLE;
4730 spec->spec_init_verbs[5].verb = 0x02;
4731 */
4732
4733 /* Terminator: spec->spec_init_verbs[NUM_SPEC_VERBS-1] */
4734 return 0;
4735}
4736
Ian Minett95c6e9c2011-06-15 15:35:17 -07004737static int patch_ca0132(struct hda_codec *codec)
4738{
4739 struct ca0132_spec *spec;
Ian Minetta73d5112012-12-20 18:53:37 -08004740 int err;
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004741 const struct snd_pci_quirk *quirk;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004742
Takashi Iwai4e76a882014-02-25 12:21:03 +01004743 codec_dbg(codec, "patch_ca0132\n");
Ian Minett95c6e9c2011-06-15 15:35:17 -07004744
4745 spec = kzalloc(sizeof(*spec), GFP_KERNEL);
4746 if (!spec)
4747 return -ENOMEM;
4748 codec->spec = spec;
Chih-Chung Chang993884f2013-03-25 10:39:23 -07004749 spec->codec = codec;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004750
Takashi Iwai225068a2015-05-29 10:42:14 +02004751 codec->patch_ops = ca0132_patch_ops;
4752 codec->pcm_format_first = 1;
4753 codec->no_sticky_stream = 1;
4754
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004755 /* Detect codec quirk */
4756 quirk = snd_pci_quirk_lookup(codec->bus->pci, ca0132_quirks);
4757 if (quirk)
4758 spec->quirk = quirk->value;
4759 else
4760 spec->quirk = QUIRK_NONE;
4761
Takashi Iwaie24aa0a2014-08-10 13:30:08 +02004762 spec->dsp_state = DSP_DOWNLOAD_INIT;
Ian Minetta7e76272012-12-20 18:53:35 -08004763 spec->num_mixers = 1;
4764 spec->mixers[0] = ca0132_mixer;
4765
Ian Minett5aaca442012-12-20 18:53:34 -08004766 spec->base_init_verbs = ca0132_base_init_verbs;
4767 spec->base_exit_verbs = ca0132_base_exit_verbs;
Ian Minett5aaca442012-12-20 18:53:34 -08004768
Chih-Chung Chang993884f2013-03-25 10:39:23 -07004769 INIT_DELAYED_WORK(&spec->unsol_hp_work, ca0132_unsol_hp_delayed);
4770
Ian Minett95c6e9c2011-06-15 15:35:17 -07004771 ca0132_init_chip(codec);
4772
4773 ca0132_config(codec);
4774
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004775 err = ca0132_prepare_verbs(codec);
4776 if (err < 0)
Takashi Iwaicc91cea2017-09-04 17:38:36 +02004777 goto error;
Gabriele Martinod5c016b2015-05-18 21:15:13 +02004778
Ian Minetta73d5112012-12-20 18:53:37 -08004779 err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, NULL);
4780 if (err < 0)
Takashi Iwaicc91cea2017-09-04 17:38:36 +02004781 goto error;
Ian Minetta73d5112012-12-20 18:53:37 -08004782
Ian Minett95c6e9c2011-06-15 15:35:17 -07004783 return 0;
Takashi Iwaicc91cea2017-09-04 17:38:36 +02004784
4785 error:
4786 ca0132_free(codec);
4787 return err;
Ian Minett95c6e9c2011-06-15 15:35:17 -07004788}
4789
4790/*
4791 * patch entries
4792 */
Takashi Iwaib9a94a92015-10-01 16:20:04 +02004793static struct hda_device_id snd_hda_id_ca0132[] = {
4794 HDA_CODEC_ENTRY(0x11020011, "CA0132", patch_ca0132),
Ian Minett95c6e9c2011-06-15 15:35:17 -07004795 {} /* terminator */
4796};
Takashi Iwaib9a94a92015-10-01 16:20:04 +02004797MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_ca0132);
Ian Minett95c6e9c2011-06-15 15:35:17 -07004798
4799MODULE_LICENSE("GPL");
Ian Minett406261c2012-12-20 18:53:41 -08004800MODULE_DESCRIPTION("Creative Sound Core3D codec");
Ian Minett95c6e9c2011-06-15 15:35:17 -07004801
Takashi Iwaid8a766a2015-02-17 15:25:37 +01004802static struct hda_codec_driver ca0132_driver = {
Takashi Iwaib9a94a92015-10-01 16:20:04 +02004803 .id = snd_hda_id_ca0132,
Ian Minett95c6e9c2011-06-15 15:35:17 -07004804};
4805
Takashi Iwaid8a766a2015-02-17 15:25:37 +01004806module_hda_codec_driver(ca0132_driver);