unicorn/qemu/hw/mips/mips_r4k.c

58 lines
1.2 KiB
C
Raw Normal View History

2015-08-21 07:04:50 +00:00
/*
* QEMU/MIPS pseudo-board
*
* emulates a simple machine with ISA-like bus.
* ISA IO space mapped to the 0x14000000 (PHYS) and
* ISA memory at the 0x10000000 (PHYS, 16Mb in size).
* All peripherial devices are attached to this "bus" with
* the standard PC ISA addresses.
*/
/* Unicorn Emulator Engine */
/* By Nguyen Anh Quynh, 2015 */
#include "hw/hw.h"
#include "hw/mips/mips.h"
#include "hw/mips/cpudevs.h"
#include "sysemu/sysemu.h"
#include "hw/boards.h"
#include "exec/address-spaces.h"
static int mips_r4k_init(struct uc_struct *uc, MachineState *machine)
2015-08-21 07:04:50 +00:00
{
const char *cpu_model = machine->cpu_model;
/* init CPUs */
if (cpu_model == NULL) {
#ifdef TARGET_MIPS64
cpu_model = "R4000";
#else
cpu_model = "24Kf";
#endif
}
2016-07-10 01:16:00 +00:00
uc->cpu = (void*) cpu_mips_init(uc, cpu_model);
if (uc->cpu == NULL) {
2015-08-21 07:04:50 +00:00
fprintf(stderr, "Unable to find CPU definition\n");
return -1;
2015-08-21 07:04:50 +00:00
}
return 0;
2015-08-21 07:04:50 +00:00
}
void mips_machine_init(struct uc_struct *uc)
{
static QEMUMachine mips_machine = {
NULL,
2017-01-23 04:39:34 +00:00
"mips",
mips_r4k_init,
NULL,
2017-01-23 04:39:34 +00:00
0,
1,
UC_ARCH_MIPS,
2015-08-21 07:04:50 +00:00
};
qemu_register_machine(uc, &mips_machine, TYPE_MACHINE, NULL);
}