Message ID | 20180503091922.28733-5-edgar.iglesias@gmail.com |
---|---|
State | New |
Headers | show |
Series | [v1,01/29] target-microblaze: dec_load: Use bool instead of unsigned int | expand |
On Thu, May 3, 2018 at 2:25 AM Edgar E. Iglesias <edgar.iglesias@gmail.com> wrote: > From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com> > Today, when running QEMU in linux-user or with boards that don't > select a specific CPU version, we treat it as an invalid version > and log a message. > Instead, if no specific version was selected, fallback to our > latest CPU version. > Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Alistair > --- > target/microblaze/cpu.c | 9 +++++++-- > 1 file changed, 7 insertions(+), 2 deletions(-) > diff --git a/target/microblaze/cpu.c b/target/microblaze/cpu.c > index 4dc1404800..06476f6efc 100644 > --- a/target/microblaze/cpu.c > +++ b/target/microblaze/cpu.c > @@ -72,6 +72,9 @@ static const struct { > {NULL, 0}, > }; > +/* If no specific version gets selected, default to the following. */ > +#define DEFAULT_CPU_VERSION "10.0" > + > static void mb_cpu_set_pc(CPUState *cs, vaddr value) > { > MicroBlazeCPU *cpu = MICROBLAZE_CPU(cs); > @@ -141,6 +144,7 @@ static void mb_cpu_realizefn(DeviceState *dev, Error **errp) > MicroBlazeCPU *cpu = MICROBLAZE_CPU(cs); > CPUMBState *env = &cpu->env; > uint8_t version_code = 0; > + const char *version; > int i = 0; > Error *local_err = NULL; > @@ -162,8 +166,9 @@ static void mb_cpu_realizefn(DeviceState *dev, Error **errp) > | PVR2_FPU_EXC_MASK \ > | 0; > - for (i = 0; mb_cpu_lookup[i].name && cpu->cfg.version; i++) { > - if (strcmp(mb_cpu_lookup[i].name, cpu->cfg.version) == 0) { > + version = cpu->cfg.version ? cpu->cfg.version : DEFAULT_CPU_VERSION; > + for (i = 0; mb_cpu_lookup[i].name && version; i++) { > + if (strcmp(mb_cpu_lookup[i].name, version) == 0) { > version_code = mb_cpu_lookup[i].version_id; > break; > } > -- > 2.14.1
diff --git a/target/microblaze/cpu.c b/target/microblaze/cpu.c index 4dc1404800..06476f6efc 100644 --- a/target/microblaze/cpu.c +++ b/target/microblaze/cpu.c @@ -72,6 +72,9 @@ static const struct { {NULL, 0}, }; +/* If no specific version gets selected, default to the following. */ +#define DEFAULT_CPU_VERSION "10.0" + static void mb_cpu_set_pc(CPUState *cs, vaddr value) { MicroBlazeCPU *cpu = MICROBLAZE_CPU(cs); @@ -141,6 +144,7 @@ static void mb_cpu_realizefn(DeviceState *dev, Error **errp) MicroBlazeCPU *cpu = MICROBLAZE_CPU(cs); CPUMBState *env = &cpu->env; uint8_t version_code = 0; + const char *version; int i = 0; Error *local_err = NULL; @@ -162,8 +166,9 @@ static void mb_cpu_realizefn(DeviceState *dev, Error **errp) | PVR2_FPU_EXC_MASK \ | 0; - for (i = 0; mb_cpu_lookup[i].name && cpu->cfg.version; i++) { - if (strcmp(mb_cpu_lookup[i].name, cpu->cfg.version) == 0) { + version = cpu->cfg.version ? cpu->cfg.version : DEFAULT_CPU_VERSION; + for (i = 0; mb_cpu_lookup[i].name && version; i++) { + if (strcmp(mb_cpu_lookup[i].name, version) == 0) { version_code = mb_cpu_lookup[i].version_id; break; }