Lines Matching full:da7219

3  * da7219.c - DA7219 ALSA SoC Codec Driver
31 #include <sound/da7219.h>
32 #include "da7219.h"
33 #include "da7219-aad.h"
258 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_volsw_locked_get() local
261 mutex_lock(&da7219->ctrl_lock); in da7219_volsw_locked_get()
263 mutex_unlock(&da7219->ctrl_lock); in da7219_volsw_locked_get()
272 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_volsw_locked_put() local
275 mutex_lock(&da7219->ctrl_lock); in da7219_volsw_locked_put()
277 mutex_unlock(&da7219->ctrl_lock); in da7219_volsw_locked_put()
286 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_enum_locked_get() local
289 mutex_lock(&da7219->ctrl_lock); in da7219_enum_locked_get()
291 mutex_unlock(&da7219->ctrl_lock); in da7219_enum_locked_get()
300 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_enum_locked_put() local
303 mutex_lock(&da7219->ctrl_lock); in da7219_enum_locked_put()
305 mutex_unlock(&da7219->ctrl_lock); in da7219_enum_locked_put()
380 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_mixin_gain_put() local
389 if ((ret == 1) && (da7219->alc_en)) in da7219_mixin_gain_put()
399 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_alc_sw_put() local
403 if ((ucontrol->value.integer.value[0]) && (!da7219->alc_en)) { in da7219_alc_sw_put()
405 da7219->alc_en = true; in da7219_alc_sw_put()
407 da7219->alc_en = false; in da7219_alc_sw_put()
418 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_tonegen_freq_get() local
425 mutex_lock(&da7219->ctrl_lock); in da7219_tonegen_freq_get()
426 ret = regmap_raw_read(da7219->regmap, reg, &val, sizeof(val)); in da7219_tonegen_freq_get()
427 mutex_unlock(&da7219->ctrl_lock); in da7219_tonegen_freq_get()
445 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_tonegen_freq_put() local
459 mutex_lock(&da7219->ctrl_lock); in da7219_tonegen_freq_put()
460 ret = regmap_raw_read(da7219->regmap, reg, &val_old, sizeof(val_old)); in da7219_tonegen_freq_put()
462 ret = regmap_raw_write(da7219->regmap, reg, in da7219_tonegen_freq_put()
464 mutex_unlock(&da7219->ctrl_lock); in da7219_tonegen_freq_put()
777 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_mic_pga_event() local
781 if (da7219->micbias_on_event) { in da7219_mic_pga_event()
786 da7219->micbias_on_event = false; in da7219_mic_pga_event()
787 msleep(da7219->mic_pga_delay); in da7219_mic_pga_event()
801 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_dai_event() local
802 struct clk *bclk = da7219->dai_clks[DA7219_DAI_BCLK_IDX]; in da7219_dai_event()
809 if (da7219->master) { in da7219_dai_event()
857 if (da7219->master) { in da7219_dai_event()
930 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_gain_ramp_event() local
936 da7219->gain_ramp_ctrl = in da7219_gain_ramp_event()
945 da7219->gain_ramp_ctrl); in da7219_gain_ramp_event()
1167 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_set_dai_sysclk() local
1170 mutex_lock(&da7219->pll_lock); in da7219_set_dai_sysclk()
1172 if ((da7219->clk_src == clk_id) && (da7219->mclk_rate == freq)) { in da7219_set_dai_sysclk()
1173 mutex_unlock(&da7219->pll_lock); in da7219_set_dai_sysclk()
1178 mutex_unlock(&da7219->pll_lock); in da7219_set_dai_sysclk()
1196 mutex_unlock(&da7219->pll_lock); in da7219_set_dai_sysclk()
1200 da7219->clk_src = clk_id; in da7219_set_dai_sysclk()
1202 if (da7219->mclk) { in da7219_set_dai_sysclk()
1203 freq = clk_round_rate(da7219->mclk, freq); in da7219_set_dai_sysclk()
1204 ret = clk_set_rate(da7219->mclk, freq); in da7219_set_dai_sysclk()
1208 mutex_unlock(&da7219->pll_lock); in da7219_set_dai_sysclk()
1213 da7219->mclk_rate = freq; in da7219_set_dai_sysclk()
1215 mutex_unlock(&da7219->pll_lock); in da7219_set_dai_sysclk()
1222 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_set_pll() local
1230 if (da7219->mclk_rate < 2000000) { in da7219_set_pll()
1232 da7219->mclk_rate); in da7219_set_pll()
1234 } else if (da7219->mclk_rate <= 4500000) { in da7219_set_pll()
1237 } else if (da7219->mclk_rate <= 9000000) { in da7219_set_pll()
1240 } else if (da7219->mclk_rate <= 18000000) { in da7219_set_pll()
1243 } else if (da7219->mclk_rate <= 36000000) { in da7219_set_pll()
1246 } else if (da7219->mclk_rate <= 54000000) { in da7219_set_pll()
1251 da7219->mclk_rate); in da7219_set_pll()
1254 freq_ref = (da7219->mclk_rate / indiv); in da7219_set_pll()
1298 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_set_dai_pll() local
1301 mutex_lock(&da7219->pll_lock); in da7219_set_dai_pll()
1303 mutex_unlock(&da7219->pll_lock); in da7219_set_dai_pll()
1311 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_set_dai_fmt() local
1316 da7219->master = true; in da7219_set_dai_fmt()
1319 da7219->master = false; in da7219_set_dai_fmt()
1428 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_set_dai_tdm_slot() local
1429 struct clk *wclk = da7219->dai_clks[DA7219_DAI_WCLK_IDX]; in da7219_set_dai_tdm_slot()
1430 struct clk *bclk = da7219->dai_clks[DA7219_DAI_BCLK_IDX]; in da7219_set_dai_tdm_slot()
1444 da7219->tdm_en = false; in da7219_set_dai_tdm_slot()
1472 if (da7219->master) { in da7219_set_dai_tdm_slot()
1497 regmap_bulk_write(da7219->regmap, DA7219_DAI_OFFSET_LOWER, in da7219_set_dai_tdm_slot()
1506 da7219->tdm_en = true; in da7219_set_dai_tdm_slot()
1564 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_hw_params() local
1565 struct clk *wclk = da7219->dai_clks[DA7219_DAI_WCLK_IDX]; in da7219_hw_params()
1566 struct clk *bclk = da7219->dai_clks[DA7219_DAI_BCLK_IDX]; in da7219_hw_params()
1600 if (da7219->master && wclk) { in da7219_hw_params()
1621 if (da7219->master && !da7219->tdm_en) { in da7219_hw_params()
1688 .name = "da7219-hifi",
1716 { .compatible = "dlg,da7219", },
1779 pdata->dai_clk_names[DA7219_DAI_WCLK_IDX] = "da7219-dai-wclk"; in da7219_fw_to_pdata()
1780 pdata->dai_clk_names[DA7219_DAI_BCLK_IDX] = "da7219-dai-bclk"; in da7219_fw_to_pdata()
1809 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_set_bias_level() local
1818 if (da7219->mclk) { in da7219_set_bias_level()
1819 ret = clk_prepare_enable(da7219->mclk); in da7219_set_bias_level()
1838 if (da7219->mclk) in da7219_set_bias_level()
1839 clk_disable_unprepare(da7219->mclk); in da7219_set_bias_level()
1844 if (!da7219->wakeup_source) in da7219_set_bias_level()
1863 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_handle_supplies() local
1869 da7219->supplies[i].supply = da7219_supply_names[i]; in da7219_handle_supplies()
1872 da7219->supplies); in da7219_handle_supplies()
1882 vddio = da7219->supplies[DA7219_SUPPLY_VDDIO].consumer; in da7219_handle_supplies()
1890 ret = regulator_bulk_enable(DA7219_NUM_SUPPLIES, da7219->supplies); in da7219_handle_supplies()
1893 regulator_bulk_free(DA7219_NUM_SUPPLIES, da7219->supplies); in da7219_handle_supplies()
1903 struct da7219_priv *da7219 = in da7219_wclk_prepare() local
1906 struct snd_soc_component *component = da7219->component; in da7219_wclk_prepare()
1908 if (!da7219->master) in da7219_wclk_prepare()
1920 struct da7219_priv *da7219 = in da7219_wclk_unprepare() local
1923 struct snd_soc_component *component = da7219->component; in da7219_wclk_unprepare()
1925 if (!da7219->master) in da7219_wclk_unprepare()
1934 struct da7219_priv *da7219 = in da7219_wclk_is_prepared() local
1937 struct snd_soc_component *component = da7219->component; in da7219_wclk_is_prepared()
1940 if (!da7219->master) in da7219_wclk_is_prepared()
1951 struct da7219_priv *da7219 = in da7219_wclk_recalc_rate() local
1954 struct snd_soc_component *component = da7219->component; in da7219_wclk_recalc_rate()
1988 struct da7219_priv *da7219 = in da7219_wclk_round_rate() local
1992 if (!da7219->master) in da7219_wclk_round_rate()
2022 struct da7219_priv *da7219 = in da7219_wclk_set_rate() local
2025 struct snd_soc_component *component = da7219->component; in da7219_wclk_set_rate()
2027 if (!da7219->master) in da7219_wclk_set_rate()
2036 struct da7219_priv *da7219 = in da7219_bclk_recalc_rate() local
2039 struct snd_soc_component *component = da7219->component; in da7219_bclk_recalc_rate()
2076 struct da7219_priv *da7219 = in da7219_bclk_round_rate() local
2081 if (!*parent_rate || !da7219->master) in da7219_bclk_round_rate()
2099 struct da7219_priv *da7219 = in da7219_bclk_set_rate() local
2102 struct snd_soc_component *component = da7219->component; in da7219_bclk_set_rate()
2105 if (!da7219->master) in da7219_bclk_set_rate()
2133 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_register_dai_clks() local
2134 struct da7219_pdata *pdata = da7219->pdata; in da7219_register_dai_clks()
2147 da7219->clk_hw_data = clk_data; in da7219_register_dai_clks()
2153 struct clk_hw *dai_clk_hw = &da7219->dai_clks_hw[i]; in da7219_register_dai_clks()
2161 if (da7219->mclk) { in da7219_register_dai_clks()
2162 parent_name = __clk_get_name(da7219->mclk); in da7219_register_dai_clks()
2172 parent_name = __clk_get_name(da7219->dai_clks[DA7219_DAI_WCLK_IDX]); in da7219_register_dai_clks()
2193 da7219->dai_clks[i] = dai_clk_hw->clk; in da7219_register_dai_clks()
2197 da7219->clk_hw_data->hws[i] = dai_clk_hw; in da7219_register_dai_clks()
2206 da7219->dai_clks_lookup[i] = dai_clk_lookup; in da7219_register_dai_clks()
2214 da7219->clk_hw_data); in da7219_register_dai_clks()
2225 if (da7219->dai_clks_lookup[i]) in da7219_register_dai_clks()
2226 clkdev_drop(da7219->dai_clks_lookup[i]); in da7219_register_dai_clks()
2228 clk_hw_unregister(&da7219->dai_clks_hw[i]); in da7219_register_dai_clks()
2232 kfree(da7219->clk_hw_data); in da7219_register_dai_clks()
2239 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_free_dai_clks() local
2247 if (da7219->dai_clks_lookup[i]) in da7219_free_dai_clks()
2248 clkdev_drop(da7219->dai_clks_lookup[i]); in da7219_free_dai_clks()
2250 clk_hw_unregister(&da7219->dai_clks_hw[i]); in da7219_free_dai_clks()
2254 kfree(da7219->clk_hw_data); in da7219_free_dai_clks()
2267 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_handle_pdata() local
2268 struct da7219_pdata *pdata = da7219->pdata; in da7219_handle_pdata()
2273 da7219->wakeup_source = pdata->wakeup_source; in da7219_handle_pdata()
2294 da7219->mic_pga_delay = DA7219_MIC_PGA_BASE_DELAY + in da7219_handle_pdata()
2452 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_probe() local
2457 da7219->component = component; in da7219_probe()
2458 mutex_init(&da7219->ctrl_lock); in da7219_probe()
2459 mutex_init(&da7219->pll_lock); in da7219_probe()
2466 regcache_cache_bypass(da7219->regmap, true); in da7219_probe()
2469 regmap_read(da7219->regmap, DA7219_SYSTEM_ACTIVE, &system_active); in da7219_probe()
2471 regmap_write(da7219->regmap, DA7219_GAIN_RAMP_CTRL, in da7219_probe()
2473 regmap_write(da7219->regmap, DA7219_SYSTEM_MODES_INPUT, 0x00); in da7219_probe()
2474 regmap_write(da7219->regmap, DA7219_SYSTEM_MODES_OUTPUT, 0x01); in da7219_probe()
2477 regmap_read(da7219->regmap, DA7219_SYSTEM_STATUS, in da7219_probe()
2487 regmap_write_bits(da7219->regmap, DA7219_ACCDET_CONFIG_1, in da7219_probe()
2489 regmap_write_bits(da7219->regmap, DA7219_CIF_CTRL, in da7219_probe()
2492 regmap_write_bits(da7219->regmap, DA7219_SYSTEM_ACTIVE, in da7219_probe()
2494 regmap_write_bits(da7219->regmap, DA7219_SYSTEM_ACTIVE, in da7219_probe()
2497 regcache_cache_bypass(da7219->regmap, false); in da7219_probe()
2498 regmap_reinit_cache(da7219->regmap, &da7219_regmap_config); in da7219_probe()
2503 ret = regmap_read(da7219->regmap, DA7219_CHIP_REVISION, &rev); in da7219_probe()
2511 ret = regmap_register_patch(da7219->regmap, da7219_rev_aa_patch, in da7219_probe()
2527 da7219->mclk = clk_get(component->dev, "mclk"); in da7219_probe()
2528 if (IS_ERR(da7219->mclk)) { in da7219_probe()
2529 if (PTR_ERR(da7219->mclk) != -ENOENT) { in da7219_probe()
2530 ret = PTR_ERR(da7219->mclk); in da7219_probe()
2533 da7219->mclk = NULL; in da7219_probe()
2585 clk_put(da7219->mclk); in da7219_probe()
2588 regulator_bulk_disable(DA7219_NUM_SUPPLIES, da7219->supplies); in da7219_probe()
2589 regulator_bulk_free(DA7219_NUM_SUPPLIES, da7219->supplies); in da7219_probe()
2596 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_remove() local
2601 clk_put(da7219->mclk); in da7219_remove()
2604 regulator_bulk_disable(DA7219_NUM_SUPPLIES, da7219->supplies); in da7219_remove()
2605 regulator_bulk_free(DA7219_NUM_SUPPLIES, da7219->supplies); in da7219_remove()
2611 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_suspend() local
2614 if (!da7219->wakeup_source) in da7219_suspend()
2624 struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component); in da7219_resume() local
2629 if (!da7219->wakeup_source) in da7219_resume()
2673 struct da7219_priv *da7219; in da7219_i2c_probe() local
2676 da7219 = devm_kzalloc(dev, sizeof(struct da7219_priv), in da7219_i2c_probe()
2678 if (!da7219) in da7219_i2c_probe()
2681 i2c_set_clientdata(i2c, da7219); in da7219_i2c_probe()
2683 da7219->regmap = devm_regmap_init_i2c(i2c, &da7219_regmap_config); in da7219_i2c_probe()
2684 if (IS_ERR(da7219->regmap)) { in da7219_i2c_probe()
2685 ret = PTR_ERR(da7219->regmap); in da7219_i2c_probe()
2691 da7219->pdata = dev_get_platdata(dev); in da7219_i2c_probe()
2692 if (!da7219->pdata) in da7219_i2c_probe()
2693 da7219->pdata = da7219_fw_to_pdata(dev); in da7219_i2c_probe()
2703 dev_err(dev, "Failed to register da7219 component: %d\n", ret); in da7219_i2c_probe()
2709 { "da7219", },
2716 .name = "da7219",
2726 MODULE_DESCRIPTION("ASoC DA7219 Codec Driver");