Lines Matching +full:ch3 +full:- +full:0
1 // SPDX-License-Identifier: GPL-2.0
3 // Copyright (C) 2020 Texas Instruments Incorporated - https://www.ti.com/
41 "ti,gpo-config-1",
42 "ti,gpo-config-2",
43 "ti,gpo-config-3",
44 "ti,gpo-config-4",
48 { ADCX140_PAGE_SELECT, 0x00 },
49 { ADCX140_SW_RESET, 0x00 },
50 { ADCX140_SLEEP_CFG, 0x00 },
51 { ADCX140_SHDN_CFG, 0x05 },
52 { ADCX140_ASI_CFG0, 0x30 },
53 { ADCX140_ASI_CFG1, 0x00 },
54 { ADCX140_ASI_CFG2, 0x00 },
55 { ADCX140_ASI_CH1, 0x00 },
56 { ADCX140_ASI_CH2, 0x01 },
57 { ADCX140_ASI_CH3, 0x02 },
58 { ADCX140_ASI_CH4, 0x03 },
59 { ADCX140_ASI_CH5, 0x04 },
60 { ADCX140_ASI_CH6, 0x05 },
61 { ADCX140_ASI_CH7, 0x06 },
62 { ADCX140_ASI_CH8, 0x07 },
63 { ADCX140_MST_CFG0, 0x02 },
64 { ADCX140_MST_CFG1, 0x48 },
65 { ADCX140_ASI_STS, 0xff },
66 { ADCX140_CLK_SRC, 0x10 },
67 { ADCX140_PDMCLK_CFG, 0x40 },
68 { ADCX140_PDM_CFG, 0x00 },
69 { ADCX140_GPIO_CFG0, 0x22 },
70 { ADCX140_GPO_CFG0, 0x00 },
71 { ADCX140_GPO_CFG1, 0x00 },
72 { ADCX140_GPO_CFG2, 0x00 },
73 { ADCX140_GPO_CFG3, 0x00 },
74 { ADCX140_GPO_VAL, 0x00 },
75 { ADCX140_GPIO_MON, 0x00 },
76 { ADCX140_GPI_CFG0, 0x00 },
77 { ADCX140_GPI_CFG1, 0x00 },
78 { ADCX140_GPI_MON, 0x00 },
79 { ADCX140_INT_CFG, 0x00 },
80 { ADCX140_INT_MASK0, 0xff },
81 { ADCX140_INT_LTCH0, 0x00 },
82 { ADCX140_BIAS_CFG, 0x00 },
83 { ADCX140_CH1_CFG0, 0x00 },
84 { ADCX140_CH1_CFG1, 0x00 },
85 { ADCX140_CH1_CFG2, 0xc9 },
86 { ADCX140_CH1_CFG3, 0x80 },
87 { ADCX140_CH1_CFG4, 0x00 },
88 { ADCX140_CH2_CFG0, 0x00 },
89 { ADCX140_CH2_CFG1, 0x00 },
90 { ADCX140_CH2_CFG2, 0xc9 },
91 { ADCX140_CH2_CFG3, 0x80 },
92 { ADCX140_CH2_CFG4, 0x00 },
93 { ADCX140_CH3_CFG0, 0x00 },
94 { ADCX140_CH3_CFG1, 0x00 },
95 { ADCX140_CH3_CFG2, 0xc9 },
96 { ADCX140_CH3_CFG3, 0x80 },
97 { ADCX140_CH3_CFG4, 0x00 },
98 { ADCX140_CH4_CFG0, 0x00 },
99 { ADCX140_CH4_CFG1, 0x00 },
100 { ADCX140_CH4_CFG2, 0xc9 },
101 { ADCX140_CH4_CFG3, 0x80 },
102 { ADCX140_CH4_CFG4, 0x00 },
103 { ADCX140_CH5_CFG2, 0xc9 },
104 { ADCX140_CH5_CFG3, 0x80 },
105 { ADCX140_CH5_CFG4, 0x00 },
106 { ADCX140_CH6_CFG2, 0xc9 },
107 { ADCX140_CH6_CFG3, 0x80 },
108 { ADCX140_CH6_CFG4, 0x00 },
109 { ADCX140_CH7_CFG2, 0xc9 },
110 { ADCX140_CH7_CFG3, 0x80 },
111 { ADCX140_CH7_CFG4, 0x00 },
112 { ADCX140_CH8_CFG2, 0xc9 },
113 { ADCX140_CH8_CFG3, 0x80 },
114 { ADCX140_CH8_CFG4, 0x00 },
115 { ADCX140_DSP_CFG0, 0x01 },
116 { ADCX140_DSP_CFG1, 0x40 },
117 { ADCX140_DRE_CFG0, 0x7b },
118 { ADCX140_AGC_CFG0, 0xe7 },
119 { ADCX140_IN_CH_EN, 0xf0 },
120 { ADCX140_ASI_OUT_CH_EN, 0x00 },
121 { ADCX140_PWR_CFG, 0x00 },
122 { ADCX140_DEV_STS0, 0x00 },
123 { ADCX140_DEV_STS1, 0x80 },
128 .range_min = 0,
131 .selector_mask = 0xff,
132 .selector_shift = 0,
133 .window_start = 0,
163 /* Digital Volume control. From -100 to 27 dB in 0.5 dB steps */
164 static DECLARE_TLV_DB_SCALE(dig_vol_tlv, -10050, 50, 0);
166 /* ADC gain. From 0 to 42 dB in 1 dB steps */
167 static DECLARE_TLV_DB_SCALE(adc_tlv, 0, 100, 0);
169 /* DRE Level. From -12 dB to -66 dB in 1 dB steps */
170 static DECLARE_TLV_DB_SCALE(dre_thresh_tlv, -6600, 100, 0);
172 static DECLARE_TLV_DB_SCALE(dre_gain_tlv, 200, 200, 0);
174 /* AGC Level. From -6 dB to -36 dB in 2 dB steps */
175 static DECLARE_TLV_DB_SCALE(agc_thresh_tlv, -3600, 200, 0);
177 static DECLARE_TLV_DB_SCALE(agc_gain_tlv, 300, 300, 0);
180 "Linear Phase", "Low Latency", "Ultra-low Latency"
194 static SOC_ENUM_SINGLE_DECL(pdmclk_select_enum, ADCX140_PDMCLK_CFG, 0,
221 SOC_DAPM_ENUM("CH3 Resistor Select", in3_resistor_enum),
316 SOC_DAPM_SINGLE("Switch", ADCX140_ASI_OUT_CH_EN, 7, 1, 0);
318 SOC_DAPM_SINGLE("Switch", ADCX140_ASI_OUT_CH_EN, 6, 1, 0);
320 SOC_DAPM_SINGLE("Switch", ADCX140_ASI_OUT_CH_EN, 5, 1, 0);
322 SOC_DAPM_SINGLE("Switch", ADCX140_ASI_OUT_CH_EN, 4, 1, 0);
324 SOC_DAPM_SINGLE("Switch", ADCX140_ASI_OUT_CH_EN, 3, 1, 0);
326 SOC_DAPM_SINGLE("Switch", ADCX140_ASI_OUT_CH_EN, 2, 1, 0);
328 SOC_DAPM_SINGLE("Switch", ADCX140_ASI_OUT_CH_EN, 1, 1, 0);
330 SOC_DAPM_SINGLE("Switch", ADCX140_ASI_OUT_CH_EN, 0, 1, 0);
333 SOC_DAPM_SINGLE("Switch", ADCX140_CH1_CFG0, 0, 1, 0);
335 SOC_DAPM_SINGLE("Switch", ADCX140_CH2_CFG0, 0, 1, 0);
337 SOC_DAPM_SINGLE("Switch", ADCX140_CH3_CFG0, 0, 1, 0);
339 SOC_DAPM_SINGLE("Switch", ADCX140_CH4_CFG0, 0, 1, 0);
342 SOC_DAPM_SINGLE("Switch", ADCX140_DSP_CFG1, 3, 1, 0);
346 SOC_DAPM_SINGLE("Digital CH1 Switch", 0, 0, 0, 0),
347 SOC_DAPM_SINGLE("Digital CH2 Switch", 0, 0, 0, 0),
348 SOC_DAPM_SINGLE("Digital CH3 Switch", 0, 0, 0, 0),
349 SOC_DAPM_SINGLE("Digital CH4 Switch", 0, 0, 0, 0),
372 SND_SOC_DAPM_MIXER("Output Mixer", SND_SOC_NOPM, 0, 0,
373 &adcx140_output_mixer_controls[0],
377 SND_SOC_DAPM_MUX("MIC1P Input Mux", SND_SOC_NOPM, 0, 0,
379 SND_SOC_DAPM_MUX("MIC2P Input Mux", SND_SOC_NOPM, 0, 0,
381 SND_SOC_DAPM_MUX("MIC3P Input Mux", SND_SOC_NOPM, 0, 0,
383 SND_SOC_DAPM_MUX("MIC4P Input Mux", SND_SOC_NOPM, 0, 0,
387 SND_SOC_DAPM_MUX("MIC1 Analog Mux", SND_SOC_NOPM, 0, 0,
389 SND_SOC_DAPM_MUX("MIC2 Analog Mux", SND_SOC_NOPM, 0, 0,
391 SND_SOC_DAPM_MUX("MIC3 Analog Mux", SND_SOC_NOPM, 0, 0,
393 SND_SOC_DAPM_MUX("MIC4 Analog Mux", SND_SOC_NOPM, 0, 0,
396 SND_SOC_DAPM_MUX("MIC1M Input Mux", SND_SOC_NOPM, 0, 0,
398 SND_SOC_DAPM_MUX("MIC2M Input Mux", SND_SOC_NOPM, 0, 0,
400 SND_SOC_DAPM_MUX("MIC3M Input Mux", SND_SOC_NOPM, 0, 0,
402 SND_SOC_DAPM_MUX("MIC4M Input Mux", SND_SOC_NOPM, 0, 0,
405 SND_SOC_DAPM_PGA("MIC_GAIN_CTL_CH1", SND_SOC_NOPM, 0, 0, NULL, 0),
406 SND_SOC_DAPM_PGA("MIC_GAIN_CTL_CH2", SND_SOC_NOPM, 0, 0, NULL, 0),
407 SND_SOC_DAPM_PGA("MIC_GAIN_CTL_CH3", SND_SOC_NOPM, 0, 0, NULL, 0),
408 SND_SOC_DAPM_PGA("MIC_GAIN_CTL_CH4", SND_SOC_NOPM, 0, 0, NULL, 0),
410 SND_SOC_DAPM_ADC("CH1_ADC", "CH1 Capture", ADCX140_IN_CH_EN, 7, 0),
411 SND_SOC_DAPM_ADC("CH2_ADC", "CH2 Capture", ADCX140_IN_CH_EN, 6, 0),
412 SND_SOC_DAPM_ADC("CH3_ADC", "CH3 Capture", ADCX140_IN_CH_EN, 5, 0),
413 SND_SOC_DAPM_ADC("CH4_ADC", "CH4 Capture", ADCX140_IN_CH_EN, 4, 0),
415 SND_SOC_DAPM_ADC("CH1_DIG", "CH1 Capture", ADCX140_IN_CH_EN, 7, 0),
416 SND_SOC_DAPM_ADC("CH2_DIG", "CH2 Capture", ADCX140_IN_CH_EN, 6, 0),
417 SND_SOC_DAPM_ADC("CH3_DIG", "CH3 Capture", ADCX140_IN_CH_EN, 5, 0),
418 SND_SOC_DAPM_ADC("CH4_DIG", "CH4 Capture", ADCX140_IN_CH_EN, 4, 0),
419 SND_SOC_DAPM_ADC("CH5_DIG", "CH5 Capture", ADCX140_IN_CH_EN, 3, 0),
420 SND_SOC_DAPM_ADC("CH6_DIG", "CH6 Capture", ADCX140_IN_CH_EN, 2, 0),
421 SND_SOC_DAPM_ADC("CH7_DIG", "CH7 Capture", ADCX140_IN_CH_EN, 1, 0),
422 SND_SOC_DAPM_ADC("CH8_DIG", "CH8 Capture", ADCX140_IN_CH_EN, 0, 0),
425 SND_SOC_DAPM_SWITCH("CH1_ASI_EN", SND_SOC_NOPM, 0, 0,
427 SND_SOC_DAPM_SWITCH("CH2_ASI_EN", SND_SOC_NOPM, 0, 0,
429 SND_SOC_DAPM_SWITCH("CH3_ASI_EN", SND_SOC_NOPM, 0, 0,
431 SND_SOC_DAPM_SWITCH("CH4_ASI_EN", SND_SOC_NOPM, 0, 0,
434 SND_SOC_DAPM_SWITCH("CH5_ASI_EN", SND_SOC_NOPM, 0, 0,
436 SND_SOC_DAPM_SWITCH("CH6_ASI_EN", SND_SOC_NOPM, 0, 0,
438 SND_SOC_DAPM_SWITCH("CH7_ASI_EN", SND_SOC_NOPM, 0, 0,
440 SND_SOC_DAPM_SWITCH("CH8_ASI_EN", SND_SOC_NOPM, 0, 0,
443 SND_SOC_DAPM_SWITCH("DRE_ENABLE", SND_SOC_NOPM, 0, 0,
446 SND_SOC_DAPM_SWITCH("CH1_DRE_EN", SND_SOC_NOPM, 0, 0,
448 SND_SOC_DAPM_SWITCH("CH2_DRE_EN", SND_SOC_NOPM, 0, 0,
450 SND_SOC_DAPM_SWITCH("CH3_DRE_EN", SND_SOC_NOPM, 0, 0,
452 SND_SOC_DAPM_SWITCH("CH4_DRE_EN", SND_SOC_NOPM, 0, 0,
455 SND_SOC_DAPM_MUX("IN1 Analog Mic Resistor", SND_SOC_NOPM, 0, 0,
457 SND_SOC_DAPM_MUX("IN2 Analog Mic Resistor", SND_SOC_NOPM, 0, 0,
459 SND_SOC_DAPM_MUX("IN3 Analog Mic Resistor", SND_SOC_NOPM, 0, 0,
461 SND_SOC_DAPM_MUX("IN4 Analog Mic Resistor", SND_SOC_NOPM, 0, 0,
464 SND_SOC_DAPM_MUX("PDM Clk Div Select", SND_SOC_NOPM, 0, 0,
467 SND_SOC_DAPM_MUX("Decimation Filter", SND_SOC_NOPM, 0, 0,
499 {"Decimation Filter", "Ultra-low Latency", "DRE_ENABLE"},
606 uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN; in adcx140_phase_calib_info()
607 uinfo->count = 1; in adcx140_phase_calib_info()
608 uinfo->value.integer.min = 0; in adcx140_phase_calib_info()
609 uinfo->value.integer.max = 1; in adcx140_phase_calib_info()
610 return 0; in adcx140_phase_calib_info()
620 value->value.integer.value[0] = adcx140->phase_calib_on ? 1 : 0; in adcx140_phase_calib_get()
623 return 0; in adcx140_phase_calib_get()
633 bool v = value->value.integer.value[0] ? true : false; in adcx140_phase_calib_put()
635 if (adcx140->phase_calib_on != v) { in adcx140_phase_calib_put()
636 adcx140->phase_calib_on = v; in adcx140_phase_calib_put()
639 return 0; in adcx140_phase_calib_put()
643 SOC_SINGLE_TLV("Analog CH1 Mic Gain Volume", ADCX140_CH1_CFG1, 2, 42, 0,
645 SOC_SINGLE_TLV("Analog CH2 Mic Gain Volume", ADCX140_CH2_CFG1, 2, 42, 0,
647 SOC_SINGLE_TLV("Analog CH3 Mic Gain Volume", ADCX140_CH3_CFG1, 2, 42, 0,
649 SOC_SINGLE_TLV("Analog CH4 Mic Gain Volume", ADCX140_CH4_CFG1, 2, 42, 0,
652 SOC_SINGLE_TLV("DRE Threshold", ADCX140_DRE_CFG0, 4, 9, 0,
654 SOC_SINGLE_TLV("DRE Max Gain", ADCX140_DRE_CFG0, 0, 12, 0,
657 SOC_SINGLE_TLV("AGC Threshold", ADCX140_AGC_CFG0, 4, 15, 0,
659 SOC_SINGLE_TLV("AGC Max Gain", ADCX140_AGC_CFG0, 0, 13, 0,
663 0, 0xff, 0, dig_vol_tlv),
665 0, 0xff, 0, dig_vol_tlv),
666 SOC_SINGLE_TLV("Digital CH3 Out Volume", ADCX140_CH3_CFG2,
667 0, 0xff, 0, dig_vol_tlv),
669 0, 0xff, 0, dig_vol_tlv),
671 0, 0xff, 0, dig_vol_tlv),
673 0, 0xff, 0, dig_vol_tlv),
675 0, 0xff, 0, dig_vol_tlv),
677 0, 0xff, 0, dig_vol_tlv),
683 int ret = 0; in adcx140_reset()
685 if (adcx140->gpio_reset) { in adcx140_reset()
686 gpiod_direction_output(adcx140->gpio_reset, 0); in adcx140_reset()
689 gpiod_direction_output(adcx140->gpio_reset, 1); in adcx140_reset()
691 ret = regmap_write(adcx140->regmap, ADCX140_SW_RESET, in adcx140_reset()
703 int pwr_ctrl = 0; in adcx140_pwr_ctrl()
704 int ret = 0; in adcx140_pwr_ctrl()
705 struct snd_soc_component *component = adcx140->component; in adcx140_pwr_ctrl()
710 if (adcx140->micbias_vg && power_state) in adcx140_pwr_ctrl()
714 ret = regmap_write(adcx140->regmap, ADCX140_PHASE_CALIB, in adcx140_pwr_ctrl()
715 adcx140->phase_calib_on ? 0x00 : 0x40); in adcx140_pwr_ctrl()
717 dev_err(component->dev, "%s: register write error %d\n", in adcx140_pwr_ctrl()
721 regmap_update_bits(adcx140->regmap, ADCX140_PWR_CFG, in adcx140_pwr_ctrl()
729 struct snd_soc_component *component = dai->component; in adcx140_hw_params()
731 u8 data = 0; in adcx140_hw_params()
747 dev_err(component->dev, "%s: Unsupported width %d\n", in adcx140_hw_params()
749 return -EINVAL; in adcx140_hw_params()
759 return 0; in adcx140_hw_params()
765 struct snd_soc_component *component = codec_dai->component; in adcx140_set_dai_fmt()
767 u8 iface_reg1 = 0; in adcx140_set_dai_fmt()
768 u8 iface_reg2 = 0; in adcx140_set_dai_fmt()
769 int offset = 0; in adcx140_set_dai_fmt()
780 dev_err(component->dev, "Invalid DAI clock provider\n"); in adcx140_set_dai_fmt()
781 return -EINVAL; in adcx140_set_dai_fmt()
800 dev_err(component->dev, "Invalid DAI interface format\n"); in adcx140_set_dai_fmt()
801 return -EINVAL; in adcx140_set_dai_fmt()
816 dev_err(component->dev, "Invalid DAI clock signal polarity\n"); in adcx140_set_dai_fmt()
817 return -EINVAL; in adcx140_set_dai_fmt()
823 adcx140->dai_fmt = fmt & SND_SOC_DAIFMT_FORMAT_MASK; in adcx140_set_dai_fmt()
841 return 0; in adcx140_set_dai_fmt()
848 struct snd_soc_component *component = codec_dai->component; in adcx140_set_dai_tdm_slot()
855 if (tx_mask != GENMASK(__fls(tx_mask), 0)) { in adcx140_set_dai_tdm_slot()
856 dev_err(component->dev, "Only lower adjacent slots are supported\n"); in adcx140_set_dai_tdm_slot()
857 return -EINVAL; in adcx140_set_dai_tdm_slot()
867 dev_err(component->dev, "Unsupported slot width %d\n", slot_width); in adcx140_set_dai_tdm_slot()
868 return -EINVAL; in adcx140_set_dai_tdm_slot()
871 adcx140->slot_width = slot_width; in adcx140_set_dai_tdm_slot()
873 return 0; in adcx140_set_dai_tdm_slot()
885 u32 gpo_output_val = 0; in adcx140_configure_gpo()
889 for (i = 0; i < ADCX140_NUM_GPOS; i++) { in adcx140_configure_gpo()
890 ret = device_property_read_u32_array(adcx140->dev, in adcx140_configure_gpo()
897 if (gpo_outputs[0] > ADCX140_GPO_CFG_MAX) { in adcx140_configure_gpo()
898 dev_err(adcx140->dev, "GPO%d config out of range\n", i + 1); in adcx140_configure_gpo()
899 return -EINVAL; in adcx140_configure_gpo()
903 dev_err(adcx140->dev, "GPO%d drive out of range\n", i + 1); in adcx140_configure_gpo()
904 return -EINVAL; in adcx140_configure_gpo()
907 gpo_output_val = gpo_outputs[0] << ADCX140_GPO_SHIFT | in adcx140_configure_gpo()
909 ret = regmap_write(adcx140->regmap, ADCX140_GPO_CFG0 + i, in adcx140_configure_gpo()
915 return 0; in adcx140_configure_gpo()
921 int gpio_count = 0; in adcx140_configure_gpio()
923 u32 gpio_output_val = 0; in adcx140_configure_gpio()
926 gpio_count = device_property_count_u32(adcx140->dev, in adcx140_configure_gpio()
927 "ti,gpio-config"); in adcx140_configure_gpio()
928 if (gpio_count == 0) in adcx140_configure_gpio()
929 return 0; in adcx140_configure_gpio()
932 return -EINVAL; in adcx140_configure_gpio()
934 ret = device_property_read_u32_array(adcx140->dev, "ti,gpio-config", in adcx140_configure_gpio()
939 if (gpio_outputs[0] > ADCX140_GPIO_CFG_MAX) { in adcx140_configure_gpio()
940 dev_err(adcx140->dev, "GPIO config out of range\n"); in adcx140_configure_gpio()
941 return -EINVAL; in adcx140_configure_gpio()
945 dev_err(adcx140->dev, "GPIO drive out of range\n"); in adcx140_configure_gpio()
946 return -EINVAL; in adcx140_configure_gpio()
949 gpio_output_val = gpio_outputs[0] << ADCX140_GPIO_SHIFT in adcx140_configure_gpio()
952 return regmap_write(adcx140->regmap, ADCX140_GPIO_CFG0, gpio_output_val); in adcx140_configure_gpio()
964 u32 pdm_edge_val = 0; in adcx140_codec_probe()
967 u32 gpi_input_val = 0; in adcx140_codec_probe()
972 ret = device_property_read_u32(adcx140->dev, "ti,mic-bias-source", in adcx140_codec_probe()
976 adcx140->micbias_vg = false; in adcx140_codec_probe()
978 adcx140->micbias_vg = true; in adcx140_codec_probe()
981 ret = device_property_read_u32(adcx140->dev, "ti,vref-source", in adcx140_codec_probe()
987 dev_err(adcx140->dev, "Mic Bias source value is invalid\n"); in adcx140_codec_probe()
988 return -EINVAL; in adcx140_codec_probe()
997 if (adcx140->supply_areg == NULL) in adcx140_codec_probe()
1000 ret = regmap_write(adcx140->regmap, ADCX140_SLEEP_CFG, sleep_cfg_val); in adcx140_codec_probe()
1002 dev_err(adcx140->dev, "setting sleep config failed %d\n", ret); in adcx140_codec_probe()
1009 pdm_count = device_property_count_u32(adcx140->dev, in adcx140_codec_probe()
1010 "ti,pdm-edge-select"); in adcx140_codec_probe()
1011 if (pdm_count <= ADCX140_NUM_PDM_EDGES && pdm_count > 0) { in adcx140_codec_probe()
1012 ret = device_property_read_u32_array(adcx140->dev, in adcx140_codec_probe()
1013 "ti,pdm-edge-select", in adcx140_codec_probe()
1018 for (i = 0; i < pdm_count; i++) in adcx140_codec_probe()
1019 pdm_edge_val |= pdm_edges[i] << (ADCX140_PDM_EDGE_SHIFT - i); in adcx140_codec_probe()
1021 ret = regmap_write(adcx140->regmap, ADCX140_PDM_CFG, in adcx140_codec_probe()
1027 gpi_count = device_property_count_u32(adcx140->dev, "ti,gpi-config"); in adcx140_codec_probe()
1028 if (gpi_count <= ADCX140_NUM_GPI_PINS && gpi_count > 0) { in adcx140_codec_probe()
1029 ret = device_property_read_u32_array(adcx140->dev, in adcx140_codec_probe()
1030 "ti,gpi-config", in adcx140_codec_probe()
1038 ret = regmap_write(adcx140->regmap, ADCX140_GPI_CFG0, in adcx140_codec_probe()
1046 ret = regmap_write(adcx140->regmap, ADCX140_GPI_CFG1, in adcx140_codec_probe()
1060 ret = regmap_update_bits(adcx140->regmap, ADCX140_BIAS_CFG, in adcx140_codec_probe()
1064 dev_err(adcx140->dev, "setting MIC bias failed %d\n", ret); in adcx140_codec_probe()
1066 tx_high_z = device_property_read_bool(adcx140->dev, "ti,asi-tx-drive"); in adcx140_codec_probe()
1068 ret = regmap_update_bits(adcx140->regmap, ADCX140_ASI_CFG0, in adcx140_codec_probe()
1071 dev_err(adcx140->dev, "Setting Tx drive failed %d\n", ret); in adcx140_codec_probe()
1097 return 0; in adcx140_set_bias_level()
1110 .idle_bias_on = 0,
1117 .name = "tlv320adcx140-codec",
1144 regulator_disable(adcx140->supply_areg); in adcx140_disable_regulator()
1152 adcx140 = devm_kzalloc(&i2c->dev, sizeof(*adcx140), GFP_KERNEL); in adcx140_i2c_probe()
1154 return -ENOMEM; in adcx140_i2c_probe()
1156 adcx140->phase_calib_on = false; in adcx140_i2c_probe()
1157 adcx140->dev = &i2c->dev; in adcx140_i2c_probe()
1159 adcx140->gpio_reset = devm_gpiod_get_optional(adcx140->dev, in adcx140_i2c_probe()
1161 if (IS_ERR(adcx140->gpio_reset)) in adcx140_i2c_probe()
1162 dev_info(&i2c->dev, "Reset GPIO not defined\n"); in adcx140_i2c_probe()
1164 adcx140->supply_areg = devm_regulator_get_optional(adcx140->dev, in adcx140_i2c_probe()
1166 if (IS_ERR(adcx140->supply_areg)) { in adcx140_i2c_probe()
1167 if (PTR_ERR(adcx140->supply_areg) == -EPROBE_DEFER) in adcx140_i2c_probe()
1168 return -EPROBE_DEFER; in adcx140_i2c_probe()
1170 adcx140->supply_areg = NULL; in adcx140_i2c_probe()
1172 ret = regulator_enable(adcx140->supply_areg); in adcx140_i2c_probe()
1174 dev_err(adcx140->dev, "Failed to enable areg\n"); in adcx140_i2c_probe()
1178 ret = devm_add_action_or_reset(&i2c->dev, adcx140_disable_regulator, adcx140); in adcx140_i2c_probe()
1183 adcx140->regmap = devm_regmap_init_i2c(i2c, &adcx140_i2c_regmap); in adcx140_i2c_probe()
1184 if (IS_ERR(adcx140->regmap)) { in adcx140_i2c_probe()
1185 ret = PTR_ERR(adcx140->regmap); in adcx140_i2c_probe()
1186 dev_err(&i2c->dev, "Failed to allocate register map: %d\n", in adcx140_i2c_probe()
1193 return devm_snd_soc_register_component(&i2c->dev, in adcx140_i2c_probe()
1199 { "tlv320adc3140", 0 },
1208 .name = "tlv320adcx140-codec",