ASoC: sun4i-spdif: Add TX fifo bit flush quirks
authorClément Péron <peron.clem@gmail.com>
Mon, 27 May 2019 20:06:23 +0000 (22:06 +0200)
committerMark Brown <broonie@kernel.org>
Tue, 28 May 2019 14:54:21 +0000 (15:54 +0100)
Allwinner H6 has a different bit to flush the TX FIFO.

Add a quirks to prepare introduction of H6 SoC.

Signed-off-by: Clément Péron <peron.clem@gmail.com>
Acked-by: Maxime Ripard <maxime.ripard@bootlin.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/sunxi/sun4i-spdif.c

index b6c66a62e91593e1185a388011087a43b9a84fe7..045d0cc4b62aedd6afe0e05ba8cfeb589b5464ad 100644 (file)
  *
  * @reg_dac_tx_data: TX FIFO offset for DMA config.
  * @has_reset: SoC needs reset deasserted.
+ * @val_fctl_ftx: TX FIFO flush bitmask.
  */
 struct sun4i_spdif_quirks {
        unsigned int reg_dac_txdata;
        bool has_reset;
+       unsigned int val_fctl_ftx;
 };
 
 struct sun4i_spdif_dev {
@@ -180,16 +182,19 @@ struct sun4i_spdif_dev {
        struct snd_soc_dai_driver cpu_dai_drv;
        struct regmap *regmap;
        struct snd_dmaengine_dai_dma_data dma_params_tx;
+       const struct sun4i_spdif_quirks *quirks;
 };
 
 static void sun4i_spdif_configure(struct sun4i_spdif_dev *host)
 {
+       const struct sun4i_spdif_quirks *quirks = host->quirks;
+
        /* soft reset SPDIF */
        regmap_write(host->regmap, SUN4I_SPDIF_CTL, SUN4I_SPDIF_CTL_RESET);
 
        /* flush TX FIFO */
        regmap_update_bits(host->regmap, SUN4I_SPDIF_FCTL,
-                          SUN4I_SPDIF_FCTL_FTX, SUN4I_SPDIF_FCTL_FTX);
+                          quirks->val_fctl_ftx, quirks->val_fctl_ftx);
 
        /* clear TX counter */
        regmap_write(host->regmap, SUN4I_SPDIF_TXCNT, 0);
@@ -418,15 +423,18 @@ static struct snd_soc_dai_driver sun4i_spdif_dai = {
 
 static const struct sun4i_spdif_quirks sun4i_a10_spdif_quirks = {
        .reg_dac_txdata = SUN4I_SPDIF_TXFIFO,
+       .val_fctl_ftx   = SUN4I_SPDIF_FCTL_FTX,
 };
 
 static const struct sun4i_spdif_quirks sun6i_a31_spdif_quirks = {
        .reg_dac_txdata = SUN4I_SPDIF_TXFIFO,
+       .val_fctl_ftx   = SUN4I_SPDIF_FCTL_FTX,
        .has_reset      = true,
 };
 
 static const struct sun4i_spdif_quirks sun8i_h3_spdif_quirks = {
        .reg_dac_txdata = SUN8I_SPDIF_TXFIFO,
+       .val_fctl_ftx   = SUN4I_SPDIF_FCTL_FTX,
        .has_reset      = true,
 };
 
@@ -507,6 +515,7 @@ static int sun4i_spdif_probe(struct platform_device *pdev)
                dev_err(&pdev->dev, "Failed to determine the quirks to use\n");
                return -ENODEV;
        }
+       host->quirks = quirks;
 
        host->regmap = devm_regmap_init_mmio(&pdev->dev, base,
                                                &sun4i_spdif_regmap_config);