regmap: maple: Fix cache corruption in regcache_maple_drop()
authorRichard Fitzgerald <rf@opensource.cirrus.com>
Wed, 27 Mar 2024 11:44:06 +0000 (11:44 +0000)
committerMark Brown <broonie@kernel.org>
Wed, 27 Mar 2024 15:00:28 +0000 (15:00 +0000)
When keeping the upper end of a cache block entry, the entry[] array
must be indexed by the offset from the base register of the block,
i.e. max - mas.index.

The code was indexing entry[] by only the register address, leading
to an out-of-bounds access that copied some part of the kernel
memory over the cache contents.

This bug was not detected by the regmap KUnit test because it only
tests with a block of registers starting at 0, so mas.index == 0.

Signed-off-by: Richard Fitzgerald <rf@opensource.cirrus.com>
Fixes: f033c26de5a5 ("regmap: Add maple tree based register cache")
Link: https://msgid.link/r/20240327114406.976986-1-rf@opensource.cirrus.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/base/regmap/regcache-maple.c

index 41edd6a430eb457a76db36e8b7e9c58758bf2fe4..c1776127a572427482bf1c7b7f321326d7a87727 100644 (file)
@@ -145,7 +145,7 @@ static int regcache_maple_drop(struct regmap *map, unsigned int min,
                        upper_index = max + 1;
                        upper_last = mas.last;
 
-                       upper = kmemdup(&entry[max + 1],
+                       upper = kmemdup(&entry[max - mas.index + 1],
                                        ((mas.last - max) *
                                         sizeof(unsigned long)),
                                        map->alloc_flags);