Commit 851da976 authored by Grant Likely's avatar Grant Likely

of/unittest: Remove test devices after adding them

The of_platform_populate() test cases don't remove the test devices
after they are added. Fix this by adding tests for
of_platform_depopulate().

At the same time rework the selftest() macro to return the test result
value. This makes it easy to use the macro inside an if() condition.
Signed-off-by: default avatarGrant Likely <grant.likely@linaro.org>
parent 5063e25a
...@@ -30,15 +30,17 @@ static struct device_node *nodes[NO_OF_NODES]; ...@@ -30,15 +30,17 @@ static struct device_node *nodes[NO_OF_NODES];
static int last_node_index; static int last_node_index;
static bool selftest_live_tree; static bool selftest_live_tree;
#define selftest(result, fmt, ...) { \ #define selftest(result, fmt, ...) ({ \
if (!(result)) { \ bool failed = !(result); \
if (failed) { \
selftest_results.failed++; \ selftest_results.failed++; \
pr_err("FAIL %s():%i " fmt, __func__, __LINE__, ##__VA_ARGS__); \ pr_err("FAIL %s():%i " fmt, __func__, __LINE__, ##__VA_ARGS__); \
} else { \ } else { \
selftest_results.passed++; \ selftest_results.passed++; \
pr_debug("pass %s():%i\n", __func__, __LINE__); \ pr_debug("pass %s():%i\n", __func__, __LINE__); \
} \ } \
} failed; \
})
static void __init of_selftest_find_node_by_name(void) static void __init of_selftest_find_node_by_name(void)
{ {
...@@ -694,10 +696,13 @@ static void __init of_selftest_match_node(void) ...@@ -694,10 +696,13 @@ static void __init of_selftest_match_node(void)
} }
} }
struct device test_bus = {
.init_name = "unittest-bus",
};
static void __init of_selftest_platform_populate(void) static void __init of_selftest_platform_populate(void)
{ {
int irq; int irq, rc;
struct device_node *np, *child; struct device_node *np, *child, *grandchild;
struct platform_device *pdev; struct platform_device *pdev;
struct of_device_id match[] = { struct of_device_id match[] = {
{ .compatible = "test-device", }, { .compatible = "test-device", },
...@@ -722,20 +727,32 @@ static void __init of_selftest_platform_populate(void) ...@@ -722,20 +727,32 @@ static void __init of_selftest_platform_populate(void)
irq = platform_get_irq(pdev, 0); irq = platform_get_irq(pdev, 0);
selftest(irq < 0 && irq != -EPROBE_DEFER, "device parsing error failed - %d\n", irq); selftest(irq < 0 && irq != -EPROBE_DEFER, "device parsing error failed - %d\n", irq);
np = of_find_node_by_path("/testcase-data/platform-tests"); if (selftest(np = of_find_node_by_path("/testcase-data/platform-tests"),
if (!np) { "No testcase data in device tree\n"));
pr_err("No testcase data in device tree\n"); return;
if (selftest(!(rc = device_register(&test_bus)),
"testbus registration failed; rc=%i\n", rc));
return; return;
}
for_each_child_of_node(np, child) { for_each_child_of_node(np, child) {
struct device_node *grandchild; of_platform_populate(child, match, NULL, &test_bus);
of_platform_populate(child, match, NULL, NULL);
for_each_child_of_node(child, grandchild) for_each_child_of_node(child, grandchild)
selftest(of_find_device_by_node(grandchild), selftest(of_find_device_by_node(grandchild),
"Could not create device for node '%s'\n", "Could not create device for node '%s'\n",
grandchild->name); grandchild->name);
} }
of_platform_depopulate(&test_bus);
for_each_child_of_node(np, child) {
for_each_child_of_node(child, grandchild)
selftest(!of_find_device_by_node(grandchild),
"device didn't get destroyed '%s'\n",
grandchild->name);
}
device_unregister(&test_bus);
of_node_put(np);
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment