In preparation for making the kmalloc family of allocators type aware,
we need to make sure that the returned type from the allocation matches
the type of the variable being assigned. (Before, the allocator would
always return "void *", which can be implicitly cast to any pointer type.)

The assigned type is "const struct cpumask **", but the returned type,
while matching, is not const qualified. To get them exactly matching,
just use the dereferenced pointer for the sizeof().

Signed-off-by: Kees Cook <[email protected]>
---
Cc: Wangyang Guo <[email protected]>
Cc: Andrew Morton <[email protected]>
Cc: Thomas Gleixner <[email protected]>
---
 lib/group_cpus.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/lib/group_cpus.c b/lib/group_cpus.c
index a93df70919df..d496c5001961 100644
--- a/lib/group_cpus.c
+++ b/lib/group_cpus.c
@@ -320,7 +320,7 @@ static int alloc_cluster_groups(unsigned int ncpus,
                goto no_cluster;
 
        /* Allocate memory based on cluster number. */
-       clusters = kcalloc(ncluster, sizeof(struct cpumask *), GFP_KERNEL);
+       clusters = kcalloc(ncluster, sizeof(*clusters), GFP_KERNEL);
        if (!clusters)
                goto no_cluster;
        cluster_groups = kcalloc(ncluster, sizeof(struct node_groups), 
GFP_KERNEL);
-- 
2.34.1


Reply via email to