Lines Matching +full:dc +full:- +full:dc +full:- +full:freq +full:- +full:hz

1 // SPDX-License-Identifier: GPL-2.0-only
3 * max98088.c -- MAX98088 ALSA SoC Audio driver
337 "Off", "100Hz", "400Hz", "600Hz", "800Hz", "1000Hz", "200-400Hz",
338 "400-600Hz", "400-800Hz",
385 unsigned int sel = ucontrol->value.integer.value[0]; in max98088_mic1pre_set()
387 max98088->mic1pre = sel; in max98088_mic1pre_set()
400 ucontrol->value.integer.value[0] = max98088->mic1pre; in max98088_mic1pre_get()
409 unsigned int sel = ucontrol->value.integer.value[0]; in max98088_mic2pre_set()
411 max98088->mic2pre = sel; in max98088_mic2pre_set()
424 ucontrol->value.integer.value[0] = max98088->mic2pre; in max98088_mic2pre_get()
434 0, 6, TLV_DB_SCALE_ITEM(-6700, 400, 0),
435 7, 14, TLV_DB_SCALE_ITEM(-4000, 300, 0),
436 15, 21, TLV_DB_SCALE_ITEM(-1700, 200, 0),
437 22, 27, TLV_DB_SCALE_ITEM(-400, 100, 0),
442 0, 6, TLV_DB_SCALE_ITEM(-6200, 400, 0),
443 7, 14, TLV_DB_SCALE_ITEM(-3500, 300, 0),
444 15, 21, TLV_DB_SCALE_ITEM(-1200, 200, 0),
498 SOC_SINGLE("DAI2 DC Block Switch", M98088_REG_20_DAI2_FILTERS,
623 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in max98088_mic_event()
628 if (w->reg == M98088_REG_35_LVL_MIC1) { in max98088_mic_event()
629 snd_soc_component_update_bits(component, w->reg, M98088_MICPRE_MASK, in max98088_mic_event()
630 (1+max98088->mic1pre)<<M98088_MICPRE_SHIFT); in max98088_mic_event()
632 snd_soc_component_update_bits(component, w->reg, M98088_MICPRE_MASK, in max98088_mic_event()
633 (1+max98088->mic2pre)<<M98088_MICPRE_SHIFT); in max98088_mic_event()
637 snd_soc_component_update_bits(component, w->reg, M98088_MICPRE_MASK, 0); in max98088_mic_event()
640 return -EINVAL; in max98088_mic_event()
647 * The line inputs are 2-channel stereo inputs with the left
653 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in max98088_line_pga()
658 return -EINVAL; in max98088_line_pga()
662 state = &max98088->ina_state; in max98088_line_pga()
665 state = &max98088->inb_state; in max98088_line_pga()
668 return -EINVAL; in max98088_line_pga()
674 snd_soc_component_update_bits(component, w->reg, in max98088_line_pga()
675 (1 << w->shift), (1 << w->shift)); in max98088_line_pga()
680 snd_soc_component_update_bits(component, w->reg, in max98088_line_pga()
681 (1 << w->shift), 0); in max98088_line_pga()
685 return -EINVAL; in max98088_line_pga()
962 return -EINVAL; in rate_value()
969 struct snd_soc_component *component = dai->component; in max98088_dai1_hw_params()
976 cdata = &max98088->dai[0]; in max98088_dai1_hw_params()
990 return -EINVAL; in max98088_dai1_hw_params()
996 return -EINVAL; in max98088_dai1_hw_params()
1000 cdata->rate = rate; in max98088_dai1_hw_params()
1007 if (max98088->sysclk == 0) { in max98088_dai1_hw_params()
1008 dev_err(component->dev, "Invalid system clock frequency\n"); in max98088_dai1_hw_params()
1009 return -EINVAL; in max98088_dai1_hw_params()
1013 pclk = DIV_ROUND_CLOSEST(max98088->sysclk, max98088->mclk_prescaler); in max98088_dai1_hw_params()
1039 struct snd_soc_component *component = dai->component; in max98088_dai2_hw_params()
1046 cdata = &max98088->dai[1]; in max98088_dai2_hw_params()
1060 return -EINVAL; in max98088_dai2_hw_params()
1066 return -EINVAL; in max98088_dai2_hw_params()
1070 cdata->rate = rate; in max98088_dai2_hw_params()
1077 if (max98088->sysclk == 0) { in max98088_dai2_hw_params()
1078 dev_err(component->dev, "Invalid system clock frequency\n"); in max98088_dai2_hw_params()
1079 return -EINVAL; in max98088_dai2_hw_params()
1083 pclk = DIV_ROUND_CLOSEST(max98088->sysclk, max98088->mclk_prescaler); in max98088_dai2_hw_params()
1106 int clk_id, unsigned int freq, int dir) in max98088_dai_set_sysclk() argument
1108 struct snd_soc_component *component = dai->component; in max98088_dai_set_sysclk()
1112 if (freq == max98088->sysclk) in max98088_dai_set_sysclk()
1115 if (!IS_ERR(max98088->mclk)) { in max98088_dai_set_sysclk()
1116 freq = clk_round_rate(max98088->mclk, freq); in max98088_dai_set_sysclk()
1117 clk_set_rate(max98088->mclk, freq); in max98088_dai_set_sysclk()
1124 if ((freq >= 10000000) && (freq < 20000000)) { in max98088_dai_set_sysclk()
1126 max98088->mclk_prescaler = 1; in max98088_dai_set_sysclk()
1127 } else if ((freq >= 20000000) && (freq < 30000000)) { in max98088_dai_set_sysclk()
1129 max98088->mclk_prescaler = 2; in max98088_dai_set_sysclk()
1131 dev_err(component->dev, "Invalid master clock frequency\n"); in max98088_dai_set_sysclk()
1132 return -EINVAL; in max98088_dai_set_sysclk()
1142 dev_dbg(dai->dev, "Clock source is %d at %uHz\n", clk_id, freq); in max98088_dai_set_sysclk()
1144 max98088->sysclk = freq; in max98088_dai_set_sysclk()
1151 struct snd_soc_component *component = codec_dai->component; in max98088_dai1_set_fmt()
1157 cdata = &max98088->dai[0]; in max98088_dai1_set_fmt()
1159 if (fmt != cdata->fmt) { in max98088_dai1_set_fmt()
1160 cdata->fmt = fmt; in max98088_dai1_set_fmt()
1175 dev_err(component->dev, "Clock mode unsupported"); in max98088_dai1_set_fmt()
1176 return -EINVAL; in max98088_dai1_set_fmt()
1186 return -EINVAL; in max98088_dai1_set_fmt()
1202 return -EINVAL; in max98088_dai1_set_fmt()
1210 if (max98088->digmic) in max98088_dai1_set_fmt()
1221 struct snd_soc_component *component = codec_dai->component; in max98088_dai2_set_fmt()
1226 cdata = &max98088->dai[1]; in max98088_dai2_set_fmt()
1228 if (fmt != cdata->fmt) { in max98088_dai2_set_fmt()
1229 cdata->fmt = fmt; in max98088_dai2_set_fmt()
1244 dev_err(component->dev, "Clock mode unsupported"); in max98088_dai2_set_fmt()
1245 return -EINVAL; in max98088_dai2_set_fmt()
1255 return -EINVAL; in max98088_dai2_set_fmt()
1271 return -EINVAL; in max98088_dai2_set_fmt()
1288 struct snd_soc_component *component = codec_dai->component; in max98088_dai1_mute()
1304 struct snd_soc_component *component = codec_dai->component; in max98088_dai2_mute()
1334 if (!IS_ERR(max98088->mclk)) { in max98088_set_bias_level()
1337 clk_disable_unprepare(max98088->mclk); in max98088_set_bias_level()
1339 clk_prepare_enable(max98088->mclk); in max98088_set_bias_level()
1345 regcache_sync(max98088->regmap); in max98088_set_bias_level()
1354 regcache_mark_dirty(max98088->regmap); in max98088_set_bias_level()
1419 dev_err(component->dev, "Bad EQ channel name '%s'\n", name); in max98088_get_channel()
1426 struct max98088_pdata *pdata = max98088->pdata; in max98088_setup_eq1()
1431 cdata = &max98088->dai[0]; in max98088_setup_eq1()
1433 if (!pdata || !max98088->eq_textcnt) in max98088_setup_eq1()
1437 fs = cdata->rate; in max98088_setup_eq1()
1438 sel = cdata->eq_sel; in max98088_setup_eq1()
1442 for (i = 0; i < pdata->eq_cfgcnt; i++) { in max98088_setup_eq1()
1443 if (strcmp(pdata->eq_cfg[i].name, max98088->eq_texts[sel]) == 0 && in max98088_setup_eq1()
1444 abs(pdata->eq_cfg[i].rate - fs) < best_val) { in max98088_setup_eq1()
1446 best_val = abs(pdata->eq_cfg[i].rate - fs); in max98088_setup_eq1()
1450 dev_dbg(component->dev, "Selected %s/%dHz for %dHz sample rate\n", in max98088_setup_eq1()
1451 pdata->eq_cfg[best].name, in max98088_setup_eq1()
1452 pdata->eq_cfg[best].rate, fs); in max98088_setup_eq1()
1458 coef_set = &pdata->eq_cfg[sel]; in max98088_setup_eq1()
1460 m98088_eq_band(component, 0, 0, coef_set->band1); in max98088_setup_eq1()
1461 m98088_eq_band(component, 0, 1, coef_set->band2); in max98088_setup_eq1()
1462 m98088_eq_band(component, 0, 2, coef_set->band3); in max98088_setup_eq1()
1463 m98088_eq_band(component, 0, 3, coef_set->band4); in max98088_setup_eq1()
1464 m98088_eq_band(component, 0, 4, coef_set->band5); in max98088_setup_eq1()
1473 struct max98088_pdata *pdata = max98088->pdata; in max98088_setup_eq2()
1478 cdata = &max98088->dai[1]; in max98088_setup_eq2()
1480 if (!pdata || !max98088->eq_textcnt) in max98088_setup_eq2()
1484 fs = cdata->rate; in max98088_setup_eq2()
1486 sel = cdata->eq_sel; in max98088_setup_eq2()
1489 for (i = 0; i < pdata->eq_cfgcnt; i++) { in max98088_setup_eq2()
1490 if (strcmp(pdata->eq_cfg[i].name, max98088->eq_texts[sel]) == 0 && in max98088_setup_eq2()
1491 abs(pdata->eq_cfg[i].rate - fs) < best_val) { in max98088_setup_eq2()
1493 best_val = abs(pdata->eq_cfg[i].rate - fs); in max98088_setup_eq2()
1497 dev_dbg(component->dev, "Selected %s/%dHz for %dHz sample rate\n", in max98088_setup_eq2()
1498 pdata->eq_cfg[best].name, in max98088_setup_eq2()
1499 pdata->eq_cfg[best].rate, fs); in max98088_setup_eq2()
1505 coef_set = &pdata->eq_cfg[sel]; in max98088_setup_eq2()
1507 m98088_eq_band(component, 1, 0, coef_set->band1); in max98088_setup_eq2()
1508 m98088_eq_band(component, 1, 1, coef_set->band2); in max98088_setup_eq2()
1509 m98088_eq_band(component, 1, 2, coef_set->band3); in max98088_setup_eq2()
1510 m98088_eq_band(component, 1, 3, coef_set->band4); in max98088_setup_eq2()
1511 m98088_eq_band(component, 1, 4, coef_set->band5); in max98088_setup_eq2()
1523 struct max98088_pdata *pdata = max98088->pdata; in max98088_put_eq_enum()
1524 int channel = max98088_get_channel(component, kcontrol->id.name); in max98088_put_eq_enum()
1526 int sel = ucontrol->value.enumerated.item[0]; in max98088_put_eq_enum()
1531 cdata = &max98088->dai[channel]; in max98088_put_eq_enum()
1533 if (sel >= pdata->eq_cfgcnt) in max98088_put_eq_enum()
1534 return -EINVAL; in max98088_put_eq_enum()
1536 cdata->eq_sel = sel; in max98088_put_eq_enum()
1555 int channel = max98088_get_channel(component, kcontrol->id.name); in max98088_get_eq_enum()
1561 cdata = &max98088->dai[channel]; in max98088_get_eq_enum()
1562 ucontrol->value.enumerated.item[0] = cdata->eq_sel; in max98088_get_eq_enum()
1569 struct max98088_pdata *pdata = max98088->pdata; in max98088_handle_eq_pdata()
1577 max98088->eq_enum, in max98088_handle_eq_pdata()
1581 max98088->eq_enum, in max98088_handle_eq_pdata()
1587 cfg = pdata->eq_cfg; in max98088_handle_eq_pdata()
1588 cfgcnt = pdata->eq_cfgcnt; in max98088_handle_eq_pdata()
1593 max98088->eq_textcnt = 0; in max98088_handle_eq_pdata()
1594 max98088->eq_texts = NULL; in max98088_handle_eq_pdata()
1596 for (j = 0; j < max98088->eq_textcnt; j++) { in max98088_handle_eq_pdata()
1597 if (strcmp(cfg[i].name, max98088->eq_texts[j]) == 0) in max98088_handle_eq_pdata()
1601 if (j != max98088->eq_textcnt) in max98088_handle_eq_pdata()
1605 t = krealloc(max98088->eq_texts, in max98088_handle_eq_pdata()
1606 sizeof(char *) * (max98088->eq_textcnt + 1), in max98088_handle_eq_pdata()
1612 t[max98088->eq_textcnt] = cfg[i].name; in max98088_handle_eq_pdata()
1613 max98088->eq_textcnt++; in max98088_handle_eq_pdata()
1614 max98088->eq_texts = t; in max98088_handle_eq_pdata()
1618 max98088->eq_enum.texts = max98088->eq_texts; in max98088_handle_eq_pdata()
1619 max98088->eq_enum.items = max98088->eq_textcnt; in max98088_handle_eq_pdata()
1623 dev_err(component->dev, "Failed to add EQ control: %d\n", ret); in max98088_handle_eq_pdata()
1629 struct max98088_pdata *pdata = max98088->pdata; in max98088_handle_pdata()
1633 dev_dbg(component->dev, "No platform data\n"); in max98088_handle_pdata()
1638 if (pdata->digmic_left_mode) in max98088_handle_pdata()
1641 if (pdata->digmic_right_mode) in max98088_handle_pdata()
1644 max98088->digmic = (regval ? 1 : 0); in max98088_handle_pdata()
1649 regval = ((pdata->receiver_mode) ? M98088_REC_LINEMODE : 0); in max98088_handle_pdata()
1654 if (pdata->eq_cfgcnt) in max98088_handle_pdata()
1664 regcache_mark_dirty(max98088->regmap); in max98088_probe()
1668 max98088->sysclk = (unsigned)-1; in max98088_probe()
1669 max98088->eq_textcnt = 0; in max98088_probe()
1671 cdata = &max98088->dai[0]; in max98088_probe()
1672 cdata->rate = (unsigned)-1; in max98088_probe()
1673 cdata->fmt = (unsigned)-1; in max98088_probe()
1674 cdata->eq_sel = 0; in max98088_probe()
1676 cdata = &max98088->dai[1]; in max98088_probe()
1677 cdata->rate = (unsigned)-1; in max98088_probe()
1678 cdata->fmt = (unsigned)-1; in max98088_probe()
1679 cdata->eq_sel = 0; in max98088_probe()
1681 max98088->ina_state = 0; in max98088_probe()
1682 max98088->inb_state = 0; in max98088_probe()
1683 max98088->ex_mode = 0; in max98088_probe()
1684 max98088->digmic = 0; in max98088_probe()
1685 max98088->mic1pre = 0; in max98088_probe()
1686 max98088->mic2pre = 0; in max98088_probe()
1690 dev_err(component->dev, "Failed to read device revision: %d\n", in max98088_probe()
1694 dev_info(component->dev, "revision %c\n", ret - 0x40 + 'A'); in max98088_probe()
1723 kfree(max98088->eq_texts); in max98088_remove()
1754 max98088 = devm_kzalloc(&i2c->dev, sizeof(struct max98088_priv), in max98088_i2c_probe()
1757 return -ENOMEM; in max98088_i2c_probe()
1759 max98088->regmap = devm_regmap_init_i2c(i2c, &max98088_regmap); in max98088_i2c_probe()
1760 if (IS_ERR(max98088->regmap)) in max98088_i2c_probe()
1761 return PTR_ERR(max98088->regmap); in max98088_i2c_probe()
1763 max98088->mclk = devm_clk_get(&i2c->dev, "mclk"); in max98088_i2c_probe()
1764 if (IS_ERR(max98088->mclk)) in max98088_i2c_probe()
1765 if (PTR_ERR(max98088->mclk) == -EPROBE_DEFER) in max98088_i2c_probe()
1766 return PTR_ERR(max98088->mclk); in max98088_i2c_probe()
1769 max98088->devtype = id->driver_data; in max98088_i2c_probe()
1772 max98088->pdata = i2c->dev.platform_data; in max98088_i2c_probe()
1774 return devm_snd_soc_register_component(&i2c->dev, &soc_component_dev_max98088, in max98088_i2c_probe()