diff options
| author | Wolfgang Denk <wd@denx.de> | 2010-09-28 23:30:47 +0200 | 
|---|---|---|
| committer | Wolfgang Denk <wd@denx.de> | 2010-09-28 23:30:47 +0200 | 
| commit | 2e6e1772c0e34871769be4aef79748fe3e47d953 (patch) | |
| tree | 00e4e19d7bccd2a1cd5753854ff4c2b8a26bebb0 /common/cmd_bootm.c | |
| parent | 1e4e5ef0469050f014aee1204dae8a9ab6053e49 (diff) | |
| parent | 3df61957938586c512c17e72d83551d190400981 (diff) | |
| download | olio-uboot-2014.01-2e6e1772c0e34871769be4aef79748fe3e47d953.tar.xz olio-uboot-2014.01-2e6e1772c0e34871769be4aef79748fe3e47d953.zip | |
Merge branch 'next' of /home/wd/git/u-boot/next
Conflicts:
	include/ppc4xx.h
Signed-off-by: Wolfgang Denk <wd@denx.de>
Diffstat (limited to 'common/cmd_bootm.c')
| -rw-r--r-- | common/cmd_bootm.c | 40 | 
1 files changed, 40 insertions, 0 deletions
| diff --git a/common/cmd_bootm.c b/common/cmd_bootm.c index 4c6ed4870..db59e6f29 100644 --- a/common/cmd_bootm.c +++ b/common/cmd_bootm.c @@ -77,6 +77,7 @@ static int image_info (unsigned long addr);  #if defined(CONFIG_CMD_IMLS)  #include <flash.h> +#include <mtd/cfi_flash.h>  extern flash_info_t flash_info[]; /* info for FLASH chips */  static int do_imls (cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]);  #endif @@ -118,6 +119,9 @@ extern void lynxkdi_boot (image_header_t *);  #ifdef CONFIG_BOOTM_RTEMS  static boot_os_fn do_bootm_rtems;  #endif +#if defined(CONFIG_BOOTM_OSE) +static boot_os_fn do_bootm_ose; +#endif  #if defined(CONFIG_CMD_ELF)  static boot_os_fn do_bootm_vxworks;  static boot_os_fn do_bootm_qnxelf; @@ -141,6 +145,9 @@ static boot_os_fn *boot_os[] = {  #ifdef CONFIG_BOOTM_RTEMS  	[IH_OS_RTEMS] = do_bootm_rtems,  #endif +#if defined(CONFIG_BOOTM_OSE) +	[IH_OS_OSE] = do_bootm_ose, +#endif  #if defined(CONFIG_CMD_ELF)  	[IH_OS_VXWORKS] = do_bootm_vxworks,  	[IH_OS_QNX] = do_bootm_qnxelf, @@ -1382,6 +1389,39 @@ static int do_bootm_rtems (int flag, int argc, char * const argv[],  }  #endif /* CONFIG_BOOTM_RTEMS */ +#if defined(CONFIG_BOOTM_OSE) +static int do_bootm_ose (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 ("OSE"); +		return 1; +	} +#endif + +	entry_point = (void (*)(void))images->ep; + +	printf ("## Transferring control to OSE (at address %08lx) ...\n", +		(ulong)entry_point); + +	show_boot_progress (15); + +	/* +	 * OSE Parameters: +	 *   None +	 */ +	(*entry_point)(); + +	return 1; +} +#endif /* CONFIG_BOOTM_OSE */ +  #if defined(CONFIG_CMD_ELF)  static int do_bootm_vxworks (int flag, int argc, char * const argv[],  			     bootm_headers_t *images) |