Lines Matching refs:rt5660
3 * rt5660.c -- RT5660 ALSA SoC audio codec driver
31 #include "rt5660.h"
355 struct rt5660_priv *rt5660 = snd_soc_component_get_drvdata(component);
358 rate = rt5660->sysclk / rl6231_get_pre_div(rt5660->regmap,
839 struct rt5660_priv *rt5660 = snd_soc_component_get_drvdata(component);
843 rt5660->lrck[dai->id] = params_rate(params);
844 pre_div = rl6231_get_clk_info(rt5660->sysclk, rt5660->lrck[dai->id]);
847 rt5660->lrck[dai->id], dai->id);
862 rt5660->bclk[dai->id] = rt5660->lrck[dai->id] * (32 << bclk_ms);
865 rt5660->bclk[dai->id], rt5660->lrck[dai->id]);
906 struct rt5660_priv *rt5660 = snd_soc_component_get_drvdata(component);
911 rt5660->master[dai->id] = 1;
916 rt5660->master[dai->id] = 0;
974 struct rt5660_priv *rt5660 = snd_soc_component_get_drvdata(component);
977 if (freq == rt5660->sysclk && clk_id == rt5660->sysclk_src)
1001 rt5660->sysclk = freq;
1002 rt5660->sysclk_src = clk_id;
1013 struct rt5660_priv *rt5660 = snd_soc_component_get_drvdata(component);
1017 if (source == rt5660->pll_src && freq_in == rt5660->pll_in &&
1018 freq_out == rt5660->pll_out)
1024 rt5660->pll_in = 0;
1025 rt5660->pll_out = 0;
1063 rt5660->pll_in = freq_in;
1064 rt5660->pll_out = freq_out;
1065 rt5660->pll_src = source;
1073 struct rt5660_priv *rt5660 = snd_soc_component_get_drvdata(component);
1084 if (IS_ERR(rt5660->mclk))
1088 clk_disable_unprepare(rt5660->mclk);
1090 ret = clk_prepare_enable(rt5660->mclk);
1124 struct rt5660_priv *rt5660 = snd_soc_component_get_drvdata(component);
1126 rt5660->component = component;
1139 struct rt5660_priv *rt5660 = snd_soc_component_get_drvdata(component);
1141 regcache_cache_only(rt5660->regmap, true);
1142 regcache_mark_dirty(rt5660->regmap);
1149 struct rt5660_priv *rt5660 = snd_soc_component_get_drvdata(component);
1151 if (rt5660->pdata.poweroff_codec_in_suspend)
1154 regcache_cache_only(rt5660->regmap, false);
1155 regcache_sync(rt5660->regmap);
1177 .name = "rt5660-aif1",
1233 { "rt5660", 0 },
1239 { .compatible = "realtek,rt5660", },
1253 static int rt5660_parse_dt(struct rt5660_priv *rt5660, struct device *dev)
1255 rt5660->pdata.in1_diff = device_property_read_bool(dev,
1257 rt5660->pdata.in3_diff = device_property_read_bool(dev,
1259 rt5660->pdata.poweroff_codec_in_suspend = device_property_read_bool(dev,
1262 &rt5660->pdata.dmic1_data_pin);
1271 struct rt5660_priv *rt5660;
1275 rt5660 = devm_kzalloc(&i2c->dev, sizeof(struct rt5660_priv),
1278 if (rt5660 == NULL)
1282 rt5660->mclk = devm_clk_get(&i2c->dev, "mclk");
1283 if (PTR_ERR(rt5660->mclk) == -EPROBE_DEFER)
1286 i2c_set_clientdata(i2c, rt5660);
1289 rt5660->pdata = *pdata;
1291 rt5660_parse_dt(rt5660, &i2c->dev);
1293 rt5660->regmap = devm_regmap_init_i2c(i2c, &rt5660_regmap);
1294 if (IS_ERR(rt5660->regmap)) {
1295 ret = PTR_ERR(rt5660->regmap);
1301 regmap_read(rt5660->regmap, RT5660_VENDOR_ID2, &val);
1304 "Device with ID register %#x is not rt5660\n", val);
1308 regmap_write(rt5660->regmap, RT5660_RESET, 0);
1310 ret = regmap_register_patch(rt5660->regmap, rt5660_patch,
1315 regmap_update_bits(rt5660->regmap, RT5660_GEN_CTRL1,
1319 if (rt5660->pdata.dmic1_data_pin) {
1320 regmap_update_bits(rt5660->regmap, RT5660_GPIO_CTRL1,
1323 if (rt5660->pdata.dmic1_data_pin == RT5660_DMIC1_DATA_GPIO2)
1324 regmap_update_bits(rt5660->regmap, RT5660_DMIC_CTRL1,
1327 else if (rt5660->pdata.dmic1_data_pin == RT5660_DMIC1_DATA_IN1P)
1328 regmap_update_bits(rt5660->regmap, RT5660_DMIC_CTRL1,
1340 .name = "rt5660",