Loading asoc/codecs/bolero/rx-macro.c +40 −2 Original line number Diff line number Diff line Loading @@ -345,6 +345,7 @@ struct rx_macro_priv { bool is_ear_mode_on; bool dev_up; bool hph_pwr_mode; bool hph_hd2_mode; u16 mclk_mux; struct mutex mclk_lock; struct mutex swr_clk_lock; Loading Loading @@ -433,6 +434,10 @@ static const char *const rx_macro_ear_mode_text[] = {"OFF", "ON"}; static const struct soc_enum rx_macro_ear_mode_enum = SOC_ENUM_SINGLE_EXT(2, rx_macro_ear_mode_text); static const char *const rx_macro_hph_hd2_mode_text[] = {"OFF", "ON"}; static const struct soc_enum rx_macro_hph_hd2_mode_enum = SOC_ENUM_SINGLE_EXT(2, rx_macro_hph_hd2_mode_text); static const char *const rx_macro_hph_pwr_mode_text[] = {"ULP", "LoHIFI"}; static const struct soc_enum rx_macro_hph_pwr_mode_enum = SOC_ENUM_SINGLE_EXT(2, rx_macro_hph_pwr_mode_text); Loading Loading @@ -1694,6 +1699,34 @@ static int rx_macro_put_ear_mode(struct snd_kcontrol *kcontrol, return 0; } static int rx_macro_get_hph_hd2_mode(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol) { struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); struct device *rx_dev = NULL; struct rx_macro_priv *rx_priv = NULL; if (!rx_macro_get_data(codec, &rx_dev, &rx_priv, __func__)) return -EINVAL; ucontrol->value.integer.value[0] = rx_priv->hph_hd2_mode; return 0; } static int rx_macro_put_hph_hd2_mode(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol) { struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); struct device *rx_dev = NULL; struct rx_macro_priv *rx_priv = NULL; if (!rx_macro_get_data(codec, &rx_dev, &rx_priv, __func__)) return -EINVAL; rx_priv->hph_hd2_mode = ucontrol->value.integer.value[0]; return 0; } static int rx_macro_get_hph_pwr_mode(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol) { Loading Loading @@ -2010,6 +2043,7 @@ static int rx_macro_enable_interp_clk(struct snd_soc_codec *codec, snd_soc_update_bits(codec, main_reg, 0x20, 0x20); rx_macro_idle_detect_control(codec, rx_priv, interp_idx, event); if (rx_priv->hph_hd2_mode) rx_macro_hd2_control(codec, interp_idx, event); rx_macro_hphdelay_lutbypass(codec, rx_priv, interp_idx, event); Loading Loading @@ -2037,6 +2071,7 @@ static int rx_macro_enable_interp_clk(struct snd_soc_codec *codec, event); rx_macro_hphdelay_lutbypass(codec, rx_priv, interp_idx, event); if (rx_priv->hph_hd2_mode) rx_macro_hd2_control(codec, interp_idx, event); rx_macro_idle_detect_control(codec, rx_priv, interp_idx, event); Loading Loading @@ -2403,6 +2438,9 @@ static const struct snd_kcontrol_new rx_macro_snd_controls[] = { SOC_ENUM_EXT("RX_EAR Mode", rx_macro_ear_mode_enum, rx_macro_get_ear_mode, rx_macro_put_ear_mode), SOC_ENUM_EXT("RX_HPH HD2 Mode", rx_macro_hph_hd2_mode_enum, rx_macro_get_hph_hd2_mode, rx_macro_put_hph_hd2_mode), SOC_ENUM_EXT("RX_HPH_PWR_MODE", rx_macro_hph_pwr_mode_enum, rx_macro_get_hph_pwr_mode, rx_macro_put_hph_pwr_mode), Loading Loading
asoc/codecs/bolero/rx-macro.c +40 −2 Original line number Diff line number Diff line Loading @@ -345,6 +345,7 @@ struct rx_macro_priv { bool is_ear_mode_on; bool dev_up; bool hph_pwr_mode; bool hph_hd2_mode; u16 mclk_mux; struct mutex mclk_lock; struct mutex swr_clk_lock; Loading Loading @@ -433,6 +434,10 @@ static const char *const rx_macro_ear_mode_text[] = {"OFF", "ON"}; static const struct soc_enum rx_macro_ear_mode_enum = SOC_ENUM_SINGLE_EXT(2, rx_macro_ear_mode_text); static const char *const rx_macro_hph_hd2_mode_text[] = {"OFF", "ON"}; static const struct soc_enum rx_macro_hph_hd2_mode_enum = SOC_ENUM_SINGLE_EXT(2, rx_macro_hph_hd2_mode_text); static const char *const rx_macro_hph_pwr_mode_text[] = {"ULP", "LoHIFI"}; static const struct soc_enum rx_macro_hph_pwr_mode_enum = SOC_ENUM_SINGLE_EXT(2, rx_macro_hph_pwr_mode_text); Loading Loading @@ -1694,6 +1699,34 @@ static int rx_macro_put_ear_mode(struct snd_kcontrol *kcontrol, return 0; } static int rx_macro_get_hph_hd2_mode(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol) { struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); struct device *rx_dev = NULL; struct rx_macro_priv *rx_priv = NULL; if (!rx_macro_get_data(codec, &rx_dev, &rx_priv, __func__)) return -EINVAL; ucontrol->value.integer.value[0] = rx_priv->hph_hd2_mode; return 0; } static int rx_macro_put_hph_hd2_mode(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol) { struct snd_soc_codec *codec = snd_soc_kcontrol_codec(kcontrol); struct device *rx_dev = NULL; struct rx_macro_priv *rx_priv = NULL; if (!rx_macro_get_data(codec, &rx_dev, &rx_priv, __func__)) return -EINVAL; rx_priv->hph_hd2_mode = ucontrol->value.integer.value[0]; return 0; } static int rx_macro_get_hph_pwr_mode(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol) { Loading Loading @@ -2010,6 +2043,7 @@ static int rx_macro_enable_interp_clk(struct snd_soc_codec *codec, snd_soc_update_bits(codec, main_reg, 0x20, 0x20); rx_macro_idle_detect_control(codec, rx_priv, interp_idx, event); if (rx_priv->hph_hd2_mode) rx_macro_hd2_control(codec, interp_idx, event); rx_macro_hphdelay_lutbypass(codec, rx_priv, interp_idx, event); Loading Loading @@ -2037,6 +2071,7 @@ static int rx_macro_enable_interp_clk(struct snd_soc_codec *codec, event); rx_macro_hphdelay_lutbypass(codec, rx_priv, interp_idx, event); if (rx_priv->hph_hd2_mode) rx_macro_hd2_control(codec, interp_idx, event); rx_macro_idle_detect_control(codec, rx_priv, interp_idx, event); Loading Loading @@ -2403,6 +2438,9 @@ static const struct snd_kcontrol_new rx_macro_snd_controls[] = { SOC_ENUM_EXT("RX_EAR Mode", rx_macro_ear_mode_enum, rx_macro_get_ear_mode, rx_macro_put_ear_mode), SOC_ENUM_EXT("RX_HPH HD2 Mode", rx_macro_hph_hd2_mode_enum, rx_macro_get_hph_hd2_mode, rx_macro_put_hph_hd2_mode), SOC_ENUM_EXT("RX_HPH_PWR_MODE", rx_macro_hph_pwr_mode_enum, rx_macro_get_hph_pwr_mode, rx_macro_put_hph_pwr_mode), Loading