test: dm: core: Add a test case for driver marked with DM_FLAG_PRE_RELOC flag
authorBin Meng <bmeng.cn@gmail.com>
Thu, 11 Oct 2018 05:07:01 +0000 (22:07 -0700)
committerSimon Glass <sjg@chromium.org>
Wed, 14 Nov 2018 17:16:27 +0000 (09:16 -0800)
Now that we fixed the pre-relocation driver binding for driver marked
with DM_FLAG_PRE_RELOC flag, add a test case to cover that scenario.

Signed-off-by: Bin Meng <bmeng.cn@gmail.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
arch/sandbox/dts/test.dts
test/dm/bus.c
test/dm/test-fdt.c

index 57e0dd766317ac87afd10b2f6355811b097cee64..ffc93d05ba127d3a212c40be92d81dc6e5e4d8fc 100644 (file)
                compatible = "denx,u-boot-fdt-test";
        };
 
+       h-test {
+               compatible = "denx,u-boot-fdt-test1";
+       };
+
        clocks {
                clk_fixed: clk-fixed {
                        compatible = "fixed-clock";
index 08137a2216a29babddd709a49b613d2e57df50c7..d0cd5a009cdebd5eda63d8c47705ca5b01154eb1 100644 (file)
@@ -107,7 +107,7 @@ UCLASS_DRIVER(testbus) = {
 /* Test that we can probe for children */
 static int dm_test_bus_children(struct unit_test_state *uts)
 {
-       int num_devices = 7;
+       int num_devices = 8;
        struct udevice *bus;
        struct uclass *uc;
 
index 79b1f1de452dde1ac23f2e0a2779995eec884142..3da384f4c5887be568b15209837a1f1949511be2 100644 (file)
@@ -84,6 +84,25 @@ U_BOOT_DRIVER(testfdt_drv) = {
        .platdata_auto_alloc_size = sizeof(struct dm_test_pdata),
 };
 
+static const struct udevice_id testfdt1_ids[] = {
+       {
+               .compatible = "denx,u-boot-fdt-test1",
+               .data = DM_TEST_TYPE_FIRST },
+       { }
+};
+
+U_BOOT_DRIVER(testfdt1_drv) = {
+       .name   = "testfdt1_drv",
+       .of_match       = testfdt1_ids,
+       .id     = UCLASS_TEST_FDT,
+       .ofdata_to_platdata = testfdt_ofdata_to_platdata,
+       .probe  = testfdt_drv_probe,
+       .ops    = &test_ops,
+       .priv_auto_alloc_size = sizeof(struct dm_test_priv),
+       .platdata_auto_alloc_size = sizeof(struct dm_test_pdata),
+       .flags = DM_FLAG_PRE_RELOC,
+};
+
 /* From here is the testfdt uclass code */
 int testfdt_ping(struct udevice *dev, int pingval, int *pingret)
 {
@@ -168,7 +187,7 @@ int dm_check_devices(struct unit_test_state *uts, int num_devices)
 /* Test that FDT-based binding works correctly */
 static int dm_test_fdt(struct unit_test_state *uts)
 {
-       const int num_devices = 7;
+       const int num_devices = 8;
        struct udevice *dev;
        struct uclass *uc;
        int ret;
@@ -208,8 +227,12 @@ static int dm_test_fdt_pre_reloc(struct unit_test_state *uts)
        ret = uclass_get(UCLASS_TEST_FDT, &uc);
        ut_assert(!ret);
 
-       /* These is only one pre-reloc device */
-       ut_asserteq(1, list_count_items(&uc->dev_head));
+       /*
+        * These are 2 pre-reloc devices:
+        * one with "u-boot,dm-pre-reloc" property (a-test node), and the other
+        * one whose driver marked with DM_FLAG_PRE_RELOC flag (h-test node).
+        */
+       ut_asserteq(2, list_count_items(&uc->dev_head));
 
        return 0;
 }