Commit 94fc95cdb2e91826bd6a4c98cea4f4d9fa0fffb1
1 parent
7a2d6d96
New -cpu options: choose CPU model for emulated target.
Only relevant on PowerPC targets, for now. git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2468 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
13 changed files
with
75 additions
and
55 deletions
hw/integratorcp.c
... | ... | @@ -516,7 +516,7 @@ static void integratorcp_init(int ram_size, int vga_ram_size, int boot_device, |
516 | 516 | static void integratorcp926_init(int ram_size, int vga_ram_size, |
517 | 517 | int boot_device, DisplayState *ds, const char **fd_filename, int snapshot, |
518 | 518 | const char *kernel_filename, const char *kernel_cmdline, |
519 | - const char *initrd_filename) | |
519 | + const char *initrd_filename, const char *cpu_model) | |
520 | 520 | { |
521 | 521 | integratorcp_init(ram_size, vga_ram_size, boot_device, ds, fd_filename, |
522 | 522 | snapshot, kernel_filename, kernel_cmdline, |
... | ... | @@ -526,7 +526,7 @@ static void integratorcp926_init(int ram_size, int vga_ram_size, |
526 | 526 | static void integratorcp1026_init(int ram_size, int vga_ram_size, |
527 | 527 | int boot_device, DisplayState *ds, const char **fd_filename, int snapshot, |
528 | 528 | const char *kernel_filename, const char *kernel_cmdline, |
529 | - const char *initrd_filename) | |
529 | + const char *initrd_filename, const char *cpu_model) | |
530 | 530 | { |
531 | 531 | integratorcp_init(ram_size, vga_ram_size, boot_device, ds, fd_filename, |
532 | 532 | snapshot, kernel_filename, kernel_cmdline, | ... | ... |
hw/mips_malta.c
... | ... | @@ -615,7 +615,7 @@ static |
615 | 615 | void mips_malta_init (int ram_size, int vga_ram_size, int boot_device, |
616 | 616 | DisplayState *ds, const char **fd_filename, int snapshot, |
617 | 617 | const char *kernel_filename, const char *kernel_cmdline, |
618 | - const char *initrd_filename) | |
618 | + const char *initrd_filename, const char *cpu_model) | |
619 | 619 | { |
620 | 620 | char buf[1024]; |
621 | 621 | unsigned long bios_offset; | ... | ... |
hw/mips_r4k.c
... | ... | @@ -130,7 +130,7 @@ static |
130 | 130 | void mips_r4k_init (int ram_size, int vga_ram_size, int boot_device, |
131 | 131 | DisplayState *ds, const char **fd_filename, int snapshot, |
132 | 132 | const char *kernel_filename, const char *kernel_cmdline, |
133 | - const char *initrd_filename) | |
133 | + const char *initrd_filename, const char *cpu_model) | |
134 | 134 | { |
135 | 135 | char buf[1024]; |
136 | 136 | unsigned long bios_offset; | ... | ... |
hw/pc.c
... | ... | @@ -758,7 +758,8 @@ static void pc_init_pci(int ram_size, int vga_ram_size, int boot_device, |
758 | 758 | int snapshot, |
759 | 759 | const char *kernel_filename, |
760 | 760 | const char *kernel_cmdline, |
761 | - const char *initrd_filename) | |
761 | + const char *initrd_filename, | |
762 | + const char *cpu_model) | |
762 | 763 | { |
763 | 764 | pc_init1(ram_size, vga_ram_size, boot_device, |
764 | 765 | ds, fd_filename, snapshot, |
... | ... | @@ -771,7 +772,8 @@ static void pc_init_isa(int ram_size, int vga_ram_size, int boot_device, |
771 | 772 | int snapshot, |
772 | 773 | const char *kernel_filename, |
773 | 774 | const char *kernel_cmdline, |
774 | - const char *initrd_filename) | |
775 | + const char *initrd_filename, | |
776 | + const char *cpu_model) | |
775 | 777 | { |
776 | 778 | pc_init1(ram_size, vga_ram_size, boot_device, |
777 | 779 | ds, fd_filename, snapshot, | ... | ... |
hw/ppc_chrp.c
... | ... | @@ -292,13 +292,14 @@ void pmac_format_nvram_partition(uint8_t *buf, int len) |
292 | 292 | } |
293 | 293 | |
294 | 294 | /* PowerPC CHRP hardware initialisation */ |
295 | -static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device, | |
296 | - DisplayState *ds, const char **fd_filename, | |
297 | - int snapshot, | |
298 | - const char *kernel_filename, | |
299 | - const char *kernel_cmdline, | |
300 | - const char *initrd_filename, | |
301 | - int is_heathrow) | |
295 | +static void ppc_chrp_init (int ram_size, int vga_ram_size, int boot_device, | |
296 | + DisplayState *ds, const char **fd_filename, | |
297 | + int snapshot, | |
298 | + const char *kernel_filename, | |
299 | + const char *kernel_cmdline, | |
300 | + const char *initrd_filename, | |
301 | + const char *cpu_model, | |
302 | + int is_heathrow) | |
302 | 303 | { |
303 | 304 | CPUState *env; |
304 | 305 | char buf[1024]; |
... | ... | @@ -320,22 +321,16 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device, |
320 | 321 | env = cpu_init(); |
321 | 322 | register_savevm("cpu", 0, 3, cpu_save, cpu_load, env); |
322 | 323 | |
323 | - /* Register CPU as a 74x/75x */ | |
324 | + /* Default CPU is a generic 74x/75x */ | |
325 | + if (cpu_model == NULL) | |
326 | + cpu_model = "750"; | |
324 | 327 | /* XXX: CPU model (or PVR) should be provided on command line */ |
325 | 328 | // ppc_find_by_name("750gx", &def); // Linux boot OK |
326 | 329 | // ppc_find_by_name("750fx", &def); // Linux boot OK |
327 | 330 | /* Linux does not boot on 750cxe (and probably other 750cx based) |
328 | 331 | * because it assumes it has 8 IBAT & DBAT pairs as it only have 4. |
329 | 332 | */ |
330 | - // ppc_find_by_name("750cxe", &def); | |
331 | - // ppc_find_by_name("750p", &def); | |
332 | - // ppc_find_by_name("740p", &def); | |
333 | - ppc_find_by_name("750", &def); | |
334 | - // ppc_find_by_name("740", &def); | |
335 | - // ppc_find_by_name("G3", &def); | |
336 | - // ppc_find_by_name("604r", &def); | |
337 | - // ppc_find_by_name("604e", &def); | |
338 | - // ppc_find_by_name("604", &def); | |
333 | + ppc_find_by_name(cpu_model, &def); | |
339 | 334 | if (def == NULL) { |
340 | 335 | cpu_abort(env, "Unable to find PowerPC CPU definition\n"); |
341 | 336 | } |
... | ... | @@ -525,30 +520,32 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device, |
525 | 520 | register_ioport_write(0x0F00, 4, 1, &PPC_debug_write, NULL); |
526 | 521 | } |
527 | 522 | |
528 | -static void ppc_core99_init(int ram_size, int vga_ram_size, int boot_device, | |
529 | - DisplayState *ds, const char **fd_filename, | |
530 | - int snapshot, | |
531 | - const char *kernel_filename, | |
532 | - const char *kernel_cmdline, | |
533 | - const char *initrd_filename) | |
523 | +static void ppc_core99_init (int ram_size, int vga_ram_size, int boot_device, | |
524 | + DisplayState *ds, const char **fd_filename, | |
525 | + int snapshot, | |
526 | + const char *kernel_filename, | |
527 | + const char *kernel_cmdline, | |
528 | + const char *initrd_filename, | |
529 | + const char *cpu_model) | |
534 | 530 | { |
535 | 531 | ppc_chrp_init(ram_size, vga_ram_size, boot_device, |
536 | 532 | ds, fd_filename, snapshot, |
537 | 533 | kernel_filename, kernel_cmdline, |
538 | - initrd_filename, 0); | |
534 | + initrd_filename, cpu_model, 0); | |
539 | 535 | } |
540 | 536 | |
541 | -static void ppc_heathrow_init(int ram_size, int vga_ram_size, int boot_device, | |
542 | - DisplayState *ds, const char **fd_filename, | |
543 | - int snapshot, | |
544 | - const char *kernel_filename, | |
545 | - const char *kernel_cmdline, | |
546 | - const char *initrd_filename) | |
537 | +static void ppc_heathrow_init (int ram_size, int vga_ram_size, int boot_device, | |
538 | + DisplayState *ds, const char **fd_filename, | |
539 | + int snapshot, | |
540 | + const char *kernel_filename, | |
541 | + const char *kernel_cmdline, | |
542 | + const char *initrd_filename, | |
543 | + const char *cpu_model) | |
547 | 544 | { |
548 | 545 | ppc_chrp_init(ram_size, vga_ram_size, boot_device, |
549 | 546 | ds, fd_filename, snapshot, |
550 | 547 | kernel_filename, kernel_cmdline, |
551 | - initrd_filename, 1); | |
548 | + initrd_filename, cpu_model, 1); | |
552 | 549 | } |
553 | 550 | |
554 | 551 | QEMUMachine core99_machine = { | ... | ... |
hw/ppc_prep.c
... | ... | @@ -518,10 +518,12 @@ CPUReadMemoryFunc *PPC_prep_io_read[] = { |
518 | 518 | #define NVRAM_SIZE 0x2000 |
519 | 519 | |
520 | 520 | /* PowerPC PREP hardware initialisation */ |
521 | -static void ppc_prep_init(int ram_size, int vga_ram_size, int boot_device, | |
522 | - DisplayState *ds, const char **fd_filename, int snapshot, | |
523 | - const char *kernel_filename, const char *kernel_cmdline, | |
524 | - const char *initrd_filename) | |
521 | +static void ppc_prep_init (int ram_size, int vga_ram_size, int boot_device, | |
522 | + DisplayState *ds, const char **fd_filename, | |
523 | + int snapshot, const char *kernel_filename, | |
524 | + const char *kernel_cmdline, | |
525 | + const char *initrd_filename, | |
526 | + const char *cpu_model) | |
525 | 527 | { |
526 | 528 | CPUState *env; |
527 | 529 | char buf[1024]; |
... | ... | @@ -543,12 +545,11 @@ static void ppc_prep_init(int ram_size, int vga_ram_size, int boot_device, |
543 | 545 | |
544 | 546 | env = cpu_init(); |
545 | 547 | register_savevm("cpu", 0, 3, cpu_save, cpu_load, env); |
546 | - | |
547 | - /* Register CPU as a 604 */ | |
548 | - /* XXX: CPU model (or PVR) should be provided on command line */ | |
549 | - // ppc_find_by_name("604r", &def); | |
550 | - // ppc_find_by_name("604e", &def); | |
551 | - ppc_find_by_name("604", &def); | |
548 | + | |
549 | + /* Default CPU is a 604 */ | |
550 | + if (cpu_model == NULL) | |
551 | + cpu_model = "604"; | |
552 | + ppc_find_by_name(cpu_model, &def); | |
552 | 553 | if (def == NULL) { |
553 | 554 | cpu_abort(env, "Unable to find PowerPC CPU definition\n"); |
554 | 555 | } | ... | ... |
hw/realview.c
... | ... | @@ -15,7 +15,7 @@ |
15 | 15 | static void realview_init(int ram_size, int vga_ram_size, int boot_device, |
16 | 16 | DisplayState *ds, const char **fd_filename, int snapshot, |
17 | 17 | const char *kernel_filename, const char *kernel_cmdline, |
18 | - const char *initrd_filename) | |
18 | + const char *initrd_filename, const char *cpu_model) | |
19 | 19 | { |
20 | 20 | CPUState *env; |
21 | 21 | void *pic; | ... | ... |
hw/shix.c
... | ... | @@ -70,7 +70,7 @@ void vga_screen_dump(const char *filename) |
70 | 70 | void shix_init(int ram_size, int vga_ram_size, int boot_device, |
71 | 71 | DisplayState * ds, const char **fd_filename, int snapshot, |
72 | 72 | const char *kernel_filename, const char *kernel_cmdline, |
73 | - const char *initrd_filename) | |
73 | + const char *initrd_filename, const char *cpu_model) | |
74 | 74 | { |
75 | 75 | int ret; |
76 | 76 | CPUState *env; | ... | ... |
hw/sun4m.c
... | ... | @@ -211,7 +211,7 @@ static void main_cpu_reset(void *opaque) |
211 | 211 | static void sun4m_init(int ram_size, int vga_ram_size, int boot_device, |
212 | 212 | DisplayState *ds, const char **fd_filename, int snapshot, |
213 | 213 | const char *kernel_filename, const char *kernel_cmdline, |
214 | - const char *initrd_filename) | |
214 | + const char *initrd_filename, const char *cpu_model) | |
215 | 215 | { |
216 | 216 | CPUState *env, *envs[MAX_CPUS]; |
217 | 217 | char buf[1024]; | ... | ... |
hw/sun4u.c
... | ... | @@ -257,7 +257,7 @@ static fdctrl_t *floppy_controller; |
257 | 257 | static void sun4u_init(int ram_size, int vga_ram_size, int boot_device, |
258 | 258 | DisplayState *ds, const char **fd_filename, int snapshot, |
259 | 259 | const char *kernel_filename, const char *kernel_cmdline, |
260 | - const char *initrd_filename) | |
260 | + const char *initrd_filename, const char *cpu_model) | |
261 | 261 | { |
262 | 262 | CPUState *env; |
263 | 263 | char buf[1024]; | ... | ... |
hw/versatilepb.c
... | ... | @@ -257,7 +257,7 @@ static void versatile_init(int ram_size, int vga_ram_size, int boot_device, |
257 | 257 | static void vpb_init(int ram_size, int vga_ram_size, int boot_device, |
258 | 258 | DisplayState *ds, const char **fd_filename, int snapshot, |
259 | 259 | const char *kernel_filename, const char *kernel_cmdline, |
260 | - const char *initrd_filename) | |
260 | + const char *initrd_filename, const char *cpu_model) | |
261 | 261 | { |
262 | 262 | versatile_init(ram_size, vga_ram_size, boot_device, |
263 | 263 | ds, fd_filename, snapshot, |
... | ... | @@ -268,7 +268,7 @@ static void vpb_init(int ram_size, int vga_ram_size, int boot_device, |
268 | 268 | static void vab_init(int ram_size, int vga_ram_size, int boot_device, |
269 | 269 | DisplayState *ds, const char **fd_filename, int snapshot, |
270 | 270 | const char *kernel_filename, const char *kernel_cmdline, |
271 | - const char *initrd_filename) | |
271 | + const char *initrd_filename, const char *cpu_model) | |
272 | 272 | { |
273 | 273 | versatile_init(ram_size, vga_ram_size, boot_device, |
274 | 274 | ds, fd_filename, snapshot, | ... | ... |
vl.c
... | ... | @@ -6355,6 +6355,7 @@ void help(void) |
6355 | 6355 | "\n" |
6356 | 6356 | "Standard options:\n" |
6357 | 6357 | "-M machine select emulated machine (-M ? for list)\n" |
6358 | + "-cpu cpu select CPU (-C ? for list)\n" | |
6358 | 6359 | "-fda/-fdb file use 'file' as floppy disk 0/1 image\n" |
6359 | 6360 | "-hda/-hdb file use 'file' as IDE hard disk 0/1 image\n" |
6360 | 6361 | "-hdc/-hdd file use 'file' as IDE hard disk 2/3 image\n" |
... | ... | @@ -6487,6 +6488,7 @@ enum { |
6487 | 6488 | QEMU_OPTION_h, |
6488 | 6489 | |
6489 | 6490 | QEMU_OPTION_M, |
6491 | + QEMU_OPTION_cpu, | |
6490 | 6492 | QEMU_OPTION_fda, |
6491 | 6493 | QEMU_OPTION_fdb, |
6492 | 6494 | QEMU_OPTION_hda, |
... | ... | @@ -6562,6 +6564,7 @@ const QEMUOption qemu_options[] = { |
6562 | 6564 | { "help", 0, QEMU_OPTION_h }, |
6563 | 6565 | |
6564 | 6566 | { "M", HAS_ARG, QEMU_OPTION_M }, |
6567 | + { "cpu", HAS_ARG, QEMU_OPTION_cpu }, | |
6565 | 6568 | { "fda", HAS_ARG, QEMU_OPTION_fda }, |
6566 | 6569 | { "fdb", HAS_ARG, QEMU_OPTION_fdb }, |
6567 | 6570 | { "hda", HAS_ARG, QEMU_OPTION_hda }, |
... | ... | @@ -6867,6 +6870,7 @@ int main(int argc, char **argv) |
6867 | 6870 | int parallel_device_index; |
6868 | 6871 | const char *loadvm = NULL; |
6869 | 6872 | QEMUMachine *machine; |
6873 | + const char *cpu_model; | |
6870 | 6874 | char usb_devices[MAX_USB_CMDLINE][128]; |
6871 | 6875 | int usb_devices_index; |
6872 | 6876 | int fds[2]; |
... | ... | @@ -6904,6 +6908,7 @@ int main(int argc, char **argv) |
6904 | 6908 | |
6905 | 6909 | register_machines(); |
6906 | 6910 | machine = first_machine; |
6911 | + cpu_model = NULL; | |
6907 | 6912 | initrd_filename = NULL; |
6908 | 6913 | for(i = 0; i < MAX_FD; i++) |
6909 | 6914 | fd_filename[i] = NULL; |
... | ... | @@ -6995,6 +7000,17 @@ int main(int argc, char **argv) |
6995 | 7000 | exit(1); |
6996 | 7001 | } |
6997 | 7002 | break; |
7003 | + case QEMU_OPTION_cpu: | |
7004 | + /* hw initialization will check this */ | |
7005 | + if (optarg[0] == '?') { | |
7006 | +#if defined(TARGET_PPC) | |
7007 | + ppc_cpu_list(stdout, &fprintf); | |
7008 | +#endif | |
7009 | + exit(1); | |
7010 | + } else { | |
7011 | + cpu_model = optarg; | |
7012 | + } | |
7013 | + break; | |
6998 | 7014 | case QEMU_OPTION_initrd: |
6999 | 7015 | initrd_filename = optarg; |
7000 | 7016 | break; |
... | ... | @@ -7569,7 +7585,7 @@ int main(int argc, char **argv) |
7569 | 7585 | |
7570 | 7586 | machine->init(ram_size, vga_ram_size, boot_device, |
7571 | 7587 | ds, fd_filename, snapshot, |
7572 | - kernel_filename, kernel_cmdline, initrd_filename); | |
7588 | + kernel_filename, kernel_cmdline, initrd_filename, cpu_model); | |
7573 | 7589 | |
7574 | 7590 | /* init USB devices */ |
7575 | 7591 | if (usb_enabled) { | ... | ... |
vl.h
... | ... | @@ -695,7 +695,7 @@ typedef void QEMUMachineInitFunc(int ram_size, int vga_ram_size, |
695 | 695 | int boot_device, |
696 | 696 | DisplayState *ds, const char **fd_filename, int snapshot, |
697 | 697 | const char *kernel_filename, const char *kernel_cmdline, |
698 | - const char *initrd_filename); | |
698 | + const char *initrd_filename, const char *cpu_model); | |
699 | 699 | |
700 | 700 | typedef struct QEMUMachine { |
701 | 701 | const char *name; |
... | ... | @@ -709,6 +709,10 @@ int qemu_register_machine(QEMUMachine *m); |
709 | 709 | typedef void SetIRQFunc(void *opaque, int irq_num, int level); |
710 | 710 | typedef void IRQRequestFunc(void *opaque, int level); |
711 | 711 | |
712 | +#if defined(TARGET_PPC) | |
713 | +void ppc_cpu_list (FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...)); | |
714 | +#endif | |
715 | + | |
712 | 716 | /* ISA bus */ |
713 | 717 | |
714 | 718 | extern target_phys_addr_t isa_mem_base; | ... | ... |