dm: test: Add test case for dev_get_dma_ranges()
authorNicolas Saenz Julienne <nsaenzjulienne@suse.de>
Tue, 12 Jan 2021 12:55:23 +0000 (13:55 +0100)
committerMatthias Brugger <mbrugger@suse.com>
Thu, 18 Feb 2021 10:56:25 +0000 (11:56 +0100)
Introduce some new nodes in sandbox's test device-tree and dm tests in
order to validate dev_get_dma_range().

Signed-off-by: Nicolas Saenz Julienne <nsaenzjulienne@suse.de>
Reviewed-by: Simon Glass <sjg@chromium.org>
Tested-by: Peter Robinson <pbrobinson@gmail.com>
Signed-off-by: Matthias Brugger <mbrugger@suse.com>
arch/sandbox/dts/test.dts
test/dm/Makefile
test/dm/read.c [new file with mode: 0644]

index e95f463..c135881 100644 (file)
                test5-gpios = <&gpio_a 19>;
        };
 
+       mmio-bus@0 {
+               #address-cells = <1>;
+               #size-cells = <1>;
+               compatible = "denx,u-boot-test-bus";
+               dma-ranges = <0x10000000 0x00000000 0x00040000>;
+
+               subnode@0 {
+                       compatible = "denx,u-boot-fdt-test";
+               };
+       };
+
+       mmio-bus@1 {
+               #address-cells = <1>;
+               #size-cells = <1>;
+               compatible = "denx,u-boot-test-bus";
+       };
+
        acpi_test1: acpi-test {
                compatible = "denx,u-boot-acpi-test";
                acpi-ssdt-test-data = "ab";
index e70e50f..c363ca4 100644 (file)
@@ -15,6 +15,7 @@ obj-$(CONFIG_UT_DM) += test-fdt.o
 obj-$(CONFIG_UT_DM) += test-uclass.o
 
 obj-$(CONFIG_UT_DM) += core.o
+obj-$(CONFIG_UT_DM) += read.o
 ifneq ($(CONFIG_SANDBOX),)
 obj-$(CONFIG_ACPIGEN) += acpi.o
 obj-$(CONFIG_ACPIGEN) += acpigen.o
diff --git a/test/dm/read.c b/test/dm/read.c
new file mode 100644 (file)
index 0000000..7768aa2
--- /dev/null
@@ -0,0 +1,49 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (c) 2020 Nicolas Saenz Julienne <nsaenzjulienne@suse.de>
+ */
+
+#include <common.h>
+#include <dm.h>
+#include <dm/device.h>
+#include <dm/ofnode.h>
+#include <dm/root.h>
+#include <dm/test.h>
+#include <dm/uclass-internal.h>
+#include <test/ut.h>
+
+static int dm_test_dma_ranges(struct unit_test_state *uts)
+{
+       struct udevice *dev;
+       phys_addr_t cpu;
+       dma_addr_t bus;
+       ofnode node;
+       u64 size;
+
+       /* dma-ranges are on the device's node */
+       node = ofnode_path("/mmio-bus@0");
+       ut_assert(ofnode_valid(node));
+       ut_assertok(uclass_get_device_by_ofnode(UCLASS_TEST_BUS, node, &dev));
+       ut_assertok(dev_get_dma_range(dev, &cpu, &bus, &size));
+       ut_asserteq_64(0x40000, size);
+       ut_asserteq_64(0x0, cpu);
+       ut_asserteq_64(0x10000000, bus);
+
+       /* dma-ranges are on the bus' node */
+       node = ofnode_path("/mmio-bus@0/subnode@0");
+       ut_assert(ofnode_valid(node));
+       ut_assertok(uclass_get_device_by_ofnode(UCLASS_TEST_FDT, node, &dev));
+       ut_assertok(dev_get_dma_range(dev, &cpu, &bus, &size));
+       ut_asserteq_64(0x40000, size);
+       ut_asserteq_64(0x0, cpu);
+       ut_asserteq_64(0x10000000, bus);
+
+       /* No dma-ranges available */
+       node = ofnode_path("/mmio-bus@1");
+       ut_assert(ofnode_valid(node));
+       ut_assertok(uclass_get_device_by_ofnode(UCLASS_TEST_BUS, node, &dev));
+       ut_asserteq(-ENOENT, dev_get_dma_range(dev, &cpu, &bus, &size));
+
+       return 0;
+}
+DM_TEST(dm_test_dma_ranges, UT_TESTF_SCAN_PDATA | UT_TESTF_SCAN_FDT);