mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-25 13:49:26 +00:00
51c397c33f
All patches automatically rebased. Build system: x86_64 Build-tested: ramips/tplink_archer-a6-v3, filogic/xiaomi_redmi-router-ax6000-ubootmod Run-tested: ramips/tplink_archer-a6-v3, filogic/xiaomi_redmi-router-ax6000-ubootmod Signed-off-by: John Audia <therealgraysky@proton.me> (cherry picked from commit 1f5fce27c195373fedcf233a48470de97752058f)
38 lines
1.4 KiB
Diff
38 lines
1.4 KiB
Diff
From 076a67c839a4fdadb9edce5ff71878b3ac8a71ed Mon Sep 17 00:00:00 2001
|
|
From: Phil Elwell <phil@raspberrypi.com>
|
|
Date: Thu, 6 Feb 2020 12:23:15 +0000
|
|
Subject: [PATCH] of: overlay: Correct symbol path fixups
|
|
|
|
When symbols from overlays are added to the live tree their paths must
|
|
be rebased. The translated symbol is normally the result of joining
|
|
the fragment-relative path (with a leading "/") to the target path
|
|
(either copied directly from the "target-path" property or resolved
|
|
from the phandle). This translation fails when the target is the root
|
|
node (a common case for Raspberry Pi overlays) because the resulting
|
|
path starts with a double slash. For example, if target-path is "/" and
|
|
the fragment adds a node called "newnode", the label associated with
|
|
that node will be assigned the path "//newnode", which can't be found
|
|
in the tree.
|
|
|
|
Fix the failure case by explicitly replacing a target path of "/" with
|
|
an empty string.
|
|
|
|
Fixes: d1651b03c2df ("of: overlay: add overlay symbols to live device tree")
|
|
|
|
Signed-off-by: Phil Elwell <phil@raspberrypi.com>
|
|
---
|
|
drivers/of/overlay.c | 2 ++
|
|
1 file changed, 2 insertions(+)
|
|
|
|
--- a/drivers/of/overlay.c
|
|
+++ b/drivers/of/overlay.c
|
|
@@ -241,6 +241,8 @@ static struct property *dup_and_fixup_sy
|
|
if (!target_path)
|
|
return NULL;
|
|
target_path_len = strlen(target_path);
|
|
+ if (!strcmp(target_path, "/"))
|
|
+ target_path_len = 0;
|
|
|
|
new_prop = kzalloc(sizeof(*new_prop), GFP_KERNEL);
|
|
if (!new_prop)
|