summaryrefslogtreecommitdiffstats
path: root/hw/ppc440.c
diff options
context:
space:
mode:
authorBlue Swirl2009-06-17 17:49:37 +0200
committerBlue Swirl2009-06-17 17:49:37 +0200
commit727170b67105fef0e229e4b2eef45f88f121aa8c (patch)
tree33b1501393a224a3dac518a59dba343ef08d55be /hw/ppc440.c
parentFix opening of read only raw images (diff)
downloadqemu-727170b67105fef0e229e4b2eef45f88f121aa8c.tar.gz
qemu-727170b67105fef0e229e4b2eef45f88f121aa8c.tar.xz
qemu-727170b67105fef0e229e4b2eef45f88f121aa8c.zip
Allow user to specify CPU model
Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
Diffstat (limited to 'hw/ppc440.c')
-rw-r--r--hw/ppc440.c13
1 files changed, 5 insertions, 8 deletions
diff --git a/hw/ppc440.c b/hw/ppc440.c
index 00d82e4bed..5171988b63 100644
--- a/hw/ppc440.c
+++ b/hw/ppc440.c
@@ -34,7 +34,8 @@ static const unsigned int ppc440ep_sdram_bank_sizes[] = {
};
CPUState *ppc440ep_init(ram_addr_t *ram_size, PCIBus **pcip,
- const unsigned int pci_irq_nrs[4], int do_init)
+ const unsigned int pci_irq_nrs[4], int do_init,
+ const char *cpu_model)
{
target_phys_addr_t ram_bases[PPC440EP_SDRAM_NR_BANKS];
target_phys_addr_t ram_sizes[PPC440EP_SDRAM_NR_BANKS];
@@ -44,13 +45,9 @@ CPUState *ppc440ep_init(ram_addr_t *ram_size, PCIBus **pcip,
qemu_irq *irqs;
qemu_irq *pci_irqs;
- env = cpu_ppc_init("440EP");
- if (!env && kvm_enabled()) {
- /* XXX Since qemu doesn't yet emulate 440, we just say it's a 405.
- * Since KVM doesn't use qemu's CPU emulation it seems to be working
- * OK. */
- env = cpu_ppc_init("405");
- }
+ if (cpu_model == NULL)
+ cpu_model = "405"; // XXX: should be 440EP
+ env = cpu_init(cpu_model);
if (!env) {
fprintf(stderr, "Unable to initialize CPU!\n");
exit(1);