test: fdtdec: test fdtdec_set_carveout()
authorLaurentiu Tudor <laurentiu.tudor@nxp.com>
Fri, 3 Apr 2020 10:43:04 +0000 (13:43 +0300)
committerSimon Glass <sjg@chromium.org>
Thu, 16 Apr 2020 14:07:58 +0000 (08:07 -0600)
Add a new test for fdtdec_set_carveout().

Signed-off-by: Laurentiu Tudor <laurentiu.tudor@nxp.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
Drop blank line at EFO:
Signed-off-by: Simon Glass <sjg@chromium.org>
test/dm/Makefile
test/dm/fdtdec.c [new file with mode: 0644]

index dd1ceff86c0cc4412d85ef736b221138045fe309..53caa29fbbacc527f4c5770429c5d4ea7aa3e80b 100644 (file)
@@ -31,6 +31,7 @@ obj-$(CONFIG_LED) += led.o
 obj-$(CONFIG_DM_MAILBOX) += mailbox.o
 obj-$(CONFIG_DM_MMC) += mmc.o
 obj-y += ofnode.o
+obj-y += fdtdec.o
 obj-$(CONFIG_OSD) += osd.o
 obj-$(CONFIG_DM_VIDEO) += panel.o
 obj-$(CONFIG_DM_PCI) += pci.o
diff --git a/test/dm/fdtdec.c b/test/dm/fdtdec.c
new file mode 100644 (file)
index 0000000..b2f75b5
--- /dev/null
@@ -0,0 +1,59 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright 2020 NXP
+ */
+
+#include <common.h>
+#include <dm.h>
+#include <dm/of_extra.h>
+#include <dm/test.h>
+#include <test/ut.h>
+
+static int dm_test_fdtdec_set_carveout(struct unit_test_state *uts)
+{
+       struct fdt_memory resv;
+       void *blob;
+       const fdt32_t *prop;
+       int blob_sz, len, offset;
+
+       blob_sz = fdt_totalsize(gd->fdt_blob) + 4096;
+       blob = malloc(blob_sz);
+       ut_assertnonnull(blob);
+
+       /* Make a writtable copy of the fdt blob */
+       ut_assertok(fdt_open_into(gd->fdt_blob, blob, blob_sz));
+
+       resv.start = 0x1000;
+       resv.end = 0x2000;
+       ut_assertok(fdtdec_set_carveout(blob, "/a-test",
+                                       "memory-region", 2, "test_resv1",
+                                       &resv));
+
+       resv.start = 0x10000;
+       resv.end = 0x20000;
+       ut_assertok(fdtdec_set_carveout(blob, "/a-test",
+                                       "memory-region", 1, "test_resv2",
+                                       &resv));
+
+       resv.start = 0x100000;
+       resv.end = 0x200000;
+       ut_assertok(fdtdec_set_carveout(blob, "/a-test",
+                                       "memory-region", 0, "test_resv3",
+                                       &resv));
+
+       offset = fdt_path_offset(blob, "/a-test");
+       ut_assert(offset > 0);
+       prop = fdt_getprop(blob, offset, "memory-region", &len);
+       ut_assertnonnull(prop);
+
+       ut_asserteq(len, 12);
+       ut_assert(fdt_node_offset_by_phandle(blob, fdt32_to_cpu(prop[0])) > 0);
+       ut_assert(fdt_node_offset_by_phandle(blob, fdt32_to_cpu(prop[1])) > 0);
+       ut_assert(fdt_node_offset_by_phandle(blob, fdt32_to_cpu(prop[2])) > 0);
+
+       free(blob);
+
+       return 0;
+}
+DM_TEST(dm_test_fdtdec_set_carveout,
+       DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT | DM_TESTF_FLAT_TREE);