The "fixed-layout" nvmem controller subnode used to be optional wrapper around nvmem controller cells subnodes. The "fixed-layout" node is now mandatory in most cases, but in order to support both recent and legacy DTs, both variants have to be supported.
Implement support for the "fixed-layout" node in the most trivial manner, check whether the nvmem cell supernode is compatible with "fixed-layout" and if it is, proceed one level above it to find the nvmem controller. Signed-off-by: Marek Vasut <[email protected]> --- Cc: Sean Anderson <[email protected]> Cc: Tom Rini <[email protected]> --- drivers/misc/nvmem.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/drivers/misc/nvmem.c b/drivers/misc/nvmem.c index d0cb0a35b81..33e80858565 100644 --- a/drivers/misc/nvmem.c +++ b/drivers/misc/nvmem.c @@ -102,6 +102,7 @@ int nvmem_cell_get_by_index(struct udevice *dev, int index, fdt_size_t size = FDT_SIZE_T_NONE; int ret; struct ofnode_phandle_args args; + ofnode par; dev_dbg(dev, "%s: index=%d\n", __func__, index); @@ -110,7 +111,11 @@ int nvmem_cell_get_by_index(struct udevice *dev, int index, if (ret) return ret; - ret = nvmem_get_device(ofnode_get_parent(args.node), cell); + par = ofnode_get_parent(args.node); + if (ofnode_device_is_compatible(par, "fixed-layout")) + par = ofnode_get_parent(par); + + ret = nvmem_get_device(par, cell); if (ret) return ret; -- 2.51.0

