Files
openbios/arch/sparc32/boot.c
Blue Swirl c4f3fbc099 Fix boot-device use
git-svn-id: svn://coreboot.org/openbios/openbios-devel@138 f158a5a8-5612-0410-a976-696ce0be7e32
2007-05-04 20:55:05 +00:00

130 lines
3.9 KiB
C

/*
*
*/
#undef BOOTSTRAP
#include "openbios/config.h"
#include "openbios/bindings.h"
#include "openbios/elfload.h"
#include "openbios/nvram.h"
#include "libc/diskio.h"
#include "sys_info.h"
#include "openprom.h"
int elf_load(struct sys_info *, const char *filename, const char *cmdline, const void *romvec);
int aout_load(struct sys_info *, const char *filename, const char *cmdline, const void *romvec);
int linux_load(struct sys_info *, const char *filename, const char *cmdline, const void *romvec);
void boot(void);
struct sys_info sys_info;
uint32_t kernel_image;
uint32_t kernel_size;
uint32_t cmdline;
uint32_t cmdline_size;
char boot_device;
extern unsigned int qemu_mem_size;
void *init_openprom(unsigned long memsize);
extern struct linux_arguments_v0 obp_arg;
void boot(void)
{
char *path = pop_fstr_copy(), *param, *oldpath = path;
char altpath[256];
int unit;
const void *romvec;
if(!path) {
push_str("boot-device");
push_str("/options");
fword("(find-dev)");
POP();
fword("get-package-property");
if (!POP()) {
path = pop_fstr_copy();
unit = 0;
} else {
switch (boot_device) {
case 'a':
path = "/obio/SUNW,fdtwo";
oldpath = "fd()";
unit = 0;
break;
case 'c':
path = "disk";
oldpath = "sd(0,0,0):d";
unit = 0;
break;
default:
case 'd':
path = "cdrom";
// FIXME: hardcoding this looks almost definitely wrong.
// With sd(0,2,0):b we get to see the solaris kernel though
//oldpath = "sd(0,2,0):d";
oldpath = "sd(0,2,0):b";
unit = 2;
break;
case 'n':
path = "net";
oldpath = "le()";
unit = 0;
break;
}
}
}
obp_arg.boot_dev_ctrl = 0;
obp_arg.boot_dev_unit = unit;
obp_arg.dev_partition = 0;
obp_arg.boot_dev[0] = oldpath[0];
obp_arg.boot_dev[1] = oldpath[1];
obp_arg.argv[0] = oldpath;
obp_arg.argv[1] = cmdline;
param = strchr(path, ' ');
if(param) {
*param = '\0';
param++;
} else if (cmdline_size) {
param = (char *)cmdline;
} else {
push_str("boot-args");
push_str("/options");
fword("(find-dev)");
POP();
fword("get-package-property");
POP();
param = pop_fstr_copy();
obp_arg.argv[1] = param;
}
romvec = init_openprom(qemu_mem_size);
if (kernel_size) {
int (*entry)(const void *romvec, int p2, int p3, int p4, int p5);
printk("[sparc] Kernel already loaded\n");
entry = (void *) kernel_image;
entry(romvec, 0, 0, 0, 0);
}
printk("[sparc] Booting file '%s' ", path);
if(param)
printk("with parameters '%s'\n", param);
else
printk("without parameters.\n");
if (elf_load(&sys_info, path, param, romvec) == LOADER_NOT_SUPPORT)
if (linux_load(&sys_info, path, param, romvec) == LOADER_NOT_SUPPORT)
if (aout_load(&sys_info, path, param, romvec) == LOADER_NOT_SUPPORT) {
sprintf(altpath, "%s:d", path);
if (elf_load(&sys_info, altpath, param, romvec) == LOADER_NOT_SUPPORT)
if (linux_load(&sys_info, altpath, param, romvec) == LOADER_NOT_SUPPORT)
if (aout_load(&sys_info, altpath, param, romvec) == LOADER_NOT_SUPPORT)
printk("Unsupported image format\n");
}
free(path);
}