1 /* 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> 27 #include <linux/mutex.h> 28 #include <linux/module.h> 29 #include <linux/firmware.h> 30 #include <sound/core.h> 31 #include "hda_codec.h" 32 #include "hda_local.h" 33 #include "hda_auto_parser.h" 34 #include "hda_jack.h" 35 36 #include "ca0132_regs.h" 37 38 /* Enable this to see controls for tuning purpose. */ 39 /*#define ENABLE_TUNING_CONTROLS*/ 40 41 #define FLOAT_ZERO 0x00000000 42 #define FLOAT_ONE 0x3f800000 43 #define FLOAT_TWO 0x40000000 44 #define FLOAT_MINUS_5 0xc0a00000 45 46 #define UNSOL_TAG_DSP 0x16 47 48 #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 56 #define MASTERCONTROL_ALLOC_DMA_CHAN 10 57 #define MASTERCONTROL_QUERY_SPEAKER_EQ_ADDRESS 60 58 59 #define WIDGET_CHIP_CTRL 0x15 60 #define WIDGET_DSP_CTRL 0x16 61 62 #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 73 #define EFX_FILE "ctefx.bin" 74 75 #ifdef CONFIG_SND_HDA_CODEC_CA0132_DSP 76 MODULE_FIRMWARE(EFX_FILE); 77 #endif 78 79 static char *dirstr[2] = { "Playback", "Capture" }; 80 81 enum { 82 SPEAKER_OUT, 83 HEADPHONE_OUT 84 }; 85 86 enum { 87 DIGITAL_MIC, 88 LINE_MIC_IN 89 }; 90 91 enum { 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 131 /* 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 138 struct ct_effect { 139 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 140 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 152 static 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 251 enum { 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 269 struct ct_tuning_ctl { 270 char name[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 271 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 279 static 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 382 struct 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 389 struct ct_voicefx_preset { 390 char *name; /*preset name*/ 391 unsigned int vals[VOICEFX_MAX_PARAM_COUNT]; 392 }; 393 394 static struct ct_voicefx ca0132_voicefx = { 395 .name = "VoiceFX Capture Switch", 396 .nid = VOICEFX, 397 .mid = 0x95, 398 .reqs = {10, 11, 12, 13, 14, 15, 16, 17, 18} 399 }; 400 401 static struct ct_voicefx_preset ca0132_voicefx_presets[] = { 402 { .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 474 enum 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 498 VENDOR_CHIPIO_8051_DATA_WRITE = 0x707, 499 VENDOR_CHIPIO_8051_DATA_READ = 0xF07, 500 501 VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE = 0x70A, 502 VENDOR_CHIPIO_CT_EXTENSIONS_GET = 0xF0A, 503 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, 510 VENDOR_CHIPIO_PARAM_SET = 0x710, 511 VENDOR_CHIPIO_PARAM_GET = 0xF10, 512 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 518 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 531 }; 532 533 /* 534 * Control flag IDs 535 */ 536 enum 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 */ 580 CONTROL_FLAG_PORT_D_10KOHM_LOAD = 21, 581 /* 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 */ 594 enum control_param_id { 595 /* 0: None, 1: Mic1In*/ 596 CONTROL_PARAM_VIP_SOURCE = 1, 597 /* 0: force HDA, 1: allow DSP if HDA Spdif1Out stream is idle */ 598 CONTROL_PARAM_SPDIF1_SOURCE = 2, 599 /* 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, 605 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 */ 635 enum 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 */ 649 enum 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 */ 659 enum 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 682 enum dsp_download_state { 683 DSP_DOWNLOAD_FAILED = -1, 684 DSP_DOWNLOAD_INIT = 0, 685 DSP_DOWNLOADING = 1, 686 DSP_DOWNLOADED = 2 687 }; 688 689 /* 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) 694 695 /* 696 * CA0132 specific 697 */ 698 699 struct ca0132_spec { 700 struct snd_kcontrol_new *mixers[5]; 701 unsigned int num_mixers; 702 const struct hda_verb *base_init_verbs; 703 const struct hda_verb *base_exit_verbs; 704 const struct hda_verb *chip_init_verbs; 705 struct hda_verb *spec_init_verbs; 706 struct auto_pin_cfg autocfg; 707 708 /* Nodes configurations */ 709 struct hda_multi_out multiout; 710 hda_nid_t out_pins[AUTO_CFG_MAX_OUTS]; 711 hda_nid_t dacs[AUTO_CFG_MAX_OUTS]; 712 unsigned int num_outputs; 713 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; 718 hda_nid_t shared_mic_nid; 719 hda_nid_t shared_out_nid; 720 hda_nid_t unsol_tag_hp; 721 hda_nid_t unsol_tag_amic1; 722 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; 736 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; 748 749 struct hda_codec *codec; 750 struct delayed_work unsol_hp_work; 751 int quirk; 752 753 #ifdef ENABLE_TUNING_CONTROLS 754 long cur_ctl_vals[TUNING_CTLS_COUNT]; 755 #endif 756 }; 757 758 /* 759 * CA0132 quirks table 760 */ 761 enum { 762 QUIRK_NONE, 763 QUIRK_ALIENWARE, 764 }; 765 766 static 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 780 static const struct snd_pci_quirk ca0132_quirks[] = { 781 SND_PCI_QUIRK(0x1028, 0x0685, "Alienware 15 2015", QUIRK_ALIENWARE), 782 SND_PCI_QUIRK(0x1028, 0x0688, "Alienware 17 2015", QUIRK_ALIENWARE), 783 SND_PCI_QUIRK(0x1028, 0x0708, "Alienware 15 R2 2016", QUIRK_ALIENWARE), 784 {} 785 }; 786 787 /* 788 * CA0132 codec access 789 */ 790 static unsigned int codec_send_command(struct hda_codec *codec, hda_nid_t nid, 791 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 800 static 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 807 static 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 818 /* Chip access helper function */ 819 static int chipio_send(struct hda_codec *codec, 820 unsigned int reg, 821 unsigned int data) 822 { 823 unsigned int res; 824 unsigned long timeout = jiffies + msecs_to_jiffies(1000); 825 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; 832 msleep(20); 833 } while (time_before(jiffies, timeout)); 834 835 return -EIO; 836 } 837 838 /* 839 * Write chip address through the vendor widget -- NOT protected by the Mutex! 840 */ 841 static int chipio_write_address(struct hda_codec *codec, 842 unsigned int chip_addx) 843 { 844 struct ca0132_spec *spec = codec->spec; 845 int res; 846 847 if (spec->curr_chip_addx == chip_addx) 848 return 0; 849 850 /* 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 860 spec->curr_chip_addx = (res < 0) ? ~0UL : chip_addx; 861 862 return res; 863 } 864 865 /* 866 * Write data through the vendor widget -- NOT protected by the Mutex! 867 */ 868 static int chipio_write_data(struct hda_codec *codec, unsigned int data) 869 { 870 struct ca0132_spec *spec = codec->spec; 871 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 882 /*If no error encountered, automatically increment the address 883 as per chip behaviour*/ 884 spec->curr_chip_addx = (res != -EIO) ? 885 (spec->curr_chip_addx + 4) : ~0UL; 886 return res; 887 } 888 889 /* 890 * Write multiple data through the vendor widget -- NOT protected by the Mutex! 891 */ 892 static 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) { 899 codec_dbg(codec, "chipio_write_data null ptr\n"); 900 return -EINVAL; 901 } 902 903 while ((count-- != 0) && (status == 0)) 904 status = chipio_write_data(codec, *data++); 905 906 return status; 907 } 908 909 910 /* 911 * Read data through the vendor widget -- NOT protected by the Mutex! 912 */ 913 static int chipio_read_data(struct hda_codec *codec, unsigned int *data) 914 { 915 struct ca0132_spec *spec = codec->spec; 916 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 933 /*If no error encountered, automatically increment the address 934 as per chip behaviour*/ 935 spec->curr_chip_addx = (res != -EIO) ? 936 (spec->curr_chip_addx + 4) : ~0UL; 937 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 */ 944 static 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 961 exit: 962 mutex_unlock(&spec->chipio_mutex); 963 return err; 964 } 965 966 /* 967 * Write multiple values to the given address through the chip I/O widget. 968 * protected by the Mutex 969 */ 970 static 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); 979 status = chipio_write_address(codec, chip_addx); 980 if (status < 0) 981 goto error; 982 983 status = chipio_write_data_multiple(codec, data, count); 984 error: 985 mutex_unlock(&spec->chipio_mutex); 986 987 return status; 988 } 989 990 /* 991 * Read the given address through the chip I/O widget 992 * protected by the Mutex 993 */ 994 static 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 1011 exit: 1012 mutex_unlock(&spec->chipio_mutex); 1013 return err; 1014 } 1015 1016 /* 1017 * Set chip control flags through the chip I/O widget. 1018 */ 1019 static 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 1032 /* 1033 * Set chip parameters through the chip I/O widget. 1034 */ 1035 static 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 1059 /* 1060 * Set sampling rate of the connection point. 1061 */ 1062 static 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 1070 /* 1071 * Enable clocks. 1072 */ 1073 static 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 */ 1096 static int dspio_send(struct hda_codec *codec, unsigned int reg, 1097 unsigned int data) 1098 { 1099 int res; 1100 unsigned long timeout = jiffies + msecs_to_jiffies(1000); 1101 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; 1107 msleep(20); 1108 } while (time_before(jiffies, timeout)); 1109 1110 return -EIO; 1111 } 1112 1113 /* 1114 * Wait for DSP to be ready for commands 1115 */ 1116 static void dspio_write_wait(struct hda_codec *codec) 1117 { 1118 int status; 1119 unsigned long timeout = jiffies + msecs_to_jiffies(1000); 1120 1121 do { 1122 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)); 1129 } 1130 1131 /* 1132 * Write SCP data to DSP 1133 */ 1134 static 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); 1155 error: 1156 mutex_unlock(&spec->chipio_mutex); 1157 1158 return (status == VENDOR_STATUS_DSPIO_SCP_COMMAND_QUEUE_FULL) ? 1159 -EIO : 0; 1160 } 1161 1162 /* 1163 * Write multiple SCP data to DSP 1164 */ 1165 static 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 1171 if ((buffer == NULL)) 1172 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 1185 static 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 1204 static 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 1213 if ((buffer == NULL)) 1214 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 1238 /* 1239 * Construct the SCP header using corresponding fields 1240 */ 1241 static inline unsigned int 1242 make_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 1261 /* 1262 * Extract corresponding fields from SCP header 1263 */ 1264 static inline void 1265 extract_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 */ 1292 struct scp_msg { 1293 unsigned int hdr; 1294 unsigned int data[SCP_MAX_DATA_WORDS]; 1295 }; 1296 1297 static 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 1308 static 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 1329 /* 1330 * Send SCP message to DSP 1331 */ 1332 static 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; 1340 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) { 1386 unsigned long timeout = jiffies + msecs_to_jiffies(1000); 1387 memset(return_buf, 0, return_buf_size); 1388 do { 1389 msleep(20); 1390 } while (spec->wait_scp && time_before(jiffies, timeout)); 1391 waiting_for_resp = false; 1392 if (!spec->wait_scp) { 1393 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 1408 /** 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 */ 1421 static 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) { 1438 codec_dbg(codec, "dspio_scp get but has no buffer\n"); 1439 return -EINVAL; 1440 } 1441 1442 if (reply != NULL && (reply_len == NULL || (*reply_len == 0))) { 1443 codec_dbg(codec, "dspio_scp bad resp buf len parms\n"); 1444 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) { 1461 codec_dbg(codec, "dspio_scp: send scp msg failed\n"); 1462 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)) { 1480 codec_dbg(codec, "reply too long for buf\n"); 1481 return -EINVAL; 1482 } else if (ret_size != reply_data_size) { 1483 codec_dbg(codec, "RetLen and HdrLen .NE.\n"); 1484 return -EINVAL; 1485 } else if (!reply) { 1486 codec_dbg(codec, "NULL reply\n"); 1487 return -EINVAL; 1488 } else { 1489 *reply_len = ret_size*sizeof(unsigned int); 1490 memcpy(reply, scp_reply.data, *reply_len); 1491 } 1492 } else { 1493 codec_dbg(codec, "reply ill-formed or errflag set\n"); 1494 return -EIO; 1495 } 1496 1497 return status; 1498 } 1499 1500 /* 1501 * Set DSP parameters 1502 */ 1503 static 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 1509 static 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 /* 1516 * Allocate a DSP DMA channel via an SCP message 1517 */ 1518 static 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 1523 codec_dbg(codec, " dspio_alloc_dma_chan() -- begin\n"); 1524 status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN, 1525 SCP_GET, NULL, 0, dma_chan, &size); 1526 1527 if (status < 0) { 1528 codec_dbg(codec, "dspio_alloc_dma_chan: SCP Failed\n"); 1529 return status; 1530 } 1531 1532 if ((*dma_chan + 1) == 0) { 1533 codec_dbg(codec, "no free dma channels to allocate\n"); 1534 return -EBUSY; 1535 } 1536 1537 codec_dbg(codec, "dspio_alloc_dma_chan: chan=%d\n", *dma_chan); 1538 codec_dbg(codec, " dspio_alloc_dma_chan() -- complete\n"); 1539 1540 return status; 1541 } 1542 1543 /* 1544 * Free a DSP DMA via an SCP message 1545 */ 1546 static int dspio_free_dma_chan(struct hda_codec *codec, unsigned int dma_chan) 1547 { 1548 int status = 0; 1549 unsigned int dummy = 0; 1550 1551 codec_dbg(codec, " dspio_free_dma_chan() -- begin\n"); 1552 codec_dbg(codec, "dspio_free_dma_chan: chan=%d\n", dma_chan); 1553 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) { 1558 codec_dbg(codec, "dspio_free_dma_chan: SCP Failed\n"); 1559 return status; 1560 } 1561 1562 codec_dbg(codec, " dspio_free_dma_chan() -- complete\n"); 1563 1564 return status; 1565 } 1566 1567 /* 1568 * (Re)start the DSP 1569 */ 1570 static 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 1602 /* 1603 * Reset the DSP 1604 */ 1605 static int dsp_reset(struct hda_codec *codec) 1606 { 1607 unsigned int res; 1608 int retry = 20; 1609 1610 codec_dbg(codec, "dsp_reset\n"); 1611 do { 1612 res = dspio_send(codec, VENDOR_DSPIO_DSP_INIT, 0); 1613 retry--; 1614 } while (res == -EIO && retry); 1615 1616 if (!retry) { 1617 codec_dbg(codec, "dsp_reset timeout\n"); 1618 return -EIO; 1619 } 1620 1621 return 0; 1622 } 1623 1624 /* 1625 * Convert chip address to DSP address 1626 */ 1627 static 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 1642 return INVALID_CHIP_ADDRESS; 1643 } 1644 1645 /* 1646 * Check if the DSP DMA is active 1647 */ 1648 static 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 1658 static 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 1670 codec_dbg(codec, "-- dsp_dma_setup_common() -- Begin ---------\n"); 1671 1672 if (dma_chan >= DSPDMAC_DMA_CFG_CHANNEL_COUNT) { 1673 codec_dbg(codec, "dma chan num invalid\n"); 1674 return -EINVAL; 1675 } 1676 1677 if (dsp_is_dma_active(codec, dma_chan)) { 1678 codec_dbg(codec, "dma already active\n"); 1679 return -EBUSY; 1680 } 1681 1682 dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram); 1683 1684 if (dsp_addx == INVALID_CHIP_ADDRESS) { 1685 codec_dbg(codec, "invalid chip addr\n"); 1686 return -ENXIO; 1687 } 1688 1689 chnl_prop = DSPDMAC_CHNLPROP_AC_MASK; 1690 active = 0; 1691 1692 codec_dbg(codec, " dsp_dma_setup_common() start reg pgm\n"); 1693 1694 if (ovly) { 1695 status = chipio_read(codec, DSPDMAC_CHNLPROP_INST_OFFSET, 1696 &chnl_prop); 1697 1698 if (status < 0) { 1699 codec_dbg(codec, "read CHNLPROP Reg fail\n"); 1700 return status; 1701 } 1702 codec_dbg(codec, "dsp_dma_setup_common() Read CHNLPROP\n"); 1703 } 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) { 1714 codec_dbg(codec, "write CHNLPROP Reg fail\n"); 1715 return status; 1716 } 1717 codec_dbg(codec, " dsp_dma_setup_common() Write CHNLPROP\n"); 1718 1719 if (ovly) { 1720 status = chipio_read(codec, DSPDMAC_ACTIVE_INST_OFFSET, 1721 &active); 1722 1723 if (status < 0) { 1724 codec_dbg(codec, "read ACTIVE Reg fail\n"); 1725 return status; 1726 } 1727 codec_dbg(codec, "dsp_dma_setup_common() Read ACTIVE\n"); 1728 } 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) { 1735 codec_dbg(codec, "write ACTIVE Reg fail\n"); 1736 return status; 1737 } 1738 1739 codec_dbg(codec, " dsp_dma_setup_common() Write ACTIVE\n"); 1740 1741 status = chipio_write(codec, DSPDMAC_AUDCHSEL_INST_OFFSET(dma_chan), 1742 port_map_mask); 1743 if (status < 0) { 1744 codec_dbg(codec, "write AUDCHSEL Reg fail\n"); 1745 return status; 1746 } 1747 codec_dbg(codec, " dsp_dma_setup_common() Write AUDCHSEL\n"); 1748 1749 status = chipio_write(codec, DSPDMAC_IRQCNT_INST_OFFSET(dma_chan), 1750 DSPDMAC_IRQCNT_BICNT_MASK | DSPDMAC_IRQCNT_CICNT_MASK); 1751 if (status < 0) { 1752 codec_dbg(codec, "write IRQCNT Reg fail\n"); 1753 return status; 1754 } 1755 codec_dbg(codec, " dsp_dma_setup_common() Write IRQCNT\n"); 1756 1757 codec_dbg(codec, 1758 "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 1763 codec_dbg(codec, "-- dsp_dma_setup_common() -- Complete ------\n"); 1764 1765 return 0; 1766 } 1767 1768 /* 1769 * Setup the DSP DMA per-transfer-specific registers 1770 */ 1771 static 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 1789 codec_dbg(codec, "-- dsp_dma_setup() -- Begin ---------\n"); 1790 1791 if (count > max_dma_count) { 1792 codec_dbg(codec, "count too big\n"); 1793 return -EINVAL; 1794 } 1795 1796 dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram); 1797 if (dsp_addx == INVALID_CHIP_ADDRESS) { 1798 codec_dbg(codec, "invalid chip addr\n"); 1799 return -ENXIO; 1800 } 1801 1802 codec_dbg(codec, " dsp_dma_setup() start reg pgm\n"); 1803 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) { 1819 codec_dbg(codec, "write DMACFG Reg fail\n"); 1820 return status; 1821 } 1822 codec_dbg(codec, " dsp_dma_setup() Write DMACFG\n"); 1823 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) { 1830 codec_dbg(codec, "write DSPADROFS Reg fail\n"); 1831 return status; 1832 } 1833 codec_dbg(codec, " dsp_dma_setup() Write DSPADROFS\n"); 1834 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) { 1844 codec_dbg(codec, "write XFRCNT Reg fail\n"); 1845 return status; 1846 } 1847 codec_dbg(codec, " dsp_dma_setup() Write XFRCNT\n"); 1848 1849 codec_dbg(codec, 1850 "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 1854 codec_dbg(codec, "-- dsp_dma_setup() -- Complete ---------\n"); 1855 1856 return 0; 1857 } 1858 1859 /* 1860 * Start the DSP DMA 1861 */ 1862 static 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 1868 codec_dbg(codec, "-- dsp_dma_start() -- Begin ---------\n"); 1869 1870 if (ovly) { 1871 status = chipio_read(codec, 1872 DSPDMAC_CHNLSTART_INST_OFFSET, ®); 1873 1874 if (status < 0) { 1875 codec_dbg(codec, "read CHNLSTART reg fail\n"); 1876 return status; 1877 } 1878 codec_dbg(codec, "-- dsp_dma_start() Read CHNLSTART\n"); 1879 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) { 1887 codec_dbg(codec, "write CHNLSTART reg fail\n"); 1888 return status; 1889 } 1890 codec_dbg(codec, "-- dsp_dma_start() -- Complete ---------\n"); 1891 1892 return status; 1893 } 1894 1895 /* 1896 * Stop the DSP DMA 1897 */ 1898 static 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 1904 codec_dbg(codec, "-- dsp_dma_stop() -- Begin ---------\n"); 1905 1906 if (ovly) { 1907 status = chipio_read(codec, 1908 DSPDMAC_CHNLSTART_INST_OFFSET, ®); 1909 1910 if (status < 0) { 1911 codec_dbg(codec, "read CHNLSTART reg fail\n"); 1912 return status; 1913 } 1914 codec_dbg(codec, "-- dsp_dma_stop() Read CHNLSTART\n"); 1915 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) { 1922 codec_dbg(codec, "write CHNLSTART reg fail\n"); 1923 return status; 1924 } 1925 codec_dbg(codec, "-- dsp_dma_stop() -- Complete ---------\n"); 1926 1927 return status; 1928 } 1929 1930 /** 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 */ 1941 static 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 1979 /* 1980 * Free router ports 1981 */ 1982 static 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 1999 /* 2000 * Allocate DSP ports for the download stream 2001 */ 2002 static 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 2008 codec_dbg(codec, " dsp_allocate_ports() -- begin\n"); 2009 2010 if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) { 2011 codec_dbg(codec, "bad rate multiple\n"); 2012 return -EINVAL; 2013 } 2014 2015 status = dsp_allocate_router_ports(codec, num_chans, 2016 rate_multi, 0, port_map); 2017 2018 codec_dbg(codec, " dsp_allocate_ports() -- complete\n"); 2019 2020 return status; 2021 } 2022 2023 static 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)) { 2035 codec_dbg(codec, "bad rate multiple\n"); 2036 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 /* 2047 * free DSP ports 2048 */ 2049 static int dsp_free_ports(struct hda_codec *codec) 2050 { 2051 int status; 2052 2053 codec_dbg(codec, " dsp_free_ports() -- begin\n"); 2054 2055 status = dsp_free_router_ports(codec); 2056 if (status < 0) { 2057 codec_dbg(codec, "free router ports fail\n"); 2058 return status; 2059 } 2060 codec_dbg(codec, " dsp_free_ports() -- complete\n"); 2061 2062 return status; 2063 } 2064 2065 /* 2066 * HDA DMA engine stuffs for DSP code download 2067 */ 2068 struct 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 2076 enum dma_state { 2077 DMA_STATE_STOP = 0, 2078 DMA_STATE_RUN = 1 2079 }; 2080 2081 static int dma_convert_to_hda_format(struct hda_codec *codec, 2082 unsigned int sample_rate, 2083 unsigned short channels, 2084 unsigned short *hda_format) 2085 { 2086 unsigned int format_val; 2087 2088 format_val = snd_hdac_calc_stream_format(sample_rate, 2089 channels, SNDRV_PCM_FORMAT_S32_LE, 32, 0); 2090 2091 if (hda_format) 2092 *hda_format = (unsigned short)format_val; 2093 2094 return 0; 2095 } 2096 2097 /* 2098 * Reset DMA for DSP download 2099 */ 2100 static 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 2106 if (dma->dmab->area) 2107 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 2119 static int dma_set_state(struct dma_engine *dma, enum dma_state state) 2120 { 2121 bool cmd; 2122 2123 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 2138 static unsigned int dma_get_buffer_size(struct dma_engine *dma) 2139 { 2140 return dma->dmab->bytes; 2141 } 2142 2143 static unsigned char *dma_get_buffer_addr(struct dma_engine *dma) 2144 { 2145 return dma->dmab->area; 2146 } 2147 2148 static 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 2156 static 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 2164 static 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 2171 struct dsp_image_seg { 2172 u32 magic; 2173 u32 chip_addr; 2174 u32 count; 2175 u32 data[0]; 2176 }; 2177 2178 static const u32 g_magic_value = 0x4c46584d; 2179 static const u32 g_chip_addr_magic_value = 0xFFFFFF01; 2180 2181 static bool is_valid(const struct dsp_image_seg *p) 2182 { 2183 return p->magic == g_magic_value; 2184 } 2185 2186 static 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 2191 static bool is_last(const struct dsp_image_seg *p) 2192 { 2193 return p->count == 0; 2194 } 2195 2196 static size_t dsp_sizeof(const struct dsp_image_seg *p) 2197 { 2198 return sizeof(*p) + p->count*sizeof(u32); 2199 } 2200 2201 static 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 */ 2210 #define INVALID_DMA_CHANNEL (~0U) 2211 2212 /* 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 */ 2217 static 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) { 2225 codec_dbg(codec, "hci_write invalid params\n"); 2226 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) { 2234 codec_dbg(codec, "hci_write chipio failed\n"); 2235 return status; 2236 } 2237 count -= 2; 2238 data += 2; 2239 } 2240 return 0; 2241 } 2242 2243 /** 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 */ 2258 static 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 { 2266 int status = 0; 2267 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; 2283 unsigned long timeout; 2284 bool dma_active; 2285 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))) { 2294 codec_dbg(codec, "hci_write\n"); 2295 return dspxfr_hci_write(codec, hci_write); 2296 } 2297 2298 if (fls == NULL || dma_engine == NULL || port_map_mask == 0) { 2299 codec_dbg(codec, "Invalid Params\n"); 2300 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)) { 2315 codec_dbg(codec, "Invalid chip_addx Params\n"); 2316 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) { 2325 codec_dbg(codec, "dma_engine buffer NULL\n"); 2326 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 2337 if (hda_frame_size_words == 0) { 2338 codec_dbg(codec, "frmsz zero\n"); 2339 return -EINVAL; 2340 } 2341 2342 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; 2346 codec_dbg(codec, 2347 "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 2352 if (buffer_size_words < hda_frame_size_words) { 2353 codec_dbg(codec, "dspxfr_one_seg:failed\n"); 2354 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); 2367 codec_dbg(codec, "dspxfr (seg loop)cnt=%u rs=%u remainder=%u\n", 2368 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) 2373 return status; 2374 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)) { 2389 codec_dbg(codec, "dspxfr:DMA did not start\n"); 2390 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); 2400 if (status < 0) 2401 return status; 2402 remainder_words = 0; 2403 } 2404 if (hci_write) { 2405 status = dspxfr_hci_write(codec, hci_write); 2406 if (status < 0) 2407 return status; 2408 hci_write = NULL; 2409 } 2410 2411 timeout = jiffies + msecs_to_jiffies(2000); 2412 do { 2413 dma_active = dsp_is_dma_active(codec, dma_chan); 2414 if (!dma_active) 2415 break; 2416 msleep(20); 2417 } while (time_before(jiffies, timeout)); 2418 if (dma_active) 2419 break; 2420 2421 codec_dbg(codec, "+++++ DMA complete\n"); 2422 dma_set_state(dma_engine, DMA_STATE_STOP); 2423 status = dma_reset(dma_engine); 2424 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 2441 /** 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 2448 * @sample_rate: sampling rate of the stream used for DSP download 2449 * @channels: channels of the stream used for DSP download 2450 * @ovly: TRUE if overlay format is required 2451 * 2452 * Returns zero or a negative error code. 2453 */ 2454 static int dspxfr_image(struct hda_codec *codec, 2455 const struct dsp_image_seg *fls_data, 2456 unsigned int reloc, 2457 unsigned int sample_rate, 2458 unsigned short channels, 2459 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); 2474 if (!dma_engine) 2475 return -ENOMEM; 2476 2477 dma_engine->dmab = kzalloc(sizeof(*dma_engine->dmab), GFP_KERNEL); 2478 if (!dma_engine->dmab) { 2479 kfree(dma_engine); 2480 return -ENOMEM; 2481 } 2482 2483 dma_engine->codec = codec; 2484 dma_convert_to_hda_format(codec, sample_rate, channels, &hda_format); 2485 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 2489 dma_chan = ovly ? INVALID_DMA_CHANNEL : 0; 2490 2491 status = codec_set_converter_format(codec, WIDGET_CHIP_CTRL, 2492 hda_format, &response); 2493 2494 if (status < 0) { 2495 codec_dbg(codec, "set converter format fail\n"); 2496 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) { 2510 codec_dbg(codec, "alloc dmachan fail\n"); 2511 dma_chan = INVALID_DMA_CHANNEL; 2512 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) { 2520 codec_dbg(codec, "alloc ports fail\n"); 2521 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) { 2528 codec_dbg(codec, "set stream chan fail\n"); 2529 goto exit; 2530 } 2531 2532 while ((fls_data != NULL) && !is_last(fls_data)) { 2533 if (!is_valid(fls_data)) { 2534 codec_dbg(codec, "FLS check fail\n"); 2535 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 2560 exit: 2561 if (ovly && (dma_chan != INVALID_DMA_CHANNEL)) 2562 dspio_free_dma_chan(codec, dma_chan); 2563 2564 if (dma_engine->dmab->area) 2565 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 */ 2575 static void dspload_post_setup(struct hda_codec *codec) 2576 { 2577 codec_dbg(codec, "---- dspload_post_setup ------\n"); 2578 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 2587 /** 2588 * dspload_image - Download DSP from a DSP Image Fast Load structure. 2589 * 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 * 2599 * 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. 2603 * Returns zero or a negative error code. 2604 */ 2605 static 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; 2613 unsigned int sample_rate; 2614 unsigned short channels; 2615 2616 codec_dbg(codec, "---- dspload_image begin ------\n"); 2617 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 2624 sample_rate = 48000; 2625 channels = (unsigned short)router_chans; 2626 2627 while (channels > 16) { 2628 sample_rate *= 2; 2629 channels /= 2; 2630 } 2631 2632 do { 2633 codec_dbg(codec, "Ready to program DMA\n"); 2634 if (!ovly) 2635 status = dsp_reset(codec); 2636 2637 if (status < 0) 2638 break; 2639 2640 codec_dbg(codec, "dsp_reset() complete\n"); 2641 status = dspxfr_image(codec, fls, reloc, sample_rate, channels, 2642 ovly); 2643 2644 if (status < 0) 2645 break; 2646 2647 codec_dbg(codec, "dspxfr_image() complete\n"); 2648 if (autostart && !ovly) { 2649 dspload_post_setup(codec); 2650 status = dsp_set_run_state(codec); 2651 } 2652 2653 codec_dbg(codec, "LOAD FINISHED\n"); 2654 } while (0); 2655 2656 return status; 2657 } 2658 2659 #ifdef CONFIG_SND_HDA_CODEC_CA0132_DSP 2660 static 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 } 2671 #else 2672 #define dspload_is_loaded(codec) false 2673 #endif 2674 2675 static bool dspload_wait_loaded(struct hda_codec *codec) 2676 { 2677 unsigned long timeout = jiffies + msecs_to_jiffies(2000); 2678 2679 do { 2680 if (dspload_is_loaded(codec)) { 2681 codec_info(codec, "ca0132 DSP downloaded and running\n"); 2682 return true; 2683 } 2684 msleep(20); 2685 } while (time_before(jiffies, timeout)); 2686 2687 codec_err(codec, "ca0132 failed to download DSP\n"); 2688 return false; 2689 } 2690 2691 /* 2692 * PCM callbacks 2693 */ 2694 static 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; 2701 2702 snd_hda_codec_setup_stream(codec, spec->dacs[0], stream_tag, 0, format); 2703 2704 return 0; 2705 } 2706 2707 static 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; 2712 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 2721 snd_hda_codec_cleanup_stream(codec, spec->dacs[0]); 2722 2723 return 0; 2724 } 2725 2726 static 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 2751 /* 2752 * Digital out 2753 */ 2754 static 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 2762 static 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; 2769 return snd_hda_multi_out_dig_prepare(codec, &spec->multiout, 2770 stream_tag, format, substream); 2771 } 2772 2773 static 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; 2778 return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout); 2779 } 2780 2781 static int ca0132_dig_playback_pcm_close(struct hda_pcm_stream *hinfo, 2782 struct hda_codec *codec, 2783 struct snd_pcm_substream *substream) 2784 { 2785 struct ca0132_spec *spec = codec->spec; 2786 return snd_hda_multi_out_dig_close(codec, &spec->multiout); 2787 } 2788 2789 /* 2790 * Analog capture 2791 */ 2792 static 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 { 2798 snd_hda_codec_setup_stream(codec, hinfo->nid, 2799 stream_tag, 0, format); 2800 2801 return 0; 2802 } 2803 2804 static 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 2813 snd_hda_codec_cleanup_stream(codec, hinfo->nid); 2814 return 0; 2815 } 2816 2817 static 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 2834 /* 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 2869 /* The following are for tuning of products */ 2870 #ifdef ENABLE_TUNING_CONTROLS 2871 2872 static unsigned int voice_focus_vals_lookup[] = { 2873 0x41A00000, 0x41A80000, 0x41B00000, 0x41B80000, 0x41C00000, 0x41C80000, 2874 0x41D00000, 0x41D80000, 0x41E00000, 0x41E80000, 0x41F00000, 0x41F80000, 2875 0x42000000, 0x42040000, 0x42080000, 0x420C0000, 0x42100000, 0x42140000, 2876 0x42180000, 0x421C0000, 0x42200000, 0x42240000, 0x42280000, 0x422C0000, 2877 0x42300000, 0x42340000, 0x42380000, 0x423C0000, 0x42400000, 0x42440000, 2878 0x42480000, 0x424C0000, 0x42500000, 0x42540000, 0x42580000, 0x425C0000, 2879 0x42600000, 0x42640000, 0x42680000, 0x426C0000, 0x42700000, 0x42740000, 2880 0x42780000, 0x427C0000, 0x42800000, 0x42820000, 0x42840000, 0x42860000, 2881 0x42880000, 0x428A0000, 0x428C0000, 0x428E0000, 0x42900000, 0x42920000, 2882 0x42940000, 0x42960000, 0x42980000, 0x429A0000, 0x429C0000, 0x429E0000, 2883 0x42A00000, 0x42A20000, 0x42A40000, 0x42A60000, 0x42A80000, 0x42AA0000, 2884 0x42AC0000, 0x42AE0000, 0x42B00000, 0x42B20000, 0x42B40000, 0x42B60000, 2885 0x42B80000, 0x42BA0000, 0x42BC0000, 0x42BE0000, 0x42C00000, 0x42C20000, 2886 0x42C40000, 0x42C60000, 0x42C80000, 0x42CA0000, 0x42CC0000, 0x42CE0000, 2887 0x42D00000, 0x42D20000, 0x42D40000, 0x42D60000, 0x42D80000, 0x42DA0000, 2888 0x42DC0000, 0x42DE0000, 0x42E00000, 0x42E20000, 0x42E40000, 0x42E60000, 2889 0x42E80000, 0x42EA0000, 0x42EC0000, 0x42EE0000, 0x42F00000, 0x42F20000, 2890 0x42F40000, 0x42F60000, 0x42F80000, 0x42FA0000, 0x42FC0000, 0x42FE0000, 2891 0x43000000, 0x43010000, 0x43020000, 0x43030000, 0x43040000, 0x43050000, 2892 0x43060000, 0x43070000, 0x43080000, 0x43090000, 0x430A0000, 0x430B0000, 2893 0x430C0000, 0x430D0000, 0x430E0000, 0x430F0000, 0x43100000, 0x43110000, 2894 0x43120000, 0x43130000, 0x43140000, 0x43150000, 0x43160000, 0x43170000, 2895 0x43180000, 0x43190000, 0x431A0000, 0x431B0000, 0x431C0000, 0x431D0000, 2896 0x431E0000, 0x431F0000, 0x43200000, 0x43210000, 0x43220000, 0x43230000, 2897 0x43240000, 0x43250000, 0x43260000, 0x43270000, 0x43280000, 0x43290000, 2898 0x432A0000, 0x432B0000, 0x432C0000, 0x432D0000, 0x432E0000, 0x432F0000, 2899 0x43300000, 0x43310000, 0x43320000, 0x43330000, 0x43340000 2900 }; 2901 2902 static unsigned int mic_svm_vals_lookup[] = { 2903 0x00000000, 0x3C23D70A, 0x3CA3D70A, 0x3CF5C28F, 0x3D23D70A, 0x3D4CCCCD, 2904 0x3D75C28F, 0x3D8F5C29, 0x3DA3D70A, 0x3DB851EC, 0x3DCCCCCD, 0x3DE147AE, 2905 0x3DF5C28F, 0x3E051EB8, 0x3E0F5C29, 0x3E19999A, 0x3E23D70A, 0x3E2E147B, 2906 0x3E3851EC, 0x3E428F5C, 0x3E4CCCCD, 0x3E570A3D, 0x3E6147AE, 0x3E6B851F, 2907 0x3E75C28F, 0x3E800000, 0x3E851EB8, 0x3E8A3D71, 0x3E8F5C29, 0x3E947AE1, 2908 0x3E99999A, 0x3E9EB852, 0x3EA3D70A, 0x3EA8F5C3, 0x3EAE147B, 0x3EB33333, 2909 0x3EB851EC, 0x3EBD70A4, 0x3EC28F5C, 0x3EC7AE14, 0x3ECCCCCD, 0x3ED1EB85, 2910 0x3ED70A3D, 0x3EDC28F6, 0x3EE147AE, 0x3EE66666, 0x3EEB851F, 0x3EF0A3D7, 2911 0x3EF5C28F, 0x3EFAE148, 0x3F000000, 0x3F028F5C, 0x3F051EB8, 0x3F07AE14, 2912 0x3F0A3D71, 0x3F0CCCCD, 0x3F0F5C29, 0x3F11EB85, 0x3F147AE1, 0x3F170A3D, 2913 0x3F19999A, 0x3F1C28F6, 0x3F1EB852, 0x3F2147AE, 0x3F23D70A, 0x3F266666, 2914 0x3F28F5C3, 0x3F2B851F, 0x3F2E147B, 0x3F30A3D7, 0x3F333333, 0x3F35C28F, 2915 0x3F3851EC, 0x3F3AE148, 0x3F3D70A4, 0x3F400000, 0x3F428F5C, 0x3F451EB8, 2916 0x3F47AE14, 0x3F4A3D71, 0x3F4CCCCD, 0x3F4F5C29, 0x3F51EB85, 0x3F547AE1, 2917 0x3F570A3D, 0x3F59999A, 0x3F5C28F6, 0x3F5EB852, 0x3F6147AE, 0x3F63D70A, 2918 0x3F666666, 0x3F68F5C3, 0x3F6B851F, 0x3F6E147B, 0x3F70A3D7, 0x3F733333, 2919 0x3F75C28F, 0x3F7851EC, 0x3F7AE148, 0x3F7D70A4, 0x3F800000 2920 }; 2921 2922 static unsigned int equalizer_vals_lookup[] = { 2923 0xC1C00000, 0xC1B80000, 0xC1B00000, 0xC1A80000, 0xC1A00000, 0xC1980000, 2924 0xC1900000, 0xC1880000, 0xC1800000, 0xC1700000, 0xC1600000, 0xC1500000, 2925 0xC1400000, 0xC1300000, 0xC1200000, 0xC1100000, 0xC1000000, 0xC0E00000, 2926 0xC0C00000, 0xC0A00000, 0xC0800000, 0xC0400000, 0xC0000000, 0xBF800000, 2927 0x00000000, 0x3F800000, 0x40000000, 0x40400000, 0x40800000, 0x40A00000, 2928 0x40C00000, 0x40E00000, 0x41000000, 0x41100000, 0x41200000, 0x41300000, 2929 0x41400000, 0x41500000, 0x41600000, 0x41700000, 0x41800000, 0x41880000, 2930 0x41900000, 0x41980000, 0x41A00000, 0x41A80000, 0x41B00000, 0x41B80000, 2931 0x41C00000 2932 }; 2933 2934 static 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 2952 static 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 2965 static 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 2978 static 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 3000 static 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 3013 static 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 3035 static 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 3048 static 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 3070 static const DECLARE_TLV_DB_SCALE(voice_focus_db_scale, 2000, 100, 0); 3071 static const DECLARE_TLV_DB_SCALE(eq_db_scale, -2400, 100, 0); 3072 3073 static int add_tuning_control(struct hda_codec *codec, 3074 hda_nid_t pnid, hda_nid_t nid, 3075 const char *name, int dir) 3076 { 3077 char namestr[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 3078 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 3113 static 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 3131 static 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 3147 /* 3148 * 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 */ 3153 static 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 3162 codec_dbg(codec, "ca0132_select_out\n"); 3163 3164 snd_hda_power_up_pm(codec); 3165 3166 auto_jack = spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID]; 3167 3168 if (auto_jack) 3169 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_hp); 3170 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) { 3180 codec_dbg(codec, "ca0132_select_out speaker\n"); 3181 /*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); 3205 snd_hda_set_pin_ctl(codec, spec->out_pins[1], 3206 pin_ctl & ~PIN_HP); 3207 /* enable speaker node */ 3208 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0, 3209 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); 3210 snd_hda_set_pin_ctl(codec, spec->out_pins[0], 3211 pin_ctl | PIN_OUT); 3212 } else { 3213 codec_dbg(codec, "ca0132_select_out hp\n"); 3214 /*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); 3238 snd_hda_set_pin_ctl(codec, spec->out_pins[0], 3239 pin_ctl & ~PIN_HP); 3240 /* enable headphone*/ 3241 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0, 3242 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); 3243 snd_hda_set_pin_ctl(codec, spec->out_pins[1], 3244 pin_ctl | PIN_HP); 3245 } 3246 3247 exit: 3248 snd_hda_power_down_pm(codec); 3249 3250 return err < 0 ? err : 0; 3251 } 3252 3253 static 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); 3257 struct hda_jack_tbl *jack; 3258 3259 ca0132_select_out(spec->codec); 3260 jack = snd_hda_jack_tbl_get(spec->codec, spec->unsol_tag_hp); 3261 if (jack) { 3262 jack->block_report = 0; 3263 snd_hda_jack_report_sync(spec->codec); 3264 } 3265 } 3266 3267 static void ca0132_set_dmic(struct hda_codec *codec, int enable); 3268 static int ca0132_mic_boost_set(struct hda_codec *codec, long val); 3269 static int ca0132_effects_set(struct hda_codec *codec, hda_nid_t nid, long val); 3270 3271 /* 3272 * Select the active VIP source 3273 */ 3274 static int ca0132_set_vipsource(struct hda_codec *codec, int val) 3275 { 3276 struct ca0132_spec *spec = codec->spec; 3277 unsigned int tmp; 3278 3279 if (spec->dsp_state != DSP_DOWNLOADED) 3280 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 */ 3318 static 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 3324 codec_dbg(codec, "ca0132_select_mic\n"); 3325 3326 snd_hda_power_up_pm(codec); 3327 3328 auto_jack = spec->vnode_lswitch[VNID_AMIC1_ASEL - VNODE_START_NID]; 3329 3330 if (auto_jack) 3331 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_amic1); 3332 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 3359 snd_hda_power_down_pm(codec); 3360 3361 return 0; 3362 } 3363 3364 /* 3365 * Check if VNODE settings take effect immediately. 3366 */ 3367 static 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; 3373 3374 switch (vnid) { 3375 case VNID_SPK: 3376 nid = spec->shared_out_nid; 3377 break; 3378 case VNID_MIC: 3379 nid = spec->shared_mic_nid; 3380 break; 3381 default: 3382 return false; 3383 } 3384 3385 if (shared_nid) 3386 *shared_nid = nid; 3387 3388 return true; 3389 } 3390 3391 /* 3392 * The following functions are control change helpers. 3393 * They return 0 if no changed. Return 1 if changed. 3394 */ 3395 static 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 /* 3415 * Set the effects parameters 3416 */ 3417 static 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 3446 codec_dbg(codec, "ca0132_effect_set: nid=0x%x, val=%ld\n", 3447 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 3459 /* 3460 * Turn on/off Playback Enhancements 3461 */ 3462 static 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 3468 codec_dbg(codec, "ca0132_pe_switch_set: val=%ld\n", 3469 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 3480 /* Check if Mic1 is streaming, if so, stop streaming */ 3481 static 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. */ 3494 static 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 /* 3505 * Turn on/off CrystalVoice 3506 */ 3507 static 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 3514 codec_dbg(codec, "ca0132_cvoice_switch_set: val=%ld\n", 3515 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 3533 static 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 3548 static 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 3605 static 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 3621 static 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 3631 static 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 3644 codec_dbg(codec, "ca0132_voicefx_put: sel=%d, preset=%s\n", 3645 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 3668 static 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 3705 static 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 3715 codec_dbg(codec, "ca0132_switch_put: nid=0x%x, val=%ld\n", 3716 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 3765 exit: 3766 snd_hda_power_down(codec); 3767 return changed; 3768 } 3769 3770 /* 3771 * Volume related 3772 */ 3773 static 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 3811 static 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 3832 static 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 3874 static 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 3912 static int add_fx_switch(struct hda_codec *codec, hda_nid_t nid, 3913 const char *pfx, int dir) 3914 { 3915 char namestr[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 3916 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 3923 static 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 */ 3938 static 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 3960 static 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 4022 /* 4023 * PCM 4024 */ 4025 static const struct hda_pcm_stream ca0132_pcm_analog_playback = { 4026 .substreams = 1, 4027 .channels_min = 2, 4028 .channels_max = 6, 4029 .ops = { 4030 .prepare = ca0132_playback_pcm_prepare, 4031 .cleanup = ca0132_playback_pcm_cleanup, 4032 .get_delay = ca0132_playback_pcm_delay, 4033 }, 4034 }; 4035 4036 static const struct hda_pcm_stream ca0132_pcm_analog_capture = { 4037 .substreams = 1, 4038 .channels_min = 2, 4039 .channels_max = 2, 4040 .ops = { 4041 .prepare = ca0132_capture_pcm_prepare, 4042 .cleanup = ca0132_capture_pcm_cleanup, 4043 .get_delay = ca0132_capture_pcm_delay, 4044 }, 4045 }; 4046 4047 static const struct hda_pcm_stream ca0132_pcm_digital_playback = { 4048 .substreams = 1, 4049 .channels_min = 2, 4050 .channels_max = 2, 4051 .ops = { 4052 .open = ca0132_dig_playback_pcm_open, 4053 .close = ca0132_dig_playback_pcm_close, 4054 .prepare = ca0132_dig_playback_pcm_prepare, 4055 .cleanup = ca0132_dig_playback_pcm_cleanup 4056 }, 4057 }; 4058 4059 static const struct hda_pcm_stream ca0132_pcm_digital_capture = { 4060 .substreams = 1, 4061 .channels_min = 2, 4062 .channels_max = 2, 4063 }; 4064 4065 static int ca0132_build_pcms(struct hda_codec *codec) 4066 { 4067 struct ca0132_spec *spec = codec->spec; 4068 struct hda_pcm *info; 4069 4070 info = snd_hda_codec_pcm_new(codec, "CA0132 Analog"); 4071 if (!info) 4072 return -ENOMEM; 4073 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; 4078 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1; 4079 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[0]; 4080 4081 info = snd_hda_codec_pcm_new(codec, "CA0132 Analog Mic-In2"); 4082 if (!info) 4083 return -ENOMEM; 4084 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]; 4087 4088 info = snd_hda_codec_pcm_new(codec, "CA0132 What U Hear"); 4089 if (!info) 4090 return -ENOMEM; 4091 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]; 4094 4095 if (!spec->dig_out && !spec->dig_in) 4096 return 0; 4097 4098 info = snd_hda_codec_pcm_new(codec, "CA0132 Digital"); 4099 if (!info) 4100 return -ENOMEM; 4101 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 } 4112 4113 return 0; 4114 } 4115 4116 static void init_output(struct hda_codec *codec, hda_nid_t pin, hda_nid_t dac) 4117 { 4118 if (pin) { 4119 snd_hda_set_pin_ctl(codec, pin, PIN_HP); 4120 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 4130 static void init_input(struct hda_codec *codec, hda_nid_t pin, hda_nid_t adc) 4131 { 4132 if (pin) { 4133 snd_hda_set_pin_ctl(codec, pin, PIN_VREF80); 4134 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 4151 static 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 */ 4163 static 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 4170 codec_dbg(codec, "ca0132_set_dmic: enable=%d\n", enable); 4171 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 */ 4207 static 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 */ 4252 static 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 4272 static void ca0132_refresh_widget_caps(struct hda_codec *codec) 4273 { 4274 struct ca0132_spec *spec = codec->spec; 4275 int i; 4276 4277 codec_dbg(codec, "ca0132_refresh_widget_caps.\n"); 4278 snd_hda_codec_update_widgets(codec); 4279 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 */ 4295 static void ca0132_setup_defaults(struct hda_codec *codec) 4296 { 4297 struct ca0132_spec *spec = codec->spec; 4298 unsigned int tmp; 4299 int num_fx; 4300 int idx, i; 4301 4302 if (spec->dsp_state != DSP_DOWNLOADED) 4303 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 */ 4339 static 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 */ 4352 static 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 } 4357 4358 static 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 4367 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); 4368 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); 4369 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000); 4370 } 4371 4372 static bool ca0132_download_dsp_images(struct hda_codec *codec) 4373 { 4374 bool dsp_loaded = false; 4375 const struct dsp_image_seg *dsp_os_image; 4376 const struct firmware *fw_entry; 4377 4378 if (request_firmware(&fw_entry, EFX_FILE, codec->card->dev) != 0) 4379 return false; 4380 4381 dsp_os_image = (struct dsp_image_seg *)(fw_entry->data); 4382 if (dspload_image(codec, dsp_os_image, 0, 0, true, 0)) { 4383 codec_err(codec, "ca0132 DSP load image failed\n"); 4384 goto exit_download; 4385 } 4386 4387 dsp_loaded = dspload_wait_loaded(codec); 4388 4389 exit_download: 4390 release_firmware(fw_entry); 4391 4392 return dsp_loaded; 4393 } 4394 4395 static void ca0132_download_dsp(struct hda_codec *codec) 4396 { 4397 struct ca0132_spec *spec = codec->spec; 4398 4399 #ifndef CONFIG_SND_HDA_CODEC_CA0132_DSP 4400 return; /* NOP */ 4401 #endif 4402 4403 if (spec->dsp_state == DSP_DOWNLOAD_FAILED) 4404 return; /* don't retry failures */ 4405 4406 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; 4412 4413 if (spec->dsp_state == DSP_DOWNLOADED) 4414 ca0132_set_dsp_msr(codec, true); 4415 } 4416 4417 static void ca0132_process_dsp_response(struct hda_codec *codec, 4418 struct hda_jack_callback *callback) 4419 { 4420 struct ca0132_spec *spec = codec->spec; 4421 4422 codec_dbg(codec, "ca0132_process_dsp_response\n"); 4423 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 4431 static void hp_callback(struct hda_codec *codec, struct hda_jack_callback *cb) 4432 { 4433 struct ca0132_spec *spec = codec->spec; 4434 struct hda_jack_tbl *tbl; 4435 4436 /* Delay enabling the HP amp, to let the mic-detection 4437 * state machine run. 4438 */ 4439 cancel_delayed_work_sync(&spec->unsol_hp_work); 4440 schedule_delayed_work(&spec->unsol_hp_work, msecs_to_jiffies(500)); 4441 tbl = snd_hda_jack_tbl_get(codec, cb->nid); 4442 if (tbl) 4443 tbl->block_report = 1; 4444 } 4445 4446 static void amic_callback(struct hda_codec *codec, struct hda_jack_callback *cb) 4447 { 4448 ca0132_select_mic(codec); 4449 } 4450 4451 static void ca0132_init_unsol(struct hda_codec *codec) 4452 { 4453 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, 4456 amic_callback); 4457 snd_hda_jack_detect_enable_callback(codec, UNSOL_TAG_DSP, 4458 ca0132_process_dsp_response); 4459 } 4460 4461 /* 4462 * Verbs tables. 4463 */ 4464 4465 /* Sends before DSP download. */ 4466 static struct hda_verb ca0132_base_init_verbs[] = { 4467 /*enable ct extension*/ 4468 {0x15, VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE, 0x1}, 4469 {} 4470 }; 4471 4472 /* Send at exit. */ 4473 static 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. */ 4482 static 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 4516 static void ca0132_init_chip(struct hda_codec *codec) 4517 { 4518 struct ca0132_spec *spec = codec->spec; 4519 int num_fx; 4520 int i; 4521 unsigned int on; 4522 4523 mutex_init(&spec->chipio_mutex); 4524 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 4549 #ifdef ENABLE_TUNING_CONTROLS 4550 ca0132_init_tuning_defaults(codec); 4551 #endif 4552 } 4553 4554 static void ca0132_exit_chip(struct hda_codec *codec) 4555 { 4556 /* put any chip cleanup stuffs here. */ 4557 4558 if (dspload_is_loaded(codec)) 4559 dsp_reset(codec); 4560 } 4561 4562 static 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 4568 if (spec->dsp_state != DSP_DOWNLOAD_FAILED) 4569 spec->dsp_state = DSP_DOWNLOAD_INIT; 4570 spec->curr_chip_addx = INVALID_CHIP_ADDRESS; 4571 4572 snd_hda_power_up_pm(codec); 4573 4574 ca0132_init_unsol(codec); 4575 4576 ca0132_init_params(codec); 4577 ca0132_init_flags(codec); 4578 snd_hda_sequence_write(codec, spec->base_init_verbs); 4579 ca0132_download_dsp(codec); 4580 ca0132_refresh_widget_caps(codec); 4581 ca0132_setup_defaults(codec); 4582 ca0132_init_analog_mic2(codec); 4583 ca0132_init_dmic(codec); 4584 4585 for (i = 0; i < spec->num_outputs; i++) 4586 init_output(codec, spec->out_pins[i], spec->dacs[0]); 4587 4588 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 4595 snd_hda_sequence_write(codec, spec->chip_init_verbs); 4596 snd_hda_sequence_write(codec, spec->spec_init_verbs); 4597 4598 ca0132_select_out(codec); 4599 ca0132_select_mic(codec); 4600 4601 snd_hda_jack_report_sync(codec); 4602 4603 snd_hda_power_down_pm(codec); 4604 4605 return 0; 4606 } 4607 4608 static void ca0132_free(struct hda_codec *codec) 4609 { 4610 struct ca0132_spec *spec = codec->spec; 4611 4612 cancel_delayed_work_sync(&spec->unsol_hp_work); 4613 snd_hda_power_up(codec); 4614 snd_hda_sequence_write(codec, spec->base_exit_verbs); 4615 ca0132_exit_chip(codec); 4616 snd_hda_power_down(codec); 4617 kfree(spec->spec_init_verbs); 4618 kfree(codec->spec); 4619 } 4620 4621 static const struct hda_codec_ops ca0132_patch_ops = { 4622 .build_controls = ca0132_build_controls, 4623 .build_pcms = ca0132_build_pcms, 4624 .init = ca0132_init, 4625 .free = ca0132_free, 4626 .unsol_event = snd_hda_jack_unsol_event, 4627 }; 4628 4629 static 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 4642 if (spec->quirk == QUIRK_ALIENWARE) { 4643 codec_dbg(codec, "ca0132_config: QUIRK_ALIENWARE applied.\n"); 4644 snd_hda_apply_pincfgs(codec, alienware_pincfgs); 4645 4646 spec->num_outputs = 2; 4647 spec->out_pins[0] = 0x0b; /* speaker out */ 4648 spec->out_pins[1] = 0x0f; 4649 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 */ 4665 spec->out_pins[1] = 0x10; /* headphone out */ 4666 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; 4689 } 4690 } 4691 4692 static 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 4737 static int patch_ca0132(struct hda_codec *codec) 4738 { 4739 struct ca0132_spec *spec; 4740 int err; 4741 const struct snd_pci_quirk *quirk; 4742 4743 codec_dbg(codec, "patch_ca0132\n"); 4744 4745 spec = kzalloc(sizeof(*spec), GFP_KERNEL); 4746 if (!spec) 4747 return -ENOMEM; 4748 codec->spec = spec; 4749 spec->codec = codec; 4750 4751 codec->patch_ops = ca0132_patch_ops; 4752 codec->pcm_format_first = 1; 4753 codec->no_sticky_stream = 1; 4754 4755 /* 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 4762 spec->dsp_state = DSP_DOWNLOAD_INIT; 4763 spec->num_mixers = 1; 4764 spec->mixers[0] = ca0132_mixer; 4765 4766 spec->base_init_verbs = ca0132_base_init_verbs; 4767 spec->base_exit_verbs = ca0132_base_exit_verbs; 4768 4769 INIT_DELAYED_WORK(&spec->unsol_hp_work, ca0132_unsol_hp_delayed); 4770 4771 ca0132_init_chip(codec); 4772 4773 ca0132_config(codec); 4774 4775 err = ca0132_prepare_verbs(codec); 4776 if (err < 0) 4777 return err; 4778 4779 err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, NULL); 4780 if (err < 0) 4781 return err; 4782 4783 return 0; 4784 } 4785 4786 /* 4787 * patch entries 4788 */ 4789 static struct hda_device_id snd_hda_id_ca0132[] = { 4790 HDA_CODEC_ENTRY(0x11020011, "CA0132", patch_ca0132), 4791 {} /* terminator */ 4792 }; 4793 MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_ca0132); 4794 4795 MODULE_LICENSE("GPL"); 4796 MODULE_DESCRIPTION("Creative Sound Core3D codec"); 4797 4798 static struct hda_codec_driver ca0132_driver = { 4799 .id = snd_hda_id_ca0132, 4800 }; 4801 4802 module_hda_codec_driver(ca0132_driver); 4803