On 05/05/2021 09:26, Neil Armstrong wrote: > This adds support for the TOACODEC found in Amlogic SM1 SoCs. > > The bits are shifted for more selection of clock sources, so this only > maps the same support for G12A to the SM1 bits. > > Signed-off-by: Neil Armstrong <narmstrong@xxxxxxxxxxxx> > --- > sound/soc/meson/g12a-toacodec.c | 64 ++++++++++++++++++++++++++++++++- > 1 file changed, 63 insertions(+), 1 deletion(-) > > diff --git a/sound/soc/meson/g12a-toacodec.c b/sound/soc/meson/g12a-toacodec.c > index 2084c9542c9c..5437ecba9c47 100644 > --- a/sound/soc/meson/g12a-toacodec.c > +++ b/sound/soc/meson/g12a-toacodec.c > @@ -21,13 +21,22 @@ > > #define TOACODEC_CTRL0 0x0 > #define CTRL0_ENABLE_SHIFT 31 > +#define CTRL0_DAT_SEL_SM1_MSB 19 > +#define CTRL0_DAT_SEL_SM1_LSB 18 > #define CTRL0_DAT_SEL_MSB 15 > #define CTRL0_DAT_SEL_LSB 14 > +#define CTRL0_LANE_SEL_SM1 16 > #define CTRL0_LANE_SEL 12 > +#define CTRL0_LRCLK_SEL_SM1_MSB 14 > +#define CTRL0_LRCLK_SEL_SM1_LSB 12 > #define CTRL0_LRCLK_SEL_MSB 9 > #define CTRL0_LRCLK_SEL_LSB 8 > +#define CTRL0_LRCLK_INV_SM1 BIT(10) > +#define CTRL0_BLK_CAP_INV_SM1 BIT(9) > #define CTRL0_BLK_CAP_INV BIT(7) > +#define CTRL0_BCLK_O_INV_SM1 BIT(8) > #define CTRL0_BCLK_O_INV BIT(6) > +#define CTRL0_BCLK_SEL_SM1_MSB 6 > #define CTRL0_BCLK_SEL_MSB 5 > #define CTRL0_BCLK_SEL_LSB 4 > #define CTRL0_MCLK_SEL GENMASK(2, 0) > @@ -41,6 +50,7 @@ struct g12a_toacodec { > }; > > struct g12a_toacodec_match_data { > + const struct snd_soc_component_driver *component_drv; > struct reg_field field_dat_sel; > struct reg_field field_lrclk_sel; > struct reg_field field_bclk_sel; > @@ -98,11 +108,20 @@ static SOC_ENUM_SINGLE_DECL(g12a_toacodec_mux_enum, TOACODEC_CTRL0, > CTRL0_DAT_SEL_LSB, > g12a_toacodec_mux_texts); > > +static SOC_ENUM_SINGLE_DECL(sm1_toacodec_mux_enum, TOACODEC_CTRL0, > + CTRL0_DAT_SEL_SM1_LSB, > + g12a_toacodec_mux_texts); > + > static const struct snd_kcontrol_new g12a_toacodec_mux = > SOC_DAPM_ENUM_EXT("Source", g12a_toacodec_mux_enum, > snd_soc_dapm_get_enum_double, > g12a_toacodec_mux_put_enum); > > +static const struct snd_kcontrol_new sm1_toacodec_mux = > + SOC_DAPM_ENUM_EXT("Source", sm1_toacodec_mux_enum, > + snd_soc_dapm_get_enum_double, > + g12a_toacodec_mux_put_enum); > + > static const struct snd_kcontrol_new g12a_toacodec_out_enable = > SOC_DAPM_SINGLE_AUTODISABLE("Switch", TOACODEC_CTRL0, > CTRL0_ENABLE_SHIFT, 1, 0); > @@ -114,6 +133,13 @@ static const struct snd_soc_dapm_widget g12a_toacodec_widgets[] = { > &g12a_toacodec_out_enable), > }; > > +static const struct snd_soc_dapm_widget sm1_toacodec_widgets[] = { > + SND_SOC_DAPM_MUX("SRC", SND_SOC_NOPM, 0, 0, > + &sm1_toacodec_mux), > + SND_SOC_DAPM_SWITCH("OUT EN", SND_SOC_NOPM, 0, 0, > + &g12a_toacodec_out_enable), > +}; > + > static int g12a_toacodec_input_hw_params(struct snd_pcm_substream *substream, > struct snd_pcm_hw_params *params, > struct snd_soc_dai *dai) > @@ -184,6 +210,13 @@ static int g12a_toacodec_component_probe(struct snd_soc_component *c) > CTRL0_BLK_CAP_INV); > } > > +static int sm1_toacodec_component_probe(struct snd_soc_component *c) > +{ > + /* Initialize the static clock parameters */ > + return snd_soc_component_write(c, TOACODEC_CTRL0, > + CTRL0_BLK_CAP_INV_SM1); > +} > + > static const struct snd_soc_dapm_route g12a_toacodec_routes[] = { > { "SRC", "I2S A", "IN A Playback" }, > { "SRC", "I2S B", "IN B Playback" }, > @@ -196,6 +229,10 @@ static const struct snd_kcontrol_new g12a_toacodec_controls[] = { > SOC_SINGLE("Lane Select", TOACODEC_CTRL0, CTRL0_LANE_SEL, 3, 0), > }; > > +static const struct snd_kcontrol_new sm1_toacodec_controls[] = { > + SOC_SINGLE("Lane Select", TOACODEC_CTRL0, CTRL0_LANE_SEL_SM1, 3, 0), > +}; > + > static const struct snd_soc_component_driver g12a_toacodec_component_drv = { > .probe = g12a_toacodec_component_probe, > .controls = g12a_toacodec_controls, > @@ -208,6 +245,18 @@ static const struct snd_soc_component_driver g12a_toacodec_component_drv = { > .non_legacy_dai_naming = 1, > }; > > +static const struct snd_soc_component_driver sm1_toacodec_component_drv = { > + .probe = sm1_toacodec_component_probe, > + .controls = sm1_toacodec_controls, > + .num_controls = ARRAY_SIZE(sm1_toacodec_controls), > + .dapm_widgets = sm1_toacodec_widgets, > + .num_dapm_widgets = ARRAY_SIZE(sm1_toacodec_widgets), > + .dapm_routes = g12a_toacodec_routes, > + .num_dapm_routes = ARRAY_SIZE(g12a_toacodec_routes), > + .endianness = 1, > + .non_legacy_dai_naming = 1, > +}; > + > static const struct regmap_config g12a_toacodec_regmap_cfg = { > .reg_bits = 32, > .val_bits = 32, > @@ -215,16 +264,29 @@ static const struct regmap_config g12a_toacodec_regmap_cfg = { > }; > > static const struct g12a_toacodec_match_data g12a_toacodec_match_data = { > + .component_drv = &g12a_toacodec_component_drv, > .field_dat_sel = REG_FIELD(TOACODEC_CTRL0, CTRL0_DAT_SEL_LSB, CTRL0_DAT_SEL_MSB), > .field_lrclk_sel = REG_FIELD(TOACODEC_CTRL0, CTRL0_LRCLK_SEL_LSB, CTRL0_LRCLK_SEL_MSB), > .field_bclk_sel = REG_FIELD(TOACODEC_CTRL0, CTRL0_BCLK_SEL_LSB, CTRL0_BCLK_SEL_MSB), > }; > > +static const struct g12a_toacodec_match_data sm1_toacodec_match_data = { > + .component_drv = &sm1_toacodec_component_drv, > + .field_dat_sel = REG_FIELD(TOACODEC_CTRL0, CTRL0_DAT_SEL_SM1_LSB, CTRL0_DAT_SEL_SM1_MSB), > + .field_lrclk_sel = REG_FIELD(TOACODEC_CTRL0, CTRL0_LRCLK_SEL_SM1_LSB, > + CTRL0_LRCLK_SEL_SM1_MSB), > + .field_bclk_sel = REG_FIELD(TOACODEC_CTRL0, CTRL0_BCLK_SEL_LSB, CTRL0_BCLK_SEL_SM1_MSB), > +}; > + > static const struct of_device_id g12a_toacodec_of_match[] = { > { > .compatible = "amlogic,g12a-toacodec", > .data = &g12a_toacodec_match_data, > }, > + { > + .compatible = "amlogic,sm1-toacodec", > + .data = &sm1_toacodec_match_data, > + }, > {} > }; > MODULE_DEVICE_TABLE(of, g12a_toacodec_of_match); > @@ -278,7 +340,7 @@ static int g12a_toacodec_probe(struct platform_device *pdev) > return PTR_ERR(priv->field_bclk_sel); > > return devm_snd_soc_register_component(dev, > - &g12a_toacodec_component_drv, g12a_toacodec_dai_drv, > + data->component_drv, g12a_toacodec_dai_drv, > ARRAY_SIZE(g12a_toacodec_dai_drv)); > } > > Oops, spurious one, please ignore it. Neil