Lines Matching +full:- +full:32000
1 // SPDX-License-Identifier: GPL-2.0-or-later
85 48, 127, TLV_DB_SCALE_ITEM(-7400, 100, 0)
88 static const DECLARE_TLV_DB_SCALE(ssm260x_inpga_tlv, -3450, 150, 0);
89 static const DECLARE_TLV_DB_SCALE(ssm260x_sidetone_tlv, -1500, 300, 0);
99 SOC_ENUM("Playback De-emphasis", ssm2602_enum[1]),
178 ARRAY_SIZE(ssm260x_output_mixer_controls) - 1), /* Last element is the mic */
215 8000, 16000, 32000, 48000, 96000,
248 {12288000, 32000, SSM2602_COEFF_SRATE(0x6, 0x0, 0x0)},
249 {18432000, 32000, SSM2602_COEFF_SRATE(0x6, 0x1, 0x0)},
250 {12000000, 32000, SSM2602_COEFF_SRATE(0x6, 0x0, 0x1)},
302 return -EINVAL;
309 struct snd_soc_component *component = dai->component;
311 int srate = ssm2602_get_coeff(ssm2602->sysclk, params_rate(params));
317 regmap_write(ssm2602->regmap, SSM2602_SRATE, srate);
334 return -EINVAL;
336 regmap_update_bits(ssm2602->regmap, SSM2602_IFACE,
344 struct snd_soc_component *component = dai->component;
347 if (ssm2602->sysclk_constraints) {
348 snd_pcm_hw_constraint_list(substream->runtime, 0,
350 ssm2602->sysclk_constraints);
358 struct ssm2602_priv *ssm2602 = snd_soc_component_get_drvdata(dai->component);
361 regmap_update_bits(ssm2602->regmap, SSM2602_APDIGI,
365 regmap_update_bits(ssm2602->regmap, SSM2602_APDIGI,
373 struct snd_soc_component *component = codec_dai->component;
378 return -EINVAL;
385 ssm2602->sysclk_constraints = &ssm2602_constraints_12288000;
391 ssm2602->sysclk_constraints = &ssm2602_constraints_11289600;
395 ssm2602->sysclk_constraints = NULL;
398 return -EINVAL;
401 ssm2602->sysclk = freq;
413 return -EINVAL;
417 ssm2602->clk_out_pwr |= mask;
419 ssm2602->clk_out_pwr &= ~mask;
421 regmap_update_bits(ssm2602->regmap, SSM2602_PWR,
422 PWR_CLK_OUT_PDN | PWR_OSC_PDN, ssm2602->clk_out_pwr);
431 struct ssm2602_priv *ssm2602 = snd_soc_component_get_drvdata(codec_dai->component);
442 return -EINVAL;
462 return -EINVAL;
479 return -EINVAL;
483 regmap_write(ssm2602->regmap, SSM2602_IFACE, iface);
495 regmap_update_bits(ssm2602->regmap, SSM2602_PWR,
497 ssm2602->clk_out_pwr);
503 regmap_update_bits(ssm2602->regmap, SSM2602_PWR,
509 regmap_update_bits(ssm2602->regmap, SSM2602_PWR,
536 .name = "ssm2602-hifi",
558 regcache_sync(ssm2602->regmap);
569 regmap_update_bits(ssm2602->regmap, SSM2602_LOUT1V,
571 regmap_update_bits(ssm2602->regmap, SSM2602_ROUT1V,
607 ret = regmap_write(ssm2602->regmap, SSM2602_RESET, 0);
609 dev_err(component->dev, "Failed to issue reset: %d\n", ret);
613 regmap_register_patch(ssm2602->regmap, ssm2602_patch,
617 regmap_update_bits(ssm2602->regmap, SSM2602_LINVOL,
619 regmap_update_bits(ssm2602->regmap, SSM2602_RINVOL,
622 regmap_write(ssm2602->regmap, SSM2602_APANA, APANA_SELECT_DAC |
625 switch (ssm2602->type) {
681 return -ENOMEM;
684 ssm2602->type = type;
685 ssm2602->regmap = regmap;