Lines Matching refs:rt5645
674 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_hweq_get() local
680 eq_param[i].reg = cpu_to_be16(rt5645->eq_param[i].reg); in rt5645_hweq_get()
681 eq_param[i].val = cpu_to_be16(rt5645->eq_param[i].val); in rt5645_hweq_get()
700 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_hweq_put() local
728 memcpy(rt5645->eq_param, eq_param, in rt5645_hweq_put()
745 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_spk_put_volsw() local
748 regmap_update_bits(rt5645->regmap, RT5645_MICBIAS, in rt5645_spk_put_volsw()
753 mod_delayed_work(system_power_efficient_wq, &rt5645->rcclock_work, in rt5645_spk_put_volsw()
850 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in set_dmic_clk() local
853 rate = rt5645->sysclk / rl6231_get_pre_div(rt5645->regmap, in set_dmic_clk()
928 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_enable_hweq() local
932 if (rt5645_validate_hweq(rt5645->eq_param[i].reg)) in rt5645_enable_hweq()
933 regmap_write(rt5645->regmap, rt5645->eq_param[i].reg, in rt5645_enable_hweq()
934 rt5645->eq_param[i].val); in rt5645_enable_hweq()
1684 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in hp_amp_power() local
1688 if (rt5645->codec_type == CODEC_TYPE_RT5650) { in hp_amp_power()
1693 regmap_write(rt5645->regmap, RT5645_PR_BASE + in hp_amp_power()
1698 regmap_write(rt5645->regmap, RT5645_PR_BASE + in hp_amp_power()
1701 regmap_write(rt5645->regmap, RT5645_PR_BASE + in hp_amp_power()
1705 rt5645->hp_on = true; in hp_amp_power()
1711 regmap_write(rt5645->regmap, RT5645_PR_BASE + in hp_amp_power()
1733 regmap_write(rt5645->regmap, RT5645_PR_BASE + in hp_amp_power()
1735 regmap_write(rt5645->regmap, RT5645_PR_BASE + in hp_amp_power()
1743 if (rt5645->codec_type == CODEC_TYPE_RT5650) { in hp_amp_power()
1744 regmap_write(rt5645->regmap, RT5645_PR_BASE + in hp_amp_power()
1747 regmap_write(rt5645->regmap, RT5645_PR_BASE + in hp_amp_power()
1777 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_hp_event() local
1783 if (rt5645->codec_type == CODEC_TYPE_RT5645) { in rt5645_hp_event()
1790 regmap_write(rt5645->regmap, RT5645_PR_BASE + in rt5645_hp_event()
1810 if (rt5645->codec_type == CODEC_TYPE_RT5645) { in rt5645_hp_event()
1817 regmap_write(rt5645->regmap, RT5645_PR_BASE + in rt5645_hp_event()
1929 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5650_hp_event() local
1933 if (rt5645->hp_on) { in rt5650_hp_event()
1935 rt5645->hp_on = false; in rt5650_hp_event()
2772 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_hw_params() local
2776 rt5645->lrck[dai->id] = params_rate(params); in rt5645_hw_params()
2777 pre_div = rl6231_get_clk_info(rt5645->sysclk, rt5645->lrck[dai->id]); in rt5645_hw_params()
2788 switch (rt5645->codec_type) { in rt5645_hw_params()
2798 rt5645->bclk[dai->id] = rt5645->lrck[dai->id] * (32 << bclk_ms); in rt5645_hw_params()
2801 rt5645->bclk[dai->id], rt5645->lrck[dai->id]); in rt5645_hw_params()
2848 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_set_dai_fmt() local
2851 switch (rt5645->codec_type) { in rt5645_set_dai_fmt()
2862 rt5645->master[dai->id] = 1; in rt5645_set_dai_fmt()
2866 rt5645->master[dai->id] = 0; in rt5645_set_dai_fmt()
2919 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_set_dai_sysclk() local
2922 if (freq == rt5645->sysclk && clk_id == rt5645->sysclk_src) in rt5645_set_dai_sysclk()
2941 rt5645->sysclk = freq; in rt5645_set_dai_sysclk()
2942 rt5645->sysclk_src = clk_id; in rt5645_set_dai_sysclk()
2953 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_set_dai_pll() local
2957 if (source == rt5645->pll_src && freq_in == rt5645->pll_in && in rt5645_set_dai_pll()
2958 freq_out == rt5645->pll_out) in rt5645_set_dai_pll()
2964 rt5645->pll_in = 0; in rt5645_set_dai_pll()
2965 rt5645->pll_out = 0; in rt5645_set_dai_pll()
3013 rt5645->pll_in = freq_in; in rt5645_set_dai_pll()
3014 rt5645->pll_out = freq_out; in rt5645_set_dai_pll()
3015 rt5645->pll_src = source; in rt5645_set_dai_pll()
3024 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_set_tdm_slot() local
3028 switch (rt5645->codec_type) { in rt5645_set_tdm_slot()
3046 if (rt5645->codec_type == CODEC_TYPE_RT5645) in rt5645_set_tdm_slot()
3089 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_set_bias_level() local
3121 if (rt5645->en_button_func) in rt5645_set_bias_level()
3123 &rt5645->jack_detect_work, in rt5645_set_bias_level()
3130 if (!rt5645->en_button_func) in rt5645_set_bias_level()
3177 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_jack_detect() local
3181 regmap_write(rt5645->regmap, RT5645_CHARGE_PUMP, 0x0e06); in rt5645_jack_detect()
3190 regmap_update_bits(rt5645->regmap, RT5645_PWR_ANLG1, in rt5645_jack_detect()
3193 regmap_update_bits(rt5645->regmap, RT5645_PWR_MIXER, in rt5645_jack_detect()
3195 regmap_update_bits(rt5645->regmap, RT5645_PWR_VOL, in rt5645_jack_detect()
3199 regmap_write(rt5645->regmap, RT5645_JD_CTRL3, 0x00f0); in rt5645_jack_detect()
3200 regmap_update_bits(rt5645->regmap, RT5645_IN1_CTRL2, in rt5645_jack_detect()
3202 regmap_update_bits(rt5645->regmap, RT5645_IN1_CTRL1, in rt5645_jack_detect()
3205 regmap_update_bits(rt5645->regmap, RT5645_IN1_CTRL2, in rt5645_jack_detect()
3209 regmap_read(rt5645->regmap, RT5645_IN1_CTRL3, &val); in rt5645_jack_detect()
3214 rt5645->jack_type = SND_JACK_HEADSET; in rt5645_jack_detect()
3215 if (rt5645->en_button_func) { in rt5645_jack_detect()
3221 rt5645->jack_type = SND_JACK_HEADPHONE; in rt5645_jack_detect()
3223 if (rt5645->pdata.level_trigger_irq) in rt5645_jack_detect()
3224 regmap_update_bits(rt5645->regmap, RT5645_IRQ_CTRL2, in rt5645_jack_detect()
3227 rt5645->jack_type = 0; in rt5645_jack_detect()
3229 regmap_update_bits(rt5645->regmap, RT5645_HP_VOL, in rt5645_jack_detect()
3232 regmap_update_bits(rt5645->regmap, RT5645_IN1_CTRL2, in rt5645_jack_detect()
3234 regmap_update_bits(rt5645->regmap, RT5645_IN1_CTRL1, in rt5645_jack_detect()
3237 if (rt5645->en_button_func) in rt5645_jack_detect()
3240 if (rt5645->pdata.jd_mode == 0) in rt5645_jack_detect()
3244 if (rt5645->pdata.level_trigger_irq) in rt5645_jack_detect()
3245 regmap_update_bits(rt5645->regmap, RT5645_IRQ_CTRL2, in rt5645_jack_detect()
3249 return rt5645->jack_type; in rt5645_jack_detect()
3270 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_set_jack_detect() local
3272 rt5645->hp_jack = hp_jack; in rt5645_set_jack_detect()
3273 rt5645->mic_jack = mic_jack; in rt5645_set_jack_detect()
3274 rt5645->btn_jack = btn_jack; in rt5645_set_jack_detect()
3275 if (rt5645->btn_jack && rt5645->codec_type == CODEC_TYPE_RT5650) { in rt5645_set_jack_detect()
3276 rt5645->en_button_func = true; in rt5645_set_jack_detect()
3277 regmap_update_bits(rt5645->regmap, RT5645_GPIO_CTRL1, in rt5645_set_jack_detect()
3279 regmap_update_bits(rt5645->regmap, RT5645_GEN_CTRL1, in rt5645_set_jack_detect()
3282 rt5645_irq(0, rt5645); in rt5645_set_jack_detect()
3290 struct rt5645_priv *rt5645 = in rt5645_jack_detect_work() local
3294 if (!rt5645->component) in rt5645_jack_detect_work()
3297 switch (rt5645->pdata.jd_mode) { in rt5645_jack_detect_work()
3299 if (rt5645->gpiod_hp_det) { in rt5645_jack_detect_work()
3300 gpio_state = gpiod_get_value(rt5645->gpiod_hp_det); in rt5645_jack_detect_work()
3301 dev_dbg(rt5645->component->dev, "gpio_state = %d\n", in rt5645_jack_detect_work()
3303 report = rt5645_jack_detect(rt5645->component, gpio_state); in rt5645_jack_detect_work()
3305 snd_soc_jack_report(rt5645->hp_jack, in rt5645_jack_detect_work()
3307 snd_soc_jack_report(rt5645->mic_jack, in rt5645_jack_detect_work()
3311 val = snd_soc_component_read32(rt5645->component, RT5645_INT_IRQ_ST) & 0x1000; in rt5645_jack_detect_work()
3316 if (!val && (rt5645->jack_type == 0)) { /* jack in */ in rt5645_jack_detect_work()
3317 report = rt5645_jack_detect(rt5645->component, 1); in rt5645_jack_detect_work()
3318 } else if (!val && rt5645->jack_type != 0) { in rt5645_jack_detect_work()
3321 if (snd_soc_component_read32(rt5645->component, RT5645_INT_IRQ_ST) & 0x4) { in rt5645_jack_detect_work()
3324 btn_type = rt5645_button_detect(rt5645->component); in rt5645_jack_detect_work()
3354 dev_err(rt5645->component->dev, in rt5645_jack_detect_work()
3361 report = rt5645->jack_type; in rt5645_jack_detect_work()
3363 mod_timer(&rt5645->btn_check_timer, in rt5645_jack_detect_work()
3369 snd_soc_component_update_bits(rt5645->component, in rt5645_jack_detect_work()
3371 rt5645_jack_detect(rt5645->component, 0); in rt5645_jack_detect_work()
3374 snd_soc_jack_report(rt5645->hp_jack, report, SND_JACK_HEADPHONE); in rt5645_jack_detect_work()
3375 snd_soc_jack_report(rt5645->mic_jack, report, SND_JACK_MICROPHONE); in rt5645_jack_detect_work()
3376 if (rt5645->en_button_func) in rt5645_jack_detect_work()
3377 snd_soc_jack_report(rt5645->btn_jack, in rt5645_jack_detect_work()
3384 struct rt5645_priv *rt5645 = in rt5645_rcclock_work() local
3387 regmap_update_bits(rt5645->regmap, RT5645_MICBIAS, in rt5645_rcclock_work()
3393 struct rt5645_priv *rt5645 = data; in rt5645_irq() local
3396 &rt5645->jack_detect_work, msecs_to_jiffies(250)); in rt5645_irq()
3403 struct rt5645_priv *rt5645 = from_timer(rt5645, t, btn_check_timer); in rt5645_btn_check_callback() local
3406 &rt5645->jack_detect_work, msecs_to_jiffies(5)); in rt5645_btn_check_callback()
3412 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_probe() local
3414 rt5645->component = component; in rt5645_probe()
3416 switch (rt5645->codec_type) { in rt5645_probe()
3424 if (rt5645->v_id < 3) { in rt5645_probe()
3443 if (rt5645->pdata.jd_mode) { in rt5645_probe()
3449 if (rt5645->pdata.long_name) in rt5645_probe()
3450 component->card->long_name = rt5645->pdata.long_name; in rt5645_probe()
3452 rt5645->eq_param = devm_kcalloc(component->dev, in rt5645_probe()
3467 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_suspend() local
3469 regcache_cache_only(rt5645->regmap, true); in rt5645_suspend()
3470 regcache_mark_dirty(rt5645->regmap); in rt5645_suspend()
3477 struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); in rt5645_resume() local
3479 regcache_cache_only(rt5645->regmap, false); in rt5645_resume()
3480 regcache_sync(rt5645->regmap); in rt5645_resume()
3776 static int rt5645_parse_dt(struct rt5645_priv *rt5645, struct device *dev) in rt5645_parse_dt() argument
3778 rt5645->pdata.in2_diff = device_property_read_bool(dev, in rt5645_parse_dt()
3781 "realtek,dmic1-data-pin", &rt5645->pdata.dmic1_data_pin); in rt5645_parse_dt()
3783 "realtek,dmic2-data-pin", &rt5645->pdata.dmic2_data_pin); in rt5645_parse_dt()
3785 "realtek,jd-mode", &rt5645->pdata.jd_mode); in rt5645_parse_dt()
3795 struct rt5645_priv *rt5645; in rt5645_i2c_probe() local
3800 rt5645 = devm_kzalloc(&i2c->dev, sizeof(struct rt5645_priv), in rt5645_i2c_probe()
3802 if (rt5645 == NULL) in rt5645_i2c_probe()
3805 rt5645->i2c = i2c; in rt5645_i2c_probe()
3806 i2c_set_clientdata(i2c, rt5645); in rt5645_i2c_probe()
3815 rt5645->pdata = *pdata; in rt5645_i2c_probe()
3817 rt5645_parse_dt(rt5645, &i2c->dev); in rt5645_i2c_probe()
3819 rt5645->pdata = jd_mode3_platform_data; in rt5645_i2c_probe()
3822 rt5645->pdata.in2_diff = QUIRK_IN2_DIFF(quirk); in rt5645_i2c_probe()
3823 rt5645->pdata.level_trigger_irq = QUIRK_LEVEL_IRQ(quirk); in rt5645_i2c_probe()
3824 rt5645->pdata.inv_jd1_1 = QUIRK_INV_JD1_1(quirk); in rt5645_i2c_probe()
3825 rt5645->pdata.jd_mode = QUIRK_JD_MODE(quirk); in rt5645_i2c_probe()
3826 rt5645->pdata.dmic1_data_pin = QUIRK_DMIC1_DATA_PIN(quirk); in rt5645_i2c_probe()
3827 rt5645->pdata.dmic2_data_pin = QUIRK_DMIC2_DATA_PIN(quirk); in rt5645_i2c_probe()
3830 rt5645->gpiod_hp_det = devm_gpiod_get_optional(&i2c->dev, "hp-detect", in rt5645_i2c_probe()
3833 if (IS_ERR(rt5645->gpiod_hp_det)) { in rt5645_i2c_probe()
3835 ret = PTR_ERR(rt5645->gpiod_hp_det); in rt5645_i2c_probe()
3844 for (i = 0; i < ARRAY_SIZE(rt5645->supplies); i++) in rt5645_i2c_probe()
3845 rt5645->supplies[i].supply = rt5645_supply_names[i]; in rt5645_i2c_probe()
3848 ARRAY_SIZE(rt5645->supplies), in rt5645_i2c_probe()
3849 rt5645->supplies); in rt5645_i2c_probe()
3855 ret = regulator_bulk_enable(ARRAY_SIZE(rt5645->supplies), in rt5645_i2c_probe()
3856 rt5645->supplies); in rt5645_i2c_probe()
3879 rt5645->regmap = devm_regmap_init_i2c(i2c, &rt5645_regmap); in rt5645_i2c_probe()
3880 rt5645->codec_type = CODEC_TYPE_RT5645; in rt5645_i2c_probe()
3883 rt5645->regmap = devm_regmap_init_i2c(i2c, &rt5650_regmap); in rt5645_i2c_probe()
3884 rt5645->codec_type = CODEC_TYPE_RT5650; in rt5645_i2c_probe()
3894 if (IS_ERR(rt5645->regmap)) { in rt5645_i2c_probe()
3895 ret = PTR_ERR(rt5645->regmap); in rt5645_i2c_probe()
3901 regmap_write(rt5645->regmap, RT5645_RESET, 0); in rt5645_i2c_probe()
3904 rt5645->v_id = val & 0xff; in rt5645_i2c_probe()
3906 regmap_write(rt5645->regmap, RT5645_AD_DA_MIXER, 0x8080); in rt5645_i2c_probe()
3908 ret = regmap_register_patch(rt5645->regmap, init_list, in rt5645_i2c_probe()
3913 if (rt5645->codec_type == CODEC_TYPE_RT5650) { in rt5645_i2c_probe()
3914 ret = regmap_register_patch(rt5645->regmap, rt5650_init_list, in rt5645_i2c_probe()
3921 regmap_update_bits(rt5645->regmap, RT5645_CLSD_OUT_CTRL, 0xc0, 0xc0); in rt5645_i2c_probe()
3923 if (rt5645->pdata.in2_diff) in rt5645_i2c_probe()
3924 regmap_update_bits(rt5645->regmap, RT5645_IN2_CTRL, in rt5645_i2c_probe()
3927 if (rt5645->pdata.dmic1_data_pin || rt5645->pdata.dmic2_data_pin) { in rt5645_i2c_probe()
3928 regmap_update_bits(rt5645->regmap, RT5645_GPIO_CTRL1, in rt5645_i2c_probe()
3931 switch (rt5645->pdata.dmic1_data_pin) { in rt5645_i2c_probe()
3933 regmap_update_bits(rt5645->regmap, RT5645_DMIC_CTRL1, in rt5645_i2c_probe()
3938 regmap_update_bits(rt5645->regmap, RT5645_GPIO_CTRL1, in rt5645_i2c_probe()
3940 regmap_update_bits(rt5645->regmap, RT5645_DMIC_CTRL1, in rt5645_i2c_probe()
3942 regmap_update_bits(rt5645->regmap, RT5645_GPIO_CTRL1, in rt5645_i2c_probe()
3947 regmap_update_bits(rt5645->regmap, RT5645_DMIC_CTRL1, in rt5645_i2c_probe()
3949 regmap_update_bits(rt5645->regmap, RT5645_GPIO_CTRL1, in rt5645_i2c_probe()
3958 switch (rt5645->pdata.dmic2_data_pin) { in rt5645_i2c_probe()
3960 regmap_update_bits(rt5645->regmap, RT5645_DMIC_CTRL1, in rt5645_i2c_probe()
3965 regmap_update_bits(rt5645->regmap, RT5645_DMIC_CTRL1, in rt5645_i2c_probe()
3967 regmap_update_bits(rt5645->regmap, RT5645_GPIO_CTRL1, in rt5645_i2c_probe()
3972 regmap_update_bits(rt5645->regmap, RT5645_DMIC_CTRL1, in rt5645_i2c_probe()
3974 regmap_update_bits(rt5645->regmap, RT5645_GPIO_CTRL1, in rt5645_i2c_probe()
3980 regmap_update_bits(rt5645->regmap, RT5645_DMIC_CTRL1, in rt5645_i2c_probe()
3982 regmap_update_bits(rt5645->regmap, RT5645_GPIO_CTRL1, in rt5645_i2c_probe()
3991 if (rt5645->pdata.jd_mode) { in rt5645_i2c_probe()
3992 regmap_update_bits(rt5645->regmap, RT5645_GEN_CTRL3, in rt5645_i2c_probe()
3995 regmap_update_bits(rt5645->regmap, RT5645_MICBIAS, in rt5645_i2c_probe()
3997 regmap_update_bits(rt5645->regmap, RT5645_IRQ_CTRL2, in rt5645_i2c_probe()
3999 regmap_update_bits(rt5645->regmap, RT5645_GEN_CTRL3, in rt5645_i2c_probe()
4001 regmap_update_bits(rt5645->regmap, RT5645_HPO_MIXER, in rt5645_i2c_probe()
4003 regmap_update_bits(rt5645->regmap, RT5645_MICBIAS, in rt5645_i2c_probe()
4005 regmap_update_bits(rt5645->regmap, RT5645_GPIO_CTRL1, in rt5645_i2c_probe()
4007 switch (rt5645->pdata.jd_mode) { in rt5645_i2c_probe()
4009 regmap_update_bits(rt5645->regmap, RT5645_A_JD_CTRL1, in rt5645_i2c_probe()
4014 regmap_update_bits(rt5645->regmap, RT5645_A_JD_CTRL1, in rt5645_i2c_probe()
4019 regmap_update_bits(rt5645->regmap, RT5645_A_JD_CTRL1, in rt5645_i2c_probe()
4026 if (rt5645->pdata.inv_jd1_1) { in rt5645_i2c_probe()
4027 regmap_update_bits(rt5645->regmap, RT5645_IRQ_CTRL2, in rt5645_i2c_probe()
4032 regmap_update_bits(rt5645->regmap, RT5645_ADDA_CLK1, in rt5645_i2c_probe()
4035 if (rt5645->pdata.level_trigger_irq) { in rt5645_i2c_probe()
4036 regmap_update_bits(rt5645->regmap, RT5645_IRQ_CTRL2, in rt5645_i2c_probe()
4039 timer_setup(&rt5645->btn_check_timer, rt5645_btn_check_callback, 0); in rt5645_i2c_probe()
4041 INIT_DELAYED_WORK(&rt5645->jack_detect_work, rt5645_jack_detect_work); in rt5645_i2c_probe()
4042 INIT_DELAYED_WORK(&rt5645->rcclock_work, rt5645_rcclock_work); in rt5645_i2c_probe()
4044 if (rt5645->i2c->irq) { in rt5645_i2c_probe()
4045 ret = request_threaded_irq(rt5645->i2c->irq, NULL, rt5645_irq, in rt5645_i2c_probe()
4047 | IRQF_ONESHOT, "rt5645", rt5645); in rt5645_i2c_probe()
4062 if (rt5645->i2c->irq) in rt5645_i2c_probe()
4063 free_irq(rt5645->i2c->irq, rt5645); in rt5645_i2c_probe()
4065 regulator_bulk_disable(ARRAY_SIZE(rt5645->supplies), rt5645->supplies); in rt5645_i2c_probe()
4071 struct rt5645_priv *rt5645 = i2c_get_clientdata(i2c); in rt5645_i2c_remove() local
4074 free_irq(i2c->irq, rt5645); in rt5645_i2c_remove()
4076 cancel_delayed_work_sync(&rt5645->jack_detect_work); in rt5645_i2c_remove()
4077 cancel_delayed_work_sync(&rt5645->rcclock_work); in rt5645_i2c_remove()
4078 del_timer_sync(&rt5645->btn_check_timer); in rt5645_i2c_remove()
4080 regulator_bulk_disable(ARRAY_SIZE(rt5645->supplies), rt5645->supplies); in rt5645_i2c_remove()
4087 struct rt5645_priv *rt5645 = i2c_get_clientdata(i2c); in rt5645_i2c_shutdown() local
4089 regmap_update_bits(rt5645->regmap, RT5645_GEN_CTRL3, in rt5645_i2c_shutdown()
4091 regmap_update_bits(rt5645->regmap, RT5645_IN1_CTRL2, RT5645_CBJ_MN_JD, in rt5645_i2c_shutdown()
4093 regmap_update_bits(rt5645->regmap, RT5645_IN1_CTRL1, RT5645_CBJ_BST1_EN, in rt5645_i2c_shutdown()
4096 regmap_write(rt5645->regmap, RT5645_RESET, 0); in rt5645_i2c_shutdown()