]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
regmap: kunit: Use array_size() and sizeof(*ptr) consistently
authorAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Thu, 6 Jun 2024 20:21:02 +0000 (23:21 +0300)
committerMark Brown <broonie@kernel.org>
Fri, 7 Jun 2024 13:29:41 +0000 (14:29 +0100)
Some of the allocations use explit sizeof(type) instead of sizeof(*ptr),
which is fragile. In particular, stress_insert() allocates double
of memory without obvious need for a test. Convert all allocations
to use array_size() and sizeof(*ptr) to eliminate similar mistakes
or wrong memory sizes.

Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20240606202102.3108729-1-andriy.shevchenko@linux.intel.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/base/regmap/regmap-kunit.c

index 31df46cbcae71166780136a402cbd5632a3cc472..9ec91b0de4a669ccbb765dad2df16ff0b609ace2 100644 (file)
@@ -163,7 +163,7 @@ static struct regmap *gen_regmap(struct kunit *test,
                        config->max_register += (BLOCK_TEST_SIZE * config->reg_stride);
        }
 
-       size = (config->max_register + 1) * sizeof(unsigned int);
+       size = array_size(config->max_register + 1, sizeof(*buf));
        buf = kmalloc(size, GFP_KERNEL);
        if (!buf)
                return ERR_PTR(-ENOMEM);
@@ -768,10 +768,9 @@ static void stress_insert(struct kunit *test)
        if (IS_ERR(map))
                return;
 
-       vals = kunit_kcalloc(test, sizeof(unsigned long), config.max_register,
-                            GFP_KERNEL);
+       buf_sz = array_size(sizeof(*vals), config.max_register);
+       vals = kunit_kmalloc(test, buf_sz, GFP_KERNEL);
        KUNIT_ASSERT_FALSE(test, vals == NULL);
-       buf_sz = sizeof(unsigned long) * config.max_register;
 
        get_random_bytes(vals, buf_sz);
 
@@ -1507,15 +1506,16 @@ static struct regmap *gen_raw_regmap(struct kunit *test,
        const struct regmap_test_param *param = test->param_value;
        u16 *buf;
        struct regmap *ret = ERR_PTR(-ENOMEM);
-       size_t size = (config->max_register + 1) * config->reg_bits / 8;
        int i, error;
        struct reg_default *defaults;
+       size_t size;
 
        config->cache_type = param->cache;
        config->val_format_endian = param->val_endian;
        config->disable_locking = config->cache_type == REGCACHE_RBTREE ||
                                        config->cache_type == REGCACHE_MAPLE;
 
+       size = array_size(config->max_register + 1, BITS_TO_BYTES(config->reg_bits));
        buf = kmalloc(size, GFP_KERNEL);
        if (!buf)
                return ERR_PTR(-ENOMEM);
@@ -1615,7 +1615,7 @@ static void raw_read_defaults(struct kunit *test)
        if (IS_ERR(map))
                return;
 
-       val_len = sizeof(*rval) * (config.max_register + 1);
+       val_len = array_size(sizeof(*rval), config.max_register + 1);
        rval = kunit_kmalloc(test, val_len, GFP_KERNEL);
        KUNIT_ASSERT_TRUE(test, rval != NULL);
        if (!rval)