|
@@ -0,0 +1,45 @@
|
|
|
+From b7c1e53751cb3990153084f31c41f25fde3b629c Mon Sep 17 00:00:00 2001
|
|
|
+From: Miquel Raynal <[email protected]>
|
|
|
+Date: Fri, 24 Nov 2023 20:38:14 +0100
|
|
|
+Subject: [PATCH] nvmem: Do not expect fixed layouts to grab a layout driver
|
|
|
+MIME-Version: 1.0
|
|
|
+Content-Type: text/plain; charset=UTF-8
|
|
|
+Content-Transfer-Encoding: 8bit
|
|
|
+
|
|
|
+Two series lived in parallel for some time, which led to this situation:
|
|
|
+- The nvmem-layout container is used for dynamic layouts
|
|
|
+- We now expect fixed layouts to also use the nvmem-layout container but
|
|
|
+this does not require any additional driver, the support is built-in the
|
|
|
+nvmem core.
|
|
|
+
|
|
|
+Ensure we don't refuse to probe for wrong reasons.
|
|
|
+
|
|
|
+Fixes: 27f699e578b1 ("nvmem: core: add support for fixed cells *layout*")
|
|
|
+Cc: [email protected]
|
|
|
+Reported-by: Luca Ceresoli <[email protected]>
|
|
|
+Signed-off-by: Miquel Raynal <[email protected]>
|
|
|
+Tested-by: Rafał Miłecki <[email protected]>
|
|
|
+Tested-by: Luca Ceresoli <[email protected]>
|
|
|
+Reviewed-by: Luca Ceresoli <[email protected]>
|
|
|
+
|
|
|
+Link: https://lore.kernel.org/r/[email protected]
|
|
|
+Signed-off-by: Greg Kroah-Hartman <[email protected]>
|
|
|
+---
|
|
|
+ drivers/nvmem/core.c | 6 ++++++
|
|
|
+ 1 file changed, 6 insertions(+)
|
|
|
+
|
|
|
+--- a/drivers/nvmem/core.c
|
|
|
++++ b/drivers/nvmem/core.c
|
|
|
+@@ -797,6 +797,12 @@ static struct nvmem_layout *nvmem_layout
|
|
|
+ if (!layout_np)
|
|
|
+ return NULL;
|
|
|
+
|
|
|
++ /* Fixed layouts don't have a matching driver */
|
|
|
++ if (of_device_is_compatible(layout_np, "fixed-layout")) {
|
|
|
++ of_node_put(layout_np);
|
|
|
++ return NULL;
|
|
|
++ }
|
|
|
++
|
|
|
+ /*
|
|
|
+ * In case the nvmem device was built-in while the layout was built as a
|
|
|
+ * module, we shall manually request the layout driver loading otherwise
|