Lines Matching +full:dai +full:- +full:tdm +full:- +full:slot +full:- +full:rx +full:- +full:mask

1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (C) ST-Ericsson SA 2012
8 * for ST-Ericsson.
14 * for ST-Ericsson.
29 #include <linux/mfd/abx500/ab8500-sysctrl.h>
30 #include <linux/mfd/abx500/ab8500-codec.h>
39 #include <sound/soc-dapm.h>
42 #include "ab8500-codec.h"
56 /* Nr of FIR/IIR-coeff banks in ANC-block */
114 /* Private data for AB8500 device-driver */
157 /* Read a register from the audio-bank of AB8500 */
172 /* Write to a register in the audio-bank of AB8500 */
188 * Controls - DAPM
215 /* Speaker Left - ANC selector */
223 /* Speaker Right - ANC selector */
232 /* Mic 1 - Mic 1a or 1b selector */
240 /* Mic 1 - AD3 - Mic 1 or DMic 3 selector */
248 /* Mic 1 - AD6 - Mic 1 or DMic 6 selector */
258 /* Mic 2 - AD5 - Mic 2 or DMic 5 selector */
268 /* LineIn left - AD1 - LineIn Left or DMic 1 selector */
276 /* LineIn right - Mic 2 or LineIn Right selector */
284 /* LineIn right - AD2 - LineIn Right or DMic2 selector */
303 /* ANC - Enable/Disable */
309 /* ANC to Earpiece - Mute */
319 /* Sidetone left - Input selector */
331 /* Sidetone right - Input selector */
360 * DAPM-widgets
369 SND_SOC_DAPM_REGULATOR_SUPPLY("V-AUD", 0, 0),
370 SND_SOC_DAPM_REGULATOR_SUPPLY("V-AMIC1", 0, 0),
371 SND_SOC_DAPM_REGULATOR_SUPPLY("V-AMIC2", 0, 0),
372 SND_SOC_DAPM_REGULATOR_SUPPLY("V-DMIC", 0, 0),
571 SND_SOC_DAPM_MIXER("MIC1A V-AMICx Enable",
574 SND_SOC_DAPM_MIXER("MIC1B V-AMICx Enable",
596 SND_SOC_DAPM_MIXER("MIC2 V-AMICx Enable", AB8500_ANACONF2,
741 * DAPM-routes
744 /* Power AB8500 audio-block when AD/DA is active */
745 {"Main Supply", NULL, "V-AUD"},
882 {"MIC2 V-AMICx Enable", NULL, "Mic 2"},
893 {"Mic 2 or LINR Select", "Mic 2", "MIC2 V-AMICx Enable"},
916 {"MIC1A V-AMICx Enable", NULL, "MIC1 Mute"},
917 {"MIC1B V-AMICx Enable", NULL, "MIC1 Mute"},
919 {"Mic 1a or 1b Select", "Mic 1a", "MIC1A V-AMICx Enable"},
920 {"Mic 1a or 1b Select", "Mic 1b", "MIC1B V-AMICx Enable"},
951 {"DMic 1", NULL, "V-DMIC"},
952 {"DMic 2", NULL, "V-DMIC"},
953 {"DMic 3", NULL, "V-DMIC"},
954 {"DMic 4", NULL, "V-DMIC"},
955 {"DMic 5", NULL, "V-DMIC"},
956 {"DMic 6", NULL, "V-DMIC"},
1013 {"MIC1A V-AMICx Enable", NULL, "V-AMIC1"},
1014 {"MIC1A V-AMICx Enable", NULL, "V-AMIC2"},
1018 {"MIC1B V-AMICx Enable", NULL, "V-AMIC1"},
1019 {"MIC1B V-AMICx Enable", NULL, "V-AMIC2"},
1023 {"MIC2 V-AMICx Enable", NULL, "V-AMIC1"},
1024 {"MIC2 V-AMICx Enable", NULL, "V-AMIC2"},
1027 /* ANC FIR-coefficients configuration sequence */
1039 if (par == AB8500_ANC_FIR_COEFFS - 1 && bnk == 1) in anc_fir()
1044 /* ANC IIR-coefficients configuration sequence */
1070 if (par == AB8500_ANC_IIR_COEFFS - 1 && bnk == 1) in anc_iir()
1075 /* ANC IIR-/FIR-coefficients configuration sequence */
1079 struct ab8500_codec_drvdata *drvdata = dev_get_drvdata(component->dev); in anc_configure()
1082 dev_dbg(component->dev, "%s: Enter.\n", __func__); in anc_configure()
1095 drvdata->anc_fir_values[par]); in anc_configure()
1103 drvdata->anc_iir_values[par]); in anc_configure()
1107 dev_dbg(component->dev, "%s: Exit.\n", __func__); in anc_configure()
1111 * Control-events
1118 struct ab8500_codec_drvdata *drvdata = dev_get_drvdata(component->dev); in sid_status_control_get()
1120 mutex_lock(&drvdata->ctrl_lock); in sid_status_control_get()
1121 ucontrol->value.enumerated.item[0] = drvdata->sid_status; in sid_status_control_get()
1122 mutex_unlock(&drvdata->ctrl_lock); in sid_status_control_get()
1127 /* Write sidetone FIR-coefficients configuration sequence */
1132 struct ab8500_codec_drvdata *drvdata = dev_get_drvdata(component->dev); in sid_status_control_put()
1136 dev_dbg(component->dev, "%s: Enter\n", __func__); in sid_status_control_put()
1138 if (ucontrol->value.enumerated.item[0] != SID_APPLY_FIR) { in sid_status_control_put()
1139 dev_err(component->dev, in sid_status_control_put()
1142 return -EIO; in sid_status_control_put()
1145 mutex_lock(&drvdata->ctrl_lock); in sid_status_control_put()
1150 dev_err(component->dev, "%s: Sidetone busy while off!\n", in sid_status_control_put()
1152 status = -EPERM; in sid_status_control_put()
1154 status = -EBUSY; in sid_status_control_put()
1162 val = snd_soc_component_read(component, drvdata->sid_fir_values[param]); in sid_status_control_put()
1173 drvdata->sid_status = SID_FIR_CONFIGURED; in sid_status_control_put()
1176 mutex_unlock(&drvdata->ctrl_lock); in sid_status_control_put()
1178 dev_dbg(component->dev, "%s: Exit\n", __func__); in sid_status_control_put()
1187 struct ab8500_codec_drvdata *drvdata = dev_get_drvdata(component->dev); in anc_status_control_get()
1189 mutex_lock(&drvdata->ctrl_lock); in anc_status_control_get()
1190 ucontrol->value.enumerated.item[0] = drvdata->anc_status; in anc_status_control_get()
1191 mutex_unlock(&drvdata->ctrl_lock); in anc_status_control_get()
1201 struct ab8500_codec_drvdata *drvdata = dev_get_drvdata(component->dev); in anc_status_control_put()
1202 struct device *dev = component->dev; in anc_status_control_put()
1209 mutex_lock(&drvdata->ctrl_lock); in anc_status_control_put()
1211 req = ucontrol->value.enumerated.item[0]; in anc_status_control_put()
1213 status = -EINVAL; in anc_status_control_put()
1220 status = -EINVAL; in anc_status_control_put()
1238 if (drvdata->anc_status == ANC_IIR_CONFIGURED) in anc_status_control_put()
1239 drvdata->anc_status = ANC_FIR_IIR_CONFIGURED; in anc_status_control_put()
1240 else if (drvdata->anc_status != ANC_FIR_IIR_CONFIGURED) in anc_status_control_put()
1241 drvdata->anc_status = ANC_FIR_CONFIGURED; in anc_status_control_put()
1244 if (drvdata->anc_status == ANC_FIR_CONFIGURED) in anc_status_control_put()
1245 drvdata->anc_status = ANC_FIR_IIR_CONFIGURED; in anc_status_control_put()
1246 else if (drvdata->anc_status != ANC_FIR_IIR_CONFIGURED) in anc_status_control_put()
1247 drvdata->anc_status = ANC_IIR_CONFIGURED; in anc_status_control_put()
1254 mutex_unlock(&drvdata->ctrl_lock); in anc_status_control_put()
1269 (struct filter_control *)kcontrol->private_value; in filter_control_info()
1271 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; in filter_control_info()
1272 uinfo->count = fc->count; in filter_control_info()
1273 uinfo->value.integer.min = fc->min; in filter_control_info()
1274 uinfo->value.integer.max = fc->max; in filter_control_info()
1285 (struct filter_control *)kcontrol->private_value; in filter_control_get()
1288 mutex_lock(&drvdata->ctrl_lock); in filter_control_get()
1289 for (i = 0; i < fc->count; i++) in filter_control_get()
1290 ucontrol->value.integer.value[i] = fc->value[i]; in filter_control_get()
1291 mutex_unlock(&drvdata->ctrl_lock); in filter_control_get()
1302 (struct filter_control *)kcontrol->private_value; in filter_control_put()
1305 mutex_lock(&drvdata->ctrl_lock); in filter_control_put()
1306 for (i = 0; i < fc->count; i++) in filter_control_put()
1307 fc->value[i] = ucontrol->value.integer.value[i]; in filter_control_put()
1308 mutex_unlock(&drvdata->ctrl_lock); in filter_control_put()
1314 * Controls - Non-DAPM ASoC
1317 static DECLARE_TLV_DB_SCALE(adx_dig_gain_tlv, -3200, 100, 1);
1318 /* -32dB = Mute */
1320 static DECLARE_TLV_DB_SCALE(dax_dig_gain_tlv, -6300, 100, 1);
1321 /* -63dB = Mute */
1323 static DECLARE_TLV_DB_SCALE(hs_ear_dig_gain_tlv, -100, 100, 1);
1324 /* -1dB = Mute */
1327 0, 3, TLV_DB_SCALE_ITEM(-3200, 400, 0),
1328 4, 15, TLV_DB_SCALE_ITEM(-1800, 200, 0)
1333 static DECLARE_TLV_DB_SCALE(lin_gain_tlv, -1000, 200, 0);
1335 static DECLARE_TLV_DB_SCALE(lin2hs_gain_tlv, -3800, 200, 1);
1336 /* -38dB = Mute */
1410 /* Digital interface - DA from slot mapping */
1468 /* Digital interface - AD to slot mapping */
1582 /* Digital interface - Burst mode */
1772 /* Digital interface - DA from slot mapping */
1773 SOC_ENUM("Digital Interface DA 1 From Slot Map", soc_enum_da1slotmap),
1774 SOC_ENUM("Digital Interface DA 2 From Slot Map", soc_enum_da2slotmap),
1775 SOC_ENUM("Digital Interface DA 3 From Slot Map", soc_enum_da3slotmap),
1776 SOC_ENUM("Digital Interface DA 4 From Slot Map", soc_enum_da4slotmap),
1777 SOC_ENUM("Digital Interface DA 5 From Slot Map", soc_enum_da5slotmap),
1778 SOC_ENUM("Digital Interface DA 6 From Slot Map", soc_enum_da6slotmap),
1779 SOC_ENUM("Digital Interface DA 7 From Slot Map", soc_enum_da7slotmap),
1780 SOC_ENUM("Digital Interface DA 8 From Slot Map", soc_enum_da8slotmap),
1782 /* Digital interface - AD to slot mapping */
1783 SOC_ENUM("Digital Interface AD To Slot 0 Map", soc_enum_adslot0map),
1784 SOC_ENUM("Digital Interface AD To Slot 1 Map", soc_enum_adslot1map),
1785 SOC_ENUM("Digital Interface AD To Slot 2 Map", soc_enum_adslot2map),
1786 SOC_ENUM("Digital Interface AD To Slot 3 Map", soc_enum_adslot3map),
1787 SOC_ENUM("Digital Interface AD To Slot 4 Map", soc_enum_adslot4map),
1788 SOC_ENUM("Digital Interface AD To Slot 5 Map", soc_enum_adslot5map),
1789 SOC_ENUM("Digital Interface AD To Slot 6 Map", soc_enum_adslot6map),
1790 SOC_ENUM("Digital Interface AD To Slot 7 Map", soc_enum_adslot7map),
1791 SOC_ENUM("Digital Interface AD To Slot 8 Map", soc_enum_adslot8map),
1792 SOC_ENUM("Digital Interface AD To Slot 9 Map", soc_enum_adslot9map),
1793 SOC_ENUM("Digital Interface AD To Slot 10 Map", soc_enum_adslot10map),
1794 SOC_ENUM("Digital Interface AD To Slot 11 Map", soc_enum_adslot11map),
1795 SOC_ENUM("Digital Interface AD To Slot 12 Map", soc_enum_adslot12map),
1796 SOC_ENUM("Digital Interface AD To Slot 13 Map", soc_enum_adslot13map),
1797 SOC_ENUM("Digital Interface AD To Slot 14 Map", soc_enum_adslot14map),
1798 SOC_ENUM("Digital Interface AD To Slot 15 Map", soc_enum_adslot15map),
1799 SOC_ENUM("Digital Interface AD To Slot 16 Map", soc_enum_adslot16map),
1800 SOC_ENUM("Digital Interface AD To Slot 17 Map", soc_enum_adslot17map),
1801 SOC_ENUM("Digital Interface AD To Slot 18 Map", soc_enum_adslot18map),
1802 SOC_ENUM("Digital Interface AD To Slot 19 Map", soc_enum_adslot19map),
1803 SOC_ENUM("Digital Interface AD To Slot 20 Map", soc_enum_adslot20map),
1804 SOC_ENUM("Digital Interface AD To Slot 21 Map", soc_enum_adslot21map),
1805 SOC_ENUM("Digital Interface AD To Slot 22 Map", soc_enum_adslot22map),
1806 SOC_ENUM("Digital Interface AD To Slot 23 Map", soc_enum_adslot23map),
1807 SOC_ENUM("Digital Interface AD To Slot 24 Map", soc_enum_adslot24map),
1808 SOC_ENUM("Digital Interface AD To Slot 25 Map", soc_enum_adslot25map),
1809 SOC_ENUM("Digital Interface AD To Slot 26 Map", soc_enum_adslot26map),
1810 SOC_ENUM("Digital Interface AD To Slot 27 Map", soc_enum_adslot27map),
1811 SOC_ENUM("Digital Interface AD To Slot 28 Map", soc_enum_adslot28map),
1812 SOC_ENUM("Digital Interface AD To Slot 29 Map", soc_enum_adslot29map),
1813 SOC_ENUM("Digital Interface AD To Slot 30 Map", soc_enum_adslot30map),
1814 SOC_ENUM("Digital Interface AD To Slot 31 Map", soc_enum_adslot31map),
1816 /* Digital interface - Loopback */
1842 /* Digital interface - Burst FIFO */
1846 SOC_ENUM("Burst FIFO Mask", soc_enum_bfifomask),
1847 SOC_ENUM("Burst FIFO Bit-clock Frequency", soc_enum_bfifo19m2),
1857 SOC_SINGLE("Burst FIFO FS Extra Bit-clocks",
1914 * Extended interface for codec-driver
1921 dev_dbg(component->dev, "%s: Enter.\n", __func__); in ab8500_audio_init_audioblock()
1923 /* Reset audio-registers and disable 32kHz-clock output 2 */ in ab8500_audio_init_audioblock()
1943 dev_dbg(component->dev, "%s: Enter.\n", __func__); in ab8500_audio_setup_mics()
1945 /* Set DMic-clocks to outputs */ in ab8500_audio_setup_mics()
1946 status = abx500_get_register_interruptible(component->dev, AB8500_MISC, in ab8500_audio_setup_mics()
1953 status = abx500_set_register_interruptible(component->dev, in ab8500_audio_setup_mics()
1960 /* Attach regulators to AMic DAPM-paths */ in ab8500_audio_setup_mics()
1961 dev_dbg(component->dev, "%s: Mic 1a regulator: %s\n", __func__, in ab8500_audio_setup_mics()
1962 amic_micbias_str(amics->mic1a_micbias)); in ab8500_audio_setup_mics()
1963 route = &ab8500_dapm_routes_mic1a_vamicx[amics->mic1a_micbias]; in ab8500_audio_setup_mics()
1965 dev_dbg(component->dev, "%s: Mic 1b regulator: %s\n", __func__, in ab8500_audio_setup_mics()
1966 amic_micbias_str(amics->mic1b_micbias)); in ab8500_audio_setup_mics()
1967 route = &ab8500_dapm_routes_mic1b_vamicx[amics->mic1b_micbias]; in ab8500_audio_setup_mics()
1969 dev_dbg(component->dev, "%s: Mic 2 regulator: %s\n", __func__, in ab8500_audio_setup_mics()
1970 amic_micbias_str(amics->mic2_micbias)); in ab8500_audio_setup_mics()
1971 route = &ab8500_dapm_routes_mic2_vamicx[amics->mic2_micbias]; in ab8500_audio_setup_mics()
1974 dev_err(component->dev, in ab8500_audio_setup_mics()
1975 "%s: Failed to add AMic-regulator DAPM-routes (%d).\n", in ab8500_audio_setup_mics()
1980 /* Set AMic-configuration */ in ab8500_audio_setup_mics()
1981 dev_dbg(component->dev, "%s: Mic 1 mic-type: %s\n", __func__, in ab8500_audio_setup_mics()
1982 amic_type_str(amics->mic1_type)); in ab8500_audio_setup_mics()
1984 amics->mic1_type == AMIC_TYPE_DIFFERENTIAL ? in ab8500_audio_setup_mics()
1986 dev_dbg(component->dev, "%s: Mic 2 mic-type: %s\n", __func__, in ab8500_audio_setup_mics()
1987 amic_type_str(amics->mic2_type)); in ab8500_audio_setup_mics()
1989 amics->mic2_type == AMIC_TYPE_DIFFERENTIAL ? in ab8500_audio_setup_mics()
2014 dev_err(component->dev, in ab8500_audio_set_ear_cmv()
2015 "%s: Unknown earpiece CM-voltage (%d)!\n", in ab8500_audio_set_ear_cmv()
2017 return -EINVAL; in ab8500_audio_set_ear_cmv()
2019 dev_dbg(component->dev, "%s: Earpiece CM-voltage: %s\n", __func__, in ab8500_audio_set_ear_cmv()
2027 static int ab8500_audio_set_bit_delay(struct snd_soc_dai *dai, in ab8500_audio_set_bit_delay() argument
2030 unsigned int mask, val; in ab8500_audio_set_bit_delay() local
2031 struct snd_soc_component *component = dai->component; in ab8500_audio_set_bit_delay()
2033 mask = BIT(AB8500_DIGIFCONF2_IF0DEL); in ab8500_audio_set_bit_delay()
2043 dev_err(dai->component->dev, in ab8500_audio_set_bit_delay()
2044 "%s: ERROR: Unsupported bit-delay (0x%x)!\n", in ab8500_audio_set_bit_delay()
2046 return -EINVAL; in ab8500_audio_set_bit_delay()
2049 dev_dbg(dai->component->dev, "%s: IF0 Bit-delay: %d bits.\n", in ab8500_audio_set_bit_delay()
2051 snd_soc_component_update_bits(component, AB8500_DIGIFCONF2, mask, val); in ab8500_audio_set_bit_delay()
2056 /* Gates clocking according format mask */
2060 unsigned int mask; in ab8500_codec_set_dai_clock_gate() local
2063 mask = BIT(AB8500_DIGIFCONF1_ENMASTGEN) | in ab8500_codec_set_dai_clock_gate()
2070 dev_dbg(component->dev, "%s: IF0 Clock is continuous.\n", in ab8500_codec_set_dai_clock_gate()
2075 dev_dbg(component->dev, "%s: IF0 Clock is gated.\n", in ab8500_codec_set_dai_clock_gate()
2079 dev_err(component->dev, in ab8500_codec_set_dai_clock_gate()
2080 "%s: ERROR: Unsupported clock mask (0x%x)!\n", in ab8500_codec_set_dai_clock_gate()
2082 return -EINVAL; in ab8500_codec_set_dai_clock_gate()
2085 snd_soc_component_update_bits(component, AB8500_DIGIFCONF1, mask, val); in ab8500_codec_set_dai_clock_gate()
2090 static int ab8500_codec_set_dai_fmt(struct snd_soc_dai *dai, unsigned int fmt) in ab8500_codec_set_dai_fmt() argument
2092 unsigned int mask; in ab8500_codec_set_dai_fmt() local
2094 struct snd_soc_component *component = dai->component; in ab8500_codec_set_dai_fmt()
2097 dev_dbg(component->dev, "%s: Enter (fmt = 0x%x)\n", __func__, fmt); in ab8500_codec_set_dai_fmt()
2099 mask = BIT(AB8500_DIGIFCONF3_IF1DATOIF0AD) | in ab8500_codec_set_dai_fmt()
2107 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_fmt()
2108 "%s: IF0 Master-mode: AB8500 provider.\n", __func__); in ab8500_codec_set_dai_fmt()
2112 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_fmt()
2113 "%s: IF0 Master-mode: AB8500 consumer.\n", __func__); in ab8500_codec_set_dai_fmt()
2117 dev_err(dai->component->dev, in ab8500_codec_set_dai_fmt()
2122 dev_err(dai->component->dev, in ab8500_codec_set_dai_fmt()
2123 "%s: ERROR: Unsupporter clocking mask 0x%x\n", in ab8500_codec_set_dai_fmt()
2125 return -EINVAL; in ab8500_codec_set_dai_fmt()
2128 snd_soc_component_update_bits(component, AB8500_DIGIFCONF3, mask, val); in ab8500_codec_set_dai_fmt()
2133 dev_err(dai->component->dev, in ab8500_codec_set_dai_fmt()
2141 mask = BIT(AB8500_DIGIFCONF2_IF0FORMAT0) | in ab8500_codec_set_dai_fmt()
2149 dev_dbg(dai->component->dev, "%s: IF0 Protocol: I2S\n", __func__); in ab8500_codec_set_dai_fmt()
2151 ab8500_audio_set_bit_delay(dai, 0); in ab8500_codec_set_dai_fmt()
2155 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_fmt()
2156 "%s: IF0 Protocol: DSP A (TDM)\n", __func__); in ab8500_codec_set_dai_fmt()
2158 ab8500_audio_set_bit_delay(dai, 1); in ab8500_codec_set_dai_fmt()
2162 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_fmt()
2163 "%s: IF0 Protocol: DSP B (TDM)\n", __func__); in ab8500_codec_set_dai_fmt()
2165 ab8500_audio_set_bit_delay(dai, 0); in ab8500_codec_set_dai_fmt()
2169 dev_err(dai->component->dev, in ab8500_codec_set_dai_fmt()
2172 return -EINVAL; in ab8500_codec_set_dai_fmt()
2177 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_fmt()
2182 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_fmt()
2188 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_fmt()
2194 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_fmt()
2201 dev_err(dai->component->dev, in ab8500_codec_set_dai_fmt()
2202 "%s: ERROR: Unsupported INV mask 0x%x\n", in ab8500_codec_set_dai_fmt()
2204 return -EINVAL; in ab8500_codec_set_dai_fmt()
2207 snd_soc_component_update_bits(component, AB8500_DIGIFCONF2, mask, val); in ab8500_codec_set_dai_fmt()
2212 static int ab8500_codec_set_dai_tdm_slot(struct snd_soc_dai *dai, in ab8500_codec_set_dai_tdm_slot() argument
2216 struct snd_soc_component *component = dai->component; in ab8500_codec_set_dai_tdm_slot()
2217 unsigned int val, mask, slot, slots_active; in ab8500_codec_set_dai_tdm_slot() local
2219 mask = BIT(AB8500_DIGIFCONF2_IF0WL0) | in ab8500_codec_set_dai_tdm_slot()
2237 dev_err(dai->component->dev, "%s: Unsupported slot-width 0x%x\n", in ab8500_codec_set_dai_tdm_slot()
2239 return -EINVAL; in ab8500_codec_set_dai_tdm_slot()
2242 dev_dbg(dai->component->dev, "%s: IF0 slot-width: %d bits.\n", in ab8500_codec_set_dai_tdm_slot()
2244 snd_soc_component_update_bits(component, AB8500_DIGIFCONF2, mask, val); in ab8500_codec_set_dai_tdm_slot()
2246 /* Setup TDM clocking according to slot count */ in ab8500_codec_set_dai_tdm_slot()
2247 dev_dbg(dai->component->dev, "%s: Slots, total: %d\n", __func__, slots); in ab8500_codec_set_dai_tdm_slot()
2248 mask = BIT(AB8500_DIGIFCONF1_IF0BITCLKOS0) | in ab8500_codec_set_dai_tdm_slot()
2265 dev_err(dai->component->dev, in ab8500_codec_set_dai_tdm_slot()
2268 return -EINVAL; in ab8500_codec_set_dai_tdm_slot()
2270 snd_soc_component_update_bits(component, AB8500_DIGIFCONF1, mask, val); in ab8500_codec_set_dai_tdm_slot()
2272 /* Setup TDM DA according to active tx slots */ in ab8500_codec_set_dai_tdm_slot()
2275 return -EINVAL; in ab8500_codec_set_dai_tdm_slot()
2277 mask = AB8500_DASLOTCONFX_SLTODAX_MASK; in ab8500_codec_set_dai_tdm_slot()
2281 dev_dbg(dai->component->dev, "%s: Slots, active, TX: %d\n", __func__, in ab8500_codec_set_dai_tdm_slot()
2288 slot = ffs(tx_mask); in ab8500_codec_set_dai_tdm_slot()
2289 snd_soc_component_update_bits(component, AB8500_DASLOTCONF1, mask, slot); in ab8500_codec_set_dai_tdm_slot()
2290 snd_soc_component_update_bits(component, AB8500_DASLOTCONF3, mask, slot); in ab8500_codec_set_dai_tdm_slot()
2291 snd_soc_component_update_bits(component, AB8500_DASLOTCONF2, mask, slot); in ab8500_codec_set_dai_tdm_slot()
2292 snd_soc_component_update_bits(component, AB8500_DASLOTCONF4, mask, slot); in ab8500_codec_set_dai_tdm_slot()
2295 slot = ffs(tx_mask); in ab8500_codec_set_dai_tdm_slot()
2296 snd_soc_component_update_bits(component, AB8500_DASLOTCONF1, mask, slot); in ab8500_codec_set_dai_tdm_slot()
2297 snd_soc_component_update_bits(component, AB8500_DASLOTCONF3, mask, slot); in ab8500_codec_set_dai_tdm_slot()
2298 slot = fls(tx_mask); in ab8500_codec_set_dai_tdm_slot()
2299 snd_soc_component_update_bits(component, AB8500_DASLOTCONF2, mask, slot); in ab8500_codec_set_dai_tdm_slot()
2300 snd_soc_component_update_bits(component, AB8500_DASLOTCONF4, mask, slot); in ab8500_codec_set_dai_tdm_slot()
2303 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_tdm_slot()
2304 "%s: In 8-channel mode DA-from-slot mapping is set manually.", in ab8500_codec_set_dai_tdm_slot()
2308 dev_err(dai->component->dev, in ab8500_codec_set_dai_tdm_slot()
2309 "%s: Unsupported number of active TX-slots (%d)!\n", in ab8500_codec_set_dai_tdm_slot()
2311 return -EINVAL; in ab8500_codec_set_dai_tdm_slot()
2314 /* Setup TDM AD according to active RX-slots */ in ab8500_codec_set_dai_tdm_slot()
2317 return -EINVAL; in ab8500_codec_set_dai_tdm_slot()
2322 dev_dbg(dai->component->dev, "%s: Slots, active, RX: %d\n", __func__, in ab8500_codec_set_dai_tdm_slot()
2329 slot = ffs(rx_mask); in ab8500_codec_set_dai_tdm_slot()
2330 snd_soc_component_update_bits(component, AB8500_ADSLOTSEL(slot), in ab8500_codec_set_dai_tdm_slot()
2331 AB8500_MASK_SLOT(slot), in ab8500_codec_set_dai_tdm_slot()
2332 AB8500_ADSLOTSELX_AD_OUT_TO_SLOT(AB8500_AD_OUT3, slot)); in ab8500_codec_set_dai_tdm_slot()
2335 slot = ffs(rx_mask); in ab8500_codec_set_dai_tdm_slot()
2337 AB8500_ADSLOTSEL(slot), in ab8500_codec_set_dai_tdm_slot()
2338 AB8500_MASK_SLOT(slot), in ab8500_codec_set_dai_tdm_slot()
2339 AB8500_ADSLOTSELX_AD_OUT_TO_SLOT(AB8500_AD_OUT3, slot)); in ab8500_codec_set_dai_tdm_slot()
2340 slot = fls(rx_mask); in ab8500_codec_set_dai_tdm_slot()
2342 AB8500_ADSLOTSEL(slot), in ab8500_codec_set_dai_tdm_slot()
2343 AB8500_MASK_SLOT(slot), in ab8500_codec_set_dai_tdm_slot()
2344 AB8500_ADSLOTSELX_AD_OUT_TO_SLOT(AB8500_AD_OUT2, slot)); in ab8500_codec_set_dai_tdm_slot()
2347 dev_dbg(dai->component->dev, in ab8500_codec_set_dai_tdm_slot()
2348 "%s: In 8-channel mode AD-to-slot mapping is set manually.", in ab8500_codec_set_dai_tdm_slot()
2352 dev_err(dai->component->dev, in ab8500_codec_set_dai_tdm_slot()
2353 "%s: Unsupported number of active RX-slots (%d)!\n", in ab8500_codec_set_dai_tdm_slot()
2355 return -EINVAL; in ab8500_codec_set_dai_tdm_slot()
2368 .name = "ab8500-codec-dai.0",
2381 .name = "ab8500-codec-dai.1",
2400 if (of_property_read_bool(np, "stericsson,amic1-type-single-ended")) in ab8500_codec_of_probe()
2401 codec->amics.mic1_type = AMIC_TYPE_SINGLE_ENDED; in ab8500_codec_of_probe()
2403 codec->amics.mic1_type = AMIC_TYPE_DIFFERENTIAL; in ab8500_codec_of_probe()
2405 if (of_property_read_bool(np, "stericsson,amic2-type-single-ended")) in ab8500_codec_of_probe()
2406 codec->amics.mic2_type = AMIC_TYPE_SINGLE_ENDED; in ab8500_codec_of_probe()
2408 codec->amics.mic2_type = AMIC_TYPE_DIFFERENTIAL; in ab8500_codec_of_probe()
2410 /* Has a non-standard Vamic been requested? */ in ab8500_codec_of_probe()
2411 if (of_property_read_bool(np, "stericsson,amic1a-bias-vamic2")) in ab8500_codec_of_probe()
2412 codec->amics.mic1a_micbias = AMIC_MICBIAS_VAMIC2; in ab8500_codec_of_probe()
2414 codec->amics.mic1a_micbias = AMIC_MICBIAS_VAMIC1; in ab8500_codec_of_probe()
2416 if (of_property_read_bool(np, "stericsson,amic1b-bias-vamic2")) in ab8500_codec_of_probe()
2417 codec->amics.mic1b_micbias = AMIC_MICBIAS_VAMIC2; in ab8500_codec_of_probe()
2419 codec->amics.mic1b_micbias = AMIC_MICBIAS_VAMIC1; in ab8500_codec_of_probe()
2421 if (of_property_read_bool(np, "stericsson,amic2-bias-vamic1")) in ab8500_codec_of_probe()
2422 codec->amics.mic2_micbias = AMIC_MICBIAS_VAMIC1; in ab8500_codec_of_probe()
2424 codec->amics.mic2_micbias = AMIC_MICBIAS_VAMIC2; in ab8500_codec_of_probe()
2426 if (!of_property_read_u32(np, "stericsson,earpeice-cmv", &value)) { in ab8500_codec_of_probe()
2429 codec->ear_cmv = EAR_CMV_0_95V; in ab8500_codec_of_probe()
2432 codec->ear_cmv = EAR_CMV_1_10V; in ab8500_codec_of_probe()
2435 codec->ear_cmv = EAR_CMV_1_27V; in ab8500_codec_of_probe()
2438 codec->ear_cmv = EAR_CMV_1_58V; in ab8500_codec_of_probe()
2441 codec->ear_cmv = EAR_CMV_UNKNOWN; in ab8500_codec_of_probe()
2445 dev_warn(dev, "No earpiece voltage found in DT - using default\n"); in ab8500_codec_of_probe()
2446 codec->ear_cmv = EAR_CMV_0_95V; in ab8500_codec_of_probe()
2453 struct device *dev = component->dev; in ab8500_codec_probe()
2454 struct device_node *np = dev->of_node; in ab8500_codec_probe()
2471 pr_err("%s: Failed to set earpiece CM-voltage (%d)!\n", in ab8500_codec_probe()
2478 dev_err(dev, "%s: failed to init audio-block (%d)!\n", in ab8500_codec_probe()
2483 /* Override HW-defaults */ in ab8500_codec_probe()
2500 drvdata->anc_fir_values = (long *)fc->value; in ab8500_codec_probe()
2503 drvdata->anc_iir_values = (long *)fc->value; in ab8500_codec_probe()
2506 drvdata->sid_fir_values = (long *)fc->value; in ab8500_codec_probe()
2510 mutex_init(&drvdata->ctrl_lock); in ab8500_codec_probe()
2533 dev_dbg(&pdev->dev, "%s: Enter.\n", __func__); in ab8500_codec_driver_probe()
2535 /* Create driver private-data struct */ in ab8500_codec_driver_probe()
2536 drvdata = devm_kzalloc(&pdev->dev, sizeof(struct ab8500_codec_drvdata), in ab8500_codec_driver_probe()
2539 return -ENOMEM; in ab8500_codec_driver_probe()
2540 drvdata->sid_status = SID_UNCONFIGURED; in ab8500_codec_driver_probe()
2541 drvdata->anc_status = ANC_UNCONFIGURED; in ab8500_codec_driver_probe()
2542 dev_set_drvdata(&pdev->dev, drvdata); in ab8500_codec_driver_probe()
2544 drvdata->regmap = devm_regmap_init(&pdev->dev, NULL, &pdev->dev, in ab8500_codec_driver_probe()
2546 if (IS_ERR(drvdata->regmap)) { in ab8500_codec_driver_probe()
2547 status = PTR_ERR(drvdata->regmap); in ab8500_codec_driver_probe()
2548 dev_err(&pdev->dev, "%s: Failed to allocate regmap: %d\n", in ab8500_codec_driver_probe()
2553 dev_dbg(&pdev->dev, "%s: Register codec.\n", __func__); in ab8500_codec_driver_probe()
2554 status = devm_snd_soc_register_component(&pdev->dev, in ab8500_codec_driver_probe()
2559 dev_err(&pdev->dev, in ab8500_codec_driver_probe()
2568 .name = "ab8500-codec",