libfdt: Add support for using aliases in fdt_path_offset()
If the path doesn't start with '/' check to see if it matches some alias under "/aliases" and substitute the matching alias value in the path and retry the lookup. Signed-off-by: Kumar Gala <galak@kernel.crashing.org> Acked-by: David Gibson <david@gibson.dropbear.id.au>main
parent
cb650ae143
commit
02cc83540b
|
@ -139,8 +139,25 @@ int fdt_path_offset(const void *fdt, const char *path)
|
||||||
|
|
||||||
FDT_CHECK_HEADER(fdt);
|
FDT_CHECK_HEADER(fdt);
|
||||||
|
|
||||||
if (*path != '/')
|
/* see if we have an alias */
|
||||||
return -FDT_ERR_BADPATH;
|
if (*path != '/') {
|
||||||
|
const char *q;
|
||||||
|
int aliasoffset = fdt_path_offset(fdt, "/aliases");
|
||||||
|
|
||||||
|
if (aliasoffset < 0)
|
||||||
|
return -FDT_ERR_BADPATH;
|
||||||
|
|
||||||
|
q = strchr(path, '/');
|
||||||
|
if (!q)
|
||||||
|
q = end;
|
||||||
|
|
||||||
|
p = fdt_getprop_namelen(fdt, aliasoffset, path, q - p, NULL);
|
||||||
|
if (!p)
|
||||||
|
return -FDT_ERR_BADPATH;
|
||||||
|
offset = fdt_path_offset(fdt, p);
|
||||||
|
|
||||||
|
p = q;
|
||||||
|
}
|
||||||
|
|
||||||
while (*p) {
|
while (*p) {
|
||||||
const char *q;
|
const char *q;
|
||||||
|
|
|
@ -11,7 +11,7 @@ LIB_TESTS_L = get_mem_rsv \
|
||||||
open_pack rw_tree1 set_name setprop del_property del_node \
|
open_pack rw_tree1 set_name setprop del_property del_node \
|
||||||
string_escapes references path-references boot-cpuid incbin \
|
string_escapes references path-references boot-cpuid incbin \
|
||||||
dtbs_equal_ordered \
|
dtbs_equal_ordered \
|
||||||
add_subnode_with_nops
|
add_subnode_with_nops path_offset_aliases
|
||||||
LIB_TESTS = $(LIB_TESTS_L:%=$(TESTS_PREFIX)%)
|
LIB_TESTS = $(LIB_TESTS_L:%=$(TESTS_PREFIX)%)
|
||||||
|
|
||||||
LIBTREE_TESTS_L = truncated_property
|
LIBTREE_TESTS_L = truncated_property
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
/dts-v1/;
|
||||||
|
|
||||||
|
/ {
|
||||||
|
aliases {
|
||||||
|
s1 = &sub1;
|
||||||
|
ss1 = &subsub1;
|
||||||
|
sss1 = &subsubsub1;
|
||||||
|
};
|
||||||
|
|
||||||
|
sub1: subnode@1 {
|
||||||
|
compatible = "subnode1";
|
||||||
|
|
||||||
|
subsub1: subsubnode {
|
||||||
|
compatible = "subsubnode1", "subsubnode";
|
||||||
|
|
||||||
|
subsubsub1: subsubsubnode {
|
||||||
|
compatible = "subsubsubnode1", "subsubsubnode";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
|
@ -0,0 +1,59 @@
|
||||||
|
/*
|
||||||
|
* libfdt - Flat Device Tree manipulation
|
||||||
|
* Testcase for fdt_path_offset()
|
||||||
|
* Copyright (C) 2006 David Gibson, IBM Corporation.
|
||||||
|
* Copyright 2008 Kumar Gala, Freescale Semiconductor, Inc.
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2.1 of
|
||||||
|
* the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#include <fdt.h>
|
||||||
|
#include <libfdt.h>
|
||||||
|
|
||||||
|
#include "tests.h"
|
||||||
|
#include "testdata.h"
|
||||||
|
|
||||||
|
void check_alias(void *fdt, const char *full_path, const char *alias_path)
|
||||||
|
{
|
||||||
|
int offset, offset_a;
|
||||||
|
|
||||||
|
offset = fdt_path_offset(fdt, full_path);
|
||||||
|
offset_a = fdt_path_offset(fdt, alias_path);
|
||||||
|
|
||||||
|
if (offset != offset_a)
|
||||||
|
FAIL("Mismatch between %s path_offset (%d) and %s path_offset alias (%d)",
|
||||||
|
full_path, offset, alias_path, offset_a);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
void *fdt;
|
||||||
|
|
||||||
|
test_init(argc, argv);
|
||||||
|
fdt = load_blob_arg(argc, argv);
|
||||||
|
|
||||||
|
check_alias(fdt, "/subnode@1", "s1");
|
||||||
|
check_alias(fdt, "/subnode@1/subsubnode", "ss1");
|
||||||
|
check_alias(fdt, "/subnode@1/subsubnode", "s1/subsubnode");
|
||||||
|
check_alias(fdt, "/subnode@1/subsubnode/subsubsubnode", "sss1");
|
||||||
|
check_alias(fdt, "/subnode@1/subsubnode/subsubsubnode", "ss1/subsubsubnode");
|
||||||
|
check_alias(fdt, "/subnode@1/subsubnode/subsubsubnode", "s1/subsubnode/subsubsubnode");
|
||||||
|
|
||||||
|
PASS();
|
||||||
|
}
|
|
@ -214,6 +214,10 @@ dtc_tests () {
|
||||||
run_dtc_test -I dts -O dtb -o dtc_comments-cmp.test.dtb comments-cmp.dts
|
run_dtc_test -I dts -O dtb -o dtc_comments-cmp.test.dtb comments-cmp.dts
|
||||||
run_test dtbs_equal_ordered dtc_comments.test.dtb dtc_comments-cmp.test.dtb
|
run_test dtbs_equal_ordered dtc_comments.test.dtb dtc_comments-cmp.test.dtb
|
||||||
|
|
||||||
|
# Check aliases support in fdt_path_offset
|
||||||
|
run_dtc_test -I dts -O dtb -o aliases.dtb aliases.dts
|
||||||
|
run_test path_offset_aliases aliases.dtb
|
||||||
|
|
||||||
# Check /include/ directive
|
# Check /include/ directive
|
||||||
run_dtc_test -I dts -O dtb -o includes.test.dtb include0.dts
|
run_dtc_test -I dts -O dtb -o includes.test.dtb include0.dts
|
||||||
run_test dtbs_equal_ordered includes.test.dtb test_tree1.dtb
|
run_test dtbs_equal_ordered includes.test.dtb test_tree1.dtb
|
||||||
|
|
Loading…
Reference in New Issue