mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-25 06:00:43 +00:00
dm: core: Mirror the chosen node parse logic in the livetree scanning
Commitf2006808f0
: ("dm: core: parse chosen node") added a logic to parse the chosen node during dm_scan_fdt_node(), but unfortunately it missed adding the same logic in dm_scan_fdt_live(). This mirrors the logic in the livetree version. The weird thing is that commitf2006808f0
did update the test case to test such logic, but even if I reset to that commit, the test case still fails, and I have no idea how it could pass. With this fix, the following 2 test cases now pass: Test: dm_test_bus_children: bus.c test/dm/bus.c:112, dm_test_bus_children(): num_devices == list_count_items(&uc->dev_head): Expected 7, got 6 Test: dm_test_fdt: test-fdt.c test/dm/test-fdt.c:184, dm_test_fdt(): num_devices == list_count_items(&uc->dev_head): Expected 7, got 6 Fixes:f2006808f0
("dm: core: parse chosen node") Signed-off-by: Bin Meng <bmeng.cn@gmail.com> Reviewed-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
6244fc64ce
commit
8e39afcd94
1 changed files with 10 additions and 0 deletions
|
@ -222,6 +222,16 @@ static int dm_scan_fdt_live(struct udevice *parent,
|
|||
int ret = 0, err;
|
||||
|
||||
for (np = node_parent->child; np; np = np->sibling) {
|
||||
/* "chosen" node isn't a device itself but may contain some: */
|
||||
if (!strcmp(np->name, "chosen")) {
|
||||
pr_debug("parsing subnodes of \"chosen\"\n");
|
||||
|
||||
err = dm_scan_fdt_live(parent, np, pre_reloc_only);
|
||||
if (err && !ret)
|
||||
ret = err;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!of_device_is_available(np)) {
|
||||
pr_debug(" - ignoring disabled device\n");
|
||||
continue;
|
||||
|
|
Loading…
Reference in a new issue