diff options
author | Linux Build Service Account <lnxbuild@localhost> | 2017-01-19 09:52:43 -0800 |
---|---|---|
committer | Gerrit - the friendly Code Review server <code-review@localhost> | 2017-01-19 09:52:42 -0800 |
commit | fdddc49ef25b6efe57e7a6e15b59dfb253dc496b (patch) | |
tree | f7edf60109f381149820ba97daaa6f85d2f93acd | |
parent | bf50e1fe71b3cab5c4f86d037f7aa3b3ac52f407 (diff) | |
parent | 21d1f8644699d29c3032f39ca2bf9e8c45a8d4c3 (diff) |
Merge "ASoC: wcd9xxx: Enable EAR LO concurrency in codec"
-rw-r--r-- | sound/soc/codecs/wcd9xxx-common-v2.c | 53 |
1 files changed, 27 insertions, 26 deletions
diff --git a/sound/soc/codecs/wcd9xxx-common-v2.c b/sound/soc/codecs/wcd9xxx-common-v2.c index 2e3f7d14877a..c2f7b1e99cd5 100644 --- a/sound/soc/codecs/wcd9xxx-common-v2.c +++ b/sound/soc/codecs/wcd9xxx-common-v2.c @@ -853,35 +853,35 @@ static void wcd_clsh_state_ear_lo(struct snd_soc_codec *codec, dev_dbg(codec->dev, "%s: mode: %s, %s\n", __func__, mode_to_str(mode), is_enable ? "enable" : "disable"); - if (is_enable && (req_state == WCD_CLSH_STATE_LO)) { - wcd_clsh_set_buck_regulator_mode(codec, CLS_AB); - } else { - if (req_state == WCD_CLSH_STATE_EAR) - goto end; - - /* LO powerdown. - * If EAR Class-H is already enabled, just - * turn on regulator other enable Class-H - * configuration + if (is_enable) { + /* LO powerup is taken care in PA sequence. + * No need to change to class AB here. */ - if (wcd_clsh_enable_status(codec)) { - wcd_clsh_set_buck_regulator_mode(codec, - CLS_H_NORMAL); - goto end; + if (req_state == WCD_CLSH_STATE_EAR) { + /* EAR powerup.*/ + if (!wcd_clsh_enable_status(codec)) { + wcd_enable_clsh_block(codec, clsh_d, true); + wcd_clsh_set_buck_mode(codec, mode); + wcd_clsh_set_flyback_mode(codec, mode); + } + snd_soc_update_bits(codec, + WCD9XXX_A_CDC_RX0_RX_PATH_CFG0, + 0x40, 0x40); } - wcd_enable_clsh_block(codec, clsh_d, true); - snd_soc_update_bits(codec, - WCD9XXX_A_CDC_RX0_RX_PATH_CFG0, - 0x40, 0x40); - wcd_clsh_set_buck_regulator_mode(codec, - CLS_H_NORMAL); - wcd_clsh_set_buck_mode(codec, mode); - wcd_clsh_set_flyback_mode(codec, mode); - wcd_clsh_flyback_ctrl(codec, clsh_d, mode, true); - wcd_clsh_buck_ctrl(codec, clsh_d, mode, true); + } else { + if (req_state == WCD_CLSH_STATE_EAR) { + /* EAR powerdown.*/ + wcd_enable_clsh_block(codec, clsh_d, false); + wcd_clsh_set_buck_mode(codec, CLS_H_NORMAL); + wcd_clsh_set_flyback_mode(codec, CLS_H_NORMAL); + snd_soc_update_bits(codec, + WCD9XXX_A_CDC_RX0_RX_PATH_CFG0, + 0x40, 0x00); + } + /* LO powerdown is taken care in PA sequence. + * No need to change to class H here. + */ } -end: - return; } static void wcd_clsh_state_hph_lo(struct snd_soc_codec *codec, @@ -1230,6 +1230,7 @@ static bool wcd_clsh_is_state_valid(u8 state) case WCD_CLSH_STATE_HPHL_LO: case WCD_CLSH_STATE_HPHR_LO: case WCD_CLSH_STATE_HPH_ST_LO: + case WCD_CLSH_STATE_EAR_LO: return true; default: return false; |