Loading sound/soc/codecs/arizona.c +2 −7 Original line number Diff line number Diff line Loading @@ -446,15 +446,9 @@ static int arizona_set_fmt(struct snd_soc_dai *dai, unsigned int fmt) case SND_SOC_DAIFMT_DSP_A: mode = 0; break; case SND_SOC_DAIFMT_DSP_B: mode = 1; break; case SND_SOC_DAIFMT_I2S: mode = 2; break; case SND_SOC_DAIFMT_LEFT_J: mode = 3; break; default: arizona_aif_err(dai, "Unsupported DAI format %d\n", fmt & SND_SOC_DAIFMT_FORMAT_MASK); Loading Loading @@ -714,7 +708,8 @@ static int arizona_hw_params(struct snd_pcm_substream *substream, snd_soc_update_bits(codec, ARIZONA_ASYNC_SAMPLE_RATE_1, ARIZONA_ASYNC_SAMPLE_RATE_MASK, sr_val); snd_soc_update_bits(codec, base + ARIZONA_AIF_RATE_CTRL, ARIZONA_AIF1_RATE_MASK, 8); ARIZONA_AIF1_RATE_MASK, 8 << ARIZONA_AIF1_RATE_SHIFT); break; default: arizona_aif_err(dai, "Invalid clock %d\n", dai_priv->clk); Loading sound/soc/codecs/arizona.h +9 −9 Original line number Diff line number Diff line Loading @@ -34,15 +34,15 @@ #define ARIZONA_FLL_SRC_MCLK1 0 #define ARIZONA_FLL_SRC_MCLK2 1 #define ARIZONA_FLL_SRC_SLIMCLK 2 #define ARIZONA_FLL_SRC_FLL1 3 #define ARIZONA_FLL_SRC_FLL2 4 #define ARIZONA_FLL_SRC_AIF1BCLK 5 #define ARIZONA_FLL_SRC_AIF2BCLK 6 #define ARIZONA_FLL_SRC_AIF3BCLK 7 #define ARIZONA_FLL_SRC_AIF1LRCLK 8 #define ARIZONA_FLL_SRC_AIF2LRCLK 9 #define ARIZONA_FLL_SRC_AIF3LRCLK 10 #define ARIZONA_FLL_SRC_SLIMCLK 3 #define ARIZONA_FLL_SRC_FLL1 4 #define ARIZONA_FLL_SRC_FLL2 5 #define ARIZONA_FLL_SRC_AIF1BCLK 8 #define ARIZONA_FLL_SRC_AIF2BCLK 9 #define ARIZONA_FLL_SRC_AIF3BCLK 10 #define ARIZONA_FLL_SRC_AIF1LRCLK 12 #define ARIZONA_FLL_SRC_AIF2LRCLK 13 #define ARIZONA_FLL_SRC_AIF3LRCLK 14 #define ARIZONA_MIXER_VOL_MASK 0x00FE #define ARIZONA_MIXER_VOL_SHIFT 1 Loading sound/soc/codecs/wm5102.c +46 −2 Original line number Diff line number Diff line Loading @@ -36,6 +36,9 @@ struct wm5102_priv { struct arizona_priv core; struct arizona_fll fll[2]; unsigned int spk_ena:2; unsigned int spk_ena_pending:1; }; static DECLARE_TLV_DB_SCALE(ana_tlv, 0, 100, 0); Loading Loading @@ -787,6 +790,47 @@ ARIZONA_MIXER_CONTROLS("AIF3TX1", ARIZONA_AIF3TX1MIX_INPUT_1_SOURCE), ARIZONA_MIXER_CONTROLS("AIF3TX2", ARIZONA_AIF3TX2MIX_INPUT_1_SOURCE), }; static int wm5102_spk_ev(struct snd_soc_dapm_widget *w, struct snd_kcontrol *kcontrol, int event) { struct snd_soc_codec *codec = w->codec; struct arizona *arizona = dev_get_drvdata(codec->dev->parent); struct wm5102_priv *wm5102 = snd_soc_codec_get_drvdata(codec); if (arizona->rev < 1) return 0; switch (event) { case SND_SOC_DAPM_PRE_PMU: if (!wm5102->spk_ena) { snd_soc_write(codec, 0x4f5, 0x25a); wm5102->spk_ena_pending = true; } break; case SND_SOC_DAPM_POST_PMU: if (wm5102->spk_ena_pending) { msleep(75); snd_soc_write(codec, 0x4f5, 0xda); wm5102->spk_ena_pending = false; wm5102->spk_ena++; } break; case SND_SOC_DAPM_PRE_PMD: wm5102->spk_ena--; if (!wm5102->spk_ena) snd_soc_write(codec, 0x4f5, 0x25a); break; case SND_SOC_DAPM_POST_PMD: if (!wm5102->spk_ena) snd_soc_write(codec, 0x4f5, 0x0da); break; } return 0; } ARIZONA_MIXER_ENUMS(EQ1, ARIZONA_EQ1MIX_INPUT_1_SOURCE); ARIZONA_MIXER_ENUMS(EQ2, ARIZONA_EQ2MIX_INPUT_1_SOURCE); ARIZONA_MIXER_ENUMS(EQ3, ARIZONA_EQ3MIX_INPUT_1_SOURCE); Loading Loading @@ -1034,10 +1078,10 @@ SND_SOC_DAPM_PGA_E("OUT3L", ARIZONA_OUTPUT_ENABLES_1, ARIZONA_OUT3L_ENA_SHIFT, 0, NULL, 0, arizona_out_ev, SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMU), SND_SOC_DAPM_PGA_E("OUT4L", ARIZONA_OUTPUT_ENABLES_1, ARIZONA_OUT4L_ENA_SHIFT, 0, NULL, 0, arizona_out_ev, ARIZONA_OUT4L_ENA_SHIFT, 0, NULL, 0, wm5102_spk_ev, SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMU), SND_SOC_DAPM_PGA_E("OUT4R", ARIZONA_OUTPUT_ENABLES_1, ARIZONA_OUT4R_ENA_SHIFT, 0, NULL, 0, arizona_out_ev, ARIZONA_OUT4R_ENA_SHIFT, 0, NULL, 0, wm5102_spk_ev, SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMU), SND_SOC_DAPM_PGA_E("OUT5L", ARIZONA_OUTPUT_ENABLES_1, ARIZONA_OUT5L_ENA_SHIFT, 0, NULL, 0, arizona_out_ev, Loading Loading
sound/soc/codecs/arizona.c +2 −7 Original line number Diff line number Diff line Loading @@ -446,15 +446,9 @@ static int arizona_set_fmt(struct snd_soc_dai *dai, unsigned int fmt) case SND_SOC_DAIFMT_DSP_A: mode = 0; break; case SND_SOC_DAIFMT_DSP_B: mode = 1; break; case SND_SOC_DAIFMT_I2S: mode = 2; break; case SND_SOC_DAIFMT_LEFT_J: mode = 3; break; default: arizona_aif_err(dai, "Unsupported DAI format %d\n", fmt & SND_SOC_DAIFMT_FORMAT_MASK); Loading Loading @@ -714,7 +708,8 @@ static int arizona_hw_params(struct snd_pcm_substream *substream, snd_soc_update_bits(codec, ARIZONA_ASYNC_SAMPLE_RATE_1, ARIZONA_ASYNC_SAMPLE_RATE_MASK, sr_val); snd_soc_update_bits(codec, base + ARIZONA_AIF_RATE_CTRL, ARIZONA_AIF1_RATE_MASK, 8); ARIZONA_AIF1_RATE_MASK, 8 << ARIZONA_AIF1_RATE_SHIFT); break; default: arizona_aif_err(dai, "Invalid clock %d\n", dai_priv->clk); Loading
sound/soc/codecs/arizona.h +9 −9 Original line number Diff line number Diff line Loading @@ -34,15 +34,15 @@ #define ARIZONA_FLL_SRC_MCLK1 0 #define ARIZONA_FLL_SRC_MCLK2 1 #define ARIZONA_FLL_SRC_SLIMCLK 2 #define ARIZONA_FLL_SRC_FLL1 3 #define ARIZONA_FLL_SRC_FLL2 4 #define ARIZONA_FLL_SRC_AIF1BCLK 5 #define ARIZONA_FLL_SRC_AIF2BCLK 6 #define ARIZONA_FLL_SRC_AIF3BCLK 7 #define ARIZONA_FLL_SRC_AIF1LRCLK 8 #define ARIZONA_FLL_SRC_AIF2LRCLK 9 #define ARIZONA_FLL_SRC_AIF3LRCLK 10 #define ARIZONA_FLL_SRC_SLIMCLK 3 #define ARIZONA_FLL_SRC_FLL1 4 #define ARIZONA_FLL_SRC_FLL2 5 #define ARIZONA_FLL_SRC_AIF1BCLK 8 #define ARIZONA_FLL_SRC_AIF2BCLK 9 #define ARIZONA_FLL_SRC_AIF3BCLK 10 #define ARIZONA_FLL_SRC_AIF1LRCLK 12 #define ARIZONA_FLL_SRC_AIF2LRCLK 13 #define ARIZONA_FLL_SRC_AIF3LRCLK 14 #define ARIZONA_MIXER_VOL_MASK 0x00FE #define ARIZONA_MIXER_VOL_SHIFT 1 Loading
sound/soc/codecs/wm5102.c +46 −2 Original line number Diff line number Diff line Loading @@ -36,6 +36,9 @@ struct wm5102_priv { struct arizona_priv core; struct arizona_fll fll[2]; unsigned int spk_ena:2; unsigned int spk_ena_pending:1; }; static DECLARE_TLV_DB_SCALE(ana_tlv, 0, 100, 0); Loading Loading @@ -787,6 +790,47 @@ ARIZONA_MIXER_CONTROLS("AIF3TX1", ARIZONA_AIF3TX1MIX_INPUT_1_SOURCE), ARIZONA_MIXER_CONTROLS("AIF3TX2", ARIZONA_AIF3TX2MIX_INPUT_1_SOURCE), }; static int wm5102_spk_ev(struct snd_soc_dapm_widget *w, struct snd_kcontrol *kcontrol, int event) { struct snd_soc_codec *codec = w->codec; struct arizona *arizona = dev_get_drvdata(codec->dev->parent); struct wm5102_priv *wm5102 = snd_soc_codec_get_drvdata(codec); if (arizona->rev < 1) return 0; switch (event) { case SND_SOC_DAPM_PRE_PMU: if (!wm5102->spk_ena) { snd_soc_write(codec, 0x4f5, 0x25a); wm5102->spk_ena_pending = true; } break; case SND_SOC_DAPM_POST_PMU: if (wm5102->spk_ena_pending) { msleep(75); snd_soc_write(codec, 0x4f5, 0xda); wm5102->spk_ena_pending = false; wm5102->spk_ena++; } break; case SND_SOC_DAPM_PRE_PMD: wm5102->spk_ena--; if (!wm5102->spk_ena) snd_soc_write(codec, 0x4f5, 0x25a); break; case SND_SOC_DAPM_POST_PMD: if (!wm5102->spk_ena) snd_soc_write(codec, 0x4f5, 0x0da); break; } return 0; } ARIZONA_MIXER_ENUMS(EQ1, ARIZONA_EQ1MIX_INPUT_1_SOURCE); ARIZONA_MIXER_ENUMS(EQ2, ARIZONA_EQ2MIX_INPUT_1_SOURCE); ARIZONA_MIXER_ENUMS(EQ3, ARIZONA_EQ3MIX_INPUT_1_SOURCE); Loading Loading @@ -1034,10 +1078,10 @@ SND_SOC_DAPM_PGA_E("OUT3L", ARIZONA_OUTPUT_ENABLES_1, ARIZONA_OUT3L_ENA_SHIFT, 0, NULL, 0, arizona_out_ev, SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMU), SND_SOC_DAPM_PGA_E("OUT4L", ARIZONA_OUTPUT_ENABLES_1, ARIZONA_OUT4L_ENA_SHIFT, 0, NULL, 0, arizona_out_ev, ARIZONA_OUT4L_ENA_SHIFT, 0, NULL, 0, wm5102_spk_ev, SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMU), SND_SOC_DAPM_PGA_E("OUT4R", ARIZONA_OUTPUT_ENABLES_1, ARIZONA_OUT4R_ENA_SHIFT, 0, NULL, 0, arizona_out_ev, ARIZONA_OUT4R_ENA_SHIFT, 0, NULL, 0, wm5102_spk_ev, SND_SOC_DAPM_PRE_PMD | SND_SOC_DAPM_POST_PMU), SND_SOC_DAPM_PGA_E("OUT5L", ARIZONA_OUTPUT_ENABLES_1, ARIZONA_OUT5L_ENA_SHIFT, 0, NULL, 0, arizona_out_ev, Loading