summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRajan Vaja <rajan.vaja@xilinx.com>2018-09-19 03:43:46 -0700
committerSimon Glass <sjg@chromium.org>2018-09-29 11:49:35 -0600
commit31b8217e83a63d1c8c70edcdcdf5aff3b1791640 (patch)
treed402e86d8d1045f15be37041c5772ea1f1e07604
parente7a52ba65be227f4fa06b851d1d92af1bef694e0 (diff)
downloadu-boot-31b8217e83a63d1c8c70edcdcdf5aff3b1791640.tar.gz
dm: test: Add "/firmware" node scan test
Add a test which verifies that all subnodes under "/firmware" nodes are scanned. Signed-off-by: Rajan Vaja <rajan.vaja@xilinx.com> Reviewed-by: Simon Glass <sjg@chromium.org> Added 'imply FIRMWARE' to sandbox Kconfig to fix test failures, fixed ordering of lines in arch/sandbox/dts/test.dts and test/dm/Makefile, updated #if condition in drivers/firmware/firmware-uclass.c: Signed-off-by: Simon Glass <sjg@chromium.org>
-rw-r--r--arch/Kconfig1
-rw-r--r--arch/sandbox/dts/test.dts6
-rw-r--r--drivers/firmware/Makefile1
-rw-r--r--drivers/firmware/firmware-sandbox.c20
-rw-r--r--drivers/firmware/firmware-uclass.c2
-rw-r--r--test/dm/Makefile1
-rw-r--r--test/dm/firmware.c22
7 files changed, 52 insertions, 1 deletions
diff --git a/arch/Kconfig b/arch/Kconfig
index 11900b02b9..9b4bcbf2fd 100644
--- a/arch/Kconfig
+++ b/arch/Kconfig
@@ -89,6 +89,7 @@ config SANDBOX
imply CMD_SF_TEST
imply CRC32_VERIFY
imply FAT_WRITE
+ imply FIRMWARE
imply HASH_VERIFY
imply LZMA
imply SCSI
diff --git a/arch/sandbox/dts/test.dts b/arch/sandbox/dts/test.dts
index 751c13b51d..42ceeb994e 100644
--- a/arch/sandbox/dts/test.dts
+++ b/arch/sandbox/dts/test.dts
@@ -190,6 +190,12 @@
fake-host-hwaddr = [00 00 66 44 22 22];
};
+ firmware {
+ sandbox_firmware: sandbox-firmware {
+ compatible = "sandbox,firmware";
+ };
+ };
+
gpio_a: base-gpios {
compatible = "sandbox,gpio";
gpio-controller;
diff --git a/drivers/firmware/Makefile b/drivers/firmware/Makefile
index 1cdda14977..6cb83582b9 100644
--- a/drivers/firmware/Makefile
+++ b/drivers/firmware/Makefile
@@ -1,3 +1,4 @@
obj-$(CONFIG_FIRMWARE) += firmware-uclass.o
obj-$(CONFIG_ARM_PSCI_FW) += psci.o
obj-$(CONFIG_TI_SCI_PROTOCOL) += ti_sci.o
+obj-$(CONFIG_SANDBOX) += firmware-sandbox.o
diff --git a/drivers/firmware/firmware-sandbox.c b/drivers/firmware/firmware-sandbox.c
new file mode 100644
index 0000000000..d970d75f78
--- /dev/null
+++ b/drivers/firmware/firmware-sandbox.c
@@ -0,0 +1,20 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * sandbox firmware driver
+ *
+ * Copyright (C) 2018 Xilinx, Inc.
+ */
+
+#include <common.h>
+#include <dm.h>
+
+static const struct udevice_id generic_sandbox_firmware_ids[] = {
+ { .compatible = "sandbox,firmware" },
+ { }
+};
+
+U_BOOT_DRIVER(sandbox_firmware) = {
+ .name = "sandbox_firmware",
+ .id = UCLASS_FIRMWARE,
+ .of_match = generic_sandbox_firmware_ids,
+};
diff --git a/drivers/firmware/firmware-uclass.c b/drivers/firmware/firmware-uclass.c
index 3d33b6deba..7fcd7fb904 100644
--- a/drivers/firmware/firmware-uclass.c
+++ b/drivers/firmware/firmware-uclass.c
@@ -7,7 +7,7 @@
UCLASS_DRIVER(firmware) = {
.id = UCLASS_FIRMWARE,
.name = "firmware",
-#if CONFIG_IS_ENABLED(OF_CONTROL)
+#if CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)
.post_bind = dm_scan_fdt_dev,
#endif
};
diff --git a/test/dm/Makefile b/test/dm/Makefile
index d7f5d6b061..00acc7f242 100644
--- a/test/dm/Makefile
+++ b/test/dm/Makefile
@@ -17,6 +17,7 @@ obj-$(CONFIG_BLK) += blk.o
obj-$(CONFIG_BOARD) += board.o
obj-$(CONFIG_CLK) += clk.o
obj-$(CONFIG_DM_ETH) += eth.o
+obj-$(CONFIG_FIRMWARE) += firmware.o
obj-$(CONFIG_DM_GPIO) += gpio.o
obj-$(CONFIG_DM_I2C) += i2c.o
obj-$(CONFIG_LED) += led.o
diff --git a/test/dm/firmware.c b/test/dm/firmware.c
new file mode 100644
index 0000000000..60fdcbb33f
--- /dev/null
+++ b/test/dm/firmware.c
@@ -0,0 +1,22 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (C) 2018 Xilinx, Inc.
+ */
+
+#include <common.h>
+#include <dm.h>
+#include <syscon.h>
+#include <asm/test.h>
+#include <dm/test.h>
+#include <test/ut.h>
+
+/* Base test of firmware probe */
+static int dm_test_firmware_probe(struct unit_test_state *uts)
+{
+ struct udevice *dev;
+
+ ut_assertok(uclass_get_device_by_name(UCLASS_FIRMWARE,
+ "sandbox-firmware", &dev));
+ return 0;
+}
+DM_TEST(dm_test_firmware_probe, DM_TESTF_SCAN_FDT);