Lines Matching +full:mux +full:- +full:delay +full:- +full:config +full:- +full:us
1 // SPDX-License-Identifier: GPL-2.0-only
3 * wm8993.c -- WM8993 ALSA SoC audio driver
5 * Copyright 2009-12 Wolfson Microelectronics plc
13 #include <linux/delay.h>
42 { 1, 0x0000 }, /* R1 - Power Management (1) */
43 { 2, 0x6000 }, /* R2 - Power Management (2) */
44 { 3, 0x0000 }, /* R3 - Power Management (3) */
45 { 4, 0x4050 }, /* R4 - Audio Interface (1) */
46 { 5, 0x4000 }, /* R5 - Audio Interface (2) */
47 { 6, 0x01C8 }, /* R6 - Clocking 1 */
48 { 7, 0x0000 }, /* R7 - Clocking 2 */
49 { 8, 0x0000 }, /* R8 - Audio Interface (3) */
50 { 9, 0x0040 }, /* R9 - Audio Interface (4) */
51 { 10, 0x0004 }, /* R10 - DAC CTRL */
52 { 11, 0x00C0 }, /* R11 - Left DAC Digital Volume */
53 { 12, 0x00C0 }, /* R12 - Right DAC Digital Volume */
54 { 13, 0x0000 }, /* R13 - Digital Side Tone */
55 { 14, 0x0300 }, /* R14 - ADC CTRL */
56 { 15, 0x00C0 }, /* R15 - Left ADC Digital Volume */
57 { 16, 0x00C0 }, /* R16 - Right ADC Digital Volume */
58 { 18, 0x0000 }, /* R18 - GPIO CTRL 1 */
59 { 19, 0x0010 }, /* R19 - GPIO1 */
60 { 20, 0x0000 }, /* R20 - IRQ_DEBOUNCE */
61 { 21, 0x0000 }, /* R21 - Inputs Clamp */
62 { 22, 0x8000 }, /* R22 - GPIOCTRL 2 */
63 { 23, 0x0800 }, /* R23 - GPIO_POL */
64 { 24, 0x008B }, /* R24 - Left Line Input 1&2 Volume */
65 { 25, 0x008B }, /* R25 - Left Line Input 3&4 Volume */
66 { 26, 0x008B }, /* R26 - Right Line Input 1&2 Volume */
67 { 27, 0x008B }, /* R27 - Right Line Input 3&4 Volume */
68 { 28, 0x006D }, /* R28 - Left Output Volume */
69 { 29, 0x006D }, /* R29 - Right Output Volume */
70 { 30, 0x0066 }, /* R30 - Line Outputs Volume */
71 { 31, 0x0020 }, /* R31 - HPOUT2 Volume */
72 { 32, 0x0079 }, /* R32 - Left OPGA Volume */
73 { 33, 0x0079 }, /* R33 - Right OPGA Volume */
74 { 34, 0x0003 }, /* R34 - SPKMIXL Attenuation */
75 { 35, 0x0003 }, /* R35 - SPKMIXR Attenuation */
76 { 36, 0x0011 }, /* R36 - SPKOUT Mixers */
77 { 37, 0x0100 }, /* R37 - SPKOUT Boost */
78 { 38, 0x0079 }, /* R38 - Speaker Volume Left */
79 { 39, 0x0079 }, /* R39 - Speaker Volume Right */
80 { 40, 0x0000 }, /* R40 - Input Mixer2 */
81 { 41, 0x0000 }, /* R41 - Input Mixer3 */
82 { 42, 0x0000 }, /* R42 - Input Mixer4 */
83 { 43, 0x0000 }, /* R43 - Input Mixer5 */
84 { 44, 0x0000 }, /* R44 - Input Mixer6 */
85 { 45, 0x0000 }, /* R45 - Output Mixer1 */
86 { 46, 0x0000 }, /* R46 - Output Mixer2 */
87 { 47, 0x0000 }, /* R47 - Output Mixer3 */
88 { 48, 0x0000 }, /* R48 - Output Mixer4 */
89 { 49, 0x0000 }, /* R49 - Output Mixer5 */
90 { 50, 0x0000 }, /* R50 - Output Mixer6 */
91 { 51, 0x0000 }, /* R51 - HPOUT2 Mixer */
92 { 52, 0x0000 }, /* R52 - Line Mixer1 */
93 { 53, 0x0000 }, /* R53 - Line Mixer2 */
94 { 54, 0x0000 }, /* R54 - Speaker Mixer */
95 { 55, 0x0000 }, /* R55 - Additional Control */
96 { 56, 0x0000 }, /* R56 - AntiPOP1 */
97 { 57, 0x0000 }, /* R57 - AntiPOP2 */
98 { 58, 0x0000 }, /* R58 - MICBIAS */
99 { 60, 0x0000 }, /* R60 - FLL Control 1 */
100 { 61, 0x0000 }, /* R61 - FLL Control 2 */
101 { 62, 0x0000 }, /* R62 - FLL Control 3 */
102 { 63, 0x2EE0 }, /* R63 - FLL Control 4 */
103 { 64, 0x0002 }, /* R64 - FLL Control 5 */
104 { 65, 0x2287 }, /* R65 - Clocking 3 */
105 { 66, 0x025F }, /* R66 - Clocking 4 */
106 { 67, 0x0000 }, /* R67 - MW Slave Control */
107 { 69, 0x0002 }, /* R69 - Bus Control 1 */
108 { 70, 0x0000 }, /* R70 - Write Sequencer 0 */
109 { 71, 0x0000 }, /* R71 - Write Sequencer 1 */
110 { 72, 0x0000 }, /* R72 - Write Sequencer 2 */
111 { 73, 0x0000 }, /* R73 - Write Sequencer 3 */
112 { 74, 0x0000 }, /* R74 - Write Sequencer 4 */
113 { 75, 0x0000 }, /* R75 - Write Sequencer 5 */
114 { 76, 0x1F25 }, /* R76 - Charge Pump 1 */
115 { 81, 0x0000 }, /* R81 - Class W 0 */
116 { 85, 0x054A }, /* R85 - DC Servo 1 */
117 { 87, 0x0000 }, /* R87 - DC Servo 3 */
118 { 96, 0x0100 }, /* R96 - Analogue HP 0 */
119 { 98, 0x0000 }, /* R98 - EQ1 */
120 { 99, 0x000C }, /* R99 - EQ2 */
121 { 100, 0x000C }, /* R100 - EQ3 */
122 { 101, 0x000C }, /* R101 - EQ4 */
123 { 102, 0x000C }, /* R102 - EQ5 */
124 { 103, 0x000C }, /* R103 - EQ6 */
125 { 104, 0x0FCA }, /* R104 - EQ7 */
126 { 105, 0x0400 }, /* R105 - EQ8 */
127 { 106, 0x00D8 }, /* R106 - EQ9 */
128 { 107, 0x1EB5 }, /* R107 - EQ10 */
129 { 108, 0xF145 }, /* R108 - EQ11 */
130 { 109, 0x0B75 }, /* R109 - EQ12 */
131 { 110, 0x01C5 }, /* R110 - EQ13 */
132 { 111, 0x1C58 }, /* R111 - EQ14 */
133 { 112, 0xF373 }, /* R112 - EQ15 */
134 { 113, 0x0A54 }, /* R113 - EQ16 */
135 { 114, 0x0558 }, /* R114 - EQ17 */
136 { 115, 0x168E }, /* R115 - EQ18 */
137 { 116, 0xF829 }, /* R116 - EQ19 */
138 { 117, 0x07AD }, /* R117 - EQ20 */
139 { 118, 0x1103 }, /* R118 - EQ21 */
140 { 119, 0x0564 }, /* R119 - EQ22 */
141 { 120, 0x0559 }, /* R120 - EQ23 */
142 { 121, 0x4000 }, /* R121 - EQ24 */
143 { 122, 0x0000 }, /* R122 - Digital Pulls */
144 { 123, 0x0F08 }, /* R123 - DRC Control 1 */
145 { 124, 0x0000 }, /* R124 - DRC Control 2 */
146 { 125, 0x0080 }, /* R125 - DRC Control 3 */
147 { 126, 0x0000 }, /* R126 - DRC Control 4 */
392 fll_div->fll_clk_ref_div = 0; in fll_factors()
395 fll_div->fll_clk_ref_div++; in fll_factors()
400 return -EINVAL; in fll_factors()
409 /* Fvco should be 90-100MHz; don't check the upper bound */ in fll_factors()
418 return -EINVAL; in fll_factors()
421 fll_div->fll_outdiv = div; in fll_factors()
428 fll_div->fll_fratio = fll_fratios[i].fll_fratio; in fll_factors()
435 return -EINVAL; in fll_factors()
441 fll_div->n = Ndiv; in fll_factors()
445 /* Calculate fractional part - scale up so we can round. */ in fll_factors()
456 fll_div->k = K / 10; in fll_factors()
459 fll_div->n, fll_div->k, in fll_factors()
460 fll_div->fll_fratio, fll_div->fll_outdiv, in fll_factors()
461 fll_div->fll_clk_ref_div); in fll_factors()
470 struct i2c_client *i2c = to_i2c_client(component->dev); in _wm8993_set_fll()
477 if (Fref == wm8993->fll_fref && Fout == wm8993->fll_fout) in _wm8993_set_fll()
482 dev_dbg(component->dev, "FLL disabled\n"); in _wm8993_set_fll()
483 wm8993->fll_fref = 0; in _wm8993_set_fll()
484 wm8993->fll_fout = 0; in _wm8993_set_fll()
513 dev_err(component->dev, "Unknown FLL ID %d\n", fll_id); in _wm8993_set_fll()
514 return -EINVAL; in _wm8993_set_fll()
545 if (i2c->irq) in _wm8993_set_fll()
552 try_wait_for_completion(&wm8993->fll_lock); in _wm8993_set_fll()
557 timeout = wait_for_completion_timeout(&wm8993->fll_lock, timeout); in _wm8993_set_fll()
558 if (i2c->irq && !timeout) in _wm8993_set_fll()
559 dev_warn(component->dev, "Timed out waiting for FLL\n"); in _wm8993_set_fll()
561 dev_dbg(component->dev, "FLL enabled at %dHz->%dHz\n", Fref, Fout); in _wm8993_set_fll()
563 wm8993->fll_fref = Fref; in _wm8993_set_fll()
564 wm8993->fll_fout = Fout; in _wm8993_set_fll()
565 wm8993->fll_src = source; in _wm8993_set_fll()
573 return _wm8993_set_fll(dai->component, fll_id, source, Fref, Fout); in wm8993_set_fll()
582 switch (wm8993->sysclk_source) { in configure_clock()
584 dev_dbg(component->dev, "Using %dHz MCLK\n", wm8993->mclk_rate); in configure_clock()
588 if (wm8993->mclk_rate > 13500000) { in configure_clock()
590 wm8993->sysclk_rate = wm8993->mclk_rate / 2; in configure_clock()
593 wm8993->sysclk_rate = wm8993->mclk_rate; in configure_clock()
599 dev_dbg(component->dev, "Using %dHz FLL clock\n", in configure_clock()
600 wm8993->fll_fout); in configure_clock()
604 if (wm8993->fll_fout > 13500000) { in configure_clock()
606 wm8993->sysclk_rate = wm8993->fll_fout / 2; in configure_clock()
609 wm8993->sysclk_rate = wm8993->fll_fout; in configure_clock()
615 dev_err(component->dev, "System clock not configured\n"); in configure_clock()
616 return -EINVAL; in configure_clock()
619 dev_dbg(component->dev, "CLK_SYS is %dHz\n", wm8993->sysclk_rate); in configure_clock()
624 static const DECLARE_TLV_DB_SCALE(sidetone_tlv, -3600, 300, 0);
625 static const DECLARE_TLV_DB_SCALE(drc_comp_threash, -4500, 75, 0);
626 static const DECLARE_TLV_DB_SCALE(drc_comp_amp, -2250, 75, 0);
627 static const DECLARE_TLV_DB_SCALE(drc_min_tlv, -1800, 600, 0);
633 static const DECLARE_TLV_DB_SCALE(drc_startup_tlv, -1800, 300, 0);
634 static const DECLARE_TLV_DB_SCALE(eq_tlv, -1200, 100, 0);
635 static const DECLARE_TLV_DB_SCALE(digital_tlv, -7200, 75, 1);
649 "Hi-Fi",
691 "181us",
692 "363us",
693 "726us",
766 SOC_ENUM("DRC FF Delay", drc_ff),
767 SOC_SINGLE("DRC Anti-clip Switch", WM8993_DRC_CONTROL_1, 9, 1, 0),
809 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in clk_sys_event()
844 SOC_DAPM_ENUM("AIFOUTL Mux", aifoutl_enum);
850 SOC_DAPM_ENUM("AIFOUTR Mux", aifoutr_enum);
856 SOC_DAPM_ENUM("AIFINL Mux", aifinl_enum);
862 SOC_DAPM_ENUM("AIFINR Mux", aifinr_enum);
890 SND_SOC_DAPM_MUX("AIFOUTL Mux", SND_SOC_NOPM, 0, 0, &aifoutl_mux),
891 SND_SOC_DAPM_MUX("AIFOUTR Mux", SND_SOC_NOPM, 0, 0, &aifoutr_mux),
899 SND_SOC_DAPM_MUX("DACL Mux", SND_SOC_NOPM, 0, 0, &aifinl_mux),
900 SND_SOC_DAPM_MUX("DACR Mux", SND_SOC_NOPM, 0, 0, &aifinr_mux),
908 SND_SOC_DAPM_MUX("Left Headphone Mux", SND_SOC_NOPM, 0, 0, &wm_hubs_hpl_mux),
909 SND_SOC_DAPM_MUX("Right Headphone Mux", SND_SOC_NOPM, 0, 0, &wm_hubs_hpr_mux),
927 { "AIFOUTL Mux", "Left", "ADCL" },
928 { "AIFOUTL Mux", "Right", "ADCR" },
929 { "AIFOUTR Mux", "Left", "ADCL" },
930 { "AIFOUTR Mux", "Right", "ADCR" },
932 { "AIFOUTL", NULL, "AIFOUTL Mux" },
933 { "AIFOUTR", NULL, "AIFOUTR Mux" },
935 { "DACL Mux", "Left", "AIFINL" },
936 { "DACL Mux", "Right", "AIFINR" },
937 { "DACR Mux", "Left", "AIFINL" },
938 { "DACR Mux", "Right", "AIFINR" },
947 { "DACL", NULL, "DACL Mux" },
951 { "DACR", NULL, "DACR Mux" },
968 { "Left Headphone Mux", "DAC", "DACL" },
969 { "Right Headphone Mux", "DAC", "DACR" },
992 ret = regulator_bulk_enable(ARRAY_SIZE(wm8993->supplies), in wm8993_set_bias_level()
993 wm8993->supplies); in wm8993_set_bias_level()
997 regcache_cache_only(wm8993->regmap, false); in wm8993_set_bias_level()
998 regcache_sync(wm8993->regmap); in wm8993_set_bias_level()
1015 if (!wm8993->pdata.lineout1_diff || in wm8993_set_bias_level()
1016 !wm8993->pdata.lineout2_diff) in wm8993_set_bias_level()
1056 regcache_cache_only(wm8993->regmap, true); in wm8993_set_bias_level()
1057 regcache_mark_dirty(wm8993->regmap); in wm8993_set_bias_level()
1059 regulator_bulk_disable(ARRAY_SIZE(wm8993->supplies), in wm8993_set_bias_level()
1060 wm8993->supplies); in wm8993_set_bias_level()
1070 struct snd_soc_component *component = codec_dai->component; in wm8993_set_sysclk()
1075 wm8993->mclk_rate = freq; in wm8993_set_sysclk()
1078 wm8993->sysclk_source = clk_id; in wm8993_set_sysclk()
1082 return -EINVAL; in wm8993_set_sysclk()
1091 struct snd_soc_component *component = dai->component; in wm8993_set_dai_fmt()
1102 wm8993->master = 0; in wm8993_set_dai_fmt()
1106 wm8993->master = 1; in wm8993_set_dai_fmt()
1110 wm8993->master = 1; in wm8993_set_dai_fmt()
1115 wm8993->master = 1; in wm8993_set_dai_fmt()
1118 return -EINVAL; in wm8993_set_dai_fmt()
1137 return -EINVAL; in wm8993_set_dai_fmt()
1151 return -EINVAL; in wm8993_set_dai_fmt()
1171 return -EINVAL; in wm8993_set_dai_fmt()
1175 return -EINVAL; in wm8993_set_dai_fmt()
1188 struct snd_soc_component *component = dai->component; in wm8993_hw_params()
1206 wm8993->fs = params_rate(params); in wm8993_hw_params()
1207 wm8993->bclk = 2 * wm8993->fs; in wm8993_hw_params()
1208 if (wm8993->tdm_slots) { in wm8993_hw_params()
1209 dev_dbg(component->dev, "Configuring for %d %d bit TDM slots\n", in wm8993_hw_params()
1210 wm8993->tdm_slots, wm8993->tdm_width); in wm8993_hw_params()
1211 wm8993->bclk *= wm8993->tdm_width * wm8993->tdm_slots; in wm8993_hw_params()
1215 wm8993->bclk *= 16; in wm8993_hw_params()
1218 wm8993->bclk *= 20; in wm8993_hw_params()
1222 wm8993->bclk *= 24; in wm8993_hw_params()
1226 wm8993->bclk *= 32; in wm8993_hw_params()
1230 return -EINVAL; in wm8993_hw_params()
1234 dev_dbg(component->dev, "Target BCLK is %dHz\n", wm8993->bclk); in wm8993_hw_params()
1242 best_val = abs((wm8993->sysclk_rate / clk_sys_rates[0].ratio) in wm8993_hw_params()
1243 - wm8993->fs); in wm8993_hw_params()
1245 cur_val = abs((wm8993->sysclk_rate / in wm8993_hw_params()
1246 clk_sys_rates[i].ratio) - wm8993->fs); in wm8993_hw_params()
1252 dev_dbg(component->dev, "Selected CLK_SYS_RATIO of %d\n", in wm8993_hw_params()
1259 best_val = abs(wm8993->fs - sample_rates[0].rate); in wm8993_hw_params()
1262 cur_val = abs(wm8993->fs - sample_rates[i].rate); in wm8993_hw_params()
1268 dev_dbg(component->dev, "Selected SAMPLE_RATE of %dHz\n", in wm8993_hw_params()
1277 cur_val = ((wm8993->sysclk_rate * 10) / bclk_divs[i].div) in wm8993_hw_params()
1278 - wm8993->bclk; in wm8993_hw_params()
1286 wm8993->bclk = (wm8993->sysclk_rate * 10) / bclk_divs[best].div; in wm8993_hw_params()
1287 dev_dbg(component->dev, "Selected BCLK_DIV of %d for %dHz BCLK\n", in wm8993_hw_params()
1288 bclk_divs[best].div, wm8993->bclk); in wm8993_hw_params()
1292 dev_dbg(component->dev, "LRCLK_RATE is %d\n", wm8993->bclk / wm8993->fs); in wm8993_hw_params()
1293 aif4 |= wm8993->bclk / wm8993->fs; in wm8993_hw_params()
1301 if (wm8993->pdata.num_retune_configs) { in wm8993_hw_params()
1306 best_val = abs(wm8993->pdata.retune_configs[0].rate in wm8993_hw_params()
1307 - wm8993->fs); in wm8993_hw_params()
1308 for (i = 0; i < wm8993->pdata.num_retune_configs; i++) { in wm8993_hw_params()
1309 cur_val = abs(wm8993->pdata.retune_configs[i].rate in wm8993_hw_params()
1310 - wm8993->fs); in wm8993_hw_params()
1316 s = &wm8993->pdata.retune_configs[best]; in wm8993_hw_params()
1318 dev_dbg(component->dev, "ReTune Mobile %s tuned for %dHz\n", in wm8993_hw_params()
1319 s->name, s->rate); in wm8993_hw_params()
1324 for (i = 1; i < ARRAY_SIZE(s->config); i++) in wm8993_hw_params()
1325 snd_soc_component_write(component, WM8993_EQ1 + i, s->config[i]); in wm8993_hw_params()
1335 struct snd_soc_component *component = codec_dai->component; in wm8993_mute()
1353 struct snd_soc_component *component = dai->component; in wm8993_set_tdm_slot()
1360 wm8993->tdm_slots = 0; in wm8993_set_tdm_slot()
1364 /* Note that we allow configurations we can't handle ourselves - in wm8993_set_tdm_slot()
1378 return -EINVAL; in wm8993_set_tdm_slot()
1389 return -EINVAL; in wm8993_set_tdm_slot()
1393 wm8993->tdm_width = slot_width; in wm8993_set_tdm_slot()
1394 wm8993->tdm_slots = slots / 2; in wm8993_set_tdm_slot()
1409 ret = regmap_read(wm8993->regmap, WM8993_GPIO_CTRL_1, &val); in wm8993_irq()
1411 dev_err(wm8993->dev, "Failed to read interrupt status: %d\n", in wm8993_irq()
1416 ret = regmap_read(wm8993->regmap, WM8993_GPIOCTRL_2, &mask); in wm8993_irq()
1418 dev_err(wm8993->dev, "Failed to read interrupt mask: %d\n", in wm8993_irq()
1429 dev_crit(wm8993->dev, "Thermal warning\n"); in wm8993_irq()
1432 dev_dbg(wm8993->dev, "FLL locked\n"); in wm8993_irq()
1433 complete(&wm8993->fll_lock); in wm8993_irq()
1436 ret = regmap_write(wm8993->regmap, WM8993_GPIO_CTRL_1, val); in wm8993_irq()
1438 dev_err(wm8993->dev, "Failed to ack interrupt: %d\n", ret); in wm8993_irq()
1461 .name = "wm8993-hifi",
1487 wm8993->hubs_data.hp_startup_mode = 1; in wm8993_probe()
1488 wm8993->hubs_data.dcs_codes_l = -2; in wm8993_probe()
1489 wm8993->hubs_data.dcs_codes_r = -2; in wm8993_probe()
1490 wm8993->hubs_data.series_startup = 1; in wm8993_probe()
1506 wm_hubs_handle_analogue_pdata(component, wm8993->pdata.lineout1_diff, in wm8993_probe()
1507 wm8993->pdata.lineout2_diff, in wm8993_probe()
1508 wm8993->pdata.lineout1fb, in wm8993_probe()
1509 wm8993->pdata.lineout2fb, in wm8993_probe()
1510 wm8993->pdata.jd_scthr, in wm8993_probe()
1511 wm8993->pdata.jd_thr, in wm8993_probe()
1512 wm8993->pdata.micbias1_delay, in wm8993_probe()
1513 wm8993->pdata.micbias2_delay, in wm8993_probe()
1514 wm8993->pdata.micbias1_lvl, in wm8993_probe()
1515 wm8993->pdata.micbias2_lvl); in wm8993_probe()
1519 if (wm8993->pdata.num_retune_configs != 0) { in wm8993_probe()
1520 dev_dbg(component->dev, "Using ReTune Mobile\n"); in wm8993_probe()
1522 dev_dbg(component->dev, "No ReTune Mobile, using normal EQ\n"); in wm8993_probe()
1532 wm_hubs_add_analogue_routes(component, wm8993->pdata.lineout1_diff, in wm8993_probe()
1533 wm8993->pdata.lineout2_diff); in wm8993_probe()
1538 if (wm8993->pdata.lineout1_diff && wm8993->pdata.lineout2_diff) in wm8993_probe()
1539 dapm->idle_bias_off = 1; in wm8993_probe()
1549 int fll_fout = wm8993->fll_fout; in wm8993_suspend()
1550 int fll_fref = wm8993->fll_fref; in wm8993_suspend()
1556 dev_err(component->dev, "Failed to stop FLL\n"); in wm8993_suspend()
1560 wm8993->fll_fout = fll_fout; in wm8993_suspend()
1561 wm8993->fll_fref = fll_fref; in wm8993_suspend()
1576 if (wm8993->fll_fout) { in wm8993_resume()
1577 int fll_fout = wm8993->fll_fout; in wm8993_resume()
1578 int fll_fref = wm8993->fll_fref; in wm8993_resume()
1580 wm8993->fll_fref = 0; in wm8993_resume()
1581 wm8993->fll_fout = 0; in wm8993_resume()
1583 ret = _wm8993_set_fll(component, 0, wm8993->fll_src, in wm8993_resume()
1586 dev_err(component->dev, "Failed to restart FLL\n"); in wm8993_resume()
1632 wm8993 = devm_kzalloc(&i2c->dev, sizeof(struct wm8993_priv), in wm8993_i2c_probe()
1635 return -ENOMEM; in wm8993_i2c_probe()
1637 wm8993->dev = &i2c->dev; in wm8993_i2c_probe()
1638 init_completion(&wm8993->fll_lock); in wm8993_i2c_probe()
1640 wm8993->regmap = devm_regmap_init_i2c(i2c, &wm8993_regmap); in wm8993_i2c_probe()
1641 if (IS_ERR(wm8993->regmap)) { in wm8993_i2c_probe()
1642 ret = PTR_ERR(wm8993->regmap); in wm8993_i2c_probe()
1643 dev_err(&i2c->dev, "Failed to allocate regmap: %d\n", ret); in wm8993_i2c_probe()
1649 for (i = 0; i < ARRAY_SIZE(wm8993->supplies); i++) in wm8993_i2c_probe()
1650 wm8993->supplies[i].supply = wm8993_supply_names[i]; in wm8993_i2c_probe()
1652 ret = devm_regulator_bulk_get(&i2c->dev, ARRAY_SIZE(wm8993->supplies), in wm8993_i2c_probe()
1653 wm8993->supplies); in wm8993_i2c_probe()
1655 dev_err(&i2c->dev, "Failed to request supplies: %d\n", ret); in wm8993_i2c_probe()
1659 ret = regulator_bulk_enable(ARRAY_SIZE(wm8993->supplies), in wm8993_i2c_probe()
1660 wm8993->supplies); in wm8993_i2c_probe()
1662 dev_err(&i2c->dev, "Failed to enable supplies: %d\n", ret); in wm8993_i2c_probe()
1666 ret = regmap_read(wm8993->regmap, WM8993_SOFTWARE_RESET, ®); in wm8993_i2c_probe()
1668 dev_err(&i2c->dev, "Failed to read chip ID: %d\n", ret); in wm8993_i2c_probe()
1673 dev_err(&i2c->dev, "Invalid ID register value %x\n", reg); in wm8993_i2c_probe()
1674 ret = -EINVAL; in wm8993_i2c_probe()
1678 ret = regmap_write(wm8993->regmap, WM8993_SOFTWARE_RESET, 0xffff); in wm8993_i2c_probe()
1682 ret = regmap_register_patch(wm8993->regmap, wm8993_regmap_patch, in wm8993_i2c_probe()
1685 dev_warn(wm8993->dev, "Failed to apply regmap patch: %d\n", in wm8993_i2c_probe()
1688 if (i2c->irq) { in wm8993_i2c_probe()
1690 ret = regmap_update_bits(wm8993->regmap, WM8993_GPIO1, in wm8993_i2c_probe()
1696 ret = request_threaded_irq(i2c->irq, NULL, wm8993_irq, in wm8993_i2c_probe()
1704 regulator_bulk_disable(ARRAY_SIZE(wm8993->supplies), wm8993->supplies); in wm8993_i2c_probe()
1706 regcache_cache_only(wm8993->regmap, true); in wm8993_i2c_probe()
1708 ret = devm_snd_soc_register_component(&i2c->dev, in wm8993_i2c_probe()
1711 dev_err(&i2c->dev, "Failed to register CODEC: %d\n", ret); in wm8993_i2c_probe()
1718 if (i2c->irq) in wm8993_i2c_probe()
1719 free_irq(i2c->irq, wm8993); in wm8993_i2c_probe()
1721 regulator_bulk_disable(ARRAY_SIZE(wm8993->supplies), wm8993->supplies); in wm8993_i2c_probe()
1729 if (i2c->irq) in wm8993_i2c_remove()
1730 free_irq(i2c->irq, wm8993); in wm8993_i2c_remove()
1731 regulator_bulk_disable(ARRAY_SIZE(wm8993->supplies), wm8993->supplies); in wm8993_i2c_remove()