Commit 3ce04b4a authored by Gaurav Minocha's avatar Gaurav Minocha Committed by Rob Herring

Removes OF_UNITTEST dependency on OF_DYNAMIC config symbol

This patch intends to remove the unittests dependency on
the functions defined in dynamic.c. So, rather than calling
of_attach_node defined in dynamic.c, minimal functionality
required to attach a new node is re-defined in unittest.c.
Also, now after executing the tests the test data is not
removed from the device tree so there is no need to call
of_detach_node.

Tested with and without OF_DYNAMIC enabled on ppc, arm and
x86
Signed-off-by: default avatarGaurav Minocha <gaurav.minocha.os@gmail.com>
Signed-off-by: default avatarRob Herring <robh@kernel.org>
parent 9a4305bd
...@@ -10,7 +10,6 @@ menu "Device Tree and Open Firmware support" ...@@ -10,7 +10,6 @@ menu "Device Tree and Open Firmware support"
config OF_UNITTEST config OF_UNITTEST
bool "Device Tree runtime unit tests" bool "Device Tree runtime unit tests"
depends on OF_IRQ && OF_EARLY_FLATTREE depends on OF_IRQ && OF_EARLY_FLATTREE
select OF_DYNAMIC
select OF_RESOLVE select OF_RESOLVE
help help
This option builds in test cases for the device tree infrastructure This option builds in test cases for the device tree infrastructure
......
...@@ -822,6 +822,7 @@ static void update_node_properties(struct device_node *np, ...@@ -822,6 +822,7 @@ static void update_node_properties(struct device_node *np,
static int attach_node_and_children(struct device_node *np) static int attach_node_and_children(struct device_node *np)
{ {
struct device_node *next, *dup, *child; struct device_node *next, *dup, *child;
unsigned long flags;
dup = of_find_node_by_path(np->full_name); dup = of_find_node_by_path(np->full_name);
if (dup) { if (dup) {
...@@ -838,8 +839,17 @@ static int attach_node_and_children(struct device_node *np) ...@@ -838,8 +839,17 @@ static int attach_node_and_children(struct device_node *np)
child = np->child; child = np->child;
np->child = NULL; np->child = NULL;
np->sibling = NULL;
of_attach_node(np); mutex_lock(&of_mutex);
raw_spin_lock_irqsave(&devtree_lock, flags);
np->sibling = np->parent->child;
np->parent->child = np;
of_node_clear_flag(np, OF_DETACHED);
raw_spin_unlock_irqrestore(&devtree_lock, flags);
__of_attach_node_sysfs(np);
mutex_unlock(&of_mutex);
while (child) { while (child) {
next = child->sibling; next = child->sibling;
attach_node_and_children(child); attach_node_and_children(child);
...@@ -911,59 +921,6 @@ static int __init selftest_data_add(void) ...@@ -911,59 +921,6 @@ static int __init selftest_data_add(void)
return 0; return 0;
} }
/**
* detach_node_and_children - detaches node
* and its children from live tree
*
* @np: Node to detach from live tree
*/
static void detach_node_and_children(struct device_node *np)
{
while (np->child)
detach_node_and_children(np->child);
of_detach_node(np);
}
/**
* selftest_data_remove - removes the selftest data
* nodes from the live tree
*/
static void selftest_data_remove(void)
{
struct device_node *np;
struct property *prop;
if (selftest_live_tree) {
of_node_put(of_aliases);
of_node_put(of_chosen);
of_aliases = NULL;
of_chosen = NULL;
for_each_child_of_node(of_root, np)
detach_node_and_children(np);
__of_detach_node_sysfs(of_root);
of_root = NULL;
return;
}
while (last_node_index-- > 0) {
if (nodes[last_node_index]) {
np = of_find_node_by_path(nodes[last_node_index]->full_name);
if (np == nodes[last_node_index]) {
if (of_aliases == np) {
of_node_put(of_aliases);
of_aliases = NULL;
}
detach_node_and_children(np);
} else {
for_each_property_of_node(np, prop) {
if (strcmp(prop->name, "testcase-alias") == 0)
of_remove_property(np, prop);
}
}
}
}
}
#ifdef CONFIG_OF_OVERLAY #ifdef CONFIG_OF_OVERLAY
static int selftest_probe(struct platform_device *pdev) static int selftest_probe(struct platform_device *pdev)
...@@ -1475,9 +1432,6 @@ static int __init of_selftest(void) ...@@ -1475,9 +1432,6 @@ static int __init of_selftest(void)
of_selftest_platform_populate(); of_selftest_platform_populate();
of_selftest_overlay(); of_selftest_overlay();
/* removing selftest data from live tree */
selftest_data_remove();
/* Double check linkage after removing testcase data */ /* Double check linkage after removing testcase data */
of_selftest_check_tree_linkage(); of_selftest_check_tree_linkage();
......
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