]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
regcache: Split regcache_count_cacheable_registers() helper
authorAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Tue, 10 Feb 2026 16:09:09 +0000 (17:09 +0100)
committerMark Brown <broonie@kernel.org>
Sun, 22 Feb 2026 23:54:25 +0000 (23:54 +0000)
The introduced helper allows to check for the non-cacheable configurations
earlier during initialisation.

Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://patch.msgid.link/20260210161058.53093-3-andriy.shevchenko@linux.intel.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/base/regmap/regcache.c

index d41cdb39c78f15fed2cd80678d297ff44145d190..73cfe8120669cb2db252a5549849d4a2630aa9f2 100644 (file)
@@ -42,13 +42,10 @@ void regcache_sort_defaults(struct reg_default *defaults, unsigned int ndefaults
 }
 EXPORT_SYMBOL_GPL(regcache_sort_defaults);
 
-static int regcache_hw_init(struct regmap *map)
+static int regcache_count_cacheable_registers(struct regmap *map)
 {
-       int i, j;
-       int ret;
        int count;
-       unsigned int reg, val;
-       void *tmp_buf;
+       int i;
 
        /* calculate the size of reg_defaults */
        for (count = 0, i = 0; i < map->num_reg_defaults_raw; i++)
@@ -57,10 +54,18 @@ static int regcache_hw_init(struct regmap *map)
                        count++;
 
        /* all registers are unreadable or volatile, so just bypass */
-       if (!count) {
+       if (!count)
                map->cache_bypass = true;
-               return 0;
-       }
+
+       return count;
+}
+
+static int regcache_hw_init(struct regmap *map, int count)
+{
+       int i, j;
+       int ret;
+       unsigned int reg, val;
+       void *tmp_buf;
 
        map->num_reg_defaults = count;
        map->reg_defaults = kmalloc_objs(struct reg_default, count);
@@ -129,6 +134,7 @@ err_free:
 
 int regcache_init(struct regmap *map, const struct regmap_config *config)
 {
+       int count = 0;
        int ret;
        int i;
        void *tmp_buf;
@@ -193,15 +199,17 @@ int regcache_init(struct regmap *map, const struct regmap_config *config)
                        return -ENOMEM;
                map->reg_defaults = tmp_buf;
        } else if (map->num_reg_defaults_raw) {
+               count = regcache_count_cacheable_registers(map);
+               if (map->cache_bypass)
+                       return 0;
+
                /* Some devices such as PMICs don't have cache defaults,
                 * we cope with this by reading back the HW registers and
                 * crafting the cache defaults by hand.
                 */
-               ret = regcache_hw_init(map);
+               ret = regcache_hw_init(map, count);
                if (ret < 0)
                        return ret;
-               if (map->cache_bypass)
-                       return 0;
        }
 
        if (!map->max_register_is_set && map->num_reg_defaults_raw) {