summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFabien Parent <fparent@baylibre.com>2016-11-24 15:02:18 +0100
committerSimon Glass <sjg@chromium.org>2016-12-02 20:53:20 -0700
commitf7f191ee41c0590917f4a969b569af0a01106380 (patch)
treece822ddba28e5ef3f0bcd0c2db433733bb8dc298
parent8269ee4f969fc66564e6e4d2744654db5f5b11ad (diff)
downloadu-boot-f7f191ee41c0590917f4a969b569af0a01106380.tar.gz
u-boot-f7f191ee41c0590917f4a969b569af0a01106380.tar.xz
u-boot-f7f191ee41c0590917f4a969b569af0a01106380.zip
cmd/fdt: fix uncallable systemsetup command
The function that is processing the 'fdt' parameters is one big if-else if. In order to be able to type command faster only the first few letter are checked to know which block of code to execute. For systemsetup, the block of code that was executed was always the wrong one and ended up in a failure. } else if (argv[1][0] == 's') { process "fdt set" command } else if (strncmp(argv[1], "sys", 3) == 0) { process "fdt systemsetup" command. } When typing "fdt systemsetup", the code that was executed was the code for "fdt set". This commit fix this issue by moving the "else if" for systemsetup before the else if for "fdt set". This allow us to keep compatibility with any script that make use of "fdt s" to set node values. Signed-off-by: Fabien Parent <fparent@baylibre.com> Acked-by: Simon Glass <sjg@chromium.org>
-rw-r--r--cmd/fdt.c22
1 files changed, 10 insertions, 12 deletions
diff --git a/cmd/fdt.c b/cmd/fdt.c
index b503357dc3..8bd345afa8 100644
--- a/cmd/fdt.c
+++ b/cmd/fdt.c
@@ -206,7 +206,17 @@ static int do_fdt(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
return 1;
}
working_fdt = newaddr;
+#ifdef CONFIG_OF_SYSTEM_SETUP
+ /* Call the board-specific fixup routine */
+ } else if (strncmp(argv[1], "sys", 3) == 0) {
+ int err = ft_system_setup(working_fdt, gd->bd);
+ if (err) {
+ printf("Failed to add system information to FDT: %s\n",
+ fdt_strerror(err));
+ return CMD_RET_FAILURE;
+ }
+#endif
/*
* Make a new node
*/
@@ -577,18 +587,6 @@ static int do_fdt(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
}
}
#endif
-#ifdef CONFIG_OF_SYSTEM_SETUP
- /* Call the board-specific fixup routine */
- else if (strncmp(argv[1], "sys", 3) == 0) {
- int err = ft_system_setup(working_fdt, gd->bd);
-
- if (err) {
- printf("Failed to add system information to FDT: %s\n",
- fdt_strerror(err));
- return CMD_RET_FAILURE;
- }
- }
-#endif
/* Create a chosen node */
else if (strncmp(argv[1], "cho", 3) == 0) {
unsigned long initrd_start = 0, initrd_end = 0;