unicorn/qemu/hw/mips/mips_r4k.c

56 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 "qemu/osdep.h"
#include "qapi/error.h"
#include "qemu-common.h"
#include "cpu.h"
2015-08-21 07:04:50 +00:00
#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
}
uc->cpu = cpu_generic_init(uc, TYPE_MIPS_CPU, cpu_model);
2016-07-10 01:16:00 +00:00
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
}
static void mips_machine_init(struct uc_struct *uc, MachineClass *mc)
2015-08-21 07:04:50 +00:00
{
mc->init = mips_r4k_init;
mc->is_default = 1;
mc->arch = UC_ARCH_MIPS;
2015-08-21 07:04:50 +00:00
}
DEFINE_MACHINE("mips", mips_machine_init)