mirror of
https://gitlab.com/qemu-project/openbios.git
synced 2024-02-13 08:34:06 +08:00
sparc32: fix pre-loaded kernel command line
Fix more breakage from r828: For some reason, QEMU/Sparc32 does not set FW_CFG_CMDLINE_SIZE, so we have to use FW_CFG_KERNEL_CMDLINE instead. Setup romvec obp_arg.argv[1] and "boot-file" property. Remove obsolete command line setup code from obio.c. Signed-off-by: Blue Swirl <blauwirbel@gmail.com> git-svn-id: svn://coreboot.org/openbios/trunk/openbios-devel@832 f158a5a8-5612-0410-a976-696ce0be7e32
This commit is contained in:
@@ -38,12 +38,6 @@
|
||||
*/
|
||||
#define SUN4M_NCPU 4
|
||||
|
||||
/* The kernel may want to examine the arguments, so hold a copy in OBP's
|
||||
* mapped memory.
|
||||
*/
|
||||
#define OBIO_CMDLINE_MAX 256
|
||||
static char obio_cmdline[OBIO_CMDLINE_MAX];
|
||||
|
||||
/* DECLARE data structures for the nodes. */
|
||||
DECLARE_UNNAMED_NODE( ob_obio, INSTALL_OPEN, sizeof(int) );
|
||||
|
||||
@@ -651,14 +645,12 @@ ob_nvram_init(uint64_t base, uint64_t offset)
|
||||
const char *stdin, *stdout;
|
||||
unsigned int i;
|
||||
char nographic;
|
||||
uint32_t size = 0;
|
||||
uint16_t machine_id;
|
||||
const struct cpudef *cpu;
|
||||
const struct machdef *mach;
|
||||
char buf[256];
|
||||
uint32_t temp;
|
||||
phandle_t chosen;
|
||||
const char *kernel_cmdline;
|
||||
|
||||
ob_new_obio_device("eeprom", NULL);
|
||||
|
||||
@@ -691,21 +683,6 @@ ob_nvram_init(uint64_t base, uint64_t offset)
|
||||
for(;;);
|
||||
}
|
||||
|
||||
kernel_size = fw_cfg_read_i32(FW_CFG_KERNEL_SIZE);
|
||||
if (kernel_size)
|
||||
kernel_image = fw_cfg_read_i32(FW_CFG_KERNEL_ADDR);
|
||||
kernel_cmdline = (const char *) fw_cfg_read_i32(FW_CFG_KERNEL_CMDLINE);
|
||||
if (kernel_cmdline) {
|
||||
size = strlen(kernel_cmdline);
|
||||
if (size > OBIO_CMDLINE_MAX - 1)
|
||||
size = OBIO_CMDLINE_MAX - 1;
|
||||
memcpy(&obio_cmdline, kernel_cmdline, size);
|
||||
}
|
||||
obio_cmdline[size] = '\0';
|
||||
qemu_cmdline = (uint32_t) &obio_cmdline;
|
||||
cmdline_size = size;
|
||||
boot_device = fw_cfg_read_i16(FW_CFG_BOOT_DEVICE);
|
||||
|
||||
fw_cfg_read(FW_CFG_NOGRAPHIC, &nographic, 1);
|
||||
graphic_depth = fw_cfg_read_i16(FW_CFG_SUN4M_DEPTH);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user