Lines Matching +full:spkvdd +full:- +full:supply

1 // SPDX-License-Identifier: GPL-2.0-only
3 * wm2000.c -- WM2000 ALSA Soc Audio driver
5 * Copyright 2008-2011 Wolfson Microelectronics PLC.
13 * system-specific calibration information. If supplied as a
14 * sequence of ASCII-encoded hexidecimal bytes this can be converted
17 * perl -e 'while (<>) { s/[\r\n]+// ; printf("%c", hex($_)); }'
48 "SPKVDD",
85 return regmap_write(wm2000->regmap, reg, value); in wm2000_write()
90 struct i2c_client *i2c = wm2000->i2c; in wm2000_reset()
96 wm2000->anc_mode = ANC_OFF; in wm2000_reset()
106 regmap_read(wm2000->regmap, reg, &val); in wm2000_poll_bit()
108 while (!(val & mask) && --timeout) { in wm2000_poll_bit()
110 regmap_read(wm2000->regmap, reg, &val); in wm2000_poll_bit()
121 struct wm2000_priv *wm2000 = dev_get_drvdata(&i2c->dev); in wm2000_power_up()
126 if (WARN_ON(wm2000->anc_mode != ANC_OFF)) in wm2000_power_up()
127 return -EINVAL; in wm2000_power_up()
129 dev_dbg(&i2c->dev, "Beginning power up\n"); in wm2000_power_up()
131 ret = regulator_bulk_enable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_power_up()
133 dev_err(&i2c->dev, "Failed to enable supplies: %d\n", ret); in wm2000_power_up()
137 rate = clk_get_rate(wm2000->mclk); in wm2000_power_up()
139 dev_dbg(&i2c->dev, "Disabling MCLK divider\n"); in wm2000_power_up()
143 dev_dbg(&i2c->dev, "Enabling MCLK divider\n"); in wm2000_power_up()
154 dev_err(&i2c->dev, "ANC engine failed to reset\n"); in wm2000_power_up()
155 regulator_bulk_disable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_power_up()
156 return -ETIMEDOUT; in wm2000_power_up()
161 dev_err(&i2c->dev, "ANC engine failed to initialise\n"); in wm2000_power_up()
162 regulator_bulk_disable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_power_up()
163 return -ETIMEDOUT; in wm2000_power_up()
170 dev_dbg(&i2c->dev, "Downloading %d bytes\n", in wm2000_power_up()
171 wm2000->anc_download_size - 2); in wm2000_power_up()
173 ret = i2c_master_send(i2c, wm2000->anc_download, in wm2000_power_up()
174 wm2000->anc_download_size); in wm2000_power_up()
176 dev_err(&i2c->dev, "i2c_transfer() failed: %d\n", ret); in wm2000_power_up()
177 regulator_bulk_disable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_power_up()
180 if (ret != wm2000->anc_download_size) { in wm2000_power_up()
181 dev_err(&i2c->dev, "i2c_transfer() failed, %d != %d\n", in wm2000_power_up()
182 ret, wm2000->anc_download_size); in wm2000_power_up()
183 regulator_bulk_disable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_power_up()
184 return -EIO; in wm2000_power_up()
187 dev_dbg(&i2c->dev, "Download complete\n"); in wm2000_power_up()
202 ret = regmap_read(wm2000->regmap, WM2000_REG_SPEECH_CLARITY, &val); in wm2000_power_up()
204 dev_err(&i2c->dev, "Unable to read Speech Clarity: %d\n", ret); in wm2000_power_up()
205 regulator_bulk_disable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_power_up()
208 if (wm2000->speech_clarity) in wm2000_power_up()
221 dev_err(&i2c->dev, "Timed out waiting for device\n"); in wm2000_power_up()
222 regulator_bulk_disable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_power_up()
223 return -ETIMEDOUT; in wm2000_power_up()
226 dev_dbg(&i2c->dev, "ANC active\n"); in wm2000_power_up()
228 dev_dbg(&i2c->dev, "Analogue active\n"); in wm2000_power_up()
229 wm2000->anc_mode = ANC_ACTIVE; in wm2000_power_up()
236 struct wm2000_priv *wm2000 = dev_get_drvdata(&i2c->dev); in wm2000_power_down()
250 dev_err(&i2c->dev, "Timeout waiting for ANC power down\n"); in wm2000_power_down()
251 return -ETIMEDOUT; in wm2000_power_down()
256 dev_err(&i2c->dev, "Timeout waiting for ANC engine idle\n"); in wm2000_power_down()
257 return -ETIMEDOUT; in wm2000_power_down()
260 regulator_bulk_disable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_power_down()
262 dev_dbg(&i2c->dev, "powered off\n"); in wm2000_power_down()
263 wm2000->anc_mode = ANC_OFF; in wm2000_power_down()
270 struct wm2000_priv *wm2000 = dev_get_drvdata(&i2c->dev); in wm2000_enter_bypass()
272 if (WARN_ON(wm2000->anc_mode != ANC_ACTIVE)) in wm2000_enter_bypass()
273 return -EINVAL; in wm2000_enter_bypass()
288 dev_err(&i2c->dev, "Timeout waiting for ANC disable\n"); in wm2000_enter_bypass()
289 return -ETIMEDOUT; in wm2000_enter_bypass()
294 dev_err(&i2c->dev, "Timeout waiting for ANC engine idle\n"); in wm2000_enter_bypass()
295 return -ETIMEDOUT; in wm2000_enter_bypass()
301 wm2000->anc_mode = ANC_BYPASS; in wm2000_enter_bypass()
302 dev_dbg(&i2c->dev, "bypass enabled\n"); in wm2000_enter_bypass()
309 struct wm2000_priv *wm2000 = dev_get_drvdata(&i2c->dev); in wm2000_exit_bypass()
311 if (WARN_ON(wm2000->anc_mode != ANC_BYPASS)) in wm2000_exit_bypass()
312 return -EINVAL; in wm2000_exit_bypass()
332 dev_err(&i2c->dev, "Timed out waiting for MOUSE\n"); in wm2000_exit_bypass()
333 return -ETIMEDOUT; in wm2000_exit_bypass()
336 wm2000->anc_mode = ANC_ACTIVE; in wm2000_exit_bypass()
337 dev_dbg(&i2c->dev, "MOUSE active\n"); in wm2000_exit_bypass()
344 struct wm2000_priv *wm2000 = dev_get_drvdata(&i2c->dev); in wm2000_enter_standby()
346 if (WARN_ON(wm2000->anc_mode != ANC_ACTIVE)) in wm2000_enter_standby()
347 return -EINVAL; in wm2000_enter_standby()
364 dev_err(&i2c->dev, in wm2000_enter_standby()
366 return -ETIMEDOUT; in wm2000_enter_standby()
370 dev_err(&i2c->dev, in wm2000_enter_standby()
372 return -ETIMEDOUT; in wm2000_enter_standby()
378 wm2000->anc_mode = ANC_STANDBY; in wm2000_enter_standby()
379 dev_dbg(&i2c->dev, "standby\n"); in wm2000_enter_standby()
381 dev_dbg(&i2c->dev, "Analogue disabled\n"); in wm2000_enter_standby()
388 struct wm2000_priv *wm2000 = dev_get_drvdata(&i2c->dev); in wm2000_exit_standby()
390 if (WARN_ON(wm2000->anc_mode != ANC_STANDBY)) in wm2000_exit_standby()
391 return -EINVAL; in wm2000_exit_standby()
413 dev_err(&i2c->dev, "Timed out waiting for MOUSE\n"); in wm2000_exit_standby()
414 return -ETIMEDOUT; in wm2000_exit_standby()
417 wm2000->anc_mode = ANC_ACTIVE; in wm2000_exit_standby()
418 dev_dbg(&i2c->dev, "MOUSE active\n"); in wm2000_exit_standby()
420 dev_dbg(&i2c->dev, "Analogue enabled\n"); in wm2000_exit_standby()
537 struct i2c_client *i2c = wm2000->i2c; in wm2000_anc_transition()
541 if (wm2000->anc_mode == mode) in wm2000_anc_transition()
545 if (anc_transitions[i].source == wm2000->anc_mode && in wm2000_anc_transition()
549 dev_err(&i2c->dev, "No transition for %d->%d\n", in wm2000_anc_transition()
550 wm2000->anc_mode, mode); in wm2000_anc_transition()
551 return -EINVAL; in wm2000_anc_transition()
556 ret = clk_prepare_enable(wm2000->mclk); in wm2000_anc_transition()
558 dev_err(&i2c->dev, "Failed to enable MCLK: %d\n", ret); in wm2000_anc_transition()
573 clk_disable_unprepare(wm2000->mclk); in wm2000_anc_transition()
580 struct i2c_client *i2c = wm2000->i2c; in wm2000_anc_set_mode()
583 if (wm2000->anc_eng_ena && wm2000->spk_ena) in wm2000_anc_set_mode()
584 if (wm2000->anc_active) in wm2000_anc_set_mode()
591 dev_dbg(&i2c->dev, "Set mode %d (enabled %d, mute %d, active %d)\n", in wm2000_anc_set_mode()
592 mode, wm2000->anc_eng_ena, !wm2000->spk_ena, in wm2000_anc_set_mode()
593 wm2000->anc_active); in wm2000_anc_set_mode()
602 struct wm2000_priv *wm2000 = dev_get_drvdata(component->dev); in wm2000_anc_mode_get()
604 ucontrol->value.integer.value[0] = wm2000->anc_active; in wm2000_anc_mode_get()
613 struct wm2000_priv *wm2000 = dev_get_drvdata(component->dev); in wm2000_anc_mode_put()
614 unsigned int anc_active = ucontrol->value.integer.value[0]; in wm2000_anc_mode_put()
618 return -EINVAL; in wm2000_anc_mode_put()
620 mutex_lock(&wm2000->lock); in wm2000_anc_mode_put()
622 wm2000->anc_active = anc_active; in wm2000_anc_mode_put()
626 mutex_unlock(&wm2000->lock); in wm2000_anc_mode_put()
635 struct wm2000_priv *wm2000 = dev_get_drvdata(component->dev); in wm2000_speaker_get()
637 ucontrol->value.integer.value[0] = wm2000->spk_ena; in wm2000_speaker_get()
646 struct wm2000_priv *wm2000 = dev_get_drvdata(component->dev); in wm2000_speaker_put()
647 unsigned int val = ucontrol->value.integer.value[0]; in wm2000_speaker_put()
651 return -EINVAL; in wm2000_speaker_put()
653 mutex_lock(&wm2000->lock); in wm2000_speaker_put()
655 wm2000->spk_ena = val; in wm2000_speaker_put()
659 mutex_unlock(&wm2000->lock); in wm2000_speaker_put()
677 struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm); in wm2000_anc_power_event()
678 struct wm2000_priv *wm2000 = dev_get_drvdata(component->dev); in wm2000_anc_power_event()
681 mutex_lock(&wm2000->lock); in wm2000_anc_power_event()
684 wm2000->anc_eng_ena = 1; in wm2000_anc_power_event()
687 wm2000->anc_eng_ena = 0; in wm2000_anc_power_event()
691 mutex_unlock(&wm2000->lock); in wm2000_anc_power_event()
720 struct wm2000_priv *wm2000 = dev_get_drvdata(component->dev); in wm2000_suspend()
727 struct wm2000_priv *wm2000 = dev_get_drvdata(component->dev); in wm2000_resume()
778 struct wm2000_priv *wm2000 = dev_get_drvdata(component->dev); in wm2000_probe()
788 struct wm2000_priv *wm2000 = dev_get_drvdata(component->dev); in wm2000_remove()
818 wm2000 = devm_kzalloc(&i2c->dev, sizeof(*wm2000), GFP_KERNEL); in wm2000_i2c_probe()
820 return -ENOMEM; in wm2000_i2c_probe()
822 mutex_init(&wm2000->lock); in wm2000_i2c_probe()
824 dev_set_drvdata(&i2c->dev, wm2000); in wm2000_i2c_probe()
826 wm2000->regmap = devm_regmap_init_i2c(i2c, &wm2000_regmap); in wm2000_i2c_probe()
827 if (IS_ERR(wm2000->regmap)) { in wm2000_i2c_probe()
828 ret = PTR_ERR(wm2000->regmap); in wm2000_i2c_probe()
829 dev_err(&i2c->dev, "Failed to allocate register map: %d\n", in wm2000_i2c_probe()
835 wm2000->supplies[i].supply = wm2000_supplies[i]; in wm2000_i2c_probe()
837 ret = devm_regulator_bulk_get(&i2c->dev, WM2000_NUM_SUPPLIES, in wm2000_i2c_probe()
838 wm2000->supplies); in wm2000_i2c_probe()
840 dev_err(&i2c->dev, "Failed to get supplies: %d\n", ret); in wm2000_i2c_probe()
844 ret = regulator_bulk_enable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_i2c_probe()
846 dev_err(&i2c->dev, "Failed to enable supplies: %d\n", ret); in wm2000_i2c_probe()
851 ret = regmap_read(wm2000->regmap, WM2000_REG_ID1, &reg); in wm2000_i2c_probe()
853 dev_err(&i2c->dev, "Unable to read ID1: %d\n", ret); in wm2000_i2c_probe()
857 ret = regmap_read(wm2000->regmap, WM2000_REG_ID2, &reg); in wm2000_i2c_probe()
859 dev_err(&i2c->dev, "Unable to read ID2: %d\n", ret); in wm2000_i2c_probe()
865 dev_err(&i2c->dev, "Device is not a WM2000 - ID %x\n", id); in wm2000_i2c_probe()
866 ret = -ENODEV; in wm2000_i2c_probe()
870 ret = regmap_read(wm2000->regmap, WM2000_REG_REVISON, &reg); in wm2000_i2c_probe()
872 dev_err(&i2c->dev, "Unable to read Revision: %d\n", ret); in wm2000_i2c_probe()
875 dev_info(&i2c->dev, "revision %c\n", reg + 'A'); in wm2000_i2c_probe()
877 wm2000->mclk = devm_clk_get(&i2c->dev, "MCLK"); in wm2000_i2c_probe()
878 if (IS_ERR(wm2000->mclk)) { in wm2000_i2c_probe()
879 ret = PTR_ERR(wm2000->mclk); in wm2000_i2c_probe()
880 dev_err(&i2c->dev, "Failed to get MCLK: %d\n", ret); in wm2000_i2c_probe()
885 pdata = dev_get_platdata(&i2c->dev); in wm2000_i2c_probe()
887 wm2000->speech_clarity = !pdata->speech_enh_disable; in wm2000_i2c_probe()
889 if (pdata->download_file) in wm2000_i2c_probe()
890 filename = pdata->download_file; in wm2000_i2c_probe()
893 ret = request_firmware(&fw, filename, &i2c->dev); in wm2000_i2c_probe()
895 dev_err(&i2c->dev, "Failed to acquire ANC data: %d\n", ret); in wm2000_i2c_probe()
899 /* Pre-cook the concatenation of the register address onto the image */ in wm2000_i2c_probe()
900 wm2000->anc_download_size = fw->size + 2; in wm2000_i2c_probe()
901 wm2000->anc_download = devm_kzalloc(&i2c->dev, in wm2000_i2c_probe()
902 wm2000->anc_download_size, in wm2000_i2c_probe()
904 if (wm2000->anc_download == NULL) { in wm2000_i2c_probe()
905 ret = -ENOMEM; in wm2000_i2c_probe()
909 wm2000->anc_download[0] = 0x80; in wm2000_i2c_probe()
910 wm2000->anc_download[1] = 0x00; in wm2000_i2c_probe()
911 memcpy(wm2000->anc_download + 2, fw->data, fw->size); in wm2000_i2c_probe()
913 wm2000->anc_eng_ena = 1; in wm2000_i2c_probe()
914 wm2000->anc_active = 1; in wm2000_i2c_probe()
915 wm2000->spk_ena = 1; in wm2000_i2c_probe()
916 wm2000->i2c = i2c; in wm2000_i2c_probe()
920 ret = devm_snd_soc_register_component(&i2c->dev, in wm2000_i2c_probe()
924 regulator_bulk_disable(WM2000_NUM_SUPPLIES, wm2000->supplies); in wm2000_i2c_probe()