Skip to content
Snippets Groups Projects
Commit 04d41409 authored by Steven Stallion's avatar Steven Stallion Committed by Tom Rini
Browse files

image: Add support for Plan 9


Signed-off-by: default avatarSteven Stallion <sstallion@gmail.com>
Cc: Tom Rini <trini@ti.com>
Reviewed-by: default avatarTom Rini <trini@ti.com>
parent 0171d52c
No related branches found
No related tags found
No related merge requests found
...@@ -128,6 +128,9 @@ static boot_os_fn do_bootm_rtems; ...@@ -128,6 +128,9 @@ static boot_os_fn do_bootm_rtems;
#if defined(CONFIG_BOOTM_OSE) #if defined(CONFIG_BOOTM_OSE)
static boot_os_fn do_bootm_ose; static boot_os_fn do_bootm_ose;
#endif #endif
#if defined(CONFIG_BOOTM_PLAN9)
static boot_os_fn do_bootm_plan9;
#endif
#if defined(CONFIG_CMD_ELF) #if defined(CONFIG_CMD_ELF)
static boot_os_fn do_bootm_vxworks; static boot_os_fn do_bootm_vxworks;
static boot_os_fn do_bootm_qnxelf; static boot_os_fn do_bootm_qnxelf;
...@@ -154,6 +157,9 @@ static boot_os_fn *boot_os[] = { ...@@ -154,6 +157,9 @@ static boot_os_fn *boot_os[] = {
#if defined(CONFIG_BOOTM_OSE) #if defined(CONFIG_BOOTM_OSE)
[IH_OS_OSE] = do_bootm_ose, [IH_OS_OSE] = do_bootm_ose,
#endif #endif
#if defined(CONFIG_BOOTM_PLAN9)
[IH_OS_PLAN9] = do_bootm_plan9,
#endif
#if defined(CONFIG_CMD_ELF) #if defined(CONFIG_CMD_ELF)
[IH_OS_VXWORKS] = do_bootm_vxworks, [IH_OS_VXWORKS] = do_bootm_vxworks,
[IH_OS_QNX] = do_bootm_qnxelf, [IH_OS_QNX] = do_bootm_qnxelf,
...@@ -1628,6 +1634,39 @@ static int do_bootm_ose(int flag, int argc, char * const argv[], ...@@ -1628,6 +1634,39 @@ static int do_bootm_ose(int flag, int argc, char * const argv[],
} }
#endif /* CONFIG_BOOTM_OSE */ #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) #if defined(CONFIG_CMD_ELF)
static int do_bootm_vxworks(int flag, int argc, char * const argv[], static int do_bootm_vxworks(int flag, int argc, char * const argv[],
bootm_headers_t *images) bootm_headers_t *images)
......
...@@ -108,6 +108,7 @@ static const table_entry_t uimage_os[] = { ...@@ -108,6 +108,7 @@ static const table_entry_t uimage_os[] = {
#endif #endif
{ IH_OS_NETBSD, "netbsd", "NetBSD", }, { IH_OS_NETBSD, "netbsd", "NetBSD", },
{ IH_OS_OSE, "ose", "Enea OSE", }, { IH_OS_OSE, "ose", "Enea OSE", },
{ IH_OS_PLAN9, "plan9", "Plan 9", },
{ IH_OS_RTEMS, "rtems", "RTEMS", }, { IH_OS_RTEMS, "rtems", "RTEMS", },
{ IH_OS_U_BOOT, "u-boot", "U-Boot", }, { IH_OS_U_BOOT, "u-boot", "U-Boot", },
#if defined(CONFIG_CMD_ELF) || defined(USE_HOSTCC) #if defined(CONFIG_CMD_ELF) || defined(USE_HOSTCC)
......
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
/* Support bootm-ing different OSes */ /* Support bootm-ing different OSes */
#define CONFIG_BOOTM_LINUX 1 #define CONFIG_BOOTM_LINUX 1
#define CONFIG_BOOTM_NETBSD 1 #define CONFIG_BOOTM_NETBSD 1
#define CONFIG_BOOTM_PLAN9 1
#define CONFIG_BOOTM_RTEMS 1 #define CONFIG_BOOTM_RTEMS 1
#define CONFIG_GZIP 1 #define CONFIG_GZIP 1
......
...@@ -84,6 +84,7 @@ ...@@ -84,6 +84,7 @@
#define IH_OS_UNITY 20 /* Unity OS */ #define IH_OS_UNITY 20 /* Unity OS */
#define IH_OS_INTEGRITY 21 /* INTEGRITY */ #define IH_OS_INTEGRITY 21 /* INTEGRITY */
#define IH_OS_OSE 22 /* OSE */ #define IH_OS_OSE 22 /* OSE */
#define IH_OS_PLAN9 23 /* Plan 9 */
/* /*
* CPU Architecture Codes (supported by Linux) * CPU Architecture Codes (supported by Linux)
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment