Some of resets are erroneously missed in the configlink_mods[], like APBIF
for example. Use of_reset_control_array_get_exclusive() which requests all
the resets. The problem was hidden by the clk driver which implicitly
de-asserts the missing resets.

Tested-by: Peter Geis <pgwipe...@gmail.com>
Tested-by: Nicolas Chauvet <kwiz...@gmail.com>
Signed-off-by: Dmitry Osipenko <dig...@gmail.com>
---
 sound/soc/tegra/tegra30_ahub.c | 66 +++++-----------------------------
 sound/soc/tegra/tegra30_ahub.h |  1 -
 2 files changed, 9 insertions(+), 58 deletions(-)

diff --git a/sound/soc/tegra/tegra30_ahub.c b/sound/soc/tegra/tegra30_ahub.c
index 156e3b9d613c..8bd3e83b2c3b 100644
--- a/sound/soc/tegra/tegra30_ahub.c
+++ b/sound/soc/tegra/tegra30_ahub.c
@@ -323,41 +323,6 @@ int tegra30_ahub_unset_rx_cif_source(enum 
tegra30_ahub_rxcif rxcif)
 }
 EXPORT_SYMBOL_GPL(tegra30_ahub_unset_rx_cif_source);
 
-#define MOD_LIST_MASK_TEGRA30  BIT(0)
-#define MOD_LIST_MASK_TEGRA114 BIT(1)
-#define MOD_LIST_MASK_TEGRA124 BIT(2)
-
-#define MOD_LIST_MASK_TEGRA30_OR_LATER \
-               (MOD_LIST_MASK_TEGRA30 | MOD_LIST_MASK_TEGRA114 | \
-                       MOD_LIST_MASK_TEGRA124)
-#define MOD_LIST_MASK_TEGRA114_OR_LATER \
-               (MOD_LIST_MASK_TEGRA114 | MOD_LIST_MASK_TEGRA124)
-
-static const struct {
-       const char *rst_name;
-       u32 mod_list_mask;
-} configlink_mods[] = {
-       { "i2s0", MOD_LIST_MASK_TEGRA30_OR_LATER },
-       { "i2s1", MOD_LIST_MASK_TEGRA30_OR_LATER },
-       { "i2s2", MOD_LIST_MASK_TEGRA30_OR_LATER },
-       { "i2s3", MOD_LIST_MASK_TEGRA30_OR_LATER },
-       { "i2s4", MOD_LIST_MASK_TEGRA30_OR_LATER },
-       { "dam0", MOD_LIST_MASK_TEGRA30_OR_LATER },
-       { "dam1", MOD_LIST_MASK_TEGRA30_OR_LATER },
-       { "dam2", MOD_LIST_MASK_TEGRA30_OR_LATER },
-       { "spdif", MOD_LIST_MASK_TEGRA30_OR_LATER },
-       { "amx", MOD_LIST_MASK_TEGRA114_OR_LATER },
-       { "adx", MOD_LIST_MASK_TEGRA114_OR_LATER },
-       { "amx1", MOD_LIST_MASK_TEGRA124 },
-       { "adx1", MOD_LIST_MASK_TEGRA124 },
-       { "afc0", MOD_LIST_MASK_TEGRA124 },
-       { "afc1", MOD_LIST_MASK_TEGRA124 },
-       { "afc2", MOD_LIST_MASK_TEGRA124 },
-       { "afc3", MOD_LIST_MASK_TEGRA124 },
-       { "afc4", MOD_LIST_MASK_TEGRA124 },
-       { "afc5", MOD_LIST_MASK_TEGRA124 },
-};
-
 #define LAST_REG(name) \
        (TEGRA30_AHUB_##name + \
         (TEGRA30_AHUB_##name##_STRIDE * TEGRA30_AHUB_##name##_COUNT) - 4)
@@ -484,17 +449,14 @@ static const struct regmap_config 
tegra30_ahub_ahub_regmap_config = {
 };
 
 static struct tegra30_ahub_soc_data soc_data_tegra30 = {
-       .mod_list_mask = MOD_LIST_MASK_TEGRA30,
        .set_audio_cif = tegra30_ahub_set_cif,
 };
 
 static struct tegra30_ahub_soc_data soc_data_tegra114 = {
-       .mod_list_mask = MOD_LIST_MASK_TEGRA114,
        .set_audio_cif = tegra30_ahub_set_cif,
 };
 
 static struct tegra30_ahub_soc_data soc_data_tegra124 = {
-       .mod_list_mask = MOD_LIST_MASK_TEGRA124,
        .set_audio_cif = tegra124_ahub_set_cif,
 };
 
@@ -510,7 +472,6 @@ static int tegra30_ahub_probe(struct platform_device *pdev)
        const struct of_device_id *match;
        const struct tegra30_ahub_soc_data *soc_data;
        struct reset_control *rst;
-       int i;
        struct resource *res0;
        void __iomem *regs_apbif, *regs_ahub;
        int ret = 0;
@@ -528,26 +489,17 @@ static int tegra30_ahub_probe(struct platform_device 
*pdev)
         * operate correctly, all devices on this bus must be out of reset.
         * Ensure that here.
         */
-       for (i = 0; i < ARRAY_SIZE(configlink_mods); i++) {
-               if (!(configlink_mods[i].mod_list_mask &
-                                       soc_data->mod_list_mask))
-                       continue;
-
-               rst = reset_control_get_exclusive(&pdev->dev,
-                                                 configlink_mods[i].rst_name);
-               if (IS_ERR(rst)) {
-                       dev_err(&pdev->dev, "Can't get reset %s\n",
-                               configlink_mods[i].rst_name);
-                       ret = PTR_ERR(rst);
-                       return ret;
-               }
-
-               ret = reset_control_deassert(rst);
-               reset_control_put(rst);
-               if (ret)
-                       return ret;
+       rst = of_reset_control_array_get_exclusive(pdev->dev.of_node);
+       if (IS_ERR(rst)) {
+               dev_err(&pdev->dev, "Can't get reset: %pe\n", rst);
+               return PTR_ERR(rst);
        }
 
+       ret = reset_control_deassert(rst);
+       reset_control_put(rst);
+       if (ret)
+               return ret;
+
        ahub = devm_kzalloc(&pdev->dev, sizeof(struct tegra30_ahub),
                            GFP_KERNEL);
        if (!ahub)
diff --git a/sound/soc/tegra/tegra30_ahub.h b/sound/soc/tegra/tegra30_ahub.h
index 6889c5f23d02..5a2500b4ea06 100644
--- a/sound/soc/tegra/tegra30_ahub.h
+++ b/sound/soc/tegra/tegra30_ahub.h
@@ -491,7 +491,6 @@ void tegra124_ahub_set_cif(struct regmap *regmap, unsigned 
int reg,
                           struct tegra30_ahub_cif_conf *conf);
 
 struct tegra30_ahub_soc_data {
-       u32 mod_list_mask;
        void (*set_audio_cif)(struct regmap *regmap,
                              unsigned int reg,
                              struct tegra30_ahub_cif_conf *conf);
-- 
2.29.2

Reply via email to