[PATCH v6 0/2] regmap: Introduce validity info for flat cache
From: Sander Vanheule
Date: Wed Oct 29 2025 - 04:13:02 EST
The flat cache behaves differently from the other caches, in that it has
no way of knowing if a cache entry is valid. Initialization has to
happen either by providing defaults, by loading defaults from hardware
(via num_reg_defaults_raw), or by performing the required register
writes. This difference in behavior may be unexpected to the user [1].
To provide feature parity between the different cache types, a new
variant of the flat cache is proposed. This allows user to migrate to
the sparse flat cache (or a different cache type) when possible.
In order to encourage migration, the second patch adds a new warning to
inform the user of their suspicious cache.
[1] https://lore.kernel.org/linux-gpio/e461ca08-ad28-44fe-85f1-afe332c1d43d@xxxxxxxx/
---
Changes since v5:
Link: https://lore.kernel.org/lkml/20251023135032.229511-1-sander@xxxxxxxxxxxxx/
- zero-initialize cache for compatibiliy
- Update regcache_type comment to document the difference between the
flat caches
Changes since v4:
Link: https://lore.kernel.org/lkml/20251022200408.63027-1-sander@xxxxxxxxxxxxx/
- Improve formatting of log message
- Reduce logging to not confuse KUnit test result parser
- Add sparse flat cache to all KUnit config lists
Changes since v3:
Link: https://lore.kernel.org/lkml/20250109180256.6269-1-sander@xxxxxxxxxxxxx/
- Split changes into two patches to provide a migration path
Changes since v2:
Link: https://lore.kernel.org/all/20250109151106.38645-1-sander@xxxxxxxxxxxxx/
- Complete renaming of index variables so regcache-flat.c compiles again
Changes since v1:
Link: https://lore.kernel.org/all/20241231100256.194753-1-sander@xxxxxxxxxxxxx/
- Fix off-by-one in length for bitmap_clear()
- Add REGCACHE_FLAT to the list of sparse cache tests
Sander Vanheule (2):
regmap: add flat cache with sparse validity
regmap: warn users about uninitialized flat cache
drivers/base/regmap/internal.h | 1 +
drivers/base/regmap/regcache-flat.c | 96 +++++++++++++++++++++++++----
drivers/base/regmap/regcache.c | 1 +
drivers/base/regmap/regmap-kunit.c | 22 +++++++
include/linux/regmap.h | 17 +++--
5 files changed, 120 insertions(+), 17 deletions(-)
--
2.51.0