Lines Matching refs:rt5663
1401 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_enable_push_button_irq() local
1413 switch (rt5663->codec_ver) { in rt5663_enable_push_button_irq()
1428 switch (rt5663->codec_ver) { in rt5663_enable_push_button_irq()
1467 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_v2_jack_detect() local
1497 rt5663->jack_type = SND_JACK_HEADSET; in rt5663_v2_jack_detect()
1506 rt5663->jack_type = SND_JACK_HEADPHONE; in rt5663_v2_jack_detect()
1512 if (rt5663->jack_type == SND_JACK_HEADSET) { in rt5663_v2_jack_detect()
1520 rt5663->jack_type = 0; in rt5663_v2_jack_detect()
1523 dev_dbg(component->dev, "jack_type = %d\n", rt5663->jack_type); in rt5663_v2_jack_detect()
1524 return rt5663->jack_type; in rt5663_v2_jack_detect()
1538 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_jack_detect() local
1588 regmap_read(rt5663->regmap, RT5663_INT_ST_2, &val); in rt5663_jack_detect()
1609 rt5663->jack_type = SND_JACK_HEADSET; in rt5663_jack_detect()
1612 if (rt5663->pdata.impedance_sensing_num) in rt5663_jack_detect()
1615 if (rt5663->pdata.dc_offset_l_manual_mic) { in rt5663_jack_detect()
1616 regmap_write(rt5663->regmap, RT5663_MIC_DECRO_2, in rt5663_jack_detect()
1617 rt5663->pdata.dc_offset_l_manual_mic >> in rt5663_jack_detect()
1619 regmap_write(rt5663->regmap, RT5663_MIC_DECRO_3, in rt5663_jack_detect()
1620 rt5663->pdata.dc_offset_l_manual_mic & in rt5663_jack_detect()
1624 if (rt5663->pdata.dc_offset_r_manual_mic) { in rt5663_jack_detect()
1625 regmap_write(rt5663->regmap, RT5663_MIC_DECRO_5, in rt5663_jack_detect()
1626 rt5663->pdata.dc_offset_r_manual_mic >> in rt5663_jack_detect()
1628 regmap_write(rt5663->regmap, RT5663_MIC_DECRO_6, in rt5663_jack_detect()
1629 rt5663->pdata.dc_offset_r_manual_mic & in rt5663_jack_detect()
1634 rt5663->jack_type = SND_JACK_HEADPHONE; in rt5663_jack_detect()
1639 if (rt5663->pdata.impedance_sensing_num) in rt5663_jack_detect()
1642 if (rt5663->pdata.dc_offset_l_manual) { in rt5663_jack_detect()
1643 regmap_write(rt5663->regmap, RT5663_MIC_DECRO_2, in rt5663_jack_detect()
1644 rt5663->pdata.dc_offset_l_manual >> 16); in rt5663_jack_detect()
1645 regmap_write(rt5663->regmap, RT5663_MIC_DECRO_3, in rt5663_jack_detect()
1646 rt5663->pdata.dc_offset_l_manual & in rt5663_jack_detect()
1650 if (rt5663->pdata.dc_offset_r_manual) { in rt5663_jack_detect()
1651 regmap_write(rt5663->regmap, RT5663_MIC_DECRO_5, in rt5663_jack_detect()
1652 rt5663->pdata.dc_offset_r_manual >> 16); in rt5663_jack_detect()
1653 regmap_write(rt5663->regmap, RT5663_MIC_DECRO_6, in rt5663_jack_detect()
1654 rt5663->pdata.dc_offset_r_manual & in rt5663_jack_detect()
1660 if (rt5663->jack_type == SND_JACK_HEADSET) in rt5663_jack_detect()
1662 rt5663->jack_type = 0; in rt5663_jack_detect()
1668 dev_dbg(component->dev, "jack_type = %d\n", rt5663->jack_type); in rt5663_jack_detect()
1669 return rt5663->jack_type; in rt5663_jack_detect()
1674 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_impedance_sensing() local
1677 for (i = 0; i < rt5663->pdata.impedance_sensing_num; i++) { in rt5663_impedance_sensing()
1678 if (rt5663->imp_table[i].vol == 7) in rt5663_impedance_sensing()
1682 if (rt5663->jack_type == SND_JACK_HEADSET) { in rt5663_impedance_sensing()
1684 rt5663->imp_table[i].dc_offset_l_manual_mic >> 16); in rt5663_impedance_sensing()
1686 rt5663->imp_table[i].dc_offset_l_manual_mic & 0xffff); in rt5663_impedance_sensing()
1688 rt5663->imp_table[i].dc_offset_r_manual_mic >> 16); in rt5663_impedance_sensing()
1690 rt5663->imp_table[i].dc_offset_r_manual_mic & 0xffff); in rt5663_impedance_sensing()
1693 rt5663->imp_table[i].dc_offset_l_manual >> 16); in rt5663_impedance_sensing()
1695 rt5663->imp_table[i].dc_offset_l_manual & 0xffff); in rt5663_impedance_sensing()
1697 rt5663->imp_table[i].dc_offset_r_manual >> 16); in rt5663_impedance_sensing()
1699 rt5663->imp_table[i].dc_offset_r_manual & 0xffff); in rt5663_impedance_sensing()
1809 for (i = 0; i < rt5663->pdata.impedance_sensing_num; i++) { in rt5663_impedance_sensing()
1810 if (value >= rt5663->imp_table[i].imp_min && in rt5663_impedance_sensing()
1811 value <= rt5663->imp_table[i].imp_max) in rt5663_impedance_sensing()
1816 rt5663->imp_table[i].vol); in rt5663_impedance_sensing()
1818 rt5663->imp_table[i].vol); in rt5663_impedance_sensing()
1820 if (rt5663->jack_type == SND_JACK_HEADSET) { in rt5663_impedance_sensing()
1822 rt5663->imp_table[i].dc_offset_l_manual_mic >> 16); in rt5663_impedance_sensing()
1824 rt5663->imp_table[i].dc_offset_l_manual_mic & 0xffff); in rt5663_impedance_sensing()
1826 rt5663->imp_table[i].dc_offset_r_manual_mic >> 16); in rt5663_impedance_sensing()
1828 rt5663->imp_table[i].dc_offset_r_manual_mic & 0xffff); in rt5663_impedance_sensing()
1831 rt5663->imp_table[i].dc_offset_l_manual >> 16); in rt5663_impedance_sensing()
1833 rt5663->imp_table[i].dc_offset_l_manual & 0xffff); in rt5663_impedance_sensing()
1835 rt5663->imp_table[i].dc_offset_r_manual >> 16); in rt5663_impedance_sensing()
1837 rt5663->imp_table[i].dc_offset_r_manual & 0xffff); in rt5663_impedance_sensing()
1857 struct rt5663_priv *rt5663 = data; in rt5663_irq() local
1859 dev_dbg(regmap_get_device(rt5663->regmap), "%s IRQ queue work\n", in rt5663_irq()
1862 queue_delayed_work(system_wq, &rt5663->jack_detect_work, in rt5663_irq()
1871 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_set_jack_detect() local
1873 rt5663->hs_jack = hs_jack; in rt5663_set_jack_detect()
1875 rt5663_irq(0, rt5663); in rt5663_set_jack_detect()
1882 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_check_jd_status() local
1888 switch (rt5663->codec_ver) { in rt5663_check_jd_status()
1902 struct rt5663_priv *rt5663 = in rt5663_jack_detect_work() local
1904 struct snd_soc_component *component = rt5663->component; in rt5663_jack_detect_work()
1912 if (rt5663->jack_type == 0) { in rt5663_jack_detect_work()
1914 switch (rt5663->codec_ver) { in rt5663_jack_detect_work()
1917 rt5663->component, 1); in rt5663_jack_detect_work()
1920 report = rt5663_jack_detect(rt5663->component, 1); in rt5663_jack_detect_work()
1921 if (rt5663->pdata.impedance_sensing_num) in rt5663_jack_detect_work()
1922 rt5663_impedance_sensing(rt5663->component); in rt5663_jack_detect_work()
1933 btn_type = rt5663_button_detect(rt5663->component); in rt5663_jack_detect_work()
1966 dev_err(rt5663->component->dev, in rt5663_jack_detect_work()
1973 report = rt5663->jack_type; in rt5663_jack_detect_work()
1975 &rt5663->jd_unplug_work); in rt5663_jack_detect_work()
1978 &rt5663->jd_unplug_work, in rt5663_jack_detect_work()
1984 switch (rt5663->codec_ver) { in rt5663_jack_detect_work()
1986 report = rt5663_v2_jack_detect(rt5663->component, 0); in rt5663_jack_detect_work()
1989 report = rt5663_jack_detect(rt5663->component, 0); in rt5663_jack_detect_work()
1996 snd_soc_jack_report(rt5663->hs_jack, report, SND_JACK_HEADSET | in rt5663_jack_detect_work()
2003 struct rt5663_priv *rt5663 = in rt5663_jd_unplug_work() local
2005 struct snd_soc_component *component = rt5663->component; in rt5663_jd_unplug_work()
2012 switch (rt5663->codec_ver) { in rt5663_jd_unplug_work()
2014 rt5663_v2_jack_detect(rt5663->component, 0); in rt5663_jd_unplug_work()
2017 rt5663_jack_detect(rt5663->component, 0); in rt5663_jd_unplug_work()
2023 snd_soc_jack_report(rt5663->hs_jack, 0, SND_JACK_HEADSET | in rt5663_jd_unplug_work()
2027 queue_delayed_work(system_wq, &rt5663->jd_unplug_work, in rt5663_jd_unplug_work()
2089 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_is_using_asrc() local
2091 if (rt5663->codec_ver == CODEC_VER_1) { in rt5663_is_using_asrc()
2131 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_i2s_use_asrc() local
2136 switch (rt5663->codec_ver) { in rt5663_i2s_use_asrc()
2151 if (rt5663->sysclk > rt5663->lrck * 384) in rt5663_i2s_use_asrc()
2176 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_sel_asrc_clk_src() local
2197 switch (rt5663->codec_ver) { in rt5663_sel_asrc_clk_src()
2323 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_hp_event() local
2327 if (rt5663->codec_ver == CODEC_VER_1) { in rt5663_hp_event()
2355 if (rt5663->codec_ver == CODEC_VER_1) { in rt5663_hp_event()
2381 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_charge_pump_event() local
2385 if (rt5663->codec_ver == CODEC_VER_0) { in rt5663_charge_pump_event()
2394 if (rt5663->codec_ver == CODEC_VER_0) { in rt5663_charge_pump_event()
2767 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_hw_params() local
2771 rt5663->lrck = params_rate(params); in rt5663_hw_params()
2774 rt5663->lrck, rt5663->sysclk); in rt5663_hw_params()
2776 pre_div = rl6231_get_clk_info(rt5663->sysclk, rt5663->lrck); in rt5663_hw_params()
2779 rt5663->lrck, dai->id); in rt5663_hw_params()
2862 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_set_dai_sysclk() local
2865 if (freq == rt5663->sysclk && clk_id == rt5663->sysclk_src) in rt5663_set_dai_sysclk()
2884 rt5663->sysclk = freq; in rt5663_set_dai_sysclk()
2885 rt5663->sysclk_src = clk_id; in rt5663_set_dai_sysclk()
2897 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_set_dai_pll() local
2902 if (source == rt5663->pll_src && freq_in == rt5663->pll_in && in rt5663_set_dai_pll()
2903 freq_out == rt5663->pll_out) in rt5663_set_dai_pll()
2909 rt5663->pll_in = 0; in rt5663_set_dai_pll()
2910 rt5663->pll_out = 0; in rt5663_set_dai_pll()
2916 switch (rt5663->codec_ver) { in rt5663_set_dai_pll()
2959 rt5663->pll_in = freq_in; in rt5663_set_dai_pll()
2960 rt5663->pll_out = freq_out; in rt5663_set_dai_pll()
2961 rt5663->pll_src = source; in rt5663_set_dai_pll()
2970 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_set_tdm_slot() local
3014 switch (rt5663->codec_ver) { in rt5663_set_tdm_slot()
3036 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_set_bclk_ratio() local
3041 if (rt5663->codec_ver == CODEC_VER_1) in rt5663_set_bclk_ratio()
3078 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_set_bias_level() local
3088 if (rt5663->codec_ver == CODEC_VER_1) { in rt5663_set_bias_level()
3101 if (rt5663->codec_ver == CODEC_VER_1) in rt5663_set_bias_level()
3111 if (rt5663->codec_ver == CODEC_VER_1) { in rt5663_set_bias_level()
3121 if (rt5663->jack_type != SND_JACK_HEADSET) in rt5663_set_bias_level()
3144 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_probe() local
3146 rt5663->component = component; in rt5663_probe()
3148 switch (rt5663->codec_ver) { in rt5663_probe()
3169 if (!rt5663->imp_table) in rt5663_probe()
3180 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_remove() local
3182 regmap_write(rt5663->regmap, RT5663_RESET, 0); in rt5663_remove()
3188 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_suspend() local
3190 if (rt5663->irq) in rt5663_suspend()
3191 disable_irq(rt5663->irq); in rt5663_suspend()
3193 cancel_delayed_work_sync(&rt5663->jack_detect_work); in rt5663_suspend()
3194 cancel_delayed_work_sync(&rt5663->jd_unplug_work); in rt5663_suspend()
3196 regcache_cache_only(rt5663->regmap, true); in rt5663_suspend()
3197 regcache_mark_dirty(rt5663->regmap); in rt5663_suspend()
3204 struct rt5663_priv *rt5663 = snd_soc_component_get_drvdata(component); in rt5663_resume() local
3206 regcache_cache_only(rt5663->regmap, false); in rt5663_resume()
3207 regcache_sync(rt5663->regmap); in rt5663_resume()
3209 rt5663_irq(0, rt5663); in rt5663_resume()
3211 if (rt5663->irq) in rt5663_resume()
3212 enable_irq(rt5663->irq); in rt5663_resume()
3331 static void rt5663_v2_calibrate(struct rt5663_priv *rt5663) in rt5663_v2_calibrate() argument
3333 regmap_write(rt5663->regmap, RT5663_BIAS_CUR_8, 0xa402); in rt5663_v2_calibrate()
3334 regmap_write(rt5663->regmap, RT5663_PWR_DIG_1, 0x0100); in rt5663_v2_calibrate()
3335 regmap_write(rt5663->regmap, RT5663_RECMIX, 0x4040); in rt5663_v2_calibrate()
3336 regmap_write(rt5663->regmap, RT5663_DIG_MISC, 0x0001); in rt5663_v2_calibrate()
3337 regmap_write(rt5663->regmap, RT5663_RC_CLK, 0x0380); in rt5663_v2_calibrate()
3338 regmap_write(rt5663->regmap, RT5663_GLB_CLK, 0x8000); in rt5663_v2_calibrate()
3339 regmap_write(rt5663->regmap, RT5663_ADDA_CLK_1, 0x1000); in rt5663_v2_calibrate()
3340 regmap_write(rt5663->regmap, RT5663_CHOP_DAC_L, 0x3030); in rt5663_v2_calibrate()
3341 regmap_write(rt5663->regmap, RT5663_CALIB_ADC, 0x3c05); in rt5663_v2_calibrate()
3342 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0xa23e); in rt5663_v2_calibrate()
3344 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0xf23e); in rt5663_v2_calibrate()
3345 regmap_write(rt5663->regmap, RT5663_HP_CALIB_2, 0x0321); in rt5663_v2_calibrate()
3346 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1, 0xfc00); in rt5663_v2_calibrate()
3350 static void rt5663_calibrate(struct rt5663_priv *rt5663) in rt5663_calibrate() argument
3354 regmap_write(rt5663->regmap, RT5663_RESET, 0x0000); in rt5663_calibrate()
3356 regmap_write(rt5663->regmap, RT5663_ANA_BIAS_CUR_4, 0x00a1); in rt5663_calibrate()
3357 regmap_write(rt5663->regmap, RT5663_RC_CLK, 0x0380); in rt5663_calibrate()
3358 regmap_write(rt5663->regmap, RT5663_GLB_CLK, 0x8000); in rt5663_calibrate()
3359 regmap_write(rt5663->regmap, RT5663_ADDA_CLK_1, 0x1000); in rt5663_calibrate()
3360 regmap_write(rt5663->regmap, RT5663_VREF_RECMIX, 0x0032); in rt5663_calibrate()
3361 regmap_write(rt5663->regmap, RT5663_HP_IMP_SEN_19, 0x000c); in rt5663_calibrate()
3362 regmap_write(rt5663->regmap, RT5663_DUMMY_1, 0x0324); in rt5663_calibrate()
3363 regmap_write(rt5663->regmap, RT5663_DIG_MISC, 0x8001); in rt5663_calibrate()
3364 regmap_write(rt5663->regmap, RT5663_VREFADJ_OP, 0x0f28); in rt5663_calibrate()
3365 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0xa23b); in rt5663_calibrate()
3367 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0xf23b); in rt5663_calibrate()
3368 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_2, 0x8000); in rt5663_calibrate()
3369 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_3, 0x0008); in rt5663_calibrate()
3370 regmap_write(rt5663->regmap, RT5663_PRE_DIV_GATING_1, 0xffff); in rt5663_calibrate()
3371 regmap_write(rt5663->regmap, RT5663_PRE_DIV_GATING_2, 0xffff); in rt5663_calibrate()
3372 regmap_write(rt5663->regmap, RT5663_CBJ_1, 0x8c10); in rt5663_calibrate()
3373 regmap_write(rt5663->regmap, RT5663_IL_CMD_2, 0x00c1); in rt5663_calibrate()
3374 regmap_write(rt5663->regmap, RT5663_EM_JACK_TYPE_1, 0xb880); in rt5663_calibrate()
3375 regmap_write(rt5663->regmap, RT5663_EM_JACK_TYPE_2, 0x4110); in rt5663_calibrate()
3376 regmap_write(rt5663->regmap, RT5663_EM_JACK_TYPE_2, 0x4118); in rt5663_calibrate()
3380 regmap_read(rt5663->regmap, RT5663_INT_ST_2, &value); in rt5663_calibrate()
3390 regmap_write(rt5663->regmap, RT5663_HP_IMP_SEN_19, 0x0000); in rt5663_calibrate()
3391 regmap_write(rt5663->regmap, RT5663_DEPOP_2, 0x3003); in rt5663_calibrate()
3392 regmap_write(rt5663->regmap, RT5663_DEPOP_1, 0x0038); in rt5663_calibrate()
3393 regmap_write(rt5663->regmap, RT5663_DEPOP_1, 0x003b); in rt5663_calibrate()
3394 regmap_write(rt5663->regmap, RT5663_PWR_DIG_2, 0x8400); in rt5663_calibrate()
3395 regmap_write(rt5663->regmap, RT5663_PWR_DIG_1, 0x8df8); in rt5663_calibrate()
3396 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_2, 0x8003); in rt5663_calibrate()
3397 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_3, 0x018c); in rt5663_calibrate()
3398 regmap_write(rt5663->regmap, RT5663_HP_CHARGE_PUMP_1, 0x1e32); in rt5663_calibrate()
3399 regmap_write(rt5663->regmap, RT5663_DUMMY_2, 0x8089); in rt5663_calibrate()
3400 regmap_write(rt5663->regmap, RT5663_DACREF_LDO, 0x3b0b); in rt5663_calibrate()
3402 regmap_write(rt5663->regmap, RT5663_STO_DAC_MIXER, 0x0000); in rt5663_calibrate()
3403 regmap_write(rt5663->regmap, RT5663_BYPASS_STO_DAC, 0x000c); in rt5663_calibrate()
3404 regmap_write(rt5663->regmap, RT5663_HP_BIAS, 0xafaa); in rt5663_calibrate()
3405 regmap_write(rt5663->regmap, RT5663_CHARGE_PUMP_1, 0x2224); in rt5663_calibrate()
3406 regmap_write(rt5663->regmap, RT5663_HP_OUT_EN, 0x8088); in rt5663_calibrate()
3407 regmap_write(rt5663->regmap, RT5663_STO_DRE_9, 0x0017); in rt5663_calibrate()
3408 regmap_write(rt5663->regmap, RT5663_STO_DRE_10, 0x0017); in rt5663_calibrate()
3409 regmap_write(rt5663->regmap, RT5663_STO1_ADC_MIXER, 0x4040); in rt5663_calibrate()
3410 regmap_write(rt5663->regmap, RT5663_CHOP_ADC, 0x3000); in rt5663_calibrate()
3411 regmap_write(rt5663->regmap, RT5663_RECMIX, 0x0005); in rt5663_calibrate()
3412 regmap_write(rt5663->regmap, RT5663_ADDA_RST, 0xc000); in rt5663_calibrate()
3413 regmap_write(rt5663->regmap, RT5663_STO1_HPF_ADJ1, 0x3320); in rt5663_calibrate()
3414 regmap_write(rt5663->regmap, RT5663_HP_CALIB_2, 0x00c9); in rt5663_calibrate()
3415 regmap_write(rt5663->regmap, RT5663_DUMMY_1, 0x004c); in rt5663_calibrate()
3416 regmap_write(rt5663->regmap, RT5663_ANA_BIAS_CUR_1, 0x1111); in rt5663_calibrate()
3417 regmap_write(rt5663->regmap, RT5663_BIAS_CUR_8, 0x4402); in rt5663_calibrate()
3418 regmap_write(rt5663->regmap, RT5663_CHARGE_PUMP_2, 0x3311); in rt5663_calibrate()
3419 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1, 0x0069); in rt5663_calibrate()
3420 regmap_write(rt5663->regmap, RT5663_HP_CALIB_3, 0x06ce); in rt5663_calibrate()
3421 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1_1, 0x6800); in rt5663_calibrate()
3422 regmap_write(rt5663->regmap, RT5663_CHARGE_PUMP_2, 0x1100); in rt5663_calibrate()
3423 regmap_write(rt5663->regmap, RT5663_HP_CALIB_7, 0x0057); in rt5663_calibrate()
3424 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1_1, 0xe800); in rt5663_calibrate()
3428 regmap_read(rt5663->regmap, RT5663_HP_CALIB_1_1, &value); in rt5663_calibrate()
3439 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1_1, 0x6200); in rt5663_calibrate()
3440 regmap_write(rt5663->regmap, RT5663_HP_CALIB_7, 0x0059); in rt5663_calibrate()
3441 regmap_write(rt5663->regmap, RT5663_HP_CALIB_1_1, 0xe200); in rt5663_calibrate()
3445 regmap_read(rt5663->regmap, RT5663_HP_CALIB_1_1, &value); in rt5663_calibrate()
3456 regmap_write(rt5663->regmap, RT5663_EM_JACK_TYPE_1, 0xb8e0); in rt5663_calibrate()
3458 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_1, 0x003b); in rt5663_calibrate()
3460 regmap_write(rt5663->regmap, RT5663_PWR_DIG_1, 0x0000); in rt5663_calibrate()
3462 regmap_write(rt5663->regmap, RT5663_DEPOP_1, 0x000b); in rt5663_calibrate()
3464 regmap_write(rt5663->regmap, RT5663_DEPOP_1, 0x0008); in rt5663_calibrate()
3466 regmap_write(rt5663->regmap, RT5663_PWR_ANLG_2, 0x0000); in rt5663_calibrate()
3470 static int rt5663_parse_dp(struct rt5663_priv *rt5663, struct device *dev) in rt5663_parse_dp() argument
3476 &rt5663->pdata.dc_offset_l_manual); in rt5663_parse_dp()
3478 &rt5663->pdata.dc_offset_r_manual); in rt5663_parse_dp()
3480 &rt5663->pdata.dc_offset_l_manual_mic); in rt5663_parse_dp()
3482 &rt5663->pdata.dc_offset_r_manual_mic); in rt5663_parse_dp()
3484 &rt5663->pdata.impedance_sensing_num); in rt5663_parse_dp()
3486 if (rt5663->pdata.impedance_sensing_num) { in rt5663_parse_dp()
3488 rt5663->pdata.impedance_sensing_num; in rt5663_parse_dp()
3489 rt5663->imp_table = devm_kzalloc(dev, table_size, GFP_KERNEL); in rt5663_parse_dp()
3490 if (!rt5663->imp_table) in rt5663_parse_dp()
3494 (u32 *)rt5663->imp_table, table_size); in rt5663_parse_dp()
3505 struct rt5663_priv *rt5663; in rt5663_i2c_probe() local
3510 rt5663 = devm_kzalloc(&i2c->dev, sizeof(struct rt5663_priv), in rt5663_i2c_probe()
3513 if (rt5663 == NULL) in rt5663_i2c_probe()
3516 i2c_set_clientdata(i2c, rt5663); in rt5663_i2c_probe()
3519 rt5663->pdata = *pdata; in rt5663_i2c_probe()
3521 ret = rt5663_parse_dp(rt5663, &i2c->dev); in rt5663_i2c_probe()
3526 for (i = 0; i < ARRAY_SIZE(rt5663->supplies); i++) in rt5663_i2c_probe()
3527 rt5663->supplies[i].supply = rt5663_supply_names[i]; in rt5663_i2c_probe()
3530 ARRAY_SIZE(rt5663->supplies), in rt5663_i2c_probe()
3531 rt5663->supplies); in rt5663_i2c_probe()
3538 for (i = 0; i < ARRAY_SIZE(rt5663->supplies); i++) { in rt5663_i2c_probe()
3539 ret = regulator_set_load(rt5663->supplies[i].consumer, in rt5663_i2c_probe()
3544 rt5663->supplies[i].supply, ret); in rt5663_i2c_probe()
3549 ret = regulator_bulk_enable(ARRAY_SIZE(rt5663->supplies), in rt5663_i2c_probe()
3550 rt5663->supplies); in rt5663_i2c_probe()
3577 rt5663->regmap = devm_regmap_init_i2c(i2c, &rt5663_v2_regmap); in rt5663_i2c_probe()
3578 rt5663->codec_ver = CODEC_VER_1; in rt5663_i2c_probe()
3581 rt5663->regmap = devm_regmap_init_i2c(i2c, &rt5663_regmap); in rt5663_i2c_probe()
3582 rt5663->codec_ver = CODEC_VER_0; in rt5663_i2c_probe()
3592 if (IS_ERR(rt5663->regmap)) { in rt5663_i2c_probe()
3593 ret = PTR_ERR(rt5663->regmap); in rt5663_i2c_probe()
3600 regmap_write(rt5663->regmap, RT5663_RESET, 0); in rt5663_i2c_probe()
3601 regcache_cache_bypass(rt5663->regmap, true); in rt5663_i2c_probe()
3602 switch (rt5663->codec_ver) { in rt5663_i2c_probe()
3604 rt5663_v2_calibrate(rt5663); in rt5663_i2c_probe()
3607 rt5663_calibrate(rt5663); in rt5663_i2c_probe()
3612 regcache_cache_bypass(rt5663->regmap, false); in rt5663_i2c_probe()
3613 regmap_write(rt5663->regmap, RT5663_RESET, 0); in rt5663_i2c_probe()
3616 switch (rt5663->codec_ver) { in rt5663_i2c_probe()
3620 ret = regmap_register_patch(rt5663->regmap, rt5663_patch_list, in rt5663_i2c_probe()
3631 regmap_update_bits(rt5663->regmap, RT5663_GPIO_1, RT5663_GP1_PIN_MASK, in rt5663_i2c_probe()
3634 regmap_update_bits(rt5663->regmap, RT5663_IL_CMD_5, in rt5663_i2c_probe()
3637 switch (rt5663->codec_ver) { in rt5663_i2c_probe()
3639 regmap_write(rt5663->regmap, RT5663_BIAS_CUR_8, 0xa402); in rt5663_i2c_probe()
3641 regmap_update_bits(rt5663->regmap, RT5663_AUTO_1MRC_CLK, in rt5663_i2c_probe()
3644 regmap_update_bits(rt5663->regmap, RT5663_PWR_ANLG_2, in rt5663_i2c_probe()
3646 regmap_update_bits(rt5663->regmap, RT5663_IRQ_1, in rt5663_i2c_probe()
3649 regmap_update_bits(rt5663->regmap, RT5663_HP_LOGIC_2, in rt5663_i2c_probe()
3651 regmap_update_bits(rt5663->regmap, RT5663_RECMIX, in rt5663_i2c_probe()
3656 regmap_update_bits(rt5663->regmap, RT5663_GPIO_2, in rt5663_i2c_probe()
3658 regmap_update_bits(rt5663->regmap, RT5663_GPIO_3, in rt5663_i2c_probe()
3660 regmap_update_bits(rt5663->regmap, RT5663_PWR_ANLG_1, in rt5663_i2c_probe()
3665 regmap_update_bits(rt5663->regmap, RT5663_DIG_MISC, in rt5663_i2c_probe()
3667 regmap_update_bits(rt5663->regmap, RT5663_AUTO_1MRC_CLK, in rt5663_i2c_probe()
3669 regmap_update_bits(rt5663->regmap, RT5663_IRQ_1, in rt5663_i2c_probe()
3671 regmap_update_bits(rt5663->regmap, RT5663_GPIO_1, in rt5663_i2c_probe()
3673 regmap_write(rt5663->regmap, RT5663_VREF_RECMIX, 0x0032); in rt5663_i2c_probe()
3674 regmap_update_bits(rt5663->regmap, RT5663_GPIO_2, in rt5663_i2c_probe()
3677 regmap_update_bits(rt5663->regmap, RT5663_RECMIX, in rt5663_i2c_probe()
3679 regmap_update_bits(rt5663->regmap, RT5663_TDM_2, in rt5663_i2c_probe()
3687 INIT_DELAYED_WORK(&rt5663->jack_detect_work, rt5663_jack_detect_work); in rt5663_i2c_probe()
3688 INIT_DELAYED_WORK(&rt5663->jd_unplug_work, rt5663_jd_unplug_work); in rt5663_i2c_probe()
3693 | IRQF_ONESHOT, "rt5663", rt5663); in rt5663_i2c_probe()
3699 rt5663->irq = i2c->irq; in rt5663_i2c_probe()
3718 free_irq(i2c->irq, rt5663); in rt5663_i2c_probe()
3720 regulator_bulk_disable(ARRAY_SIZE(rt5663->supplies), rt5663->supplies); in rt5663_i2c_probe()
3726 struct rt5663_priv *rt5663 = i2c_get_clientdata(i2c); in rt5663_i2c_remove() local
3729 free_irq(i2c->irq, rt5663); in rt5663_i2c_remove()
3731 regulator_bulk_disable(ARRAY_SIZE(rt5663->supplies), rt5663->supplies); in rt5663_i2c_remove()
3736 struct rt5663_priv *rt5663 = i2c_get_clientdata(client); in rt5663_i2c_shutdown() local
3738 regmap_write(rt5663->regmap, RT5663_RESET, 0); in rt5663_i2c_shutdown()