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 {} 784 }; 785 786 /* 787 * CA0132 codec access 788 */ 789 static unsigned int codec_send_command(struct hda_codec *codec, hda_nid_t nid, 790 unsigned int verb, unsigned int parm, unsigned int *res) 791 { 792 unsigned int response; 793 response = snd_hda_codec_read(codec, nid, 0, verb, parm); 794 *res = response; 795 796 return ((response == -1) ? -1 : 0); 797 } 798 799 static int codec_set_converter_format(struct hda_codec *codec, hda_nid_t nid, 800 unsigned short converter_format, unsigned int *res) 801 { 802 return codec_send_command(codec, nid, VENDOR_CHIPIO_STREAM_FORMAT, 803 converter_format & 0xffff, res); 804 } 805 806 static int codec_set_converter_stream_channel(struct hda_codec *codec, 807 hda_nid_t nid, unsigned char stream, 808 unsigned char channel, unsigned int *res) 809 { 810 unsigned char converter_stream_channel = 0; 811 812 converter_stream_channel = (stream << 4) | (channel & 0x0f); 813 return codec_send_command(codec, nid, AC_VERB_SET_CHANNEL_STREAMID, 814 converter_stream_channel, res); 815 } 816 817 /* Chip access helper function */ 818 static int chipio_send(struct hda_codec *codec, 819 unsigned int reg, 820 unsigned int data) 821 { 822 unsigned int res; 823 unsigned long timeout = jiffies + msecs_to_jiffies(1000); 824 825 /* send bits of data specified by reg */ 826 do { 827 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, 828 reg, data); 829 if (res == VENDOR_STATUS_CHIPIO_OK) 830 return 0; 831 msleep(20); 832 } while (time_before(jiffies, timeout)); 833 834 return -EIO; 835 } 836 837 /* 838 * Write chip address through the vendor widget -- NOT protected by the Mutex! 839 */ 840 static int chipio_write_address(struct hda_codec *codec, 841 unsigned int chip_addx) 842 { 843 struct ca0132_spec *spec = codec->spec; 844 int res; 845 846 if (spec->curr_chip_addx == chip_addx) 847 return 0; 848 849 /* send low 16 bits of the address */ 850 res = chipio_send(codec, VENDOR_CHIPIO_ADDRESS_LOW, 851 chip_addx & 0xffff); 852 853 if (res != -EIO) { 854 /* send high 16 bits of the address */ 855 res = chipio_send(codec, VENDOR_CHIPIO_ADDRESS_HIGH, 856 chip_addx >> 16); 857 } 858 859 spec->curr_chip_addx = (res < 0) ? ~0UL : chip_addx; 860 861 return res; 862 } 863 864 /* 865 * Write data through the vendor widget -- NOT protected by the Mutex! 866 */ 867 static int chipio_write_data(struct hda_codec *codec, unsigned int data) 868 { 869 struct ca0132_spec *spec = codec->spec; 870 int res; 871 872 /* send low 16 bits of the data */ 873 res = chipio_send(codec, VENDOR_CHIPIO_DATA_LOW, data & 0xffff); 874 875 if (res != -EIO) { 876 /* send high 16 bits of the data */ 877 res = chipio_send(codec, VENDOR_CHIPIO_DATA_HIGH, 878 data >> 16); 879 } 880 881 /*If no error encountered, automatically increment the address 882 as per chip behaviour*/ 883 spec->curr_chip_addx = (res != -EIO) ? 884 (spec->curr_chip_addx + 4) : ~0UL; 885 return res; 886 } 887 888 /* 889 * Write multiple data through the vendor widget -- NOT protected by the Mutex! 890 */ 891 static int chipio_write_data_multiple(struct hda_codec *codec, 892 const u32 *data, 893 unsigned int count) 894 { 895 int status = 0; 896 897 if (data == NULL) { 898 codec_dbg(codec, "chipio_write_data null ptr\n"); 899 return -EINVAL; 900 } 901 902 while ((count-- != 0) && (status == 0)) 903 status = chipio_write_data(codec, *data++); 904 905 return status; 906 } 907 908 909 /* 910 * Read data through the vendor widget -- NOT protected by the Mutex! 911 */ 912 static int chipio_read_data(struct hda_codec *codec, unsigned int *data) 913 { 914 struct ca0132_spec *spec = codec->spec; 915 int res; 916 917 /* post read */ 918 res = chipio_send(codec, VENDOR_CHIPIO_HIC_POST_READ, 0); 919 920 if (res != -EIO) { 921 /* read status */ 922 res = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); 923 } 924 925 if (res != -EIO) { 926 /* read data */ 927 *data = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, 928 VENDOR_CHIPIO_HIC_READ_DATA, 929 0); 930 } 931 932 /*If no error encountered, automatically increment the address 933 as per chip behaviour*/ 934 spec->curr_chip_addx = (res != -EIO) ? 935 (spec->curr_chip_addx + 4) : ~0UL; 936 return res; 937 } 938 939 /* 940 * Write given value to the given address through the chip I/O widget. 941 * protected by the Mutex 942 */ 943 static int chipio_write(struct hda_codec *codec, 944 unsigned int chip_addx, const unsigned int data) 945 { 946 struct ca0132_spec *spec = codec->spec; 947 int err; 948 949 mutex_lock(&spec->chipio_mutex); 950 951 /* write the address, and if successful proceed to write data */ 952 err = chipio_write_address(codec, chip_addx); 953 if (err < 0) 954 goto exit; 955 956 err = chipio_write_data(codec, data); 957 if (err < 0) 958 goto exit; 959 960 exit: 961 mutex_unlock(&spec->chipio_mutex); 962 return err; 963 } 964 965 /* 966 * Write multiple values to the given address through the chip I/O widget. 967 * protected by the Mutex 968 */ 969 static int chipio_write_multiple(struct hda_codec *codec, 970 u32 chip_addx, 971 const u32 *data, 972 unsigned int count) 973 { 974 struct ca0132_spec *spec = codec->spec; 975 int status; 976 977 mutex_lock(&spec->chipio_mutex); 978 status = chipio_write_address(codec, chip_addx); 979 if (status < 0) 980 goto error; 981 982 status = chipio_write_data_multiple(codec, data, count); 983 error: 984 mutex_unlock(&spec->chipio_mutex); 985 986 return status; 987 } 988 989 /* 990 * Read the given address through the chip I/O widget 991 * protected by the Mutex 992 */ 993 static int chipio_read(struct hda_codec *codec, 994 unsigned int chip_addx, unsigned int *data) 995 { 996 struct ca0132_spec *spec = codec->spec; 997 int err; 998 999 mutex_lock(&spec->chipio_mutex); 1000 1001 /* write the address, and if successful proceed to write data */ 1002 err = chipio_write_address(codec, chip_addx); 1003 if (err < 0) 1004 goto exit; 1005 1006 err = chipio_read_data(codec, data); 1007 if (err < 0) 1008 goto exit; 1009 1010 exit: 1011 mutex_unlock(&spec->chipio_mutex); 1012 return err; 1013 } 1014 1015 /* 1016 * Set chip control flags through the chip I/O widget. 1017 */ 1018 static void chipio_set_control_flag(struct hda_codec *codec, 1019 enum control_flag_id flag_id, 1020 bool flag_state) 1021 { 1022 unsigned int val; 1023 unsigned int flag_bit; 1024 1025 flag_bit = (flag_state ? 1 : 0); 1026 val = (flag_bit << 7) | (flag_id); 1027 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1028 VENDOR_CHIPIO_FLAG_SET, val); 1029 } 1030 1031 /* 1032 * Set chip parameters through the chip I/O widget. 1033 */ 1034 static void chipio_set_control_param(struct hda_codec *codec, 1035 enum control_param_id param_id, int param_val) 1036 { 1037 struct ca0132_spec *spec = codec->spec; 1038 int val; 1039 1040 if ((param_id < 32) && (param_val < 8)) { 1041 val = (param_val << 5) | (param_id); 1042 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1043 VENDOR_CHIPIO_PARAM_SET, val); 1044 } else { 1045 mutex_lock(&spec->chipio_mutex); 1046 if (chipio_send(codec, VENDOR_CHIPIO_STATUS, 0) == 0) { 1047 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1048 VENDOR_CHIPIO_PARAM_EX_ID_SET, 1049 param_id); 1050 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1051 VENDOR_CHIPIO_PARAM_EX_VALUE_SET, 1052 param_val); 1053 } 1054 mutex_unlock(&spec->chipio_mutex); 1055 } 1056 } 1057 1058 /* 1059 * Set sampling rate of the connection point. 1060 */ 1061 static void chipio_set_conn_rate(struct hda_codec *codec, 1062 int connid, enum ca0132_sample_rate rate) 1063 { 1064 chipio_set_control_param(codec, CONTROL_PARAM_CONN_POINT_ID, connid); 1065 chipio_set_control_param(codec, CONTROL_PARAM_CONN_POINT_SAMPLE_RATE, 1066 rate); 1067 } 1068 1069 /* 1070 * Enable clocks. 1071 */ 1072 static void chipio_enable_clocks(struct hda_codec *codec) 1073 { 1074 struct ca0132_spec *spec = codec->spec; 1075 1076 mutex_lock(&spec->chipio_mutex); 1077 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1078 VENDOR_CHIPIO_8051_ADDRESS_LOW, 0); 1079 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1080 VENDOR_CHIPIO_PLL_PMU_WRITE, 0xff); 1081 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1082 VENDOR_CHIPIO_8051_ADDRESS_LOW, 5); 1083 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1084 VENDOR_CHIPIO_PLL_PMU_WRITE, 0x0b); 1085 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1086 VENDOR_CHIPIO_8051_ADDRESS_LOW, 6); 1087 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1088 VENDOR_CHIPIO_PLL_PMU_WRITE, 0xff); 1089 mutex_unlock(&spec->chipio_mutex); 1090 } 1091 1092 /* 1093 * CA0132 DSP IO stuffs 1094 */ 1095 static int dspio_send(struct hda_codec *codec, unsigned int reg, 1096 unsigned int data) 1097 { 1098 int res; 1099 unsigned long timeout = jiffies + msecs_to_jiffies(1000); 1100 1101 /* send bits of data specified by reg to dsp */ 1102 do { 1103 res = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, reg, data); 1104 if ((res >= 0) && (res != VENDOR_STATUS_DSPIO_BUSY)) 1105 return res; 1106 msleep(20); 1107 } while (time_before(jiffies, timeout)); 1108 1109 return -EIO; 1110 } 1111 1112 /* 1113 * Wait for DSP to be ready for commands 1114 */ 1115 static void dspio_write_wait(struct hda_codec *codec) 1116 { 1117 int status; 1118 unsigned long timeout = jiffies + msecs_to_jiffies(1000); 1119 1120 do { 1121 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, 1122 VENDOR_DSPIO_STATUS, 0); 1123 if ((status == VENDOR_STATUS_DSPIO_OK) || 1124 (status == VENDOR_STATUS_DSPIO_SCP_RESPONSE_QUEUE_EMPTY)) 1125 break; 1126 msleep(1); 1127 } while (time_before(jiffies, timeout)); 1128 } 1129 1130 /* 1131 * Write SCP data to DSP 1132 */ 1133 static int dspio_write(struct hda_codec *codec, unsigned int scp_data) 1134 { 1135 struct ca0132_spec *spec = codec->spec; 1136 int status; 1137 1138 dspio_write_wait(codec); 1139 1140 mutex_lock(&spec->chipio_mutex); 1141 status = dspio_send(codec, VENDOR_DSPIO_SCP_WRITE_DATA_LOW, 1142 scp_data & 0xffff); 1143 if (status < 0) 1144 goto error; 1145 1146 status = dspio_send(codec, VENDOR_DSPIO_SCP_WRITE_DATA_HIGH, 1147 scp_data >> 16); 1148 if (status < 0) 1149 goto error; 1150 1151 /* OK, now check if the write itself has executed*/ 1152 status = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, 1153 VENDOR_DSPIO_STATUS, 0); 1154 error: 1155 mutex_unlock(&spec->chipio_mutex); 1156 1157 return (status == VENDOR_STATUS_DSPIO_SCP_COMMAND_QUEUE_FULL) ? 1158 -EIO : 0; 1159 } 1160 1161 /* 1162 * Write multiple SCP data to DSP 1163 */ 1164 static int dspio_write_multiple(struct hda_codec *codec, 1165 unsigned int *buffer, unsigned int size) 1166 { 1167 int status = 0; 1168 unsigned int count; 1169 1170 if ((buffer == NULL)) 1171 return -EINVAL; 1172 1173 count = 0; 1174 while (count < size) { 1175 status = dspio_write(codec, *buffer++); 1176 if (status != 0) 1177 break; 1178 count++; 1179 } 1180 1181 return status; 1182 } 1183 1184 static int dspio_read(struct hda_codec *codec, unsigned int *data) 1185 { 1186 int status; 1187 1188 status = dspio_send(codec, VENDOR_DSPIO_SCP_POST_READ_DATA, 0); 1189 if (status == -EIO) 1190 return status; 1191 1192 status = dspio_send(codec, VENDOR_DSPIO_STATUS, 0); 1193 if (status == -EIO || 1194 status == VENDOR_STATUS_DSPIO_SCP_RESPONSE_QUEUE_EMPTY) 1195 return -EIO; 1196 1197 *data = snd_hda_codec_read(codec, WIDGET_DSP_CTRL, 0, 1198 VENDOR_DSPIO_SCP_READ_DATA, 0); 1199 1200 return 0; 1201 } 1202 1203 static int dspio_read_multiple(struct hda_codec *codec, unsigned int *buffer, 1204 unsigned int *buf_size, unsigned int size_count) 1205 { 1206 int status = 0; 1207 unsigned int size = *buf_size; 1208 unsigned int count; 1209 unsigned int skip_count; 1210 unsigned int dummy; 1211 1212 if ((buffer == NULL)) 1213 return -1; 1214 1215 count = 0; 1216 while (count < size && count < size_count) { 1217 status = dspio_read(codec, buffer++); 1218 if (status != 0) 1219 break; 1220 count++; 1221 } 1222 1223 skip_count = count; 1224 if (status == 0) { 1225 while (skip_count < size) { 1226 status = dspio_read(codec, &dummy); 1227 if (status != 0) 1228 break; 1229 skip_count++; 1230 } 1231 } 1232 *buf_size = count; 1233 1234 return status; 1235 } 1236 1237 /* 1238 * Construct the SCP header using corresponding fields 1239 */ 1240 static inline unsigned int 1241 make_scp_header(unsigned int target_id, unsigned int source_id, 1242 unsigned int get_flag, unsigned int req, 1243 unsigned int device_flag, unsigned int resp_flag, 1244 unsigned int error_flag, unsigned int data_size) 1245 { 1246 unsigned int header = 0; 1247 1248 header = (data_size & 0x1f) << 27; 1249 header |= (error_flag & 0x01) << 26; 1250 header |= (resp_flag & 0x01) << 25; 1251 header |= (device_flag & 0x01) << 24; 1252 header |= (req & 0x7f) << 17; 1253 header |= (get_flag & 0x01) << 16; 1254 header |= (source_id & 0xff) << 8; 1255 header |= target_id & 0xff; 1256 1257 return header; 1258 } 1259 1260 /* 1261 * Extract corresponding fields from SCP header 1262 */ 1263 static inline void 1264 extract_scp_header(unsigned int header, 1265 unsigned int *target_id, unsigned int *source_id, 1266 unsigned int *get_flag, unsigned int *req, 1267 unsigned int *device_flag, unsigned int *resp_flag, 1268 unsigned int *error_flag, unsigned int *data_size) 1269 { 1270 if (data_size) 1271 *data_size = (header >> 27) & 0x1f; 1272 if (error_flag) 1273 *error_flag = (header >> 26) & 0x01; 1274 if (resp_flag) 1275 *resp_flag = (header >> 25) & 0x01; 1276 if (device_flag) 1277 *device_flag = (header >> 24) & 0x01; 1278 if (req) 1279 *req = (header >> 17) & 0x7f; 1280 if (get_flag) 1281 *get_flag = (header >> 16) & 0x01; 1282 if (source_id) 1283 *source_id = (header >> 8) & 0xff; 1284 if (target_id) 1285 *target_id = header & 0xff; 1286 } 1287 1288 #define SCP_MAX_DATA_WORDS (16) 1289 1290 /* Structure to contain any SCP message */ 1291 struct scp_msg { 1292 unsigned int hdr; 1293 unsigned int data[SCP_MAX_DATA_WORDS]; 1294 }; 1295 1296 static void dspio_clear_response_queue(struct hda_codec *codec) 1297 { 1298 unsigned int dummy = 0; 1299 int status = -1; 1300 1301 /* clear all from the response queue */ 1302 do { 1303 status = dspio_read(codec, &dummy); 1304 } while (status == 0); 1305 } 1306 1307 static int dspio_get_response_data(struct hda_codec *codec) 1308 { 1309 struct ca0132_spec *spec = codec->spec; 1310 unsigned int data = 0; 1311 unsigned int count; 1312 1313 if (dspio_read(codec, &data) < 0) 1314 return -EIO; 1315 1316 if ((data & 0x00ffffff) == spec->wait_scp_header) { 1317 spec->scp_resp_header = data; 1318 spec->scp_resp_count = data >> 27; 1319 count = spec->wait_num_data; 1320 dspio_read_multiple(codec, spec->scp_resp_data, 1321 &spec->scp_resp_count, count); 1322 return 0; 1323 } 1324 1325 return -EIO; 1326 } 1327 1328 /* 1329 * Send SCP message to DSP 1330 */ 1331 static int dspio_send_scp_message(struct hda_codec *codec, 1332 unsigned char *send_buf, 1333 unsigned int send_buf_size, 1334 unsigned char *return_buf, 1335 unsigned int return_buf_size, 1336 unsigned int *bytes_returned) 1337 { 1338 struct ca0132_spec *spec = codec->spec; 1339 int status = -1; 1340 unsigned int scp_send_size = 0; 1341 unsigned int total_size; 1342 bool waiting_for_resp = false; 1343 unsigned int header; 1344 struct scp_msg *ret_msg; 1345 unsigned int resp_src_id, resp_target_id; 1346 unsigned int data_size, src_id, target_id, get_flag, device_flag; 1347 1348 if (bytes_returned) 1349 *bytes_returned = 0; 1350 1351 /* get scp header from buffer */ 1352 header = *((unsigned int *)send_buf); 1353 extract_scp_header(header, &target_id, &src_id, &get_flag, NULL, 1354 &device_flag, NULL, NULL, &data_size); 1355 scp_send_size = data_size + 1; 1356 total_size = (scp_send_size * 4); 1357 1358 if (send_buf_size < total_size) 1359 return -EINVAL; 1360 1361 if (get_flag || device_flag) { 1362 if (!return_buf || return_buf_size < 4 || !bytes_returned) 1363 return -EINVAL; 1364 1365 spec->wait_scp_header = *((unsigned int *)send_buf); 1366 1367 /* swap source id with target id */ 1368 resp_target_id = src_id; 1369 resp_src_id = target_id; 1370 spec->wait_scp_header &= 0xffff0000; 1371 spec->wait_scp_header |= (resp_src_id << 8) | (resp_target_id); 1372 spec->wait_num_data = return_buf_size/sizeof(unsigned int) - 1; 1373 spec->wait_scp = 1; 1374 waiting_for_resp = true; 1375 } 1376 1377 status = dspio_write_multiple(codec, (unsigned int *)send_buf, 1378 scp_send_size); 1379 if (status < 0) { 1380 spec->wait_scp = 0; 1381 return status; 1382 } 1383 1384 if (waiting_for_resp) { 1385 unsigned long timeout = jiffies + msecs_to_jiffies(1000); 1386 memset(return_buf, 0, return_buf_size); 1387 do { 1388 msleep(20); 1389 } while (spec->wait_scp && time_before(jiffies, timeout)); 1390 waiting_for_resp = false; 1391 if (!spec->wait_scp) { 1392 ret_msg = (struct scp_msg *)return_buf; 1393 memcpy(&ret_msg->hdr, &spec->scp_resp_header, 4); 1394 memcpy(&ret_msg->data, spec->scp_resp_data, 1395 spec->wait_num_data); 1396 *bytes_returned = (spec->scp_resp_count + 1) * 4; 1397 status = 0; 1398 } else { 1399 status = -EIO; 1400 } 1401 spec->wait_scp = 0; 1402 } 1403 1404 return status; 1405 } 1406 1407 /** 1408 * Prepare and send the SCP message to DSP 1409 * @codec: the HDA codec 1410 * @mod_id: ID of the DSP module to send the command 1411 * @req: ID of request to send to the DSP module 1412 * @dir: SET or GET 1413 * @data: pointer to the data to send with the request, request specific 1414 * @len: length of the data, in bytes 1415 * @reply: point to the buffer to hold data returned for a reply 1416 * @reply_len: length of the reply buffer returned from GET 1417 * 1418 * Returns zero or a negative error code. 1419 */ 1420 static int dspio_scp(struct hda_codec *codec, 1421 int mod_id, int req, int dir, void *data, unsigned int len, 1422 void *reply, unsigned int *reply_len) 1423 { 1424 int status = 0; 1425 struct scp_msg scp_send, scp_reply; 1426 unsigned int ret_bytes, send_size, ret_size; 1427 unsigned int send_get_flag, reply_resp_flag, reply_error_flag; 1428 unsigned int reply_data_size; 1429 1430 memset(&scp_send, 0, sizeof(scp_send)); 1431 memset(&scp_reply, 0, sizeof(scp_reply)); 1432 1433 if ((len != 0 && data == NULL) || (len > SCP_MAX_DATA_WORDS)) 1434 return -EINVAL; 1435 1436 if (dir == SCP_GET && reply == NULL) { 1437 codec_dbg(codec, "dspio_scp get but has no buffer\n"); 1438 return -EINVAL; 1439 } 1440 1441 if (reply != NULL && (reply_len == NULL || (*reply_len == 0))) { 1442 codec_dbg(codec, "dspio_scp bad resp buf len parms\n"); 1443 return -EINVAL; 1444 } 1445 1446 scp_send.hdr = make_scp_header(mod_id, 0x20, (dir == SCP_GET), req, 1447 0, 0, 0, len/sizeof(unsigned int)); 1448 if (data != NULL && len > 0) { 1449 len = min((unsigned int)(sizeof(scp_send.data)), len); 1450 memcpy(scp_send.data, data, len); 1451 } 1452 1453 ret_bytes = 0; 1454 send_size = sizeof(unsigned int) + len; 1455 status = dspio_send_scp_message(codec, (unsigned char *)&scp_send, 1456 send_size, (unsigned char *)&scp_reply, 1457 sizeof(scp_reply), &ret_bytes); 1458 1459 if (status < 0) { 1460 codec_dbg(codec, "dspio_scp: send scp msg failed\n"); 1461 return status; 1462 } 1463 1464 /* extract send and reply headers members */ 1465 extract_scp_header(scp_send.hdr, NULL, NULL, &send_get_flag, 1466 NULL, NULL, NULL, NULL, NULL); 1467 extract_scp_header(scp_reply.hdr, NULL, NULL, NULL, NULL, NULL, 1468 &reply_resp_flag, &reply_error_flag, 1469 &reply_data_size); 1470 1471 if (!send_get_flag) 1472 return 0; 1473 1474 if (reply_resp_flag && !reply_error_flag) { 1475 ret_size = (ret_bytes - sizeof(scp_reply.hdr)) 1476 / sizeof(unsigned int); 1477 1478 if (*reply_len < ret_size*sizeof(unsigned int)) { 1479 codec_dbg(codec, "reply too long for buf\n"); 1480 return -EINVAL; 1481 } else if (ret_size != reply_data_size) { 1482 codec_dbg(codec, "RetLen and HdrLen .NE.\n"); 1483 return -EINVAL; 1484 } else { 1485 *reply_len = ret_size*sizeof(unsigned int); 1486 memcpy(reply, scp_reply.data, *reply_len); 1487 } 1488 } else { 1489 codec_dbg(codec, "reply ill-formed or errflag set\n"); 1490 return -EIO; 1491 } 1492 1493 return status; 1494 } 1495 1496 /* 1497 * Set DSP parameters 1498 */ 1499 static int dspio_set_param(struct hda_codec *codec, int mod_id, 1500 int req, void *data, unsigned int len) 1501 { 1502 return dspio_scp(codec, mod_id, req, SCP_SET, data, len, NULL, NULL); 1503 } 1504 1505 static int dspio_set_uint_param(struct hda_codec *codec, int mod_id, 1506 int req, unsigned int data) 1507 { 1508 return dspio_set_param(codec, mod_id, req, &data, sizeof(unsigned int)); 1509 } 1510 1511 /* 1512 * Allocate a DSP DMA channel via an SCP message 1513 */ 1514 static int dspio_alloc_dma_chan(struct hda_codec *codec, unsigned int *dma_chan) 1515 { 1516 int status = 0; 1517 unsigned int size = sizeof(dma_chan); 1518 1519 codec_dbg(codec, " dspio_alloc_dma_chan() -- begin\n"); 1520 status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN, 1521 SCP_GET, NULL, 0, dma_chan, &size); 1522 1523 if (status < 0) { 1524 codec_dbg(codec, "dspio_alloc_dma_chan: SCP Failed\n"); 1525 return status; 1526 } 1527 1528 if ((*dma_chan + 1) == 0) { 1529 codec_dbg(codec, "no free dma channels to allocate\n"); 1530 return -EBUSY; 1531 } 1532 1533 codec_dbg(codec, "dspio_alloc_dma_chan: chan=%d\n", *dma_chan); 1534 codec_dbg(codec, " dspio_alloc_dma_chan() -- complete\n"); 1535 1536 return status; 1537 } 1538 1539 /* 1540 * Free a DSP DMA via an SCP message 1541 */ 1542 static int dspio_free_dma_chan(struct hda_codec *codec, unsigned int dma_chan) 1543 { 1544 int status = 0; 1545 unsigned int dummy = 0; 1546 1547 codec_dbg(codec, " dspio_free_dma_chan() -- begin\n"); 1548 codec_dbg(codec, "dspio_free_dma_chan: chan=%d\n", dma_chan); 1549 1550 status = dspio_scp(codec, MASTERCONTROL, MASTERCONTROL_ALLOC_DMA_CHAN, 1551 SCP_SET, &dma_chan, sizeof(dma_chan), NULL, &dummy); 1552 1553 if (status < 0) { 1554 codec_dbg(codec, "dspio_free_dma_chan: SCP Failed\n"); 1555 return status; 1556 } 1557 1558 codec_dbg(codec, " dspio_free_dma_chan() -- complete\n"); 1559 1560 return status; 1561 } 1562 1563 /* 1564 * (Re)start the DSP 1565 */ 1566 static int dsp_set_run_state(struct hda_codec *codec) 1567 { 1568 unsigned int dbg_ctrl_reg; 1569 unsigned int halt_state; 1570 int err; 1571 1572 err = chipio_read(codec, DSP_DBGCNTL_INST_OFFSET, &dbg_ctrl_reg); 1573 if (err < 0) 1574 return err; 1575 1576 halt_state = (dbg_ctrl_reg & DSP_DBGCNTL_STATE_MASK) >> 1577 DSP_DBGCNTL_STATE_LOBIT; 1578 1579 if (halt_state != 0) { 1580 dbg_ctrl_reg &= ~((halt_state << DSP_DBGCNTL_SS_LOBIT) & 1581 DSP_DBGCNTL_SS_MASK); 1582 err = chipio_write(codec, DSP_DBGCNTL_INST_OFFSET, 1583 dbg_ctrl_reg); 1584 if (err < 0) 1585 return err; 1586 1587 dbg_ctrl_reg |= (halt_state << DSP_DBGCNTL_EXEC_LOBIT) & 1588 DSP_DBGCNTL_EXEC_MASK; 1589 err = chipio_write(codec, DSP_DBGCNTL_INST_OFFSET, 1590 dbg_ctrl_reg); 1591 if (err < 0) 1592 return err; 1593 } 1594 1595 return 0; 1596 } 1597 1598 /* 1599 * Reset the DSP 1600 */ 1601 static int dsp_reset(struct hda_codec *codec) 1602 { 1603 unsigned int res; 1604 int retry = 20; 1605 1606 codec_dbg(codec, "dsp_reset\n"); 1607 do { 1608 res = dspio_send(codec, VENDOR_DSPIO_DSP_INIT, 0); 1609 retry--; 1610 } while (res == -EIO && retry); 1611 1612 if (!retry) { 1613 codec_dbg(codec, "dsp_reset timeout\n"); 1614 return -EIO; 1615 } 1616 1617 return 0; 1618 } 1619 1620 /* 1621 * Convert chip address to DSP address 1622 */ 1623 static unsigned int dsp_chip_to_dsp_addx(unsigned int chip_addx, 1624 bool *code, bool *yram) 1625 { 1626 *code = *yram = false; 1627 1628 if (UC_RANGE(chip_addx, 1)) { 1629 *code = true; 1630 return UC_OFF(chip_addx); 1631 } else if (X_RANGE_ALL(chip_addx, 1)) { 1632 return X_OFF(chip_addx); 1633 } else if (Y_RANGE_ALL(chip_addx, 1)) { 1634 *yram = true; 1635 return Y_OFF(chip_addx); 1636 } 1637 1638 return INVALID_CHIP_ADDRESS; 1639 } 1640 1641 /* 1642 * Check if the DSP DMA is active 1643 */ 1644 static bool dsp_is_dma_active(struct hda_codec *codec, unsigned int dma_chan) 1645 { 1646 unsigned int dma_chnlstart_reg; 1647 1648 chipio_read(codec, DSPDMAC_CHNLSTART_INST_OFFSET, &dma_chnlstart_reg); 1649 1650 return ((dma_chnlstart_reg & (1 << 1651 (DSPDMAC_CHNLSTART_EN_LOBIT + dma_chan))) != 0); 1652 } 1653 1654 static int dsp_dma_setup_common(struct hda_codec *codec, 1655 unsigned int chip_addx, 1656 unsigned int dma_chan, 1657 unsigned int port_map_mask, 1658 bool ovly) 1659 { 1660 int status = 0; 1661 unsigned int chnl_prop; 1662 unsigned int dsp_addx; 1663 unsigned int active; 1664 bool code, yram; 1665 1666 codec_dbg(codec, "-- dsp_dma_setup_common() -- Begin ---------\n"); 1667 1668 if (dma_chan >= DSPDMAC_DMA_CFG_CHANNEL_COUNT) { 1669 codec_dbg(codec, "dma chan num invalid\n"); 1670 return -EINVAL; 1671 } 1672 1673 if (dsp_is_dma_active(codec, dma_chan)) { 1674 codec_dbg(codec, "dma already active\n"); 1675 return -EBUSY; 1676 } 1677 1678 dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram); 1679 1680 if (dsp_addx == INVALID_CHIP_ADDRESS) { 1681 codec_dbg(codec, "invalid chip addr\n"); 1682 return -ENXIO; 1683 } 1684 1685 chnl_prop = DSPDMAC_CHNLPROP_AC_MASK; 1686 active = 0; 1687 1688 codec_dbg(codec, " dsp_dma_setup_common() start reg pgm\n"); 1689 1690 if (ovly) { 1691 status = chipio_read(codec, DSPDMAC_CHNLPROP_INST_OFFSET, 1692 &chnl_prop); 1693 1694 if (status < 0) { 1695 codec_dbg(codec, "read CHNLPROP Reg fail\n"); 1696 return status; 1697 } 1698 codec_dbg(codec, "dsp_dma_setup_common() Read CHNLPROP\n"); 1699 } 1700 1701 if (!code) 1702 chnl_prop &= ~(1 << (DSPDMAC_CHNLPROP_MSPCE_LOBIT + dma_chan)); 1703 else 1704 chnl_prop |= (1 << (DSPDMAC_CHNLPROP_MSPCE_LOBIT + dma_chan)); 1705 1706 chnl_prop &= ~(1 << (DSPDMAC_CHNLPROP_DCON_LOBIT + dma_chan)); 1707 1708 status = chipio_write(codec, DSPDMAC_CHNLPROP_INST_OFFSET, chnl_prop); 1709 if (status < 0) { 1710 codec_dbg(codec, "write CHNLPROP Reg fail\n"); 1711 return status; 1712 } 1713 codec_dbg(codec, " dsp_dma_setup_common() Write CHNLPROP\n"); 1714 1715 if (ovly) { 1716 status = chipio_read(codec, DSPDMAC_ACTIVE_INST_OFFSET, 1717 &active); 1718 1719 if (status < 0) { 1720 codec_dbg(codec, "read ACTIVE Reg fail\n"); 1721 return status; 1722 } 1723 codec_dbg(codec, "dsp_dma_setup_common() Read ACTIVE\n"); 1724 } 1725 1726 active &= (~(1 << (DSPDMAC_ACTIVE_AAR_LOBIT + dma_chan))) & 1727 DSPDMAC_ACTIVE_AAR_MASK; 1728 1729 status = chipio_write(codec, DSPDMAC_ACTIVE_INST_OFFSET, active); 1730 if (status < 0) { 1731 codec_dbg(codec, "write ACTIVE Reg fail\n"); 1732 return status; 1733 } 1734 1735 codec_dbg(codec, " dsp_dma_setup_common() Write ACTIVE\n"); 1736 1737 status = chipio_write(codec, DSPDMAC_AUDCHSEL_INST_OFFSET(dma_chan), 1738 port_map_mask); 1739 if (status < 0) { 1740 codec_dbg(codec, "write AUDCHSEL Reg fail\n"); 1741 return status; 1742 } 1743 codec_dbg(codec, " dsp_dma_setup_common() Write AUDCHSEL\n"); 1744 1745 status = chipio_write(codec, DSPDMAC_IRQCNT_INST_OFFSET(dma_chan), 1746 DSPDMAC_IRQCNT_BICNT_MASK | DSPDMAC_IRQCNT_CICNT_MASK); 1747 if (status < 0) { 1748 codec_dbg(codec, "write IRQCNT Reg fail\n"); 1749 return status; 1750 } 1751 codec_dbg(codec, " dsp_dma_setup_common() Write IRQCNT\n"); 1752 1753 codec_dbg(codec, 1754 "ChipA=0x%x,DspA=0x%x,dmaCh=%u, " 1755 "CHSEL=0x%x,CHPROP=0x%x,Active=0x%x\n", 1756 chip_addx, dsp_addx, dma_chan, 1757 port_map_mask, chnl_prop, active); 1758 1759 codec_dbg(codec, "-- dsp_dma_setup_common() -- Complete ------\n"); 1760 1761 return 0; 1762 } 1763 1764 /* 1765 * Setup the DSP DMA per-transfer-specific registers 1766 */ 1767 static int dsp_dma_setup(struct hda_codec *codec, 1768 unsigned int chip_addx, 1769 unsigned int count, 1770 unsigned int dma_chan) 1771 { 1772 int status = 0; 1773 bool code, yram; 1774 unsigned int dsp_addx; 1775 unsigned int addr_field; 1776 unsigned int incr_field; 1777 unsigned int base_cnt; 1778 unsigned int cur_cnt; 1779 unsigned int dma_cfg = 0; 1780 unsigned int adr_ofs = 0; 1781 unsigned int xfr_cnt = 0; 1782 const unsigned int max_dma_count = 1 << (DSPDMAC_XFRCNT_BCNT_HIBIT - 1783 DSPDMAC_XFRCNT_BCNT_LOBIT + 1); 1784 1785 codec_dbg(codec, "-- dsp_dma_setup() -- Begin ---------\n"); 1786 1787 if (count > max_dma_count) { 1788 codec_dbg(codec, "count too big\n"); 1789 return -EINVAL; 1790 } 1791 1792 dsp_addx = dsp_chip_to_dsp_addx(chip_addx, &code, &yram); 1793 if (dsp_addx == INVALID_CHIP_ADDRESS) { 1794 codec_dbg(codec, "invalid chip addr\n"); 1795 return -ENXIO; 1796 } 1797 1798 codec_dbg(codec, " dsp_dma_setup() start reg pgm\n"); 1799 1800 addr_field = dsp_addx << DSPDMAC_DMACFG_DBADR_LOBIT; 1801 incr_field = 0; 1802 1803 if (!code) { 1804 addr_field <<= 1; 1805 if (yram) 1806 addr_field |= (1 << DSPDMAC_DMACFG_DBADR_LOBIT); 1807 1808 incr_field = (1 << DSPDMAC_DMACFG_AINCR_LOBIT); 1809 } 1810 1811 dma_cfg = addr_field + incr_field; 1812 status = chipio_write(codec, DSPDMAC_DMACFG_INST_OFFSET(dma_chan), 1813 dma_cfg); 1814 if (status < 0) { 1815 codec_dbg(codec, "write DMACFG Reg fail\n"); 1816 return status; 1817 } 1818 codec_dbg(codec, " dsp_dma_setup() Write DMACFG\n"); 1819 1820 adr_ofs = (count - 1) << (DSPDMAC_DSPADROFS_BOFS_LOBIT + 1821 (code ? 0 : 1)); 1822 1823 status = chipio_write(codec, DSPDMAC_DSPADROFS_INST_OFFSET(dma_chan), 1824 adr_ofs); 1825 if (status < 0) { 1826 codec_dbg(codec, "write DSPADROFS Reg fail\n"); 1827 return status; 1828 } 1829 codec_dbg(codec, " dsp_dma_setup() Write DSPADROFS\n"); 1830 1831 base_cnt = (count - 1) << DSPDMAC_XFRCNT_BCNT_LOBIT; 1832 1833 cur_cnt = (count - 1) << DSPDMAC_XFRCNT_CCNT_LOBIT; 1834 1835 xfr_cnt = base_cnt | cur_cnt; 1836 1837 status = chipio_write(codec, 1838 DSPDMAC_XFRCNT_INST_OFFSET(dma_chan), xfr_cnt); 1839 if (status < 0) { 1840 codec_dbg(codec, "write XFRCNT Reg fail\n"); 1841 return status; 1842 } 1843 codec_dbg(codec, " dsp_dma_setup() Write XFRCNT\n"); 1844 1845 codec_dbg(codec, 1846 "ChipA=0x%x, cnt=0x%x, DMACFG=0x%x, " 1847 "ADROFS=0x%x, XFRCNT=0x%x\n", 1848 chip_addx, count, dma_cfg, adr_ofs, xfr_cnt); 1849 1850 codec_dbg(codec, "-- dsp_dma_setup() -- Complete ---------\n"); 1851 1852 return 0; 1853 } 1854 1855 /* 1856 * Start the DSP DMA 1857 */ 1858 static int dsp_dma_start(struct hda_codec *codec, 1859 unsigned int dma_chan, bool ovly) 1860 { 1861 unsigned int reg = 0; 1862 int status = 0; 1863 1864 codec_dbg(codec, "-- dsp_dma_start() -- Begin ---------\n"); 1865 1866 if (ovly) { 1867 status = chipio_read(codec, 1868 DSPDMAC_CHNLSTART_INST_OFFSET, ®); 1869 1870 if (status < 0) { 1871 codec_dbg(codec, "read CHNLSTART reg fail\n"); 1872 return status; 1873 } 1874 codec_dbg(codec, "-- dsp_dma_start() Read CHNLSTART\n"); 1875 1876 reg &= ~(DSPDMAC_CHNLSTART_EN_MASK | 1877 DSPDMAC_CHNLSTART_DIS_MASK); 1878 } 1879 1880 status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET, 1881 reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_EN_LOBIT))); 1882 if (status < 0) { 1883 codec_dbg(codec, "write CHNLSTART reg fail\n"); 1884 return status; 1885 } 1886 codec_dbg(codec, "-- dsp_dma_start() -- Complete ---------\n"); 1887 1888 return status; 1889 } 1890 1891 /* 1892 * Stop the DSP DMA 1893 */ 1894 static int dsp_dma_stop(struct hda_codec *codec, 1895 unsigned int dma_chan, bool ovly) 1896 { 1897 unsigned int reg = 0; 1898 int status = 0; 1899 1900 codec_dbg(codec, "-- dsp_dma_stop() -- Begin ---------\n"); 1901 1902 if (ovly) { 1903 status = chipio_read(codec, 1904 DSPDMAC_CHNLSTART_INST_OFFSET, ®); 1905 1906 if (status < 0) { 1907 codec_dbg(codec, "read CHNLSTART reg fail\n"); 1908 return status; 1909 } 1910 codec_dbg(codec, "-- dsp_dma_stop() Read CHNLSTART\n"); 1911 reg &= ~(DSPDMAC_CHNLSTART_EN_MASK | 1912 DSPDMAC_CHNLSTART_DIS_MASK); 1913 } 1914 1915 status = chipio_write(codec, DSPDMAC_CHNLSTART_INST_OFFSET, 1916 reg | (1 << (dma_chan + DSPDMAC_CHNLSTART_DIS_LOBIT))); 1917 if (status < 0) { 1918 codec_dbg(codec, "write CHNLSTART reg fail\n"); 1919 return status; 1920 } 1921 codec_dbg(codec, "-- dsp_dma_stop() -- Complete ---------\n"); 1922 1923 return status; 1924 } 1925 1926 /** 1927 * Allocate router ports 1928 * 1929 * @codec: the HDA codec 1930 * @num_chans: number of channels in the stream 1931 * @ports_per_channel: number of ports per channel 1932 * @start_device: start device 1933 * @port_map: pointer to the port list to hold the allocated ports 1934 * 1935 * Returns zero or a negative error code. 1936 */ 1937 static int dsp_allocate_router_ports(struct hda_codec *codec, 1938 unsigned int num_chans, 1939 unsigned int ports_per_channel, 1940 unsigned int start_device, 1941 unsigned int *port_map) 1942 { 1943 int status = 0; 1944 int res; 1945 u8 val; 1946 1947 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); 1948 if (status < 0) 1949 return status; 1950 1951 val = start_device << 6; 1952 val |= (ports_per_channel - 1) << 4; 1953 val |= num_chans - 1; 1954 1955 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1956 VENDOR_CHIPIO_PORT_ALLOC_CONFIG_SET, 1957 val); 1958 1959 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1960 VENDOR_CHIPIO_PORT_ALLOC_SET, 1961 MEM_CONNID_DSP); 1962 1963 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); 1964 if (status < 0) 1965 return status; 1966 1967 res = snd_hda_codec_read(codec, WIDGET_CHIP_CTRL, 0, 1968 VENDOR_CHIPIO_PORT_ALLOC_GET, 0); 1969 1970 *port_map = res; 1971 1972 return (res < 0) ? res : 0; 1973 } 1974 1975 /* 1976 * Free router ports 1977 */ 1978 static int dsp_free_router_ports(struct hda_codec *codec) 1979 { 1980 int status = 0; 1981 1982 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); 1983 if (status < 0) 1984 return status; 1985 1986 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 1987 VENDOR_CHIPIO_PORT_FREE_SET, 1988 MEM_CONNID_DSP); 1989 1990 status = chipio_send(codec, VENDOR_CHIPIO_STATUS, 0); 1991 1992 return status; 1993 } 1994 1995 /* 1996 * Allocate DSP ports for the download stream 1997 */ 1998 static int dsp_allocate_ports(struct hda_codec *codec, 1999 unsigned int num_chans, 2000 unsigned int rate_multi, unsigned int *port_map) 2001 { 2002 int status; 2003 2004 codec_dbg(codec, " dsp_allocate_ports() -- begin\n"); 2005 2006 if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) { 2007 codec_dbg(codec, "bad rate multiple\n"); 2008 return -EINVAL; 2009 } 2010 2011 status = dsp_allocate_router_ports(codec, num_chans, 2012 rate_multi, 0, port_map); 2013 2014 codec_dbg(codec, " dsp_allocate_ports() -- complete\n"); 2015 2016 return status; 2017 } 2018 2019 static int dsp_allocate_ports_format(struct hda_codec *codec, 2020 const unsigned short fmt, 2021 unsigned int *port_map) 2022 { 2023 int status; 2024 unsigned int num_chans; 2025 2026 unsigned int sample_rate_div = ((get_hdafmt_rate(fmt) >> 0) & 3) + 1; 2027 unsigned int sample_rate_mul = ((get_hdafmt_rate(fmt) >> 3) & 3) + 1; 2028 unsigned int rate_multi = sample_rate_mul / sample_rate_div; 2029 2030 if ((rate_multi != 1) && (rate_multi != 2) && (rate_multi != 4)) { 2031 codec_dbg(codec, "bad rate multiple\n"); 2032 return -EINVAL; 2033 } 2034 2035 num_chans = get_hdafmt_chs(fmt) + 1; 2036 2037 status = dsp_allocate_ports(codec, num_chans, rate_multi, port_map); 2038 2039 return status; 2040 } 2041 2042 /* 2043 * free DSP ports 2044 */ 2045 static int dsp_free_ports(struct hda_codec *codec) 2046 { 2047 int status; 2048 2049 codec_dbg(codec, " dsp_free_ports() -- begin\n"); 2050 2051 status = dsp_free_router_ports(codec); 2052 if (status < 0) { 2053 codec_dbg(codec, "free router ports fail\n"); 2054 return status; 2055 } 2056 codec_dbg(codec, " dsp_free_ports() -- complete\n"); 2057 2058 return status; 2059 } 2060 2061 /* 2062 * HDA DMA engine stuffs for DSP code download 2063 */ 2064 struct dma_engine { 2065 struct hda_codec *codec; 2066 unsigned short m_converter_format; 2067 struct snd_dma_buffer *dmab; 2068 unsigned int buf_size; 2069 }; 2070 2071 2072 enum dma_state { 2073 DMA_STATE_STOP = 0, 2074 DMA_STATE_RUN = 1 2075 }; 2076 2077 static int dma_convert_to_hda_format(struct hda_codec *codec, 2078 unsigned int sample_rate, 2079 unsigned short channels, 2080 unsigned short *hda_format) 2081 { 2082 unsigned int format_val; 2083 2084 format_val = snd_hdac_calc_stream_format(sample_rate, 2085 channels, SNDRV_PCM_FORMAT_S32_LE, 32, 0); 2086 2087 if (hda_format) 2088 *hda_format = (unsigned short)format_val; 2089 2090 return 0; 2091 } 2092 2093 /* 2094 * Reset DMA for DSP download 2095 */ 2096 static int dma_reset(struct dma_engine *dma) 2097 { 2098 struct hda_codec *codec = dma->codec; 2099 struct ca0132_spec *spec = codec->spec; 2100 int status; 2101 2102 if (dma->dmab->area) 2103 snd_hda_codec_load_dsp_cleanup(codec, dma->dmab); 2104 2105 status = snd_hda_codec_load_dsp_prepare(codec, 2106 dma->m_converter_format, 2107 dma->buf_size, 2108 dma->dmab); 2109 if (status < 0) 2110 return status; 2111 spec->dsp_stream_id = status; 2112 return 0; 2113 } 2114 2115 static int dma_set_state(struct dma_engine *dma, enum dma_state state) 2116 { 2117 bool cmd; 2118 2119 switch (state) { 2120 case DMA_STATE_STOP: 2121 cmd = false; 2122 break; 2123 case DMA_STATE_RUN: 2124 cmd = true; 2125 break; 2126 default: 2127 return 0; 2128 } 2129 2130 snd_hda_codec_load_dsp_trigger(dma->codec, cmd); 2131 return 0; 2132 } 2133 2134 static unsigned int dma_get_buffer_size(struct dma_engine *dma) 2135 { 2136 return dma->dmab->bytes; 2137 } 2138 2139 static unsigned char *dma_get_buffer_addr(struct dma_engine *dma) 2140 { 2141 return dma->dmab->area; 2142 } 2143 2144 static int dma_xfer(struct dma_engine *dma, 2145 const unsigned int *data, 2146 unsigned int count) 2147 { 2148 memcpy(dma->dmab->area, data, count); 2149 return 0; 2150 } 2151 2152 static void dma_get_converter_format( 2153 struct dma_engine *dma, 2154 unsigned short *format) 2155 { 2156 if (format) 2157 *format = dma->m_converter_format; 2158 } 2159 2160 static unsigned int dma_get_stream_id(struct dma_engine *dma) 2161 { 2162 struct ca0132_spec *spec = dma->codec->spec; 2163 2164 return spec->dsp_stream_id; 2165 } 2166 2167 struct dsp_image_seg { 2168 u32 magic; 2169 u32 chip_addr; 2170 u32 count; 2171 u32 data[0]; 2172 }; 2173 2174 static const u32 g_magic_value = 0x4c46584d; 2175 static const u32 g_chip_addr_magic_value = 0xFFFFFF01; 2176 2177 static bool is_valid(const struct dsp_image_seg *p) 2178 { 2179 return p->magic == g_magic_value; 2180 } 2181 2182 static bool is_hci_prog_list_seg(const struct dsp_image_seg *p) 2183 { 2184 return g_chip_addr_magic_value == p->chip_addr; 2185 } 2186 2187 static bool is_last(const struct dsp_image_seg *p) 2188 { 2189 return p->count == 0; 2190 } 2191 2192 static size_t dsp_sizeof(const struct dsp_image_seg *p) 2193 { 2194 return sizeof(*p) + p->count*sizeof(u32); 2195 } 2196 2197 static const struct dsp_image_seg *get_next_seg_ptr( 2198 const struct dsp_image_seg *p) 2199 { 2200 return (struct dsp_image_seg *)((unsigned char *)(p) + dsp_sizeof(p)); 2201 } 2202 2203 /* 2204 * CA0132 chip DSP transfer stuffs. For DSP download. 2205 */ 2206 #define INVALID_DMA_CHANNEL (~0U) 2207 2208 /* 2209 * Program a list of address/data pairs via the ChipIO widget. 2210 * The segment data is in the format of successive pairs of words. 2211 * These are repeated as indicated by the segment's count field. 2212 */ 2213 static int dspxfr_hci_write(struct hda_codec *codec, 2214 const struct dsp_image_seg *fls) 2215 { 2216 int status; 2217 const u32 *data; 2218 unsigned int count; 2219 2220 if (fls == NULL || fls->chip_addr != g_chip_addr_magic_value) { 2221 codec_dbg(codec, "hci_write invalid params\n"); 2222 return -EINVAL; 2223 } 2224 2225 count = fls->count; 2226 data = (u32 *)(fls->data); 2227 while (count >= 2) { 2228 status = chipio_write(codec, data[0], data[1]); 2229 if (status < 0) { 2230 codec_dbg(codec, "hci_write chipio failed\n"); 2231 return status; 2232 } 2233 count -= 2; 2234 data += 2; 2235 } 2236 return 0; 2237 } 2238 2239 /** 2240 * Write a block of data into DSP code or data RAM using pre-allocated 2241 * DMA engine. 2242 * 2243 * @codec: the HDA codec 2244 * @fls: pointer to a fast load image 2245 * @reloc: Relocation address for loading single-segment overlays, or 0 for 2246 * no relocation 2247 * @dma_engine: pointer to DMA engine to be used for DSP download 2248 * @dma_chan: The number of DMA channels used for DSP download 2249 * @port_map_mask: port mapping 2250 * @ovly: TRUE if overlay format is required 2251 * 2252 * Returns zero or a negative error code. 2253 */ 2254 static int dspxfr_one_seg(struct hda_codec *codec, 2255 const struct dsp_image_seg *fls, 2256 unsigned int reloc, 2257 struct dma_engine *dma_engine, 2258 unsigned int dma_chan, 2259 unsigned int port_map_mask, 2260 bool ovly) 2261 { 2262 int status = 0; 2263 bool comm_dma_setup_done = false; 2264 const unsigned int *data; 2265 unsigned int chip_addx; 2266 unsigned int words_to_write; 2267 unsigned int buffer_size_words; 2268 unsigned char *buffer_addx; 2269 unsigned short hda_format; 2270 unsigned int sample_rate_div; 2271 unsigned int sample_rate_mul; 2272 unsigned int num_chans; 2273 unsigned int hda_frame_size_words; 2274 unsigned int remainder_words; 2275 const u32 *data_remainder; 2276 u32 chip_addx_remainder; 2277 unsigned int run_size_words; 2278 const struct dsp_image_seg *hci_write = NULL; 2279 unsigned long timeout; 2280 bool dma_active; 2281 2282 if (fls == NULL) 2283 return -EINVAL; 2284 if (is_hci_prog_list_seg(fls)) { 2285 hci_write = fls; 2286 fls = get_next_seg_ptr(fls); 2287 } 2288 2289 if (hci_write && (!fls || is_last(fls))) { 2290 codec_dbg(codec, "hci_write\n"); 2291 return dspxfr_hci_write(codec, hci_write); 2292 } 2293 2294 if (fls == NULL || dma_engine == NULL || port_map_mask == 0) { 2295 codec_dbg(codec, "Invalid Params\n"); 2296 return -EINVAL; 2297 } 2298 2299 data = fls->data; 2300 chip_addx = fls->chip_addr, 2301 words_to_write = fls->count; 2302 2303 if (!words_to_write) 2304 return hci_write ? dspxfr_hci_write(codec, hci_write) : 0; 2305 if (reloc) 2306 chip_addx = (chip_addx & (0xFFFF0000 << 2)) + (reloc << 2); 2307 2308 if (!UC_RANGE(chip_addx, words_to_write) && 2309 !X_RANGE_ALL(chip_addx, words_to_write) && 2310 !Y_RANGE_ALL(chip_addx, words_to_write)) { 2311 codec_dbg(codec, "Invalid chip_addx Params\n"); 2312 return -EINVAL; 2313 } 2314 2315 buffer_size_words = (unsigned int)dma_get_buffer_size(dma_engine) / 2316 sizeof(u32); 2317 2318 buffer_addx = dma_get_buffer_addr(dma_engine); 2319 2320 if (buffer_addx == NULL) { 2321 codec_dbg(codec, "dma_engine buffer NULL\n"); 2322 return -EINVAL; 2323 } 2324 2325 dma_get_converter_format(dma_engine, &hda_format); 2326 sample_rate_div = ((get_hdafmt_rate(hda_format) >> 0) & 3) + 1; 2327 sample_rate_mul = ((get_hdafmt_rate(hda_format) >> 3) & 3) + 1; 2328 num_chans = get_hdafmt_chs(hda_format) + 1; 2329 2330 hda_frame_size_words = ((sample_rate_div == 0) ? 0 : 2331 (num_chans * sample_rate_mul / sample_rate_div)); 2332 2333 if (hda_frame_size_words == 0) { 2334 codec_dbg(codec, "frmsz zero\n"); 2335 return -EINVAL; 2336 } 2337 2338 buffer_size_words = min(buffer_size_words, 2339 (unsigned int)(UC_RANGE(chip_addx, 1) ? 2340 65536 : 32768)); 2341 buffer_size_words -= buffer_size_words % hda_frame_size_words; 2342 codec_dbg(codec, 2343 "chpadr=0x%08x frmsz=%u nchan=%u " 2344 "rate_mul=%u div=%u bufsz=%u\n", 2345 chip_addx, hda_frame_size_words, num_chans, 2346 sample_rate_mul, sample_rate_div, buffer_size_words); 2347 2348 if (buffer_size_words < hda_frame_size_words) { 2349 codec_dbg(codec, "dspxfr_one_seg:failed\n"); 2350 return -EINVAL; 2351 } 2352 2353 remainder_words = words_to_write % hda_frame_size_words; 2354 data_remainder = data; 2355 chip_addx_remainder = chip_addx; 2356 2357 data += remainder_words; 2358 chip_addx += remainder_words*sizeof(u32); 2359 words_to_write -= remainder_words; 2360 2361 while (words_to_write != 0) { 2362 run_size_words = min(buffer_size_words, words_to_write); 2363 codec_dbg(codec, "dspxfr (seg loop)cnt=%u rs=%u remainder=%u\n", 2364 words_to_write, run_size_words, remainder_words); 2365 dma_xfer(dma_engine, data, run_size_words*sizeof(u32)); 2366 if (!comm_dma_setup_done) { 2367 status = dsp_dma_stop(codec, dma_chan, ovly); 2368 if (status < 0) 2369 return status; 2370 status = dsp_dma_setup_common(codec, chip_addx, 2371 dma_chan, port_map_mask, ovly); 2372 if (status < 0) 2373 return status; 2374 comm_dma_setup_done = true; 2375 } 2376 2377 status = dsp_dma_setup(codec, chip_addx, 2378 run_size_words, dma_chan); 2379 if (status < 0) 2380 return status; 2381 status = dsp_dma_start(codec, dma_chan, ovly); 2382 if (status < 0) 2383 return status; 2384 if (!dsp_is_dma_active(codec, dma_chan)) { 2385 codec_dbg(codec, "dspxfr:DMA did not start\n"); 2386 return -EIO; 2387 } 2388 status = dma_set_state(dma_engine, DMA_STATE_RUN); 2389 if (status < 0) 2390 return status; 2391 if (remainder_words != 0) { 2392 status = chipio_write_multiple(codec, 2393 chip_addx_remainder, 2394 data_remainder, 2395 remainder_words); 2396 if (status < 0) 2397 return status; 2398 remainder_words = 0; 2399 } 2400 if (hci_write) { 2401 status = dspxfr_hci_write(codec, hci_write); 2402 if (status < 0) 2403 return status; 2404 hci_write = NULL; 2405 } 2406 2407 timeout = jiffies + msecs_to_jiffies(2000); 2408 do { 2409 dma_active = dsp_is_dma_active(codec, dma_chan); 2410 if (!dma_active) 2411 break; 2412 msleep(20); 2413 } while (time_before(jiffies, timeout)); 2414 if (dma_active) 2415 break; 2416 2417 codec_dbg(codec, "+++++ DMA complete\n"); 2418 dma_set_state(dma_engine, DMA_STATE_STOP); 2419 status = dma_reset(dma_engine); 2420 2421 if (status < 0) 2422 return status; 2423 2424 data += run_size_words; 2425 chip_addx += run_size_words*sizeof(u32); 2426 words_to_write -= run_size_words; 2427 } 2428 2429 if (remainder_words != 0) { 2430 status = chipio_write_multiple(codec, chip_addx_remainder, 2431 data_remainder, remainder_words); 2432 } 2433 2434 return status; 2435 } 2436 2437 /** 2438 * Write the entire DSP image of a DSP code/data overlay to DSP memories 2439 * 2440 * @codec: the HDA codec 2441 * @fls_data: pointer to a fast load image 2442 * @reloc: Relocation address for loading single-segment overlays, or 0 for 2443 * no relocation 2444 * @sample_rate: sampling rate of the stream used for DSP download 2445 * @channels: channels of the stream used for DSP download 2446 * @ovly: TRUE if overlay format is required 2447 * 2448 * Returns zero or a negative error code. 2449 */ 2450 static int dspxfr_image(struct hda_codec *codec, 2451 const struct dsp_image_seg *fls_data, 2452 unsigned int reloc, 2453 unsigned int sample_rate, 2454 unsigned short channels, 2455 bool ovly) 2456 { 2457 struct ca0132_spec *spec = codec->spec; 2458 int status; 2459 unsigned short hda_format = 0; 2460 unsigned int response; 2461 unsigned char stream_id = 0; 2462 struct dma_engine *dma_engine; 2463 unsigned int dma_chan; 2464 unsigned int port_map_mask; 2465 2466 if (fls_data == NULL) 2467 return -EINVAL; 2468 2469 dma_engine = kzalloc(sizeof(*dma_engine), GFP_KERNEL); 2470 if (!dma_engine) 2471 return -ENOMEM; 2472 2473 dma_engine->dmab = kzalloc(sizeof(*dma_engine->dmab), GFP_KERNEL); 2474 if (!dma_engine->dmab) { 2475 kfree(dma_engine); 2476 return -ENOMEM; 2477 } 2478 2479 dma_engine->codec = codec; 2480 dma_convert_to_hda_format(codec, sample_rate, channels, &hda_format); 2481 dma_engine->m_converter_format = hda_format; 2482 dma_engine->buf_size = (ovly ? DSP_DMA_WRITE_BUFLEN_OVLY : 2483 DSP_DMA_WRITE_BUFLEN_INIT) * 2; 2484 2485 dma_chan = ovly ? INVALID_DMA_CHANNEL : 0; 2486 2487 status = codec_set_converter_format(codec, WIDGET_CHIP_CTRL, 2488 hda_format, &response); 2489 2490 if (status < 0) { 2491 codec_dbg(codec, "set converter format fail\n"); 2492 goto exit; 2493 } 2494 2495 status = snd_hda_codec_load_dsp_prepare(codec, 2496 dma_engine->m_converter_format, 2497 dma_engine->buf_size, 2498 dma_engine->dmab); 2499 if (status < 0) 2500 goto exit; 2501 spec->dsp_stream_id = status; 2502 2503 if (ovly) { 2504 status = dspio_alloc_dma_chan(codec, &dma_chan); 2505 if (status < 0) { 2506 codec_dbg(codec, "alloc dmachan fail\n"); 2507 dma_chan = INVALID_DMA_CHANNEL; 2508 goto exit; 2509 } 2510 } 2511 2512 port_map_mask = 0; 2513 status = dsp_allocate_ports_format(codec, hda_format, 2514 &port_map_mask); 2515 if (status < 0) { 2516 codec_dbg(codec, "alloc ports fail\n"); 2517 goto exit; 2518 } 2519 2520 stream_id = dma_get_stream_id(dma_engine); 2521 status = codec_set_converter_stream_channel(codec, 2522 WIDGET_CHIP_CTRL, stream_id, 0, &response); 2523 if (status < 0) { 2524 codec_dbg(codec, "set stream chan fail\n"); 2525 goto exit; 2526 } 2527 2528 while ((fls_data != NULL) && !is_last(fls_data)) { 2529 if (!is_valid(fls_data)) { 2530 codec_dbg(codec, "FLS check fail\n"); 2531 status = -EINVAL; 2532 goto exit; 2533 } 2534 status = dspxfr_one_seg(codec, fls_data, reloc, 2535 dma_engine, dma_chan, 2536 port_map_mask, ovly); 2537 if (status < 0) 2538 break; 2539 2540 if (is_hci_prog_list_seg(fls_data)) 2541 fls_data = get_next_seg_ptr(fls_data); 2542 2543 if ((fls_data != NULL) && !is_last(fls_data)) 2544 fls_data = get_next_seg_ptr(fls_data); 2545 } 2546 2547 if (port_map_mask != 0) 2548 status = dsp_free_ports(codec); 2549 2550 if (status < 0) 2551 goto exit; 2552 2553 status = codec_set_converter_stream_channel(codec, 2554 WIDGET_CHIP_CTRL, 0, 0, &response); 2555 2556 exit: 2557 if (ovly && (dma_chan != INVALID_DMA_CHANNEL)) 2558 dspio_free_dma_chan(codec, dma_chan); 2559 2560 if (dma_engine->dmab->area) 2561 snd_hda_codec_load_dsp_cleanup(codec, dma_engine->dmab); 2562 kfree(dma_engine->dmab); 2563 kfree(dma_engine); 2564 2565 return status; 2566 } 2567 2568 /* 2569 * CA0132 DSP download stuffs. 2570 */ 2571 static void dspload_post_setup(struct hda_codec *codec) 2572 { 2573 codec_dbg(codec, "---- dspload_post_setup ------\n"); 2574 2575 /*set DSP speaker to 2.0 configuration*/ 2576 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x18), 0x08080080); 2577 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x19), 0x3f800000); 2578 2579 /*update write pointer*/ 2580 chipio_write(codec, XRAM_XRAM_INST_OFFSET(0x29), 0x00000002); 2581 } 2582 2583 /** 2584 * dspload_image - Download DSP from a DSP Image Fast Load structure. 2585 * 2586 * @codec: the HDA codec 2587 * @fls: pointer to a fast load image 2588 * @ovly: TRUE if overlay format is required 2589 * @reloc: Relocation address for loading single-segment overlays, or 0 for 2590 * no relocation 2591 * @autostart: TRUE if DSP starts after loading; ignored if ovly is TRUE 2592 * @router_chans: number of audio router channels to be allocated (0 means use 2593 * internal defaults; max is 32) 2594 * 2595 * Download DSP from a DSP Image Fast Load structure. This structure is a 2596 * linear, non-constant sized element array of structures, each of which 2597 * contain the count of the data to be loaded, the data itself, and the 2598 * corresponding starting chip address of the starting data location. 2599 * Returns zero or a negative error code. 2600 */ 2601 static int dspload_image(struct hda_codec *codec, 2602 const struct dsp_image_seg *fls, 2603 bool ovly, 2604 unsigned int reloc, 2605 bool autostart, 2606 int router_chans) 2607 { 2608 int status = 0; 2609 unsigned int sample_rate; 2610 unsigned short channels; 2611 2612 codec_dbg(codec, "---- dspload_image begin ------\n"); 2613 if (router_chans == 0) { 2614 if (!ovly) 2615 router_chans = DMA_TRANSFER_FRAME_SIZE_NWORDS; 2616 else 2617 router_chans = DMA_OVERLAY_FRAME_SIZE_NWORDS; 2618 } 2619 2620 sample_rate = 48000; 2621 channels = (unsigned short)router_chans; 2622 2623 while (channels > 16) { 2624 sample_rate *= 2; 2625 channels /= 2; 2626 } 2627 2628 do { 2629 codec_dbg(codec, "Ready to program DMA\n"); 2630 if (!ovly) 2631 status = dsp_reset(codec); 2632 2633 if (status < 0) 2634 break; 2635 2636 codec_dbg(codec, "dsp_reset() complete\n"); 2637 status = dspxfr_image(codec, fls, reloc, sample_rate, channels, 2638 ovly); 2639 2640 if (status < 0) 2641 break; 2642 2643 codec_dbg(codec, "dspxfr_image() complete\n"); 2644 if (autostart && !ovly) { 2645 dspload_post_setup(codec); 2646 status = dsp_set_run_state(codec); 2647 } 2648 2649 codec_dbg(codec, "LOAD FINISHED\n"); 2650 } while (0); 2651 2652 return status; 2653 } 2654 2655 #ifdef CONFIG_SND_HDA_CODEC_CA0132_DSP 2656 static bool dspload_is_loaded(struct hda_codec *codec) 2657 { 2658 unsigned int data = 0; 2659 int status = 0; 2660 2661 status = chipio_read(codec, 0x40004, &data); 2662 if ((status < 0) || (data != 1)) 2663 return false; 2664 2665 return true; 2666 } 2667 #else 2668 #define dspload_is_loaded(codec) false 2669 #endif 2670 2671 static bool dspload_wait_loaded(struct hda_codec *codec) 2672 { 2673 unsigned long timeout = jiffies + msecs_to_jiffies(2000); 2674 2675 do { 2676 if (dspload_is_loaded(codec)) { 2677 codec_info(codec, "ca0132 DSP downloaded and running\n"); 2678 return true; 2679 } 2680 msleep(20); 2681 } while (time_before(jiffies, timeout)); 2682 2683 codec_err(codec, "ca0132 failed to download DSP\n"); 2684 return false; 2685 } 2686 2687 /* 2688 * PCM callbacks 2689 */ 2690 static int ca0132_playback_pcm_prepare(struct hda_pcm_stream *hinfo, 2691 struct hda_codec *codec, 2692 unsigned int stream_tag, 2693 unsigned int format, 2694 struct snd_pcm_substream *substream) 2695 { 2696 struct ca0132_spec *spec = codec->spec; 2697 2698 snd_hda_codec_setup_stream(codec, spec->dacs[0], stream_tag, 0, format); 2699 2700 return 0; 2701 } 2702 2703 static int ca0132_playback_pcm_cleanup(struct hda_pcm_stream *hinfo, 2704 struct hda_codec *codec, 2705 struct snd_pcm_substream *substream) 2706 { 2707 struct ca0132_spec *spec = codec->spec; 2708 2709 if (spec->dsp_state == DSP_DOWNLOADING) 2710 return 0; 2711 2712 /*If Playback effects are on, allow stream some time to flush 2713 *effects tail*/ 2714 if (spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]) 2715 msleep(50); 2716 2717 snd_hda_codec_cleanup_stream(codec, spec->dacs[0]); 2718 2719 return 0; 2720 } 2721 2722 static unsigned int ca0132_playback_pcm_delay(struct hda_pcm_stream *info, 2723 struct hda_codec *codec, 2724 struct snd_pcm_substream *substream) 2725 { 2726 struct ca0132_spec *spec = codec->spec; 2727 unsigned int latency = DSP_PLAYBACK_INIT_LATENCY; 2728 struct snd_pcm_runtime *runtime = substream->runtime; 2729 2730 if (spec->dsp_state != DSP_DOWNLOADED) 2731 return 0; 2732 2733 /* Add latency if playback enhancement and either effect is enabled. */ 2734 if (spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]) { 2735 if ((spec->effects_switch[SURROUND - EFFECT_START_NID]) || 2736 (spec->effects_switch[DIALOG_PLUS - EFFECT_START_NID])) 2737 latency += DSP_PLAY_ENHANCEMENT_LATENCY; 2738 } 2739 2740 /* Applying Speaker EQ adds latency as well. */ 2741 if (spec->cur_out_type == SPEAKER_OUT) 2742 latency += DSP_SPEAKER_OUT_LATENCY; 2743 2744 return (latency * runtime->rate) / 1000; 2745 } 2746 2747 /* 2748 * Digital out 2749 */ 2750 static int ca0132_dig_playback_pcm_open(struct hda_pcm_stream *hinfo, 2751 struct hda_codec *codec, 2752 struct snd_pcm_substream *substream) 2753 { 2754 struct ca0132_spec *spec = codec->spec; 2755 return snd_hda_multi_out_dig_open(codec, &spec->multiout); 2756 } 2757 2758 static int ca0132_dig_playback_pcm_prepare(struct hda_pcm_stream *hinfo, 2759 struct hda_codec *codec, 2760 unsigned int stream_tag, 2761 unsigned int format, 2762 struct snd_pcm_substream *substream) 2763 { 2764 struct ca0132_spec *spec = codec->spec; 2765 return snd_hda_multi_out_dig_prepare(codec, &spec->multiout, 2766 stream_tag, format, substream); 2767 } 2768 2769 static int ca0132_dig_playback_pcm_cleanup(struct hda_pcm_stream *hinfo, 2770 struct hda_codec *codec, 2771 struct snd_pcm_substream *substream) 2772 { 2773 struct ca0132_spec *spec = codec->spec; 2774 return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout); 2775 } 2776 2777 static int ca0132_dig_playback_pcm_close(struct hda_pcm_stream *hinfo, 2778 struct hda_codec *codec, 2779 struct snd_pcm_substream *substream) 2780 { 2781 struct ca0132_spec *spec = codec->spec; 2782 return snd_hda_multi_out_dig_close(codec, &spec->multiout); 2783 } 2784 2785 /* 2786 * Analog capture 2787 */ 2788 static int ca0132_capture_pcm_prepare(struct hda_pcm_stream *hinfo, 2789 struct hda_codec *codec, 2790 unsigned int stream_tag, 2791 unsigned int format, 2792 struct snd_pcm_substream *substream) 2793 { 2794 snd_hda_codec_setup_stream(codec, hinfo->nid, 2795 stream_tag, 0, format); 2796 2797 return 0; 2798 } 2799 2800 static int ca0132_capture_pcm_cleanup(struct hda_pcm_stream *hinfo, 2801 struct hda_codec *codec, 2802 struct snd_pcm_substream *substream) 2803 { 2804 struct ca0132_spec *spec = codec->spec; 2805 2806 if (spec->dsp_state == DSP_DOWNLOADING) 2807 return 0; 2808 2809 snd_hda_codec_cleanup_stream(codec, hinfo->nid); 2810 return 0; 2811 } 2812 2813 static unsigned int ca0132_capture_pcm_delay(struct hda_pcm_stream *info, 2814 struct hda_codec *codec, 2815 struct snd_pcm_substream *substream) 2816 { 2817 struct ca0132_spec *spec = codec->spec; 2818 unsigned int latency = DSP_CAPTURE_INIT_LATENCY; 2819 struct snd_pcm_runtime *runtime = substream->runtime; 2820 2821 if (spec->dsp_state != DSP_DOWNLOADED) 2822 return 0; 2823 2824 if (spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID]) 2825 latency += DSP_CRYSTAL_VOICE_LATENCY; 2826 2827 return (latency * runtime->rate) / 1000; 2828 } 2829 2830 /* 2831 * Controls stuffs. 2832 */ 2833 2834 /* 2835 * Mixer controls helpers. 2836 */ 2837 #define CA0132_CODEC_VOL_MONO(xname, nid, channel, dir) \ 2838 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \ 2839 .name = xname, \ 2840 .subdevice = HDA_SUBDEV_AMP_FLAG, \ 2841 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | \ 2842 SNDRV_CTL_ELEM_ACCESS_TLV_READ | \ 2843 SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK, \ 2844 .info = ca0132_volume_info, \ 2845 .get = ca0132_volume_get, \ 2846 .put = ca0132_volume_put, \ 2847 .tlv = { .c = ca0132_volume_tlv }, \ 2848 .private_value = HDA_COMPOSE_AMP_VAL(nid, channel, 0, dir) } 2849 2850 #define CA0132_CODEC_MUTE_MONO(xname, nid, channel, dir) \ 2851 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \ 2852 .name = xname, \ 2853 .subdevice = HDA_SUBDEV_AMP_FLAG, \ 2854 .info = snd_hda_mixer_amp_switch_info, \ 2855 .get = ca0132_switch_get, \ 2856 .put = ca0132_switch_put, \ 2857 .private_value = HDA_COMPOSE_AMP_VAL(nid, channel, 0, dir) } 2858 2859 /* stereo */ 2860 #define CA0132_CODEC_VOL(xname, nid, dir) \ 2861 CA0132_CODEC_VOL_MONO(xname, nid, 3, dir) 2862 #define CA0132_CODEC_MUTE(xname, nid, dir) \ 2863 CA0132_CODEC_MUTE_MONO(xname, nid, 3, dir) 2864 2865 /* The followings are for tuning of products */ 2866 #ifdef ENABLE_TUNING_CONTROLS 2867 2868 static unsigned int voice_focus_vals_lookup[] = { 2869 0x41A00000, 0x41A80000, 0x41B00000, 0x41B80000, 0x41C00000, 0x41C80000, 2870 0x41D00000, 0x41D80000, 0x41E00000, 0x41E80000, 0x41F00000, 0x41F80000, 2871 0x42000000, 0x42040000, 0x42080000, 0x420C0000, 0x42100000, 0x42140000, 2872 0x42180000, 0x421C0000, 0x42200000, 0x42240000, 0x42280000, 0x422C0000, 2873 0x42300000, 0x42340000, 0x42380000, 0x423C0000, 0x42400000, 0x42440000, 2874 0x42480000, 0x424C0000, 0x42500000, 0x42540000, 0x42580000, 0x425C0000, 2875 0x42600000, 0x42640000, 0x42680000, 0x426C0000, 0x42700000, 0x42740000, 2876 0x42780000, 0x427C0000, 0x42800000, 0x42820000, 0x42840000, 0x42860000, 2877 0x42880000, 0x428A0000, 0x428C0000, 0x428E0000, 0x42900000, 0x42920000, 2878 0x42940000, 0x42960000, 0x42980000, 0x429A0000, 0x429C0000, 0x429E0000, 2879 0x42A00000, 0x42A20000, 0x42A40000, 0x42A60000, 0x42A80000, 0x42AA0000, 2880 0x42AC0000, 0x42AE0000, 0x42B00000, 0x42B20000, 0x42B40000, 0x42B60000, 2881 0x42B80000, 0x42BA0000, 0x42BC0000, 0x42BE0000, 0x42C00000, 0x42C20000, 2882 0x42C40000, 0x42C60000, 0x42C80000, 0x42CA0000, 0x42CC0000, 0x42CE0000, 2883 0x42D00000, 0x42D20000, 0x42D40000, 0x42D60000, 0x42D80000, 0x42DA0000, 2884 0x42DC0000, 0x42DE0000, 0x42E00000, 0x42E20000, 0x42E40000, 0x42E60000, 2885 0x42E80000, 0x42EA0000, 0x42EC0000, 0x42EE0000, 0x42F00000, 0x42F20000, 2886 0x42F40000, 0x42F60000, 0x42F80000, 0x42FA0000, 0x42FC0000, 0x42FE0000, 2887 0x43000000, 0x43010000, 0x43020000, 0x43030000, 0x43040000, 0x43050000, 2888 0x43060000, 0x43070000, 0x43080000, 0x43090000, 0x430A0000, 0x430B0000, 2889 0x430C0000, 0x430D0000, 0x430E0000, 0x430F0000, 0x43100000, 0x43110000, 2890 0x43120000, 0x43130000, 0x43140000, 0x43150000, 0x43160000, 0x43170000, 2891 0x43180000, 0x43190000, 0x431A0000, 0x431B0000, 0x431C0000, 0x431D0000, 2892 0x431E0000, 0x431F0000, 0x43200000, 0x43210000, 0x43220000, 0x43230000, 2893 0x43240000, 0x43250000, 0x43260000, 0x43270000, 0x43280000, 0x43290000, 2894 0x432A0000, 0x432B0000, 0x432C0000, 0x432D0000, 0x432E0000, 0x432F0000, 2895 0x43300000, 0x43310000, 0x43320000, 0x43330000, 0x43340000 2896 }; 2897 2898 static unsigned int mic_svm_vals_lookup[] = { 2899 0x00000000, 0x3C23D70A, 0x3CA3D70A, 0x3CF5C28F, 0x3D23D70A, 0x3D4CCCCD, 2900 0x3D75C28F, 0x3D8F5C29, 0x3DA3D70A, 0x3DB851EC, 0x3DCCCCCD, 0x3DE147AE, 2901 0x3DF5C28F, 0x3E051EB8, 0x3E0F5C29, 0x3E19999A, 0x3E23D70A, 0x3E2E147B, 2902 0x3E3851EC, 0x3E428F5C, 0x3E4CCCCD, 0x3E570A3D, 0x3E6147AE, 0x3E6B851F, 2903 0x3E75C28F, 0x3E800000, 0x3E851EB8, 0x3E8A3D71, 0x3E8F5C29, 0x3E947AE1, 2904 0x3E99999A, 0x3E9EB852, 0x3EA3D70A, 0x3EA8F5C3, 0x3EAE147B, 0x3EB33333, 2905 0x3EB851EC, 0x3EBD70A4, 0x3EC28F5C, 0x3EC7AE14, 0x3ECCCCCD, 0x3ED1EB85, 2906 0x3ED70A3D, 0x3EDC28F6, 0x3EE147AE, 0x3EE66666, 0x3EEB851F, 0x3EF0A3D7, 2907 0x3EF5C28F, 0x3EFAE148, 0x3F000000, 0x3F028F5C, 0x3F051EB8, 0x3F07AE14, 2908 0x3F0A3D71, 0x3F0CCCCD, 0x3F0F5C29, 0x3F11EB85, 0x3F147AE1, 0x3F170A3D, 2909 0x3F19999A, 0x3F1C28F6, 0x3F1EB852, 0x3F2147AE, 0x3F23D70A, 0x3F266666, 2910 0x3F28F5C3, 0x3F2B851F, 0x3F2E147B, 0x3F30A3D7, 0x3F333333, 0x3F35C28F, 2911 0x3F3851EC, 0x3F3AE148, 0x3F3D70A4, 0x3F400000, 0x3F428F5C, 0x3F451EB8, 2912 0x3F47AE14, 0x3F4A3D71, 0x3F4CCCCD, 0x3F4F5C29, 0x3F51EB85, 0x3F547AE1, 2913 0x3F570A3D, 0x3F59999A, 0x3F5C28F6, 0x3F5EB852, 0x3F6147AE, 0x3F63D70A, 2914 0x3F666666, 0x3F68F5C3, 0x3F6B851F, 0x3F6E147B, 0x3F70A3D7, 0x3F733333, 2915 0x3F75C28F, 0x3F7851EC, 0x3F7AE148, 0x3F7D70A4, 0x3F800000 2916 }; 2917 2918 static unsigned int equalizer_vals_lookup[] = { 2919 0xC1C00000, 0xC1B80000, 0xC1B00000, 0xC1A80000, 0xC1A00000, 0xC1980000, 2920 0xC1900000, 0xC1880000, 0xC1800000, 0xC1700000, 0xC1600000, 0xC1500000, 2921 0xC1400000, 0xC1300000, 0xC1200000, 0xC1100000, 0xC1000000, 0xC0E00000, 2922 0xC0C00000, 0xC0A00000, 0xC0800000, 0xC0400000, 0xC0000000, 0xBF800000, 2923 0x00000000, 0x3F800000, 0x40000000, 0x40400000, 0x40800000, 0x40A00000, 2924 0x40C00000, 0x40E00000, 0x41000000, 0x41100000, 0x41200000, 0x41300000, 2925 0x41400000, 0x41500000, 0x41600000, 0x41700000, 0x41800000, 0x41880000, 2926 0x41900000, 0x41980000, 0x41A00000, 0x41A80000, 0x41B00000, 0x41B80000, 2927 0x41C00000 2928 }; 2929 2930 static int tuning_ctl_set(struct hda_codec *codec, hda_nid_t nid, 2931 unsigned int *lookup, int idx) 2932 { 2933 int i = 0; 2934 2935 for (i = 0; i < TUNING_CTLS_COUNT; i++) 2936 if (nid == ca0132_tuning_ctls[i].nid) 2937 break; 2938 2939 snd_hda_power_up(codec); 2940 dspio_set_param(codec, ca0132_tuning_ctls[i].mid, 2941 ca0132_tuning_ctls[i].req, 2942 &(lookup[idx]), sizeof(unsigned int)); 2943 snd_hda_power_down(codec); 2944 2945 return 1; 2946 } 2947 2948 static int tuning_ctl_get(struct snd_kcontrol *kcontrol, 2949 struct snd_ctl_elem_value *ucontrol) 2950 { 2951 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 2952 struct ca0132_spec *spec = codec->spec; 2953 hda_nid_t nid = get_amp_nid(kcontrol); 2954 long *valp = ucontrol->value.integer.value; 2955 int idx = nid - TUNING_CTL_START_NID; 2956 2957 *valp = spec->cur_ctl_vals[idx]; 2958 return 0; 2959 } 2960 2961 static int voice_focus_ctl_info(struct snd_kcontrol *kcontrol, 2962 struct snd_ctl_elem_info *uinfo) 2963 { 2964 int chs = get_amp_channels(kcontrol); 2965 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; 2966 uinfo->count = chs == 3 ? 2 : 1; 2967 uinfo->value.integer.min = 20; 2968 uinfo->value.integer.max = 180; 2969 uinfo->value.integer.step = 1; 2970 2971 return 0; 2972 } 2973 2974 static int voice_focus_ctl_put(struct snd_kcontrol *kcontrol, 2975 struct snd_ctl_elem_value *ucontrol) 2976 { 2977 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 2978 struct ca0132_spec *spec = codec->spec; 2979 hda_nid_t nid = get_amp_nid(kcontrol); 2980 long *valp = ucontrol->value.integer.value; 2981 int idx; 2982 2983 idx = nid - TUNING_CTL_START_NID; 2984 /* any change? */ 2985 if (spec->cur_ctl_vals[idx] == *valp) 2986 return 0; 2987 2988 spec->cur_ctl_vals[idx] = *valp; 2989 2990 idx = *valp - 20; 2991 tuning_ctl_set(codec, nid, voice_focus_vals_lookup, idx); 2992 2993 return 1; 2994 } 2995 2996 static int mic_svm_ctl_info(struct snd_kcontrol *kcontrol, 2997 struct snd_ctl_elem_info *uinfo) 2998 { 2999 int chs = get_amp_channels(kcontrol); 3000 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; 3001 uinfo->count = chs == 3 ? 2 : 1; 3002 uinfo->value.integer.min = 0; 3003 uinfo->value.integer.max = 100; 3004 uinfo->value.integer.step = 1; 3005 3006 return 0; 3007 } 3008 3009 static int mic_svm_ctl_put(struct snd_kcontrol *kcontrol, 3010 struct snd_ctl_elem_value *ucontrol) 3011 { 3012 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3013 struct ca0132_spec *spec = codec->spec; 3014 hda_nid_t nid = get_amp_nid(kcontrol); 3015 long *valp = ucontrol->value.integer.value; 3016 int idx; 3017 3018 idx = nid - TUNING_CTL_START_NID; 3019 /* any change? */ 3020 if (spec->cur_ctl_vals[idx] == *valp) 3021 return 0; 3022 3023 spec->cur_ctl_vals[idx] = *valp; 3024 3025 idx = *valp; 3026 tuning_ctl_set(codec, nid, mic_svm_vals_lookup, idx); 3027 3028 return 0; 3029 } 3030 3031 static int equalizer_ctl_info(struct snd_kcontrol *kcontrol, 3032 struct snd_ctl_elem_info *uinfo) 3033 { 3034 int chs = get_amp_channels(kcontrol); 3035 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; 3036 uinfo->count = chs == 3 ? 2 : 1; 3037 uinfo->value.integer.min = 0; 3038 uinfo->value.integer.max = 48; 3039 uinfo->value.integer.step = 1; 3040 3041 return 0; 3042 } 3043 3044 static int equalizer_ctl_put(struct snd_kcontrol *kcontrol, 3045 struct snd_ctl_elem_value *ucontrol) 3046 { 3047 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3048 struct ca0132_spec *spec = codec->spec; 3049 hda_nid_t nid = get_amp_nid(kcontrol); 3050 long *valp = ucontrol->value.integer.value; 3051 int idx; 3052 3053 idx = nid - TUNING_CTL_START_NID; 3054 /* any change? */ 3055 if (spec->cur_ctl_vals[idx] == *valp) 3056 return 0; 3057 3058 spec->cur_ctl_vals[idx] = *valp; 3059 3060 idx = *valp; 3061 tuning_ctl_set(codec, nid, equalizer_vals_lookup, idx); 3062 3063 return 1; 3064 } 3065 3066 static const DECLARE_TLV_DB_SCALE(voice_focus_db_scale, 2000, 100, 0); 3067 static const DECLARE_TLV_DB_SCALE(eq_db_scale, -2400, 100, 0); 3068 3069 static int add_tuning_control(struct hda_codec *codec, 3070 hda_nid_t pnid, hda_nid_t nid, 3071 const char *name, int dir) 3072 { 3073 char namestr[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 3074 int type = dir ? HDA_INPUT : HDA_OUTPUT; 3075 struct snd_kcontrol_new knew = 3076 HDA_CODEC_VOLUME_MONO(namestr, nid, 1, 0, type); 3077 3078 knew.access = SNDRV_CTL_ELEM_ACCESS_READWRITE | 3079 SNDRV_CTL_ELEM_ACCESS_TLV_READ; 3080 knew.tlv.c = 0; 3081 knew.tlv.p = 0; 3082 switch (pnid) { 3083 case VOICE_FOCUS: 3084 knew.info = voice_focus_ctl_info; 3085 knew.get = tuning_ctl_get; 3086 knew.put = voice_focus_ctl_put; 3087 knew.tlv.p = voice_focus_db_scale; 3088 break; 3089 case MIC_SVM: 3090 knew.info = mic_svm_ctl_info; 3091 knew.get = tuning_ctl_get; 3092 knew.put = mic_svm_ctl_put; 3093 break; 3094 case EQUALIZER: 3095 knew.info = equalizer_ctl_info; 3096 knew.get = tuning_ctl_get; 3097 knew.put = equalizer_ctl_put; 3098 knew.tlv.p = eq_db_scale; 3099 break; 3100 default: 3101 return 0; 3102 } 3103 knew.private_value = 3104 HDA_COMPOSE_AMP_VAL(nid, 1, 0, type); 3105 sprintf(namestr, "%s %s Volume", name, dirstr[dir]); 3106 return snd_hda_ctl_add(codec, nid, snd_ctl_new1(&knew, codec)); 3107 } 3108 3109 static int add_tuning_ctls(struct hda_codec *codec) 3110 { 3111 int i; 3112 int err; 3113 3114 for (i = 0; i < TUNING_CTLS_COUNT; i++) { 3115 err = add_tuning_control(codec, 3116 ca0132_tuning_ctls[i].parent_nid, 3117 ca0132_tuning_ctls[i].nid, 3118 ca0132_tuning_ctls[i].name, 3119 ca0132_tuning_ctls[i].direct); 3120 if (err < 0) 3121 return err; 3122 } 3123 3124 return 0; 3125 } 3126 3127 static void ca0132_init_tuning_defaults(struct hda_codec *codec) 3128 { 3129 struct ca0132_spec *spec = codec->spec; 3130 int i; 3131 3132 /* Wedge Angle defaults to 30. 10 below is 30 - 20. 20 is min. */ 3133 spec->cur_ctl_vals[WEDGE_ANGLE - TUNING_CTL_START_NID] = 10; 3134 /* SVM level defaults to 0.74. */ 3135 spec->cur_ctl_vals[SVM_LEVEL - TUNING_CTL_START_NID] = 74; 3136 3137 /* EQ defaults to 0dB. */ 3138 for (i = 2; i < TUNING_CTLS_COUNT; i++) 3139 spec->cur_ctl_vals[i] = 24; 3140 } 3141 #endif /*ENABLE_TUNING_CONTROLS*/ 3142 3143 /* 3144 * Select the active output. 3145 * If autodetect is enabled, output will be selected based on jack detection. 3146 * If jack inserted, headphone will be selected, else built-in speakers 3147 * If autodetect is disabled, output will be selected based on selection. 3148 */ 3149 static int ca0132_select_out(struct hda_codec *codec) 3150 { 3151 struct ca0132_spec *spec = codec->spec; 3152 unsigned int pin_ctl; 3153 int jack_present; 3154 int auto_jack; 3155 unsigned int tmp; 3156 int err; 3157 3158 codec_dbg(codec, "ca0132_select_out\n"); 3159 3160 snd_hda_power_up_pm(codec); 3161 3162 auto_jack = spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID]; 3163 3164 if (auto_jack) 3165 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_hp); 3166 else 3167 jack_present = 3168 spec->vnode_lswitch[VNID_HP_SEL - VNODE_START_NID]; 3169 3170 if (jack_present) 3171 spec->cur_out_type = HEADPHONE_OUT; 3172 else 3173 spec->cur_out_type = SPEAKER_OUT; 3174 3175 if (spec->cur_out_type == SPEAKER_OUT) { 3176 codec_dbg(codec, "ca0132_select_out speaker\n"); 3177 /*speaker out config*/ 3178 tmp = FLOAT_ONE; 3179 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp); 3180 if (err < 0) 3181 goto exit; 3182 /*enable speaker EQ*/ 3183 tmp = FLOAT_ONE; 3184 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp); 3185 if (err < 0) 3186 goto exit; 3187 3188 /* Setup EAPD */ 3189 snd_hda_codec_write(codec, spec->out_pins[1], 0, 3190 VENDOR_CHIPIO_EAPD_SEL_SET, 0x02); 3191 snd_hda_codec_write(codec, spec->out_pins[0], 0, 3192 AC_VERB_SET_EAPD_BTLENABLE, 0x00); 3193 snd_hda_codec_write(codec, spec->out_pins[0], 0, 3194 VENDOR_CHIPIO_EAPD_SEL_SET, 0x00); 3195 snd_hda_codec_write(codec, spec->out_pins[0], 0, 3196 AC_VERB_SET_EAPD_BTLENABLE, 0x02); 3197 3198 /* disable headphone node */ 3199 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0, 3200 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); 3201 snd_hda_set_pin_ctl(codec, spec->out_pins[1], 3202 pin_ctl & ~PIN_HP); 3203 /* enable speaker node */ 3204 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0, 3205 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); 3206 snd_hda_set_pin_ctl(codec, spec->out_pins[0], 3207 pin_ctl | PIN_OUT); 3208 } else { 3209 codec_dbg(codec, "ca0132_select_out hp\n"); 3210 /*headphone out config*/ 3211 tmp = FLOAT_ZERO; 3212 err = dspio_set_uint_param(codec, 0x80, 0x04, tmp); 3213 if (err < 0) 3214 goto exit; 3215 /*disable speaker EQ*/ 3216 tmp = FLOAT_ZERO; 3217 err = dspio_set_uint_param(codec, 0x8f, 0x00, tmp); 3218 if (err < 0) 3219 goto exit; 3220 3221 /* Setup EAPD */ 3222 snd_hda_codec_write(codec, spec->out_pins[0], 0, 3223 VENDOR_CHIPIO_EAPD_SEL_SET, 0x00); 3224 snd_hda_codec_write(codec, spec->out_pins[0], 0, 3225 AC_VERB_SET_EAPD_BTLENABLE, 0x00); 3226 snd_hda_codec_write(codec, spec->out_pins[1], 0, 3227 VENDOR_CHIPIO_EAPD_SEL_SET, 0x02); 3228 snd_hda_codec_write(codec, spec->out_pins[0], 0, 3229 AC_VERB_SET_EAPD_BTLENABLE, 0x02); 3230 3231 /* disable speaker*/ 3232 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[0], 0, 3233 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); 3234 snd_hda_set_pin_ctl(codec, spec->out_pins[0], 3235 pin_ctl & ~PIN_HP); 3236 /* enable headphone*/ 3237 pin_ctl = snd_hda_codec_read(codec, spec->out_pins[1], 0, 3238 AC_VERB_GET_PIN_WIDGET_CONTROL, 0); 3239 snd_hda_set_pin_ctl(codec, spec->out_pins[1], 3240 pin_ctl | PIN_HP); 3241 } 3242 3243 exit: 3244 snd_hda_power_down_pm(codec); 3245 3246 return err < 0 ? err : 0; 3247 } 3248 3249 static void ca0132_unsol_hp_delayed(struct work_struct *work) 3250 { 3251 struct ca0132_spec *spec = container_of( 3252 to_delayed_work(work), struct ca0132_spec, unsol_hp_work); 3253 struct hda_jack_tbl *jack; 3254 3255 ca0132_select_out(spec->codec); 3256 jack = snd_hda_jack_tbl_get(spec->codec, spec->unsol_tag_hp); 3257 if (jack) { 3258 jack->block_report = 0; 3259 snd_hda_jack_report_sync(spec->codec); 3260 } 3261 } 3262 3263 static void ca0132_set_dmic(struct hda_codec *codec, int enable); 3264 static int ca0132_mic_boost_set(struct hda_codec *codec, long val); 3265 static int ca0132_effects_set(struct hda_codec *codec, hda_nid_t nid, long val); 3266 3267 /* 3268 * Select the active VIP source 3269 */ 3270 static int ca0132_set_vipsource(struct hda_codec *codec, int val) 3271 { 3272 struct ca0132_spec *spec = codec->spec; 3273 unsigned int tmp; 3274 3275 if (spec->dsp_state != DSP_DOWNLOADED) 3276 return 0; 3277 3278 /* if CrystalVoice if off, vipsource should be 0 */ 3279 if (!spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] || 3280 (val == 0)) { 3281 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, 0); 3282 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); 3283 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); 3284 if (spec->cur_mic_type == DIGITAL_MIC) 3285 tmp = FLOAT_TWO; 3286 else 3287 tmp = FLOAT_ONE; 3288 dspio_set_uint_param(codec, 0x80, 0x00, tmp); 3289 tmp = FLOAT_ZERO; 3290 dspio_set_uint_param(codec, 0x80, 0x05, tmp); 3291 } else { 3292 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_16_000); 3293 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_16_000); 3294 if (spec->cur_mic_type == DIGITAL_MIC) 3295 tmp = FLOAT_TWO; 3296 else 3297 tmp = FLOAT_ONE; 3298 dspio_set_uint_param(codec, 0x80, 0x00, tmp); 3299 tmp = FLOAT_ONE; 3300 dspio_set_uint_param(codec, 0x80, 0x05, tmp); 3301 msleep(20); 3302 chipio_set_control_param(codec, CONTROL_PARAM_VIP_SOURCE, val); 3303 } 3304 3305 return 1; 3306 } 3307 3308 /* 3309 * Select the active microphone. 3310 * If autodetect is enabled, mic will be selected based on jack detection. 3311 * If jack inserted, ext.mic will be selected, else built-in mic 3312 * If autodetect is disabled, mic will be selected based on selection. 3313 */ 3314 static int ca0132_select_mic(struct hda_codec *codec) 3315 { 3316 struct ca0132_spec *spec = codec->spec; 3317 int jack_present; 3318 int auto_jack; 3319 3320 codec_dbg(codec, "ca0132_select_mic\n"); 3321 3322 snd_hda_power_up_pm(codec); 3323 3324 auto_jack = spec->vnode_lswitch[VNID_AMIC1_ASEL - VNODE_START_NID]; 3325 3326 if (auto_jack) 3327 jack_present = snd_hda_jack_detect(codec, spec->unsol_tag_amic1); 3328 else 3329 jack_present = 3330 spec->vnode_lswitch[VNID_AMIC1_SEL - VNODE_START_NID]; 3331 3332 if (jack_present) 3333 spec->cur_mic_type = LINE_MIC_IN; 3334 else 3335 spec->cur_mic_type = DIGITAL_MIC; 3336 3337 if (spec->cur_mic_type == DIGITAL_MIC) { 3338 /* enable digital Mic */ 3339 chipio_set_conn_rate(codec, MEM_CONNID_DMIC, SR_32_000); 3340 ca0132_set_dmic(codec, 1); 3341 ca0132_mic_boost_set(codec, 0); 3342 /* set voice focus */ 3343 ca0132_effects_set(codec, VOICE_FOCUS, 3344 spec->effects_switch 3345 [VOICE_FOCUS - EFFECT_START_NID]); 3346 } else { 3347 /* disable digital Mic */ 3348 chipio_set_conn_rate(codec, MEM_CONNID_DMIC, SR_96_000); 3349 ca0132_set_dmic(codec, 0); 3350 ca0132_mic_boost_set(codec, spec->cur_mic_boost); 3351 /* disable voice focus */ 3352 ca0132_effects_set(codec, VOICE_FOCUS, 0); 3353 } 3354 3355 snd_hda_power_down_pm(codec); 3356 3357 return 0; 3358 } 3359 3360 /* 3361 * Check if VNODE settings take effect immediately. 3362 */ 3363 static bool ca0132_is_vnode_effective(struct hda_codec *codec, 3364 hda_nid_t vnid, 3365 hda_nid_t *shared_nid) 3366 { 3367 struct ca0132_spec *spec = codec->spec; 3368 hda_nid_t nid; 3369 3370 switch (vnid) { 3371 case VNID_SPK: 3372 nid = spec->shared_out_nid; 3373 break; 3374 case VNID_MIC: 3375 nid = spec->shared_mic_nid; 3376 break; 3377 default: 3378 return false; 3379 } 3380 3381 if (shared_nid) 3382 *shared_nid = nid; 3383 3384 return true; 3385 } 3386 3387 /* 3388 * The following functions are control change helpers. 3389 * They return 0 if no changed. Return 1 if changed. 3390 */ 3391 static int ca0132_voicefx_set(struct hda_codec *codec, int enable) 3392 { 3393 struct ca0132_spec *spec = codec->spec; 3394 unsigned int tmp; 3395 3396 /* based on CrystalVoice state to enable VoiceFX. */ 3397 if (enable) { 3398 tmp = spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] ? 3399 FLOAT_ONE : FLOAT_ZERO; 3400 } else { 3401 tmp = FLOAT_ZERO; 3402 } 3403 3404 dspio_set_uint_param(codec, ca0132_voicefx.mid, 3405 ca0132_voicefx.reqs[0], tmp); 3406 3407 return 1; 3408 } 3409 3410 /* 3411 * Set the effects parameters 3412 */ 3413 static int ca0132_effects_set(struct hda_codec *codec, hda_nid_t nid, long val) 3414 { 3415 struct ca0132_spec *spec = codec->spec; 3416 unsigned int on; 3417 int num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT; 3418 int err = 0; 3419 int idx = nid - EFFECT_START_NID; 3420 3421 if ((idx < 0) || (idx >= num_fx)) 3422 return 0; /* no changed */ 3423 3424 /* for out effect, qualify with PE */ 3425 if ((nid >= OUT_EFFECT_START_NID) && (nid < OUT_EFFECT_END_NID)) { 3426 /* if PE if off, turn off out effects. */ 3427 if (!spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]) 3428 val = 0; 3429 } 3430 3431 /* for in effect, qualify with CrystalVoice */ 3432 if ((nid >= IN_EFFECT_START_NID) && (nid < IN_EFFECT_END_NID)) { 3433 /* if CrystalVoice if off, turn off in effects. */ 3434 if (!spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID]) 3435 val = 0; 3436 3437 /* Voice Focus applies to 2-ch Mic, Digital Mic */ 3438 if ((nid == VOICE_FOCUS) && (spec->cur_mic_type != DIGITAL_MIC)) 3439 val = 0; 3440 } 3441 3442 codec_dbg(codec, "ca0132_effect_set: nid=0x%x, val=%ld\n", 3443 nid, val); 3444 3445 on = (val == 0) ? FLOAT_ZERO : FLOAT_ONE; 3446 err = dspio_set_uint_param(codec, ca0132_effects[idx].mid, 3447 ca0132_effects[idx].reqs[0], on); 3448 3449 if (err < 0) 3450 return 0; /* no changed */ 3451 3452 return 1; 3453 } 3454 3455 /* 3456 * Turn on/off Playback Enhancements 3457 */ 3458 static int ca0132_pe_switch_set(struct hda_codec *codec) 3459 { 3460 struct ca0132_spec *spec = codec->spec; 3461 hda_nid_t nid; 3462 int i, ret = 0; 3463 3464 codec_dbg(codec, "ca0132_pe_switch_set: val=%ld\n", 3465 spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID]); 3466 3467 i = OUT_EFFECT_START_NID - EFFECT_START_NID; 3468 nid = OUT_EFFECT_START_NID; 3469 /* PE affects all out effects */ 3470 for (; nid < OUT_EFFECT_END_NID; nid++, i++) 3471 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]); 3472 3473 return ret; 3474 } 3475 3476 /* Check if Mic1 is streaming, if so, stop streaming */ 3477 static int stop_mic1(struct hda_codec *codec) 3478 { 3479 struct ca0132_spec *spec = codec->spec; 3480 unsigned int oldval = snd_hda_codec_read(codec, spec->adcs[0], 0, 3481 AC_VERB_GET_CONV, 0); 3482 if (oldval != 0) 3483 snd_hda_codec_write(codec, spec->adcs[0], 0, 3484 AC_VERB_SET_CHANNEL_STREAMID, 3485 0); 3486 return oldval; 3487 } 3488 3489 /* Resume Mic1 streaming if it was stopped. */ 3490 static void resume_mic1(struct hda_codec *codec, unsigned int oldval) 3491 { 3492 struct ca0132_spec *spec = codec->spec; 3493 /* Restore the previous stream and channel */ 3494 if (oldval != 0) 3495 snd_hda_codec_write(codec, spec->adcs[0], 0, 3496 AC_VERB_SET_CHANNEL_STREAMID, 3497 oldval); 3498 } 3499 3500 /* 3501 * Turn on/off CrystalVoice 3502 */ 3503 static int ca0132_cvoice_switch_set(struct hda_codec *codec) 3504 { 3505 struct ca0132_spec *spec = codec->spec; 3506 hda_nid_t nid; 3507 int i, ret = 0; 3508 unsigned int oldval; 3509 3510 codec_dbg(codec, "ca0132_cvoice_switch_set: val=%ld\n", 3511 spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID]); 3512 3513 i = IN_EFFECT_START_NID - EFFECT_START_NID; 3514 nid = IN_EFFECT_START_NID; 3515 /* CrystalVoice affects all in effects */ 3516 for (; nid < IN_EFFECT_END_NID; nid++, i++) 3517 ret |= ca0132_effects_set(codec, nid, spec->effects_switch[i]); 3518 3519 /* including VoiceFX */ 3520 ret |= ca0132_voicefx_set(codec, (spec->voicefx_val ? 1 : 0)); 3521 3522 /* set correct vipsource */ 3523 oldval = stop_mic1(codec); 3524 ret |= ca0132_set_vipsource(codec, 1); 3525 resume_mic1(codec, oldval); 3526 return ret; 3527 } 3528 3529 static int ca0132_mic_boost_set(struct hda_codec *codec, long val) 3530 { 3531 struct ca0132_spec *spec = codec->spec; 3532 int ret = 0; 3533 3534 if (val) /* on */ 3535 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, 3536 HDA_INPUT, 0, HDA_AMP_VOLMASK, 3); 3537 else /* off */ 3538 ret = snd_hda_codec_amp_update(codec, spec->input_pins[0], 0, 3539 HDA_INPUT, 0, HDA_AMP_VOLMASK, 0); 3540 3541 return ret; 3542 } 3543 3544 static int ca0132_vnode_switch_set(struct snd_kcontrol *kcontrol, 3545 struct snd_ctl_elem_value *ucontrol) 3546 { 3547 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3548 hda_nid_t nid = get_amp_nid(kcontrol); 3549 hda_nid_t shared_nid = 0; 3550 bool effective; 3551 int ret = 0; 3552 struct ca0132_spec *spec = codec->spec; 3553 int auto_jack; 3554 3555 if (nid == VNID_HP_SEL) { 3556 auto_jack = 3557 spec->vnode_lswitch[VNID_HP_ASEL - VNODE_START_NID]; 3558 if (!auto_jack) 3559 ca0132_select_out(codec); 3560 return 1; 3561 } 3562 3563 if (nid == VNID_AMIC1_SEL) { 3564 auto_jack = 3565 spec->vnode_lswitch[VNID_AMIC1_ASEL - VNODE_START_NID]; 3566 if (!auto_jack) 3567 ca0132_select_mic(codec); 3568 return 1; 3569 } 3570 3571 if (nid == VNID_HP_ASEL) { 3572 ca0132_select_out(codec); 3573 return 1; 3574 } 3575 3576 if (nid == VNID_AMIC1_ASEL) { 3577 ca0132_select_mic(codec); 3578 return 1; 3579 } 3580 3581 /* if effective conditions, then update hw immediately. */ 3582 effective = ca0132_is_vnode_effective(codec, nid, &shared_nid); 3583 if (effective) { 3584 int dir = get_amp_direction(kcontrol); 3585 int ch = get_amp_channels(kcontrol); 3586 unsigned long pval; 3587 3588 mutex_lock(&codec->control_mutex); 3589 pval = kcontrol->private_value; 3590 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(shared_nid, ch, 3591 0, dir); 3592 ret = snd_hda_mixer_amp_switch_put(kcontrol, ucontrol); 3593 kcontrol->private_value = pval; 3594 mutex_unlock(&codec->control_mutex); 3595 } 3596 3597 return ret; 3598 } 3599 /* End of control change helpers. */ 3600 3601 static int ca0132_voicefx_info(struct snd_kcontrol *kcontrol, 3602 struct snd_ctl_elem_info *uinfo) 3603 { 3604 unsigned int items = sizeof(ca0132_voicefx_presets) 3605 / sizeof(struct ct_voicefx_preset); 3606 3607 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED; 3608 uinfo->count = 1; 3609 uinfo->value.enumerated.items = items; 3610 if (uinfo->value.enumerated.item >= items) 3611 uinfo->value.enumerated.item = items - 1; 3612 strcpy(uinfo->value.enumerated.name, 3613 ca0132_voicefx_presets[uinfo->value.enumerated.item].name); 3614 return 0; 3615 } 3616 3617 static int ca0132_voicefx_get(struct snd_kcontrol *kcontrol, 3618 struct snd_ctl_elem_value *ucontrol) 3619 { 3620 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3621 struct ca0132_spec *spec = codec->spec; 3622 3623 ucontrol->value.enumerated.item[0] = spec->voicefx_val; 3624 return 0; 3625 } 3626 3627 static int ca0132_voicefx_put(struct snd_kcontrol *kcontrol, 3628 struct snd_ctl_elem_value *ucontrol) 3629 { 3630 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3631 struct ca0132_spec *spec = codec->spec; 3632 int i, err = 0; 3633 int sel = ucontrol->value.enumerated.item[0]; 3634 unsigned int items = sizeof(ca0132_voicefx_presets) 3635 / sizeof(struct ct_voicefx_preset); 3636 3637 if (sel >= items) 3638 return 0; 3639 3640 codec_dbg(codec, "ca0132_voicefx_put: sel=%d, preset=%s\n", 3641 sel, ca0132_voicefx_presets[sel].name); 3642 3643 /* 3644 * Idx 0 is default. 3645 * Default needs to qualify with CrystalVoice state. 3646 */ 3647 for (i = 0; i < VOICEFX_MAX_PARAM_COUNT; i++) { 3648 err = dspio_set_uint_param(codec, ca0132_voicefx.mid, 3649 ca0132_voicefx.reqs[i], 3650 ca0132_voicefx_presets[sel].vals[i]); 3651 if (err < 0) 3652 break; 3653 } 3654 3655 if (err >= 0) { 3656 spec->voicefx_val = sel; 3657 /* enable voice fx */ 3658 ca0132_voicefx_set(codec, (sel ? 1 : 0)); 3659 } 3660 3661 return 1; 3662 } 3663 3664 static int ca0132_switch_get(struct snd_kcontrol *kcontrol, 3665 struct snd_ctl_elem_value *ucontrol) 3666 { 3667 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3668 struct ca0132_spec *spec = codec->spec; 3669 hda_nid_t nid = get_amp_nid(kcontrol); 3670 int ch = get_amp_channels(kcontrol); 3671 long *valp = ucontrol->value.integer.value; 3672 3673 /* vnode */ 3674 if ((nid >= VNODE_START_NID) && (nid < VNODE_END_NID)) { 3675 if (ch & 1) { 3676 *valp = spec->vnode_lswitch[nid - VNODE_START_NID]; 3677 valp++; 3678 } 3679 if (ch & 2) { 3680 *valp = spec->vnode_rswitch[nid - VNODE_START_NID]; 3681 valp++; 3682 } 3683 return 0; 3684 } 3685 3686 /* effects, include PE and CrystalVoice */ 3687 if ((nid >= EFFECT_START_NID) && (nid < EFFECT_END_NID)) { 3688 *valp = spec->effects_switch[nid - EFFECT_START_NID]; 3689 return 0; 3690 } 3691 3692 /* mic boost */ 3693 if (nid == spec->input_pins[0]) { 3694 *valp = spec->cur_mic_boost; 3695 return 0; 3696 } 3697 3698 return 0; 3699 } 3700 3701 static int ca0132_switch_put(struct snd_kcontrol *kcontrol, 3702 struct snd_ctl_elem_value *ucontrol) 3703 { 3704 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3705 struct ca0132_spec *spec = codec->spec; 3706 hda_nid_t nid = get_amp_nid(kcontrol); 3707 int ch = get_amp_channels(kcontrol); 3708 long *valp = ucontrol->value.integer.value; 3709 int changed = 1; 3710 3711 codec_dbg(codec, "ca0132_switch_put: nid=0x%x, val=%ld\n", 3712 nid, *valp); 3713 3714 snd_hda_power_up(codec); 3715 /* vnode */ 3716 if ((nid >= VNODE_START_NID) && (nid < VNODE_END_NID)) { 3717 if (ch & 1) { 3718 spec->vnode_lswitch[nid - VNODE_START_NID] = *valp; 3719 valp++; 3720 } 3721 if (ch & 2) { 3722 spec->vnode_rswitch[nid - VNODE_START_NID] = *valp; 3723 valp++; 3724 } 3725 changed = ca0132_vnode_switch_set(kcontrol, ucontrol); 3726 goto exit; 3727 } 3728 3729 /* PE */ 3730 if (nid == PLAY_ENHANCEMENT) { 3731 spec->effects_switch[nid - EFFECT_START_NID] = *valp; 3732 changed = ca0132_pe_switch_set(codec); 3733 goto exit; 3734 } 3735 3736 /* CrystalVoice */ 3737 if (nid == CRYSTAL_VOICE) { 3738 spec->effects_switch[nid - EFFECT_START_NID] = *valp; 3739 changed = ca0132_cvoice_switch_set(codec); 3740 goto exit; 3741 } 3742 3743 /* out and in effects */ 3744 if (((nid >= OUT_EFFECT_START_NID) && (nid < OUT_EFFECT_END_NID)) || 3745 ((nid >= IN_EFFECT_START_NID) && (nid < IN_EFFECT_END_NID))) { 3746 spec->effects_switch[nid - EFFECT_START_NID] = *valp; 3747 changed = ca0132_effects_set(codec, nid, *valp); 3748 goto exit; 3749 } 3750 3751 /* mic boost */ 3752 if (nid == spec->input_pins[0]) { 3753 spec->cur_mic_boost = *valp; 3754 3755 /* Mic boost does not apply to Digital Mic */ 3756 if (spec->cur_mic_type != DIGITAL_MIC) 3757 changed = ca0132_mic_boost_set(codec, *valp); 3758 goto exit; 3759 } 3760 3761 exit: 3762 snd_hda_power_down(codec); 3763 return changed; 3764 } 3765 3766 /* 3767 * Volume related 3768 */ 3769 static int ca0132_volume_info(struct snd_kcontrol *kcontrol, 3770 struct snd_ctl_elem_info *uinfo) 3771 { 3772 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3773 struct ca0132_spec *spec = codec->spec; 3774 hda_nid_t nid = get_amp_nid(kcontrol); 3775 int ch = get_amp_channels(kcontrol); 3776 int dir = get_amp_direction(kcontrol); 3777 unsigned long pval; 3778 int err; 3779 3780 switch (nid) { 3781 case VNID_SPK: 3782 /* follow shared_out info */ 3783 nid = spec->shared_out_nid; 3784 mutex_lock(&codec->control_mutex); 3785 pval = kcontrol->private_value; 3786 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir); 3787 err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo); 3788 kcontrol->private_value = pval; 3789 mutex_unlock(&codec->control_mutex); 3790 break; 3791 case VNID_MIC: 3792 /* follow shared_mic info */ 3793 nid = spec->shared_mic_nid; 3794 mutex_lock(&codec->control_mutex); 3795 pval = kcontrol->private_value; 3796 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir); 3797 err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo); 3798 kcontrol->private_value = pval; 3799 mutex_unlock(&codec->control_mutex); 3800 break; 3801 default: 3802 err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo); 3803 } 3804 return err; 3805 } 3806 3807 static int ca0132_volume_get(struct snd_kcontrol *kcontrol, 3808 struct snd_ctl_elem_value *ucontrol) 3809 { 3810 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3811 struct ca0132_spec *spec = codec->spec; 3812 hda_nid_t nid = get_amp_nid(kcontrol); 3813 int ch = get_amp_channels(kcontrol); 3814 long *valp = ucontrol->value.integer.value; 3815 3816 /* store the left and right volume */ 3817 if (ch & 1) { 3818 *valp = spec->vnode_lvol[nid - VNODE_START_NID]; 3819 valp++; 3820 } 3821 if (ch & 2) { 3822 *valp = spec->vnode_rvol[nid - VNODE_START_NID]; 3823 valp++; 3824 } 3825 return 0; 3826 } 3827 3828 static int ca0132_volume_put(struct snd_kcontrol *kcontrol, 3829 struct snd_ctl_elem_value *ucontrol) 3830 { 3831 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3832 struct ca0132_spec *spec = codec->spec; 3833 hda_nid_t nid = get_amp_nid(kcontrol); 3834 int ch = get_amp_channels(kcontrol); 3835 long *valp = ucontrol->value.integer.value; 3836 hda_nid_t shared_nid = 0; 3837 bool effective; 3838 int changed = 1; 3839 3840 /* store the left and right volume */ 3841 if (ch & 1) { 3842 spec->vnode_lvol[nid - VNODE_START_NID] = *valp; 3843 valp++; 3844 } 3845 if (ch & 2) { 3846 spec->vnode_rvol[nid - VNODE_START_NID] = *valp; 3847 valp++; 3848 } 3849 3850 /* if effective conditions, then update hw immediately. */ 3851 effective = ca0132_is_vnode_effective(codec, nid, &shared_nid); 3852 if (effective) { 3853 int dir = get_amp_direction(kcontrol); 3854 unsigned long pval; 3855 3856 snd_hda_power_up(codec); 3857 mutex_lock(&codec->control_mutex); 3858 pval = kcontrol->private_value; 3859 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(shared_nid, ch, 3860 0, dir); 3861 changed = snd_hda_mixer_amp_volume_put(kcontrol, ucontrol); 3862 kcontrol->private_value = pval; 3863 mutex_unlock(&codec->control_mutex); 3864 snd_hda_power_down(codec); 3865 } 3866 3867 return changed; 3868 } 3869 3870 static int ca0132_volume_tlv(struct snd_kcontrol *kcontrol, int op_flag, 3871 unsigned int size, unsigned int __user *tlv) 3872 { 3873 struct hda_codec *codec = snd_kcontrol_chip(kcontrol); 3874 struct ca0132_spec *spec = codec->spec; 3875 hda_nid_t nid = get_amp_nid(kcontrol); 3876 int ch = get_amp_channels(kcontrol); 3877 int dir = get_amp_direction(kcontrol); 3878 unsigned long pval; 3879 int err; 3880 3881 switch (nid) { 3882 case VNID_SPK: 3883 /* follow shared_out tlv */ 3884 nid = spec->shared_out_nid; 3885 mutex_lock(&codec->control_mutex); 3886 pval = kcontrol->private_value; 3887 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir); 3888 err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv); 3889 kcontrol->private_value = pval; 3890 mutex_unlock(&codec->control_mutex); 3891 break; 3892 case VNID_MIC: 3893 /* follow shared_mic tlv */ 3894 nid = spec->shared_mic_nid; 3895 mutex_lock(&codec->control_mutex); 3896 pval = kcontrol->private_value; 3897 kcontrol->private_value = HDA_COMPOSE_AMP_VAL(nid, ch, 0, dir); 3898 err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv); 3899 kcontrol->private_value = pval; 3900 mutex_unlock(&codec->control_mutex); 3901 break; 3902 default: 3903 err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv); 3904 } 3905 return err; 3906 } 3907 3908 static int add_fx_switch(struct hda_codec *codec, hda_nid_t nid, 3909 const char *pfx, int dir) 3910 { 3911 char namestr[SNDRV_CTL_ELEM_ID_NAME_MAXLEN]; 3912 int type = dir ? HDA_INPUT : HDA_OUTPUT; 3913 struct snd_kcontrol_new knew = 3914 CA0132_CODEC_MUTE_MONO(namestr, nid, 1, type); 3915 sprintf(namestr, "%s %s Switch", pfx, dirstr[dir]); 3916 return snd_hda_ctl_add(codec, nid, snd_ctl_new1(&knew, codec)); 3917 } 3918 3919 static int add_voicefx(struct hda_codec *codec) 3920 { 3921 struct snd_kcontrol_new knew = 3922 HDA_CODEC_MUTE_MONO(ca0132_voicefx.name, 3923 VOICEFX, 1, 0, HDA_INPUT); 3924 knew.info = ca0132_voicefx_info; 3925 knew.get = ca0132_voicefx_get; 3926 knew.put = ca0132_voicefx_put; 3927 return snd_hda_ctl_add(codec, VOICEFX, snd_ctl_new1(&knew, codec)); 3928 } 3929 3930 /* 3931 * When changing Node IDs for Mixer Controls below, make sure to update 3932 * Node IDs in ca0132_config() as well. 3933 */ 3934 static struct snd_kcontrol_new ca0132_mixer[] = { 3935 CA0132_CODEC_VOL("Master Playback Volume", VNID_SPK, HDA_OUTPUT), 3936 CA0132_CODEC_MUTE("Master Playback Switch", VNID_SPK, HDA_OUTPUT), 3937 CA0132_CODEC_VOL("Capture Volume", VNID_MIC, HDA_INPUT), 3938 CA0132_CODEC_MUTE("Capture Switch", VNID_MIC, HDA_INPUT), 3939 HDA_CODEC_VOLUME("Analog-Mic2 Capture Volume", 0x08, 0, HDA_INPUT), 3940 HDA_CODEC_MUTE("Analog-Mic2 Capture Switch", 0x08, 0, HDA_INPUT), 3941 HDA_CODEC_VOLUME("What U Hear Capture Volume", 0x0a, 0, HDA_INPUT), 3942 HDA_CODEC_MUTE("What U Hear Capture Switch", 0x0a, 0, HDA_INPUT), 3943 CA0132_CODEC_MUTE_MONO("Mic1-Boost (30dB) Capture Switch", 3944 0x12, 1, HDA_INPUT), 3945 CA0132_CODEC_MUTE_MONO("HP/Speaker Playback Switch", 3946 VNID_HP_SEL, 1, HDA_OUTPUT), 3947 CA0132_CODEC_MUTE_MONO("AMic1/DMic Capture Switch", 3948 VNID_AMIC1_SEL, 1, HDA_INPUT), 3949 CA0132_CODEC_MUTE_MONO("HP/Speaker Auto Detect Playback Switch", 3950 VNID_HP_ASEL, 1, HDA_OUTPUT), 3951 CA0132_CODEC_MUTE_MONO("AMic1/DMic Auto Detect Capture Switch", 3952 VNID_AMIC1_ASEL, 1, HDA_INPUT), 3953 { } /* end */ 3954 }; 3955 3956 static int ca0132_build_controls(struct hda_codec *codec) 3957 { 3958 struct ca0132_spec *spec = codec->spec; 3959 int i, num_fx; 3960 int err = 0; 3961 3962 /* Add Mixer controls */ 3963 for (i = 0; i < spec->num_mixers; i++) { 3964 err = snd_hda_add_new_ctls(codec, spec->mixers[i]); 3965 if (err < 0) 3966 return err; 3967 } 3968 3969 /* Add in and out effects controls. 3970 * VoiceFX, PE and CrystalVoice are added separately. 3971 */ 3972 num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT; 3973 for (i = 0; i < num_fx; i++) { 3974 err = add_fx_switch(codec, ca0132_effects[i].nid, 3975 ca0132_effects[i].name, 3976 ca0132_effects[i].direct); 3977 if (err < 0) 3978 return err; 3979 } 3980 3981 err = add_fx_switch(codec, PLAY_ENHANCEMENT, "PlayEnhancement", 0); 3982 if (err < 0) 3983 return err; 3984 3985 err = add_fx_switch(codec, CRYSTAL_VOICE, "CrystalVoice", 1); 3986 if (err < 0) 3987 return err; 3988 3989 add_voicefx(codec); 3990 3991 #ifdef ENABLE_TUNING_CONTROLS 3992 add_tuning_ctls(codec); 3993 #endif 3994 3995 err = snd_hda_jack_add_kctls(codec, &spec->autocfg); 3996 if (err < 0) 3997 return err; 3998 3999 if (spec->dig_out) { 4000 err = snd_hda_create_spdif_out_ctls(codec, spec->dig_out, 4001 spec->dig_out); 4002 if (err < 0) 4003 return err; 4004 err = snd_hda_create_spdif_share_sw(codec, &spec->multiout); 4005 if (err < 0) 4006 return err; 4007 /* spec->multiout.share_spdif = 1; */ 4008 } 4009 4010 if (spec->dig_in) { 4011 err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in); 4012 if (err < 0) 4013 return err; 4014 } 4015 return 0; 4016 } 4017 4018 /* 4019 * PCM 4020 */ 4021 static const struct hda_pcm_stream ca0132_pcm_analog_playback = { 4022 .substreams = 1, 4023 .channels_min = 2, 4024 .channels_max = 6, 4025 .ops = { 4026 .prepare = ca0132_playback_pcm_prepare, 4027 .cleanup = ca0132_playback_pcm_cleanup, 4028 .get_delay = ca0132_playback_pcm_delay, 4029 }, 4030 }; 4031 4032 static const struct hda_pcm_stream ca0132_pcm_analog_capture = { 4033 .substreams = 1, 4034 .channels_min = 2, 4035 .channels_max = 2, 4036 .ops = { 4037 .prepare = ca0132_capture_pcm_prepare, 4038 .cleanup = ca0132_capture_pcm_cleanup, 4039 .get_delay = ca0132_capture_pcm_delay, 4040 }, 4041 }; 4042 4043 static const struct hda_pcm_stream ca0132_pcm_digital_playback = { 4044 .substreams = 1, 4045 .channels_min = 2, 4046 .channels_max = 2, 4047 .ops = { 4048 .open = ca0132_dig_playback_pcm_open, 4049 .close = ca0132_dig_playback_pcm_close, 4050 .prepare = ca0132_dig_playback_pcm_prepare, 4051 .cleanup = ca0132_dig_playback_pcm_cleanup 4052 }, 4053 }; 4054 4055 static const struct hda_pcm_stream ca0132_pcm_digital_capture = { 4056 .substreams = 1, 4057 .channels_min = 2, 4058 .channels_max = 2, 4059 }; 4060 4061 static int ca0132_build_pcms(struct hda_codec *codec) 4062 { 4063 struct ca0132_spec *spec = codec->spec; 4064 struct hda_pcm *info; 4065 4066 info = snd_hda_codec_pcm_new(codec, "CA0132 Analog"); 4067 if (!info) 4068 return -ENOMEM; 4069 info->stream[SNDRV_PCM_STREAM_PLAYBACK] = ca0132_pcm_analog_playback; 4070 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dacs[0]; 4071 info->stream[SNDRV_PCM_STREAM_PLAYBACK].channels_max = 4072 spec->multiout.max_channels; 4073 info->stream[SNDRV_PCM_STREAM_CAPTURE] = ca0132_pcm_analog_capture; 4074 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1; 4075 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[0]; 4076 4077 info = snd_hda_codec_pcm_new(codec, "CA0132 Analog Mic-In2"); 4078 if (!info) 4079 return -ENOMEM; 4080 info->stream[SNDRV_PCM_STREAM_CAPTURE] = ca0132_pcm_analog_capture; 4081 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1; 4082 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[1]; 4083 4084 info = snd_hda_codec_pcm_new(codec, "CA0132 What U Hear"); 4085 if (!info) 4086 return -ENOMEM; 4087 info->stream[SNDRV_PCM_STREAM_CAPTURE] = ca0132_pcm_analog_capture; 4088 info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = 1; 4089 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adcs[2]; 4090 4091 if (!spec->dig_out && !spec->dig_in) 4092 return 0; 4093 4094 info = snd_hda_codec_pcm_new(codec, "CA0132 Digital"); 4095 if (!info) 4096 return -ENOMEM; 4097 info->pcm_type = HDA_PCM_TYPE_SPDIF; 4098 if (spec->dig_out) { 4099 info->stream[SNDRV_PCM_STREAM_PLAYBACK] = 4100 ca0132_pcm_digital_playback; 4101 info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->dig_out; 4102 } 4103 if (spec->dig_in) { 4104 info->stream[SNDRV_PCM_STREAM_CAPTURE] = 4105 ca0132_pcm_digital_capture; 4106 info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->dig_in; 4107 } 4108 4109 return 0; 4110 } 4111 4112 static void init_output(struct hda_codec *codec, hda_nid_t pin, hda_nid_t dac) 4113 { 4114 if (pin) { 4115 snd_hda_set_pin_ctl(codec, pin, PIN_HP); 4116 if (get_wcaps(codec, pin) & AC_WCAP_OUT_AMP) 4117 snd_hda_codec_write(codec, pin, 0, 4118 AC_VERB_SET_AMP_GAIN_MUTE, 4119 AMP_OUT_UNMUTE); 4120 } 4121 if (dac && (get_wcaps(codec, dac) & AC_WCAP_OUT_AMP)) 4122 snd_hda_codec_write(codec, dac, 0, 4123 AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO); 4124 } 4125 4126 static void init_input(struct hda_codec *codec, hda_nid_t pin, hda_nid_t adc) 4127 { 4128 if (pin) { 4129 snd_hda_set_pin_ctl(codec, pin, PIN_VREF80); 4130 if (get_wcaps(codec, pin) & AC_WCAP_IN_AMP) 4131 snd_hda_codec_write(codec, pin, 0, 4132 AC_VERB_SET_AMP_GAIN_MUTE, 4133 AMP_IN_UNMUTE(0)); 4134 } 4135 if (adc && (get_wcaps(codec, adc) & AC_WCAP_IN_AMP)) { 4136 snd_hda_codec_write(codec, adc, 0, AC_VERB_SET_AMP_GAIN_MUTE, 4137 AMP_IN_UNMUTE(0)); 4138 4139 /* init to 0 dB and unmute. */ 4140 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0, 4141 HDA_AMP_VOLMASK, 0x5a); 4142 snd_hda_codec_amp_stereo(codec, adc, HDA_INPUT, 0, 4143 HDA_AMP_MUTE, 0); 4144 } 4145 } 4146 4147 static void refresh_amp_caps(struct hda_codec *codec, hda_nid_t nid, int dir) 4148 { 4149 unsigned int caps; 4150 4151 caps = snd_hda_param_read(codec, nid, dir == HDA_OUTPUT ? 4152 AC_PAR_AMP_OUT_CAP : AC_PAR_AMP_IN_CAP); 4153 snd_hda_override_amp_caps(codec, nid, dir, caps); 4154 } 4155 4156 /* 4157 * Switch between Digital built-in mic and analog mic. 4158 */ 4159 static void ca0132_set_dmic(struct hda_codec *codec, int enable) 4160 { 4161 struct ca0132_spec *spec = codec->spec; 4162 unsigned int tmp; 4163 u8 val; 4164 unsigned int oldval; 4165 4166 codec_dbg(codec, "ca0132_set_dmic: enable=%d\n", enable); 4167 4168 oldval = stop_mic1(codec); 4169 ca0132_set_vipsource(codec, 0); 4170 if (enable) { 4171 /* set DMic input as 2-ch */ 4172 tmp = FLOAT_TWO; 4173 dspio_set_uint_param(codec, 0x80, 0x00, tmp); 4174 4175 val = spec->dmic_ctl; 4176 val |= 0x80; 4177 snd_hda_codec_write(codec, spec->input_pins[0], 0, 4178 VENDOR_CHIPIO_DMIC_CTL_SET, val); 4179 4180 if (!(spec->dmic_ctl & 0x20)) 4181 chipio_set_control_flag(codec, CONTROL_FLAG_DMIC, 1); 4182 } else { 4183 /* set AMic input as mono */ 4184 tmp = FLOAT_ONE; 4185 dspio_set_uint_param(codec, 0x80, 0x00, tmp); 4186 4187 val = spec->dmic_ctl; 4188 /* clear bit7 and bit5 to disable dmic */ 4189 val &= 0x5f; 4190 snd_hda_codec_write(codec, spec->input_pins[0], 0, 4191 VENDOR_CHIPIO_DMIC_CTL_SET, val); 4192 4193 if (!(spec->dmic_ctl & 0x20)) 4194 chipio_set_control_flag(codec, CONTROL_FLAG_DMIC, 0); 4195 } 4196 ca0132_set_vipsource(codec, 1); 4197 resume_mic1(codec, oldval); 4198 } 4199 4200 /* 4201 * Initialization for Digital Mic. 4202 */ 4203 static void ca0132_init_dmic(struct hda_codec *codec) 4204 { 4205 struct ca0132_spec *spec = codec->spec; 4206 u8 val; 4207 4208 /* Setup Digital Mic here, but don't enable. 4209 * Enable based on jack detect. 4210 */ 4211 4212 /* MCLK uses MPIO1, set to enable. 4213 * Bit 2-0: MPIO select 4214 * Bit 3: set to disable 4215 * Bit 7-4: reserved 4216 */ 4217 val = 0x01; 4218 snd_hda_codec_write(codec, spec->input_pins[0], 0, 4219 VENDOR_CHIPIO_DMIC_MCLK_SET, val); 4220 4221 /* Data1 uses MPIO3. Data2 not use 4222 * Bit 2-0: Data1 MPIO select 4223 * Bit 3: set disable Data1 4224 * Bit 6-4: Data2 MPIO select 4225 * Bit 7: set disable Data2 4226 */ 4227 val = 0x83; 4228 snd_hda_codec_write(codec, spec->input_pins[0], 0, 4229 VENDOR_CHIPIO_DMIC_PIN_SET, val); 4230 4231 /* Use Ch-0 and Ch-1. Rate is 48K, mode 1. Disable DMic first. 4232 * Bit 3-0: Channel mask 4233 * Bit 4: set for 48KHz, clear for 32KHz 4234 * Bit 5: mode 4235 * Bit 6: set to select Data2, clear for Data1 4236 * Bit 7: set to enable DMic, clear for AMic 4237 */ 4238 val = 0x23; 4239 /* keep a copy of dmic ctl val for enable/disable dmic purpuse */ 4240 spec->dmic_ctl = val; 4241 snd_hda_codec_write(codec, spec->input_pins[0], 0, 4242 VENDOR_CHIPIO_DMIC_CTL_SET, val); 4243 } 4244 4245 /* 4246 * Initialization for Analog Mic 2 4247 */ 4248 static void ca0132_init_analog_mic2(struct hda_codec *codec) 4249 { 4250 struct ca0132_spec *spec = codec->spec; 4251 4252 mutex_lock(&spec->chipio_mutex); 4253 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 4254 VENDOR_CHIPIO_8051_ADDRESS_LOW, 0x20); 4255 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 4256 VENDOR_CHIPIO_8051_ADDRESS_HIGH, 0x19); 4257 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 4258 VENDOR_CHIPIO_8051_DATA_WRITE, 0x00); 4259 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 4260 VENDOR_CHIPIO_8051_ADDRESS_LOW, 0x2D); 4261 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 4262 VENDOR_CHIPIO_8051_ADDRESS_HIGH, 0x19); 4263 snd_hda_codec_write(codec, WIDGET_CHIP_CTRL, 0, 4264 VENDOR_CHIPIO_8051_DATA_WRITE, 0x00); 4265 mutex_unlock(&spec->chipio_mutex); 4266 } 4267 4268 static void ca0132_refresh_widget_caps(struct hda_codec *codec) 4269 { 4270 struct ca0132_spec *spec = codec->spec; 4271 int i; 4272 4273 codec_dbg(codec, "ca0132_refresh_widget_caps.\n"); 4274 snd_hda_codec_update_widgets(codec); 4275 4276 for (i = 0; i < spec->multiout.num_dacs; i++) 4277 refresh_amp_caps(codec, spec->dacs[i], HDA_OUTPUT); 4278 4279 for (i = 0; i < spec->num_outputs; i++) 4280 refresh_amp_caps(codec, spec->out_pins[i], HDA_OUTPUT); 4281 4282 for (i = 0; i < spec->num_inputs; i++) { 4283 refresh_amp_caps(codec, spec->adcs[i], HDA_INPUT); 4284 refresh_amp_caps(codec, spec->input_pins[i], HDA_INPUT); 4285 } 4286 } 4287 4288 /* 4289 * Setup default parameters for DSP 4290 */ 4291 static void ca0132_setup_defaults(struct hda_codec *codec) 4292 { 4293 struct ca0132_spec *spec = codec->spec; 4294 unsigned int tmp; 4295 int num_fx; 4296 int idx, i; 4297 4298 if (spec->dsp_state != DSP_DOWNLOADED) 4299 return; 4300 4301 /* out, in effects + voicefx */ 4302 num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT + 1; 4303 for (idx = 0; idx < num_fx; idx++) { 4304 for (i = 0; i <= ca0132_effects[idx].params; i++) { 4305 dspio_set_uint_param(codec, ca0132_effects[idx].mid, 4306 ca0132_effects[idx].reqs[i], 4307 ca0132_effects[idx].def_vals[i]); 4308 } 4309 } 4310 4311 /*remove DSP headroom*/ 4312 tmp = FLOAT_ZERO; 4313 dspio_set_uint_param(codec, 0x96, 0x3C, tmp); 4314 4315 /*set speaker EQ bypass attenuation*/ 4316 dspio_set_uint_param(codec, 0x8f, 0x01, tmp); 4317 4318 /* set AMic1 and AMic2 as mono mic */ 4319 tmp = FLOAT_ONE; 4320 dspio_set_uint_param(codec, 0x80, 0x00, tmp); 4321 dspio_set_uint_param(codec, 0x80, 0x01, tmp); 4322 4323 /* set AMic1 as CrystalVoice input */ 4324 tmp = FLOAT_ONE; 4325 dspio_set_uint_param(codec, 0x80, 0x05, tmp); 4326 4327 /* set WUH source */ 4328 tmp = FLOAT_TWO; 4329 dspio_set_uint_param(codec, 0x31, 0x00, tmp); 4330 } 4331 4332 /* 4333 * Initialization of flags in chip 4334 */ 4335 static void ca0132_init_flags(struct hda_codec *codec) 4336 { 4337 chipio_set_control_flag(codec, CONTROL_FLAG_IDLE_ENABLE, 0); 4338 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_A_COMMON_MODE, 0); 4339 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_D_COMMON_MODE, 0); 4340 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_A_10KOHM_LOAD, 0); 4341 chipio_set_control_flag(codec, CONTROL_FLAG_PORT_D_10KOHM_LOAD, 0); 4342 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_C_HIGH_PASS, 1); 4343 } 4344 4345 /* 4346 * Initialization of parameters in chip 4347 */ 4348 static void ca0132_init_params(struct hda_codec *codec) 4349 { 4350 chipio_set_control_param(codec, CONTROL_PARAM_PORTA_160OHM_GAIN, 6); 4351 chipio_set_control_param(codec, CONTROL_PARAM_PORTD_160OHM_GAIN, 6); 4352 } 4353 4354 static void ca0132_set_dsp_msr(struct hda_codec *codec, bool is96k) 4355 { 4356 chipio_set_control_flag(codec, CONTROL_FLAG_DSP_96KHZ, is96k); 4357 chipio_set_control_flag(codec, CONTROL_FLAG_DAC_96KHZ, is96k); 4358 chipio_set_control_flag(codec, CONTROL_FLAG_SRC_RATE_96KHZ, is96k); 4359 chipio_set_control_flag(codec, CONTROL_FLAG_SRC_CLOCK_196MHZ, is96k); 4360 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_B_96KHZ, is96k); 4361 chipio_set_control_flag(codec, CONTROL_FLAG_ADC_C_96KHZ, is96k); 4362 4363 chipio_set_conn_rate(codec, MEM_CONNID_MICIN1, SR_96_000); 4364 chipio_set_conn_rate(codec, MEM_CONNID_MICOUT1, SR_96_000); 4365 chipio_set_conn_rate(codec, MEM_CONNID_WUH, SR_48_000); 4366 } 4367 4368 static bool ca0132_download_dsp_images(struct hda_codec *codec) 4369 { 4370 bool dsp_loaded = false; 4371 const struct dsp_image_seg *dsp_os_image; 4372 const struct firmware *fw_entry; 4373 4374 if (request_firmware(&fw_entry, EFX_FILE, codec->card->dev) != 0) 4375 return false; 4376 4377 dsp_os_image = (struct dsp_image_seg *)(fw_entry->data); 4378 if (dspload_image(codec, dsp_os_image, 0, 0, true, 0)) { 4379 codec_err(codec, "ca0132 DSP load image failed\n"); 4380 goto exit_download; 4381 } 4382 4383 dsp_loaded = dspload_wait_loaded(codec); 4384 4385 exit_download: 4386 release_firmware(fw_entry); 4387 4388 return dsp_loaded; 4389 } 4390 4391 static void ca0132_download_dsp(struct hda_codec *codec) 4392 { 4393 struct ca0132_spec *spec = codec->spec; 4394 4395 #ifndef CONFIG_SND_HDA_CODEC_CA0132_DSP 4396 return; /* NOP */ 4397 #endif 4398 4399 if (spec->dsp_state == DSP_DOWNLOAD_FAILED) 4400 return; /* don't retry failures */ 4401 4402 chipio_enable_clocks(codec); 4403 spec->dsp_state = DSP_DOWNLOADING; 4404 if (!ca0132_download_dsp_images(codec)) 4405 spec->dsp_state = DSP_DOWNLOAD_FAILED; 4406 else 4407 spec->dsp_state = DSP_DOWNLOADED; 4408 4409 if (spec->dsp_state == DSP_DOWNLOADED) 4410 ca0132_set_dsp_msr(codec, true); 4411 } 4412 4413 static void ca0132_process_dsp_response(struct hda_codec *codec, 4414 struct hda_jack_callback *callback) 4415 { 4416 struct ca0132_spec *spec = codec->spec; 4417 4418 codec_dbg(codec, "ca0132_process_dsp_response\n"); 4419 if (spec->wait_scp) { 4420 if (dspio_get_response_data(codec) >= 0) 4421 spec->wait_scp = 0; 4422 } 4423 4424 dspio_clear_response_queue(codec); 4425 } 4426 4427 static void hp_callback(struct hda_codec *codec, struct hda_jack_callback *cb) 4428 { 4429 struct ca0132_spec *spec = codec->spec; 4430 struct hda_jack_tbl *tbl; 4431 4432 /* Delay enabling the HP amp, to let the mic-detection 4433 * state machine run. 4434 */ 4435 cancel_delayed_work_sync(&spec->unsol_hp_work); 4436 schedule_delayed_work(&spec->unsol_hp_work, msecs_to_jiffies(500)); 4437 tbl = snd_hda_jack_tbl_get(codec, cb->nid); 4438 if (tbl) 4439 tbl->block_report = 1; 4440 } 4441 4442 static void amic_callback(struct hda_codec *codec, struct hda_jack_callback *cb) 4443 { 4444 ca0132_select_mic(codec); 4445 } 4446 4447 static void ca0132_init_unsol(struct hda_codec *codec) 4448 { 4449 struct ca0132_spec *spec = codec->spec; 4450 snd_hda_jack_detect_enable_callback(codec, spec->unsol_tag_hp, hp_callback); 4451 snd_hda_jack_detect_enable_callback(codec, spec->unsol_tag_amic1, 4452 amic_callback); 4453 snd_hda_jack_detect_enable_callback(codec, UNSOL_TAG_DSP, 4454 ca0132_process_dsp_response); 4455 } 4456 4457 /* 4458 * Verbs tables. 4459 */ 4460 4461 /* Sends before DSP download. */ 4462 static struct hda_verb ca0132_base_init_verbs[] = { 4463 /*enable ct extension*/ 4464 {0x15, VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE, 0x1}, 4465 {} 4466 }; 4467 4468 /* Send at exit. */ 4469 static struct hda_verb ca0132_base_exit_verbs[] = { 4470 /*set afg to D3*/ 4471 {0x01, AC_VERB_SET_POWER_STATE, 0x03}, 4472 /*disable ct extension*/ 4473 {0x15, VENDOR_CHIPIO_CT_EXTENSIONS_ENABLE, 0}, 4474 {} 4475 }; 4476 4477 /* Other verbs tables. Sends after DSP download. */ 4478 static struct hda_verb ca0132_init_verbs0[] = { 4479 /* chip init verbs */ 4480 {0x15, 0x70D, 0xF0}, 4481 {0x15, 0x70E, 0xFE}, 4482 {0x15, 0x707, 0x75}, 4483 {0x15, 0x707, 0xD3}, 4484 {0x15, 0x707, 0x09}, 4485 {0x15, 0x707, 0x53}, 4486 {0x15, 0x707, 0xD4}, 4487 {0x15, 0x707, 0xEF}, 4488 {0x15, 0x707, 0x75}, 4489 {0x15, 0x707, 0xD3}, 4490 {0x15, 0x707, 0x09}, 4491 {0x15, 0x707, 0x02}, 4492 {0x15, 0x707, 0x37}, 4493 {0x15, 0x707, 0x78}, 4494 {0x15, 0x53C, 0xCE}, 4495 {0x15, 0x575, 0xC9}, 4496 {0x15, 0x53D, 0xCE}, 4497 {0x15, 0x5B7, 0xC9}, 4498 {0x15, 0x70D, 0xE8}, 4499 {0x15, 0x70E, 0xFE}, 4500 {0x15, 0x707, 0x02}, 4501 {0x15, 0x707, 0x68}, 4502 {0x15, 0x707, 0x62}, 4503 {0x15, 0x53A, 0xCE}, 4504 {0x15, 0x546, 0xC9}, 4505 {0x15, 0x53B, 0xCE}, 4506 {0x15, 0x5E8, 0xC9}, 4507 {0x15, 0x717, 0x0D}, 4508 {0x15, 0x718, 0x20}, 4509 {} 4510 }; 4511 4512 static void ca0132_init_chip(struct hda_codec *codec) 4513 { 4514 struct ca0132_spec *spec = codec->spec; 4515 int num_fx; 4516 int i; 4517 unsigned int on; 4518 4519 mutex_init(&spec->chipio_mutex); 4520 4521 spec->cur_out_type = SPEAKER_OUT; 4522 spec->cur_mic_type = DIGITAL_MIC; 4523 spec->cur_mic_boost = 0; 4524 4525 for (i = 0; i < VNODES_COUNT; i++) { 4526 spec->vnode_lvol[i] = 0x5a; 4527 spec->vnode_rvol[i] = 0x5a; 4528 spec->vnode_lswitch[i] = 0; 4529 spec->vnode_rswitch[i] = 0; 4530 } 4531 4532 /* 4533 * Default states for effects are in ca0132_effects[]. 4534 */ 4535 num_fx = OUT_EFFECTS_COUNT + IN_EFFECTS_COUNT; 4536 for (i = 0; i < num_fx; i++) { 4537 on = (unsigned int)ca0132_effects[i].reqs[0]; 4538 spec->effects_switch[i] = on ? 1 : 0; 4539 } 4540 4541 spec->voicefx_val = 0; 4542 spec->effects_switch[PLAY_ENHANCEMENT - EFFECT_START_NID] = 1; 4543 spec->effects_switch[CRYSTAL_VOICE - EFFECT_START_NID] = 0; 4544 4545 #ifdef ENABLE_TUNING_CONTROLS 4546 ca0132_init_tuning_defaults(codec); 4547 #endif 4548 } 4549 4550 static void ca0132_exit_chip(struct hda_codec *codec) 4551 { 4552 /* put any chip cleanup stuffs here. */ 4553 4554 if (dspload_is_loaded(codec)) 4555 dsp_reset(codec); 4556 } 4557 4558 static int ca0132_init(struct hda_codec *codec) 4559 { 4560 struct ca0132_spec *spec = codec->spec; 4561 struct auto_pin_cfg *cfg = &spec->autocfg; 4562 int i; 4563 4564 if (spec->dsp_state != DSP_DOWNLOAD_FAILED) 4565 spec->dsp_state = DSP_DOWNLOAD_INIT; 4566 spec->curr_chip_addx = INVALID_CHIP_ADDRESS; 4567 4568 snd_hda_power_up_pm(codec); 4569 4570 ca0132_init_unsol(codec); 4571 4572 ca0132_init_params(codec); 4573 ca0132_init_flags(codec); 4574 snd_hda_sequence_write(codec, spec->base_init_verbs); 4575 ca0132_download_dsp(codec); 4576 ca0132_refresh_widget_caps(codec); 4577 ca0132_setup_defaults(codec); 4578 ca0132_init_analog_mic2(codec); 4579 ca0132_init_dmic(codec); 4580 4581 for (i = 0; i < spec->num_outputs; i++) 4582 init_output(codec, spec->out_pins[i], spec->dacs[0]); 4583 4584 init_output(codec, cfg->dig_out_pins[0], spec->dig_out); 4585 4586 for (i = 0; i < spec->num_inputs; i++) 4587 init_input(codec, spec->input_pins[i], spec->adcs[i]); 4588 4589 init_input(codec, cfg->dig_in_pin, spec->dig_in); 4590 4591 snd_hda_sequence_write(codec, spec->chip_init_verbs); 4592 snd_hda_sequence_write(codec, spec->spec_init_verbs); 4593 4594 ca0132_select_out(codec); 4595 ca0132_select_mic(codec); 4596 4597 snd_hda_jack_report_sync(codec); 4598 4599 snd_hda_power_down_pm(codec); 4600 4601 return 0; 4602 } 4603 4604 static void ca0132_free(struct hda_codec *codec) 4605 { 4606 struct ca0132_spec *spec = codec->spec; 4607 4608 cancel_delayed_work_sync(&spec->unsol_hp_work); 4609 snd_hda_power_up(codec); 4610 snd_hda_sequence_write(codec, spec->base_exit_verbs); 4611 ca0132_exit_chip(codec); 4612 snd_hda_power_down(codec); 4613 kfree(spec->spec_init_verbs); 4614 kfree(codec->spec); 4615 } 4616 4617 static const struct hda_codec_ops ca0132_patch_ops = { 4618 .build_controls = ca0132_build_controls, 4619 .build_pcms = ca0132_build_pcms, 4620 .init = ca0132_init, 4621 .free = ca0132_free, 4622 .unsol_event = snd_hda_jack_unsol_event, 4623 }; 4624 4625 static void ca0132_config(struct hda_codec *codec) 4626 { 4627 struct ca0132_spec *spec = codec->spec; 4628 struct auto_pin_cfg *cfg = &spec->autocfg; 4629 4630 spec->dacs[0] = 0x2; 4631 spec->dacs[1] = 0x3; 4632 spec->dacs[2] = 0x4; 4633 4634 spec->multiout.dac_nids = spec->dacs; 4635 spec->multiout.num_dacs = 3; 4636 spec->multiout.max_channels = 2; 4637 4638 if (spec->quirk == QUIRK_ALIENWARE) { 4639 codec_dbg(codec, "ca0132_config: QUIRK_ALIENWARE applied.\n"); 4640 snd_hda_apply_pincfgs(codec, alienware_pincfgs); 4641 4642 spec->num_outputs = 2; 4643 spec->out_pins[0] = 0x0b; /* speaker out */ 4644 spec->out_pins[1] = 0x0f; 4645 spec->shared_out_nid = 0x2; 4646 spec->unsol_tag_hp = 0x0f; 4647 4648 spec->adcs[0] = 0x7; /* digital mic / analog mic1 */ 4649 spec->adcs[1] = 0x8; /* analog mic2 */ 4650 spec->adcs[2] = 0xa; /* what u hear */ 4651 4652 spec->num_inputs = 3; 4653 spec->input_pins[0] = 0x12; 4654 spec->input_pins[1] = 0x11; 4655 spec->input_pins[2] = 0x13; 4656 spec->shared_mic_nid = 0x7; 4657 spec->unsol_tag_amic1 = 0x11; 4658 } else { 4659 spec->num_outputs = 2; 4660 spec->out_pins[0] = 0x0b; /* speaker out */ 4661 spec->out_pins[1] = 0x10; /* headphone out */ 4662 spec->shared_out_nid = 0x2; 4663 spec->unsol_tag_hp = spec->out_pins[1]; 4664 4665 spec->adcs[0] = 0x7; /* digital mic / analog mic1 */ 4666 spec->adcs[1] = 0x8; /* analog mic2 */ 4667 spec->adcs[2] = 0xa; /* what u hear */ 4668 4669 spec->num_inputs = 3; 4670 spec->input_pins[0] = 0x12; 4671 spec->input_pins[1] = 0x11; 4672 spec->input_pins[2] = 0x13; 4673 spec->shared_mic_nid = 0x7; 4674 spec->unsol_tag_amic1 = spec->input_pins[0]; 4675 4676 /* SPDIF I/O */ 4677 spec->dig_out = 0x05; 4678 spec->multiout.dig_out_nid = spec->dig_out; 4679 cfg->dig_out_pins[0] = 0x0c; 4680 cfg->dig_outs = 1; 4681 cfg->dig_out_type[0] = HDA_PCM_TYPE_SPDIF; 4682 spec->dig_in = 0x09; 4683 cfg->dig_in_pin = 0x0e; 4684 cfg->dig_in_type = HDA_PCM_TYPE_SPDIF; 4685 } 4686 } 4687 4688 static int ca0132_prepare_verbs(struct hda_codec *codec) 4689 { 4690 /* Verbs + terminator (an empty element) */ 4691 #define NUM_SPEC_VERBS 4 4692 struct ca0132_spec *spec = codec->spec; 4693 4694 spec->chip_init_verbs = ca0132_init_verbs0; 4695 spec->spec_init_verbs = kzalloc(sizeof(struct hda_verb) * NUM_SPEC_VERBS, GFP_KERNEL); 4696 if (!spec->spec_init_verbs) 4697 return -ENOMEM; 4698 4699 /* HP jack autodetection */ 4700 spec->spec_init_verbs[0].nid = spec->unsol_tag_hp; 4701 spec->spec_init_verbs[0].param = AC_VERB_SET_UNSOLICITED_ENABLE; 4702 spec->spec_init_verbs[0].verb = AC_USRSP_EN | spec->unsol_tag_hp; 4703 4704 /* MIC1 jack autodetection */ 4705 spec->spec_init_verbs[1].nid = spec->unsol_tag_amic1; 4706 spec->spec_init_verbs[1].param = AC_VERB_SET_UNSOLICITED_ENABLE; 4707 spec->spec_init_verbs[1].verb = AC_USRSP_EN | spec->unsol_tag_amic1; 4708 4709 /* config EAPD */ 4710 spec->spec_init_verbs[2].nid = 0x0b; 4711 spec->spec_init_verbs[2].param = 0x78D; 4712 spec->spec_init_verbs[2].verb = 0x00; 4713 4714 /* Previously commented configuration */ 4715 /* 4716 spec->spec_init_verbs[3].nid = 0x0b; 4717 spec->spec_init_verbs[3].param = AC_VERB_SET_EAPD_BTLENABLE; 4718 spec->spec_init_verbs[3].verb = 0x02; 4719 4720 spec->spec_init_verbs[4].nid = 0x10; 4721 spec->spec_init_verbs[4].param = 0x78D; 4722 spec->spec_init_verbs[4].verb = 0x02; 4723 4724 spec->spec_init_verbs[5].nid = 0x10; 4725 spec->spec_init_verbs[5].param = AC_VERB_SET_EAPD_BTLENABLE; 4726 spec->spec_init_verbs[5].verb = 0x02; 4727 */ 4728 4729 /* Terminator: spec->spec_init_verbs[NUM_SPEC_VERBS-1] */ 4730 return 0; 4731 } 4732 4733 static int patch_ca0132(struct hda_codec *codec) 4734 { 4735 struct ca0132_spec *spec; 4736 int err; 4737 const struct snd_pci_quirk *quirk; 4738 4739 codec_dbg(codec, "patch_ca0132\n"); 4740 4741 spec = kzalloc(sizeof(*spec), GFP_KERNEL); 4742 if (!spec) 4743 return -ENOMEM; 4744 codec->spec = spec; 4745 spec->codec = codec; 4746 4747 codec->patch_ops = ca0132_patch_ops; 4748 codec->pcm_format_first = 1; 4749 codec->no_sticky_stream = 1; 4750 4751 /* Detect codec quirk */ 4752 quirk = snd_pci_quirk_lookup(codec->bus->pci, ca0132_quirks); 4753 if (quirk) 4754 spec->quirk = quirk->value; 4755 else 4756 spec->quirk = QUIRK_NONE; 4757 4758 spec->dsp_state = DSP_DOWNLOAD_INIT; 4759 spec->num_mixers = 1; 4760 spec->mixers[0] = ca0132_mixer; 4761 4762 spec->base_init_verbs = ca0132_base_init_verbs; 4763 spec->base_exit_verbs = ca0132_base_exit_verbs; 4764 4765 INIT_DELAYED_WORK(&spec->unsol_hp_work, ca0132_unsol_hp_delayed); 4766 4767 ca0132_init_chip(codec); 4768 4769 ca0132_config(codec); 4770 4771 err = ca0132_prepare_verbs(codec); 4772 if (err < 0) 4773 return err; 4774 4775 err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, NULL); 4776 if (err < 0) 4777 return err; 4778 4779 return 0; 4780 } 4781 4782 /* 4783 * patch entries 4784 */ 4785 static struct hda_device_id snd_hda_id_ca0132[] = { 4786 HDA_CODEC_ENTRY(0x11020011, "CA0132", patch_ca0132), 4787 {} /* terminator */ 4788 }; 4789 MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_ca0132); 4790 4791 MODULE_LICENSE("GPL"); 4792 MODULE_DESCRIPTION("Creative Sound Core3D codec"); 4793 4794 static struct hda_codec_driver ca0132_driver = { 4795 .id = snd_hda_id_ca0132, 4796 }; 4797 4798 module_hda_codec_driver(ca0132_driver); 4799