mirror of
				https://github.com/yuzu-emu/unicorn.git
				synced 2025-10-25 14:38:00 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * 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)
 | |
| {
 | |
|     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 = (void*) cpu_mips_init(uc, cpu_model);
 | |
|     if (uc->cpu == NULL) {
 | |
|         fprintf(stderr, "Unable to find CPU definition\n");
 | |
|         return -1;
 | |
|     }
 | |
| 
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| void mips_machine_init(struct uc_struct *uc)
 | |
| {
 | |
|     static QEMUMachine mips_machine = {
 | |
|         NULL,
 | |
|         "mips",
 | |
|         mips_r4k_init,
 | |
|         NULL,
 | |
|         0,
 | |
|         1,
 | |
|         UC_ARCH_MIPS,
 | |
|     };
 | |
| 
 | |
|     qemu_register_machine(uc, &mips_machine, TYPE_MACHINE, NULL);
 | |
| }
 |