diff options
author | Andreas Bießmann <andreas.devel@googlemail.com> | 2013-07-02 11:57:44 (GMT) |
---|---|---|
committer | Tom Rini <trini@ti.com> | 2013-07-02 13:17:17 (GMT) |
commit | 2cb0e55a3cd737be1d228a9f90b3d34fab0d0d46 (patch) | |
tree | d1fa4cc5f2de7f08a29020e65a3fd1f9988ffbcd /arch/nios2 | |
parent | 5a34d9bf31a021987f97f20aefa812b97b58584e (diff) | |
download | u-boot-2cb0e55a3cd737be1d228a9f90b3d34fab0d0d46.tar.xz |
avr32/m68k/microblaze/nds32/nios2/openrisc/sh/sparc: fix do_bootm_linux
Commit 35fc84fa1ff51e15ecd3e464dac87eb105ffed30 broke bootm on avr32. It
requires to call do_bootm_linux() with flag set to BOOTM_STATE_OS_PREP before
calling it again with flag set to BOOTM_STATE_OS_GO.
Fix this by allowing flag set to BOOTM_STATE_OS_PREP, this however will
require a complete refactoring later on.
Signed-off-by: Andreas Bießmann <andreas.devel@googlemail.com>
[trini: Apply to m68k, microblaze, nds32, nios2, openrisc, sh and sparc]
Signed-off-by: Tom Rini <trini@ti.com>
Diffstat (limited to 'arch/nios2')
-rw-r--r-- | arch/nios2/lib/bootm.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/arch/nios2/lib/bootm.c b/arch/nios2/lib/bootm.c index 114e146..51597ea 100644 --- a/arch/nios2/lib/bootm.c +++ b/arch/nios2/lib/bootm.c @@ -45,6 +45,12 @@ int do_bootm_linux(int flag, int argc, char * const argv[], bootm_headers_t *ima if (of_flat_tree) initrd_end = (ulong)of_flat_tree; + /* + * allow the PREP bootm subcommand, it is required for bootm to work + */ + if (flag & BOOTM_STATE_OS_PREP) + return 0; + if ((flag != 0) && (flag != BOOTM_STATE_OS_GO)) return 1; |