diff options
author | ths <ths@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-04-05 23:12:54 +0000 |
---|---|---|
committer | ths <ths@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-04-05 23:12:54 +0000 |
commit | fb82fea06403d7d7b064b9ef7acc9c62dcd52850 (patch) | |
tree | 15550d9cfc8e9fc43dc449ef963497a334d69bf4 /hw | |
parent | bf9525e9d8e8a8f56d350f7e7fec33bd9eacb5dd (diff) |
Clear BEV and ERL for the fake bootloader.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2609 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'hw')
-rw-r--r-- | hw/mips_malta.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/hw/mips_malta.c b/hw/mips_malta.c index 2f3288bd7f..97707c1166 100644 --- a/hw/mips_malta.c +++ b/hw/mips_malta.c @@ -654,8 +654,10 @@ static void main_cpu_reset(void *opaque) /* The bootload does not need to be rewritten as it is located in a read only location. The kernel location and the arguments table location does not change. */ - if (env->kernel_filename) + if (env->kernel_filename) { + env->CP0_Status &= ~((1 << CP0St_BEV) | (1 << CP0St_ERL)); load_kernel (env); + } } static @@ -709,6 +711,7 @@ void mips_malta_init (int ram_size, int vga_ram_size, int boot_device, env->kernel_cmdline = kernel_cmdline; env->initrd_filename = initrd_filename; kernel_entry = load_kernel(env); + env->CP0_Status &= ~((1 << CP0St_BEV) | (1 << CP0St_ERL)); write_bootloader(env, bios_offset, kernel_entry); } else { snprintf(buf, sizeof(buf), "%s/%s", bios_dir, BIOS_FILENAME); |