On Mon, Nov 28, 2016 at 06:05:37PM +0200, Pantelis Antoniou wrote: > Add a test that checks for existence or not of a node. > It is useful for testing the various cases when generating > symbols and fixups for dynamic device tree objects. > > Signed-off-by: Pantelis Antoniou <pantelis.antoniou@xxxxxxxxxxxx> Can you please add a test-for-the-test by putting a couple of invocations of this on test_tree1 into the runner script (one 'exists' and one 'not-exists' should suffice). > --- > tests/.gitignore | 1 + > tests/Makefile.tests | 3 +- > tests/check_path.c | 82 ++++++++++++++++++++++++++++++++++++++++++++++++++++ > 3 files changed, 85 insertions(+), 1 deletion(-) > create mode 100644 tests/check_path.c > > diff --git a/tests/.gitignore b/tests/.gitignore > index 354b565..9e209d5 100644 > --- a/tests/.gitignore > +++ b/tests/.gitignore > @@ -8,6 +8,7 @@ tmp.* > /asm_tree_dump > /boot-cpuid > /char_literal > +/check_path > /del_node > /del_property > /dtbs_equal_ordered > diff --git a/tests/Makefile.tests b/tests/Makefile.tests > index eb039c5..3d7a4f8 100644 > --- a/tests/Makefile.tests > +++ b/tests/Makefile.tests > @@ -25,7 +25,8 @@ LIB_TESTS_L = get_mem_rsv \ > integer-expressions \ > property_iterate \ > subnode_iterate \ > - overlay overlay_bad_fixup > + overlay overlay_bad_fixup \ > + check_path > LIB_TESTS = $(LIB_TESTS_L:%=$(TESTS_PREFIX)%) > > LIBTREE_TESTS_L = truncated_property > diff --git a/tests/check_path.c b/tests/check_path.c > new file mode 100644 > index 0000000..0d6a73b > --- /dev/null > +++ b/tests/check_path.c > @@ -0,0 +1,82 @@ > +/* > + * libfdt - Flat Device Tree manipulation > + * Testcase for node existence > + * Copyright (C) 2016 Konsulko 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 <stdio.h> > + > +#include <libfdt.h> > + > +#include "tests.h" > + > +#define CHECK(code) \ > + { \ > + if (code) \ > + FAIL(#code ": %s", fdt_strerror(code)); \ > + } > + > +/* 4k ought to be enough for anybody */ > +#define FDT_COPY_SIZE (4 * 1024) > + > +static void *open_dt(char *path) > +{ > + void *dt, *copy; > + > + dt = load_blob(path); > + copy = xmalloc(FDT_COPY_SIZE); > + > + /* > + * Resize our DTs to 4k so that we have room to operate on > + */ > + CHECK(fdt_open_into(dt, copy, FDT_COPY_SIZE)); > + > + return copy; > +} > + > +int main(int argc, char *argv[]) > +{ > + void *fdt_base; > + int fail_config, exists, check_exists; > + > + test_init(argc, argv); > + fail_config = 0; > + > + if (argc != 4) > + fail_config = 1; > + > + if (!fail_config) { > + if (!strcmp(argv[2], "exists")) > + check_exists = 1; > + else if (!strcmp(argv[2], "not-exists")) > + check_exists = 0; > + else > + fail_config = 1; > + } > + > + if (fail_config) > + CONFIG("Usage: %s <base dtb> <[exists|not-exists]> <node-path>", argv[0]); > + > + fdt_base = open_dt(argv[1]); > + > + exists = fdt_path_offset(fdt_base, argv[3]) >= 0; > + > + if (exists == check_exists) > + PASS(); > + else > + FAIL(); > +} -- David Gibson | I'll have my music baroque, and my code david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_ | _way_ _around_! http://www.ozlabs.org/~dgibson
Attachment:
signature.asc
Description: PGP signature