Lines Matching +full:out +full:- +full:mono

1 // SPDX-License-Identifier: GPL-2.0-only
3 * rt5640.c -- RT5640/RT5639 ALSA SoC audio codec driver
27 #include <sound/soc-dapm.h>
340 static const DECLARE_TLV_DB_SCALE(out_vol_tlv, -4650, 150, 0);
341 static const DECLARE_TLV_DB_MINMAX(dac_vol_tlv, -6562, 0);
342 static const DECLARE_TLV_DB_SCALE(in_vol_tlv, -3450, 150, 0);
343 static const DECLARE_TLV_DB_MINMAX(adc_vol_tlv, -1762, 3000);
392 SOC_DOUBLE("OUT Playback Switch", RT5640_OUTPUT,
394 SOC_DOUBLE("OUT Channel Switch", RT5640_OUTPUT,
396 SOC_DOUBLE_TLV("OUT Playback Volume", RT5640_OUTPUT,
426 SOC_DOUBLE("Mono ADC Capture Switch", RT5640_DUMMY1,
428 SOC_DOUBLE_TLV("Mono ADC Capture Volume", RT5640_ADC_DATA,
445 /* MONO Output Control */
446 SOC_SINGLE("Mono Playback Switch", RT5640_MONO_OUT, RT5640_L_MUTE_SFT,
451 * set_dmic_clk - Set parameter of dmic.
461 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in set_dmic_clk()
465 rate = rt5640->sysclk / rl6231_get_pre_div(rt5640->regmap, in set_dmic_clk()
469 dev_err(component->dev, "Failed to set DMIC clock\n"); in set_dmic_clk()
479 struct snd_soc_component *component = snd_soc_dapm_to_component(source->dapm); in is_using_asrc()
482 if (!rt5640->asrc_en) in is_using_asrc()
607 SOC_DAPM_SINGLE("OUT MIXL Switch", RT5640_REC_L2_MIXER,
622 SOC_DAPM_SINGLE("OUT MIXR Switch", RT5640_REC_R2_MIXER,
636 SOC_DAPM_SINGLE("OUT MIXL Switch", RT5640_SPK_L_MIXER,
649 SOC_DAPM_SINGLE("OUT MIXR Switch", RT5640_SPK_R_MIXER,
812 /* Mono ADC source */
814 "Mono DAC MIXL", "ADCL"
821 SOC_DAPM_ENUM("Mono ADC1 left source", rt5640_mono_adc_l1_enum);
824 "DMIC L1", "DMIC L2", "Mono DAC MIXL"
831 SOC_DAPM_ENUM("Mono ADC2 left source", rt5640_mono_adc_l2_enum);
834 "Mono DAC MIXR", "ADCR"
841 SOC_DAPM_ENUM("Mono ADC1 right source", rt5640_mono_adc_r1_enum);
844 "DMIC R1", "DMIC R2", "Mono DAC MIXR"
851 SOC_DAPM_ENUM("Mono ADC2 right source", rt5640_mono_adc_r2_enum);
921 regmap_update_bits(rt5640->regmap, RT5640_PR_BASE + in hp_amp_power_on()
923 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M2, in hp_amp_power_on()
925 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M1, in hp_amp_power_on()
928 regmap_write(rt5640->regmap, RT5640_PR_BASE + RT5640_HP_DCC_INT1, in hp_amp_power_on()
931 regmap_update_bits(rt5640->regmap, RT5640_PWR_ANLG1, in hp_amp_power_on()
933 regmap_update_bits(rt5640->regmap, RT5640_PWR_ANLG1, in hp_amp_power_on()
937 regmap_update_bits(rt5640->regmap, RT5640_PWR_ANLG1, in hp_amp_power_on()
946 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M2, in rt5640_pmu_depop()
949 regmap_update_bits(rt5640->regmap, RT5640_CHARGE_PUMP, in rt5640_pmu_depop()
952 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M3, in rt5640_pmu_depop()
958 regmap_write(rt5640->regmap, RT5640_PR_BASE + in rt5640_pmu_depop()
960 regmap_update_bits(rt5640->regmap, RT5640_DEPOP_M1, in rt5640_pmu_depop()
963 regmap_update_bits(rt5640->regmap, RT5640_PR_BASE + in rt5640_pmu_depop()
970 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in rt5640_hp_event()
976 rt5640->hp_mute = false; in rt5640_hp_event()
980 rt5640->hp_mute = true; in rt5640_hp_event()
994 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in rt5640_lout_event()
1023 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in rt5640_hp_power_event()
1039 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in rt5640_hp_post_event()
1044 if (!rt5640->hp_mute) in rt5640_hp_post_event()
1127 SND_SOC_DAPM_MUX("Mono ADC L2 Mux", SND_SOC_NOPM, 0, 0,
1129 SND_SOC_DAPM_MUX("Mono ADC L1 Mux", SND_SOC_NOPM, 0, 0,
1131 SND_SOC_DAPM_MUX("Mono ADC R1 Mux", SND_SOC_NOPM, 0, 0,
1133 SND_SOC_DAPM_MUX("Mono ADC R2 Mux", SND_SOC_NOPM, 0, 0,
1142 SND_SOC_DAPM_SUPPLY("Mono Left Filter", RT5640_PWR_DIG2,
1144 SND_SOC_DAPM_MIXER("Mono ADC MIXL", SND_SOC_NOPM, 0, 0,
1146 SND_SOC_DAPM_SUPPLY("Mono Right Filter", RT5640_PWR_DIG2,
1148 SND_SOC_DAPM_MIXER("Mono ADC MIXR", SND_SOC_NOPM, 0, 0,
1193 SND_SOC_DAPM_MIXER("Mono DAC MIXL", SND_SOC_NOPM, 0, 0,
1195 SND_SOC_DAPM_MIXER("Mono DAC MIXR", SND_SOC_NOPM, 0, 0,
1214 /* SPK/OUT Mixer */
1232 /* SPO/HPO/LOUT/Mono Mixer */
1295 SND_SOC_DAPM_MIXER("OUT MIXL", RT5640_PWR_MIXER, RT5640_PWR_OM_L_BIT,
1297 SND_SOC_DAPM_MIXER("OUT MIXR", RT5640_PWR_MIXER, RT5640_PWR_OM_R_BIT,
1305 SND_SOC_DAPM_MIXER("Mono MIX", RT5640_PWR_ANLG1, RT5640_PWR_MM_BIT, 0,
1307 SND_SOC_DAPM_SUPPLY("Improve MONO Amp Drv", RT5640_PWR_ANLG1,
1320 SND_SOC_DAPM_MIXER("OUT MIXL", RT5640_PWR_MIXER, RT5640_PWR_OM_L_BIT,
1322 SND_SOC_DAPM_MIXER("OUT MIXR", RT5640_PWR_MIXER, RT5640_PWR_OM_R_BIT,
1362 {"RECMIXL", "OUT MIXL Switch", "OUT MIXL"},
1369 {"RECMIXR", "OUT MIXR Switch", "OUT MIXR"},
1395 {"Mono ADC L2 Mux", "DMIC L1", "DMIC L1"},
1396 {"Mono ADC L2 Mux", "DMIC L2", "DMIC L2"},
1397 {"Mono ADC L2 Mux", "Mono DAC MIXL", "Mono DAC MIXL"},
1398 {"Mono ADC L1 Mux", "Mono DAC MIXL", "Mono DAC MIXL"},
1399 {"Mono ADC L1 Mux", "ADCL", "ADC L"},
1401 {"Mono ADC R1 Mux", "Mono DAC MIXR", "Mono DAC MIXR"},
1402 {"Mono ADC R1 Mux", "ADCR", "ADC R"},
1403 {"Mono ADC R2 Mux", "DMIC R1", "DMIC R1"},
1404 {"Mono ADC R2 Mux", "DMIC R2", "DMIC R2"},
1405 {"Mono ADC R2 Mux", "Mono DAC MIXR", "Mono DAC MIXR"},
1415 {"Mono ADC MIXL", "ADC1 Switch", "Mono ADC L1 Mux"},
1416 {"Mono ADC MIXL", "ADC2 Switch", "Mono ADC L2 Mux"},
1417 {"Mono ADC MIXL", NULL, "Mono Left Filter"},
1419 {"Mono ADC MIXR", "ADC1 Switch", "Mono ADC R1 Mux"},
1420 {"Mono ADC MIXR", "ADC2 Switch", "Mono ADC R2 Mux"},
1421 {"Mono ADC MIXR", NULL, "Mono Right Filter"},
1423 {"IF2 ADC L", NULL, "Mono ADC MIXL"},
1424 {"IF2 ADC R", NULL, "Mono ADC MIXR"},
1484 {"Mono DAC MIXL", "DAC L1 Switch", "DAC MIXL"},
1485 {"Mono DAC MIXR", "DAC R1 Switch", "DAC MIXR"},
1498 {"SPK MIXL", "OUT MIXL Switch", "OUT MIXL"},
1502 {"SPK MIXR", "OUT MIXR Switch", "OUT MIXR"},
1504 {"OUT MIXL", "BST1 Switch", "BST1"},
1505 {"OUT MIXL", "INL Switch", "INL VOL"},
1506 {"OUT MIXL", "REC MIXL Switch", "RECMIXL"},
1507 {"OUT MIXL", "DAC L1 Switch", "DAC L1"},
1509 {"OUT MIXR", "BST2 Switch", "BST2"},
1510 {"OUT MIXR", "BST1 Switch", "BST1"},
1511 {"OUT MIXR", "INR Switch", "INR VOL"},
1512 {"OUT MIXR", "REC MIXR Switch", "RECMIXR"},
1513 {"OUT MIXR", "DAC R1 Switch", "DAC R1"},
1517 {"HPOVOL L", NULL, "OUT MIXL"},
1518 {"HPOVOL R", NULL, "OUT MIXR"},
1519 {"OUTVOL L", NULL, "OUT MIXL"},
1520 {"OUTVOL R", NULL, "OUT MIXR"},
1589 {"Mono DAC MIXL", "DAC L2 Switch", "DAC L2 Mux"},
1590 {"Mono DAC MIXL", "DAC R2 Switch", "DAC R2 Mux"},
1592 {"Mono DAC MIXR", "DAC R2 Switch", "DAC R2 Mux"},
1593 {"Mono DAC MIXR", "DAC L2 Switch", "DAC L2 Mux"},
1598 {"DAC L2", NULL, "Mono DAC MIXL"},
1600 {"DAC R2", NULL, "Mono DAC MIXR"},
1606 {"OUT MIXL", "SPK MIXL Switch", "SPK MIXL"},
1607 {"OUT MIXR", "SPK MIXR Switch", "SPK MIXR"},
1609 {"OUT MIXL", "DAC R2 Switch", "DAC R2"},
1610 {"OUT MIXL", "DAC L2 Switch", "DAC L2"},
1612 {"OUT MIXR", "DAC L2 Switch", "DAC L2"},
1613 {"OUT MIXR", "DAC R2 Switch", "DAC R2"},
1618 {"Mono MIX", "DAC R2 Switch", "DAC R2"},
1619 {"Mono MIX", "DAC L2 Switch", "DAC L2"},
1620 {"Mono MIX", "OUTVOL R Switch", "OUTVOL R"},
1621 {"Mono MIX", "OUTVOL L Switch", "OUTVOL L"},
1622 {"Mono MIX", "BST1 Switch", "BST1"},
1624 {"MONOP", NULL, "Mono MIX"},
1625 {"MONON", NULL, "Mono MIX"},
1626 {"MONOP", NULL, "Improve MONO Amp Drv"},
1633 {"Mono DAC MIXL", "DAC L2 Switch", "IF2 DAC L"},
1634 {"Mono DAC MIXL", "DAC R2 Switch", "IF2 DAC R"},
1636 {"Mono DAC MIXR", "DAC R2 Switch", "IF2 DAC R"},
1637 {"Mono DAC MIXR", "DAC L2 Switch", "IF2 DAC L"},
1651 return -EINVAL; in get_sdp_info()
1689 ret = -EINVAL; in get_sdp_info()
1699 struct snd_soc_component *component = dai->component; in rt5640_hw_params()
1704 rt5640->lrck[dai->id] = params_rate(params); in rt5640_hw_params()
1705 pre_div = rl6231_get_clk_info(rt5640->sysclk, rt5640->lrck[dai->id]); in rt5640_hw_params()
1707 dev_err(component->dev, "Unsupported clock setting %d for DAI %d\n", in rt5640_hw_params()
1708 rt5640->lrck[dai->id], dai->id); in rt5640_hw_params()
1709 return -EINVAL; in rt5640_hw_params()
1713 dev_err(component->dev, "Unsupported frame size: %d\n", frame_size); in rt5640_hw_params()
1720 rt5640->bclk[dai->id] = rt5640->lrck[dai->id] * (32 << bclk_ms); in rt5640_hw_params()
1722 dev_dbg(dai->dev, "bclk is %dHz and lrck is %dHz\n", in rt5640_hw_params()
1723 rt5640->bclk[dai->id], rt5640->lrck[dai->id]); in rt5640_hw_params()
1724 dev_dbg(dai->dev, "bclk_ms is %d and pre_div is %d for iis %d\n", in rt5640_hw_params()
1725 bclk_ms, pre_div, dai->id); in rt5640_hw_params()
1740 return -EINVAL; in rt5640_hw_params()
1743 dai_sel = get_sdp_info(component, dai->id); in rt5640_hw_params()
1745 dev_err(component->dev, "Failed to get sdp info: %d\n", dai_sel); in rt5640_hw_params()
1746 return -EINVAL; in rt5640_hw_params()
1770 struct snd_soc_component *component = dai->component; in rt5640_set_dai_fmt()
1777 rt5640->master[dai->id] = 1; in rt5640_set_dai_fmt()
1781 rt5640->master[dai->id] = 0; in rt5640_set_dai_fmt()
1784 return -EINVAL; in rt5640_set_dai_fmt()
1794 return -EINVAL; in rt5640_set_dai_fmt()
1810 return -EINVAL; in rt5640_set_dai_fmt()
1813 dai_sel = get_sdp_info(component, dai->id); in rt5640_set_dai_fmt()
1815 dev_err(component->dev, "Failed to get sdp info: %d\n", dai_sel); in rt5640_set_dai_fmt()
1816 return -EINVAL; in rt5640_set_dai_fmt()
1835 struct snd_soc_component *component = dai->component; in rt5640_set_dai_sysclk()
1843 ret = clk_set_rate(rt5640->mclk, freq); in rt5640_set_dai_sysclk()
1857 dev_err(component->dev, "Invalid clock id (%d)\n", clk_id); in rt5640_set_dai_sysclk()
1858 return -EINVAL; in rt5640_set_dai_sysclk()
1864 rt5640->sysclk = freq; in rt5640_set_dai_sysclk()
1865 rt5640->sysclk_src = clk_id; in rt5640_set_dai_sysclk()
1867 dev_dbg(dai->dev, "Sysclk is %dHz and clock id is %d\n", freq, clk_id); in rt5640_set_dai_sysclk()
1874 struct snd_soc_component *component = dai->component; in rt5640_set_dai_pll()
1879 if (source == rt5640->pll_src && freq_in == rt5640->pll_in && in rt5640_set_dai_pll()
1880 freq_out == rt5640->pll_out) in rt5640_set_dai_pll()
1884 dev_dbg(component->dev, "PLL disabled\n"); in rt5640_set_dai_pll()
1886 rt5640->pll_in = 0; in rt5640_set_dai_pll()
1887 rt5640->pll_out = 0; in rt5640_set_dai_pll()
1907 dev_err(component->dev, "Unknown PLL source %d\n", source); in rt5640_set_dai_pll()
1908 return -EINVAL; in rt5640_set_dai_pll()
1913 dev_err(component->dev, "Unsupported input clock %d\n", freq_in); in rt5640_set_dai_pll()
1917 dev_dbg(component->dev, "bypass=%d m=%d n=%d k=%d\n", in rt5640_set_dai_pll()
1927 rt5640->pll_in = freq_in; in rt5640_set_dai_pll()
1928 rt5640->pll_out = freq_out; in rt5640_set_dai_pll()
1929 rt5640->pll_src = source; in rt5640_set_dai_pll()
1953 clk_disable_unprepare(rt5640->mclk); in rt5640_set_bias_level()
1955 ret = clk_prepare_enable(rt5640->mclk); in rt5640_set_bias_level()
1987 if (rt5640->jd_src == RT5640_JD_SRC_HDA_HEADER) in rt5640_set_bias_level()
2008 regmap_update_bits(rt5640->regmap, RT5640_GPIO_CTRL1, in rt5640_dmic_enable()
2012 regmap_update_bits(rt5640->regmap, RT5640_DMIC, in rt5640_dmic_enable()
2014 regmap_update_bits(rt5640->regmap, RT5640_GPIO_CTRL1, in rt5640_dmic_enable()
2019 regmap_update_bits(rt5640->regmap, RT5640_DMIC, in rt5640_dmic_enable()
2021 regmap_update_bits(rt5640->regmap, RT5640_GPIO_CTRL1, in rt5640_dmic_enable()
2042 return -EINVAL; in rt5640_sel_asrc_clk_src()
2046 return -EINVAL; in rt5640_sel_asrc_clk_src()
2088 rt5640->asrc_en = true; in rt5640_sel_asrc_clk_src()
2091 rt5640->asrc_en = false; in rt5640_sel_asrc_clk_src()
2107 /* OVCD is unreliable when used with RCCLK as sysclk-source */ in rt5640_enable_micbias1_for_ovcd()
2108 if (rt5640->use_platform_clock) in rt5640_enable_micbias1_for_ovcd()
2121 if (rt5640->use_platform_clock) in rt5640_disable_micbias1_for_ovcd()
2136 rt5640->ovcd_irq_enabled = true; in rt5640_enable_micbias1_ovcd_irq()
2145 rt5640->ovcd_irq_enabled = false; in rt5640_disable_micbias1_ovcd_irq()
2159 dev_dbg(component->dev, "irq ctrl2 %#04x\n", val); in rt5640_micbias1_ovcd()
2169 if (rt5640->jd_gpio) in rt5640_jack_inserted()
2170 val = gpiod_get_value(rt5640->jd_gpio) ? RT5640_JD_STATUS : 0; in rt5640_jack_inserted()
2174 dev_dbg(component->dev, "irq status %#04x\n", val); in rt5640_jack_inserted()
2176 if (rt5640->jd_inverted) in rt5640_jack_inserted()
2182 /* Jack detect and button-press timings */
2195 rt5640->poll_count = 0; in rt5640_start_button_press_work()
2196 rt5640->press_count = 0; in rt5640_start_button_press_work()
2197 rt5640->release_count = 0; in rt5640_start_button_press_work()
2198 rt5640->pressed = false; in rt5640_start_button_press_work()
2199 rt5640->press_reported = false; in rt5640_start_button_press_work()
2201 schedule_delayed_work(&rt5640->bp_work, msecs_to_jiffies(BP_POLL_TIME)); in rt5640_start_button_press_work()
2208 struct snd_soc_component *component = rt5640->component; in rt5640_button_press_work()
2215 rt5640->release_count = 0; in rt5640_button_press_work()
2216 rt5640->press_count++; in rt5640_button_press_work()
2218 if (rt5640->press_count >= BP_THRESHOLD) in rt5640_button_press_work()
2219 rt5640->pressed = true; in rt5640_button_press_work()
2222 rt5640->press_count = 0; in rt5640_button_press_work()
2223 rt5640->release_count++; in rt5640_button_press_work()
2228 * at least JACK_UNPLUG_TIME milli-seconds before reporting a press. in rt5640_button_press_work()
2230 rt5640->poll_count++; in rt5640_button_press_work()
2231 if (rt5640->poll_count < (JACK_UNPLUG_TIME / BP_POLL_TIME)) { in rt5640_button_press_work()
2232 schedule_delayed_work(&rt5640->bp_work, in rt5640_button_press_work()
2237 if (rt5640->pressed && !rt5640->press_reported) { in rt5640_button_press_work()
2238 dev_dbg(component->dev, "headset button press\n"); in rt5640_button_press_work()
2239 snd_soc_jack_report(rt5640->jack, SND_JACK_BTN_0, in rt5640_button_press_work()
2241 rt5640->press_reported = true; in rt5640_button_press_work()
2244 if (rt5640->release_count >= BP_THRESHOLD) { in rt5640_button_press_work()
2245 if (rt5640->press_reported) { in rt5640_button_press_work()
2246 dev_dbg(component->dev, "headset button release\n"); in rt5640_button_press_work()
2247 snd_soc_jack_report(rt5640->jack, 0, SND_JACK_BTN_0); in rt5640_button_press_work()
2249 /* Re-enable OVCD IRQ to detect next press */ in rt5640_button_press_work()
2254 schedule_delayed_work(&rt5640->bp_work, msecs_to_jiffies(BP_POLL_TIME)); in rt5640_button_press_work()
2269 /* Clear any previous over-current status flag */ in rt5640_detect_headset()
2289 dev_dbg(component->dev, "jack mic-gnd shorted\n"); in rt5640_detect_headset()
2295 dev_dbg(component->dev, "jack mic-gnd open\n"); in rt5640_detect_headset()
2303 …dev_err(component->dev, "Error detecting headset vs headphones, bad contact?, assuming headphones\… in rt5640_detect_headset()
2312 struct snd_soc_component *component = rt5640->component; in rt5640_jack_work()
2315 if (rt5640->jd_src == RT5640_JD_SRC_HDA_HEADER) { in rt5640_jack_work()
2321 dev_dbg(component->dev, "mic jack status %d\n", in rt5640_jack_work()
2333 dev_dbg(component->dev, "headphone jack status %d\n", in rt5640_jack_work()
2342 snd_soc_jack_report(rt5640->jack, jack_type, SND_JACK_HEADSET); in rt5640_jack_work()
2349 if (rt5640->jack->status & SND_JACK_HEADPHONE) { in rt5640_jack_work()
2350 if (rt5640->jack->status & SND_JACK_MICROPHONE) { in rt5640_jack_work()
2351 cancel_delayed_work_sync(&rt5640->bp_work); in rt5640_jack_work()
2355 snd_soc_jack_report(rt5640->jack, 0, in rt5640_jack_work()
2357 dev_dbg(component->dev, "jack unplugged\n"); in rt5640_jack_work()
2359 } else if (!(rt5640->jack->status & SND_JACK_HEADPHONE)) { in rt5640_jack_work()
2361 WARN_ON(rt5640->ovcd_irq_enabled); in rt5640_jack_work()
2371 dev_dbg(component->dev, "detect status %#02x\n", status); in rt5640_jack_work()
2372 snd_soc_jack_report(rt5640->jack, status, SND_JACK_HEADSET); in rt5640_jack_work()
2373 } else if (rt5640->ovcd_irq_enabled && rt5640_micbias1_ovcd(component)) { in rt5640_jack_work()
2374 dev_dbg(component->dev, "OVCD IRQ\n"); in rt5640_jack_work()
2389 * If the jack-detect IRQ flag goes high (unplug) after our in rt5640_jack_work()
2392 * we react to edges, we miss the unplug event -> recheck. in rt5640_jack_work()
2394 queue_delayed_work(system_long_wq, &rt5640->jack_work, 0); in rt5640_jack_work()
2403 if (rt5640->jd_src == RT5640_JD_SRC_HDA_HEADER) in rt5640_irq()
2406 if (rt5640->jack) in rt5640_irq()
2407 mod_delayed_work(system_long_wq, &rt5640->jack_work, delay); in rt5640_irq()
2416 queue_delayed_work(system_long_wq, &rt5640->jack_work, in rt5640_jd_gpio_irq()
2426 if (rt5640->jd_gpio_irq_requested) { in rt5640_disable_irq_and_cancel_work()
2427 free_irq(rt5640->jd_gpio_irq, rt5640); in rt5640_disable_irq_and_cancel_work()
2428 rt5640->jd_gpio_irq_requested = false; in rt5640_disable_irq_and_cancel_work()
2431 if (rt5640->irq_requested) { in rt5640_disable_irq_and_cancel_work()
2432 free_irq(rt5640->irq, rt5640); in rt5640_disable_irq_and_cancel_work()
2433 rt5640->irq_requested = false; in rt5640_disable_irq_and_cancel_work()
2436 cancel_delayed_work_sync(&rt5640->jack_work); in rt5640_disable_irq_and_cancel_work()
2437 cancel_delayed_work_sync(&rt5640->bp_work); in rt5640_disable_irq_and_cancel_work()
2445 0xa800 | rt5640->ovcd_sf); in rt5640_set_ovcd_params()
2449 rt5640->ovcd_th | RT5640_MIC1_OVCD_EN); in rt5640_set_ovcd_params()
2452 * The over-current-detect is only reliable in detecting the absence in rt5640_set_ovcd_params()
2453 * of over-current, when the mic-contact in the jack is short-circuited, in rt5640_set_ovcd_params()
2454 * the hardware periodically retries if it can apply the bias-current in rt5640_set_ovcd_params()
2455 * leading to the ovcd status flip-flopping 1-0-1 with it being 0 about in rt5640_set_ovcd_params()
2470 * soc_remove_component() force-disables jack and thus rt5640->jack in rt5640_disable_jack_detect()
2473 if (!rt5640->jack) in rt5640_disable_jack_detect()
2478 if (rt5640->jack->status & SND_JACK_MICROPHONE) { in rt5640_disable_jack_detect()
2481 snd_soc_jack_report(rt5640->jack, 0, SND_JACK_BTN_0); in rt5640_disable_jack_detect()
2484 rt5640->jd_gpio = NULL; in rt5640_disable_jack_detect()
2485 rt5640->jack = NULL; in rt5640_disable_jack_detect()
2495 /* Select JD-source */ in rt5640_enable_jack_detect()
2497 RT5640_JD_MASK, rt5640->jd_src << RT5640_JD_SFT); in rt5640_enable_jack_detect()
2512 * All IRQs get or-ed together, so we need the jack IRQ to report 0 in rt5640_enable_jack_detect()
2517 if (rt5640->jd_inverted) { in rt5640_enable_jack_detect()
2518 if (rt5640->jd_src == RT5640_JD_SRC_JD1_IN4P) in rt5640_enable_jack_detect()
2521 else if (rt5640->jd_src == RT5640_JD_SRC_JD2_IN4N) in rt5640_enable_jack_detect()
2526 if (rt5640->jd_src == RT5640_JD_SRC_JD1_IN4P) in rt5640_enable_jack_detect()
2529 else if (rt5640->jd_src == RT5640_JD_SRC_JD2_IN4N) in rt5640_enable_jack_detect()
2537 rt5640->jack = jack; in rt5640_enable_jack_detect()
2538 if (rt5640->jack->status & SND_JACK_MICROPHONE) { in rt5640_enable_jack_detect()
2543 if (jack_data && jack_data->codec_irq_override) in rt5640_enable_jack_detect()
2544 rt5640->irq = jack_data->codec_irq_override; in rt5640_enable_jack_detect()
2546 if (jack_data && jack_data->jd_gpio) { in rt5640_enable_jack_detect()
2547 rt5640->jd_gpio = jack_data->jd_gpio; in rt5640_enable_jack_detect()
2548 rt5640->jd_gpio_irq = gpiod_to_irq(rt5640->jd_gpio); in rt5640_enable_jack_detect()
2550 ret = request_irq(rt5640->jd_gpio_irq, rt5640_jd_gpio_irq, in rt5640_enable_jack_detect()
2552 "rt5640-jd-gpio", rt5640); in rt5640_enable_jack_detect()
2554 dev_warn(component->dev, "Failed to request jd GPIO IRQ %d: %d\n", in rt5640_enable_jack_detect()
2555 rt5640->jd_gpio_irq, ret); in rt5640_enable_jack_detect()
2559 rt5640->jd_gpio_irq_requested = true; in rt5640_enable_jack_detect()
2562 if (jack_data && jack_data->use_platform_clock) in rt5640_enable_jack_detect()
2563 rt5640->use_platform_clock = jack_data->use_platform_clock; in rt5640_enable_jack_detect()
2565 ret = request_irq(rt5640->irq, rt5640_irq, in rt5640_enable_jack_detect()
2569 dev_warn(component->dev, "Failed to request IRQ %d: %d\n", rt5640->irq, ret); in rt5640_enable_jack_detect()
2573 rt5640->irq_requested = true; in rt5640_enable_jack_detect()
2576 queue_delayed_work(system_long_wq, &rt5640->jack_work, 0); in rt5640_enable_jack_detect()
2618 rt5640->jack = jack; in rt5640_enable_hda_jack_detect()
2620 ret = request_irq(rt5640->irq, rt5640_irq, in rt5640_enable_hda_jack_detect()
2623 dev_warn(component->dev, "Failed to request IRQ %d: %d\n", rt5640->irq, ret); in rt5640_enable_hda_jack_detect()
2624 rt5640->jack = NULL; in rt5640_enable_hda_jack_detect()
2627 rt5640->irq_requested = true; in rt5640_enable_hda_jack_detect()
2630 queue_delayed_work(system_long_wq, &rt5640->jack_work, 0); in rt5640_enable_hda_jack_detect()
2642 if (rt5640->jd_src == RT5640_JD_SRC_HDA_HEADER) in rt5640_set_jack()
2663 rt5640->mclk = devm_clk_get_optional(component->dev, "mclk"); in rt5640_probe()
2664 if (IS_ERR(rt5640->mclk)) in rt5640_probe()
2665 return PTR_ERR(rt5640->mclk); in rt5640_probe()
2667 rt5640->component = component; in rt5640_probe()
2697 dev_err(component->dev, in rt5640_probe()
2699 return -ENODEV; in rt5640_probe()
2703 * Note on some platforms the platform code may need to add device-props in rt5640_probe()
2706 * rt5640_i2c_probe(), so that the platform-code can attach extra in rt5640_probe()
2709 if (device_property_read_bool(component->dev, "realtek,in1-differential")) in rt5640_probe()
2713 if (device_property_read_bool(component->dev, "realtek,in2-differential")) in rt5640_probe()
2717 if (device_property_read_bool(component->dev, "realtek,in3-differential")) in rt5640_probe()
2721 if (device_property_read_bool(component->dev, "realtek,lout-differential")) in rt5640_probe()
2725 if (device_property_read_u32(component->dev, "realtek,dmic1-data-pin", in rt5640_probe()
2727 dmic1_data_pin = val - 1; in rt5640_probe()
2731 if (device_property_read_u32(component->dev, "realtek,dmic2-data-pin", in rt5640_probe()
2733 dmic2_data_pin = val - 1; in rt5640_probe()
2740 if (device_property_read_u32(component->dev, in rt5640_probe()
2741 "realtek,jack-detect-source", &val) == 0) { in rt5640_probe()
2743 rt5640->jd_src = val; in rt5640_probe()
2745 …dev_warn(component->dev, "Warning: Invalid jack-detect-source value: %d, leaving jack-detect disab… in rt5640_probe()
2749 if (!device_property_read_bool(component->dev, "realtek,jack-detect-not-inverted")) in rt5640_probe()
2750 rt5640->jd_inverted = true; in rt5640_probe()
2754 * threshold and scale-factor are 2000µA and 0.75. For an effective in rt5640_probe()
2757 rt5640->ovcd_th = RT5640_MIC1_OVTH_2000UA; in rt5640_probe()
2758 rt5640->ovcd_sf = RT5640_MIC_OVCD_SF_0P75; in rt5640_probe()
2760 if (device_property_read_u32(component->dev, in rt5640_probe()
2761 "realtek,over-current-threshold-microamp", &val) == 0) { in rt5640_probe()
2764 rt5640->ovcd_th = RT5640_MIC1_OVTH_600UA; in rt5640_probe()
2767 rt5640->ovcd_th = RT5640_MIC1_OVTH_1500UA; in rt5640_probe()
2770 rt5640->ovcd_th = RT5640_MIC1_OVTH_2000UA; in rt5640_probe()
2773 …dev_warn(component->dev, "Warning: Invalid over-current-threshold-microamp value: %d, defaulting t… in rt5640_probe()
2778 if (device_property_read_u32(component->dev, in rt5640_probe()
2779 "realtek,over-current-scale-factor", &val) == 0) { in rt5640_probe()
2781 rt5640->ovcd_sf = val << RT5640_MIC_OVCD_SF_SFT; in rt5640_probe()
2783 …dev_warn(component->dev, "Warning: Invalid over-current-scale-factor value: %d, defaulting to 0.75… in rt5640_probe()
2800 if (rt5640->jack) { in rt5640_suspend()
2802 disable_irq(rt5640->irq); in rt5640_suspend()
2803 cancel_delayed_work_sync(&rt5640->jack_work); in rt5640_suspend()
2804 cancel_delayed_work_sync(&rt5640->bp_work); in rt5640_suspend()
2809 regcache_cache_only(rt5640->regmap, true); in rt5640_suspend()
2810 regcache_mark_dirty(rt5640->regmap); in rt5640_suspend()
2811 if (rt5640->ldo1_en) in rt5640_suspend()
2812 gpiod_set_value_cansleep(rt5640->ldo1_en, 0); in rt5640_suspend()
2821 if (rt5640->ldo1_en) { in rt5640_resume()
2822 gpiod_set_value_cansleep(rt5640->ldo1_en, 1); in rt5640_resume()
2826 regcache_cache_only(rt5640->regmap, false); in rt5640_resume()
2827 regcache_sync(rt5640->regmap); in rt5640_resume()
2829 if (rt5640->jack) { in rt5640_resume()
2830 if (rt5640->jd_src == RT5640_JD_SRC_HDA_HEADER) { in rt5640_resume()
2834 if (rt5640->jd_inverted) { in rt5640_resume()
2835 if (rt5640->jd_src == RT5640_JD_SRC_JD2_IN4N) in rt5640_resume()
2844 if (rt5640->jd_src == RT5640_JD_SRC_JD2_IN4N) in rt5640_resume()
2856 enable_irq(rt5640->irq); in rt5640_resume()
2857 queue_delayed_work(system_long_wq, &rt5640->jack_work, 0); in rt5640_resume()
2880 .name = "rt5640-aif1",
2899 .name = "rt5640-aif2",
2989 rt5640 = devm_kzalloc(&i2c->dev, in rt5640_i2c_probe()
2993 return -ENOMEM; in rt5640_i2c_probe()
2996 rt5640->ldo1_en = devm_gpiod_get_optional(&i2c->dev, in rt5640_i2c_probe()
2997 "realtek,ldo1-en", in rt5640_i2c_probe()
2999 if (IS_ERR(rt5640->ldo1_en)) in rt5640_i2c_probe()
3000 return PTR_ERR(rt5640->ldo1_en); in rt5640_i2c_probe()
3002 if (rt5640->ldo1_en) { in rt5640_i2c_probe()
3003 gpiod_set_consumer_name(rt5640->ldo1_en, "RT5640 LDO1_EN"); in rt5640_i2c_probe()
3007 rt5640->regmap = devm_regmap_init_i2c(i2c, &rt5640_regmap); in rt5640_i2c_probe()
3008 if (IS_ERR(rt5640->regmap)) { in rt5640_i2c_probe()
3009 ret = PTR_ERR(rt5640->regmap); in rt5640_i2c_probe()
3010 dev_err(&i2c->dev, "Failed to allocate register map: %d\n", in rt5640_i2c_probe()
3015 regmap_read(rt5640->regmap, RT5640_VENDOR_ID2, &val); in rt5640_i2c_probe()
3017 dev_err(&i2c->dev, in rt5640_i2c_probe()
3019 return -ENODEV; in rt5640_i2c_probe()
3022 regmap_write(rt5640->regmap, RT5640_RESET, 0); in rt5640_i2c_probe()
3024 ret = regmap_register_patch(rt5640->regmap, init_list, in rt5640_i2c_probe()
3027 dev_warn(&i2c->dev, "Failed to apply regmap patch: %d\n", ret); in rt5640_i2c_probe()
3029 regmap_update_bits(rt5640->regmap, RT5640_DUMMY1, in rt5640_i2c_probe()
3032 rt5640->hp_mute = true; in rt5640_i2c_probe()
3033 rt5640->irq = i2c->irq; in rt5640_i2c_probe()
3034 INIT_DELAYED_WORK(&rt5640->bp_work, rt5640_button_press_work); in rt5640_i2c_probe()
3035 INIT_DELAYED_WORK(&rt5640->jack_work, rt5640_jack_work); in rt5640_i2c_probe()
3037 /* Make sure work is stopped on probe-error / remove */ in rt5640_i2c_probe()
3038 ret = devm_add_action_or_reset(&i2c->dev, rt5640_disable_irq_and_cancel_work, rt5640); in rt5640_i2c_probe()
3042 return devm_snd_soc_register_component(&i2c->dev, in rt5640_i2c_probe()