diff options
Diffstat (limited to 'common/cmd_bootm.c')
| -rw-r--r-- | common/cmd_bootm.c | 47 | 
1 files changed, 43 insertions, 4 deletions
diff --git a/common/cmd_bootm.c b/common/cmd_bootm.c index 2e9335207..7438469d0 100644 --- a/common/cmd_bootm.c +++ b/common/cmd_bootm.c @@ -88,7 +88,7 @@ static int do_imls(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]);  #include <linux/err.h>  #include <nand.h> -#ifdef CONFIG_SILENT_CONSOLE +#if defined(CONFIG_SILENT_CONSOLE) && !defined(CONFIG_SILENT_U_BOOT_ONLY)  static void fixup_silent_linux(void);  #endif @@ -128,6 +128,9 @@ static boot_os_fn do_bootm_rtems;  #if defined(CONFIG_BOOTM_OSE)  static boot_os_fn do_bootm_ose;  #endif +#if defined(CONFIG_BOOTM_PLAN9) +static boot_os_fn do_bootm_plan9; +#endif  #if defined(CONFIG_CMD_ELF)  static boot_os_fn do_bootm_vxworks;  static boot_os_fn do_bootm_qnxelf; @@ -154,6 +157,9 @@ static boot_os_fn *boot_os[] = {  #if defined(CONFIG_BOOTM_OSE)  	[IH_OS_OSE] = do_bootm_ose,  #endif +#if defined(CONFIG_BOOTM_PLAN9) +	[IH_OS_PLAN9] = do_bootm_plan9, +#endif  #if defined(CONFIG_CMD_ELF)  	[IH_OS_VXWORKS] = do_bootm_vxworks,  	[IH_OS_QNX] = do_bootm_qnxelf, @@ -694,7 +700,7 @@ int do_bootm(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])  	bootstage_mark(BOOTSTAGE_ID_CHECK_BOOT_OS); -#ifdef CONFIG_SILENT_CONSOLE +#if defined(CONFIG_SILENT_CONSOLE) && !defined(CONFIG_SILENT_U_BOOT_ONLY)  	if (images.os.os == IH_OS_LINUX)  		fixup_silent_linux();  #endif @@ -1413,7 +1419,7 @@ U_BOOT_CMD(  /*******************************************************************/  /* helper routines */  /*******************************************************************/ -#ifdef CONFIG_SILENT_CONSOLE +#if defined(CONFIG_SILENT_CONSOLE) && !defined(CONFIG_SILENT_U_BOOT_ONLY)  static void fixup_silent_linux(void)  {  	char buf[256], *start, *end; @@ -1628,6 +1634,39 @@ static int do_bootm_ose(int flag, int argc, char * const argv[],  }  #endif /* CONFIG_BOOTM_OSE */ +#if defined(CONFIG_BOOTM_PLAN9) +static int do_bootm_plan9(int flag, int argc, char * const argv[], +			   bootm_headers_t *images) +{ +	void (*entry_point)(void); + +	if ((flag != 0) && (flag != BOOTM_STATE_OS_GO)) +		return 1; + +#if defined(CONFIG_FIT) +	if (!images->legacy_hdr_valid) { +		fit_unsupported_reset("Plan 9"); +		return 1; +	} +#endif + +	entry_point = (void (*)(void))images->ep; + +	printf("## Transferring control to Plan 9 (at address %08lx) ...\n", +		(ulong)entry_point); + +	bootstage_mark(BOOTSTAGE_ID_RUN_OS); + +	/* +	 * Plan 9 Parameters: +	 *   None +	 */ +	(*entry_point)(); + +	return 1; +} +#endif /* CONFIG_BOOTM_PLAN9 */ +  #if defined(CONFIG_CMD_ELF)  static int do_bootm_vxworks(int flag, int argc, char * const argv[],  			     bootm_headers_t *images) @@ -1806,7 +1845,7 @@ static int do_bootz(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])  	usb_stop();  #endif -#ifdef CONFIG_SILENT_CONSOLE +#if defined(CONFIG_SILENT_CONSOLE) && !defined(CONFIG_SILENT_U_BOOT_ONLY)  	fixup_silent_linux();  #endif  	arch_preboot_os();  |