|
@@ -32,6 +32,9 @@ int fit_find_config_node(const void *fdt)
|
|
{
|
|
{
|
|
const char *name;
|
|
const char *name;
|
|
int conf, node, len;
|
|
int conf, node, len;
|
|
|
|
+ const char *dflt_conf_name;
|
|
|
|
+ const char *dflt_conf_desc = NULL;
|
|
|
|
+ int dflt_conf_node = -ENOENT;
|
|
|
|
|
|
conf = fdt_path_offset(fdt, FIT_CONFS_PATH);
|
|
conf = fdt_path_offset(fdt, FIT_CONFS_PATH);
|
|
if (conf < 0) {
|
|
if (conf < 0) {
|
|
@@ -39,6 +42,9 @@ int fit_find_config_node(const void *fdt)
|
|
conf);
|
|
conf);
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ dflt_conf_name = fdt_getprop(fdt, conf, "default", &len);
|
|
|
|
+
|
|
for (node = fdt_first_subnode(fdt, conf);
|
|
for (node = fdt_first_subnode(fdt, conf);
|
|
node >= 0;
|
|
node >= 0;
|
|
node = fdt_next_subnode(fdt, node)) {
|
|
node = fdt_next_subnode(fdt, node)) {
|
|
@@ -50,6 +56,15 @@ int fit_find_config_node(const void *fdt)
|
|
#endif
|
|
#endif
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ if (dflt_conf_name) {
|
|
|
|
+ const char *node_name = fdt_get_name(fdt, node, NULL);
|
|
|
|
+ if (strcmp(dflt_conf_name, node_name) == 0) {
|
|
|
|
+ dflt_conf_node = node;
|
|
|
|
+ dflt_conf_desc = name;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
if (board_fit_config_name_match(name))
|
|
if (board_fit_config_name_match(name))
|
|
continue;
|
|
continue;
|
|
|
|
|
|
@@ -58,5 +73,10 @@ int fit_find_config_node(const void *fdt)
|
|
return node;
|
|
return node;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ if (dflt_conf_node != -ENOENT) {
|
|
|
|
+ debug("Selecting default config '%s'", dflt_conf_desc);
|
|
|
|
+ return dflt_conf_node;
|
|
|
|
+ }
|
|
|
|
+
|
|
return -ENOENT;
|
|
return -ENOENT;
|
|
}
|
|
}
|