aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorths <ths@c046a42c-6fe2-441c-8c8c-71466251a162>2007-05-30 20:46:02 +0000
committerths <ths@c046a42c-6fe2-441c-8c8c-71466251a162>2007-05-30 20:46:02 +0000
commit51b2772f28f51b04e10e6e51f411f7246e1159d9 (patch)
tree46ac64740a6e04204a5e8285a715d5c564311b7f
parentfdf41d225e8c90f2822b4c706552e005837218a5 (diff)
downloadqemu-51b2772f28f51b04e10e6e51f411f7246e1159d9.zip
qemu-51b2772f28f51b04e10e6e51f411f7246e1159d9.tar.gz
qemu-51b2772f28f51b04e10e6e51f411f7246e1159d9.tar.bz2
Fix CPU (re-)selection on reset.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2900 c046a42c-6fe2-441c-8c8c-71466251a162
-rw-r--r--hw/mips_malta.c1
-rw-r--r--hw/mips_pica61.c1
-rw-r--r--hw/mips_r4k.c1
-rw-r--r--target-mips/cpu.h5
-rw-r--r--target-mips/translate_init.c8
5 files changed, 12 insertions, 4 deletions
diff --git a/hw/mips_malta.c b/hw/mips_malta.c
index 6339cc9..f775c2f 100644
--- a/hw/mips_malta.c
+++ b/hw/mips_malta.c
@@ -748,6 +748,7 @@ static void main_cpu_reset(void *opaque)
{
CPUState *env = opaque;
cpu_reset(env);
+ cpu_mips_register(env, NULL);
/* The bootload does not need to be rewritten as it is located in a
read only location. The kernel location and the arguments table
diff --git a/hw/mips_pica61.c b/hw/mips_pica61.c
index 40ea8b5..5bb3405 100644
--- a/hw/mips_pica61.c
+++ b/hw/mips_pica61.c
@@ -51,6 +51,7 @@ static void main_cpu_reset(void *opaque)
{
CPUState *env = opaque;
cpu_reset(env);
+ cpu_mips_register(env, NULL);
}
static
diff --git a/hw/mips_r4k.c b/hw/mips_r4k.c
index d600dbb..2208922 100644
--- a/hw/mips_r4k.c
+++ b/hw/mips_r4k.c
@@ -128,6 +128,7 @@ static void main_cpu_reset(void *opaque)
{
CPUState *env = opaque;
cpu_reset(env);
+ cpu_mips_register(env, NULL);
if (env->kernel_filename)
load_kernel (env, env->ram_size, env->kernel_filename,
diff --git a/target-mips/cpu.h b/target-mips/cpu.h
index 36c58ec..9fa0ca8 100644
--- a/target-mips/cpu.h
+++ b/target-mips/cpu.h
@@ -48,6 +48,8 @@ struct r4k_tlb_t {
target_ulong PFN[2];
};
+typedef struct mips_def_t mips_def_t;
+
typedef struct CPUMIPSState CPUMIPSState;
struct CPUMIPSState {
/* General integer registers */
@@ -295,6 +297,8 @@ struct CPUMIPSState {
const char *kernel_cmdline;
const char *initrd_filename;
+ mips_def_t *cpu_model;
+
struct QEMUTimer *timer; /* Internal timer */
};
@@ -308,7 +312,6 @@ void r4k_do_tlbwi (void);
void r4k_do_tlbwr (void);
void r4k_do_tlbp (void);
void r4k_do_tlbr (void);
-typedef struct mips_def_t mips_def_t;
int mips_find_by_name (const unsigned char *name, mips_def_t **def);
void mips_cpu_list (FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...));
int cpu_mips_register (CPUMIPSState *env, mips_def_t *def);
diff --git a/target-mips/translate_init.c b/target-mips/translate_init.c
index 7d60f19..e14b734 100644
--- a/target-mips/translate_init.c
+++ b/target-mips/translate_init.c
@@ -207,12 +207,14 @@ static void r4k_mmu_init (CPUMIPSState *env, mips_def_t *def)
int cpu_mips_register (CPUMIPSState *env, mips_def_t *def)
{
if (!def)
+ def = env->cpu_model;
+ if (!def)
cpu_abort(env, "Unable to find MIPS CPU definition\n");
+ env->cpu_model = def;
env->CP0_PRid = def->CP0_PRid;
-#ifdef TARGET_WORDS_BIGENDIAN
- env->CP0_Config0 = def->CP0_Config0 | (1 << CP0C0_BE);
-#else
env->CP0_Config0 = def->CP0_Config0;
+#ifdef TARGET_WORDS_BIGENDIAN
+ env->CP0_Config0 |= (1 << CP0C0_BE);
#endif
env->CP0_Config1 = def->CP0_Config1;
env->CP0_Config2 = def->CP0_Config2;