2009-05-21 17:48:31 +02:00
|
|
|
/* gameplaySP
|
|
|
|
*
|
|
|
|
* Copyright (C) 2006 Exophase <exophase@gmail.com>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation; either version 2 of
|
|
|
|
* the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CPU_H
|
|
|
|
#define CPU_H
|
|
|
|
|
2021-08-24 17:15:27 +02:00
|
|
|
#include <stdbool.h>
|
2021-03-23 19:47:51 +01:00
|
|
|
#include "gpsp_config.h"
|
|
|
|
|
2009-05-21 17:48:31 +02:00
|
|
|
// System mode and user mode are represented as the same here
|
|
|
|
|
2021-07-11 13:35:21 +02:00
|
|
|
typedef u32 cpu_mode_type;
|
|
|
|
|
2023-01-11 20:44:56 +01:00
|
|
|
// Bit 4 indicates privilege level
|
|
|
|
#define MODE_USER 0x00 // Non-privileged mode
|
|
|
|
#define MODE_SYSTEM 0x10 // Privileged modes
|
|
|
|
#define MODE_IRQ 0x11
|
|
|
|
#define MODE_FIQ 0x12
|
|
|
|
#define MODE_SUPERVISOR 0x13
|
|
|
|
#define MODE_ABORT 0x14
|
|
|
|
#define MODE_UNDEFINED 0x15
|
|
|
|
#define MODE_INVALID 0x16
|
|
|
|
|
|
|
|
// Discards privilege bit
|
|
|
|
#define REG_MODE(m) (reg_mode[(m) & 0xF])
|
|
|
|
#define REG_SPSR(m) (spsr[(m) & 0xF])
|
|
|
|
#define PRIVMODE(m) ((m) >> 4)
|
2009-05-21 17:48:31 +02:00
|
|
|
|
2021-10-15 21:28:40 +02:00
|
|
|
#define CPU_ACTIVE 0
|
|
|
|
#define CPU_HALT 1
|
|
|
|
#define CPU_STOP 2
|
|
|
|
|
2023-04-14 01:41:55 +02:00
|
|
|
typedef u8 cpu_alert_type;
|
|
|
|
|
|
|
|
#define CPU_ALERT_NONE 0
|
|
|
|
#define CPU_ALERT_HALT (1 << 0)
|
|
|
|
#define CPU_ALERT_SMC (1 << 1)
|
|
|
|
#define CPU_ALERT_IRQ (1 << 2)
|
2009-05-21 17:48:31 +02:00
|
|
|
|
2021-07-11 13:35:21 +02:00
|
|
|
typedef u16 irq_type;
|
|
|
|
|
|
|
|
#define IRQ_NONE 0x0000
|
|
|
|
#define IRQ_VBLANK 0x0001
|
|
|
|
#define IRQ_HBLANK 0x0002
|
|
|
|
#define IRQ_VCOUNT 0x0004
|
|
|
|
#define IRQ_TIMER0 0x0008
|
|
|
|
#define IRQ_TIMER1 0x0010
|
|
|
|
#define IRQ_TIMER2 0x0020
|
|
|
|
#define IRQ_TIMER3 0x0040
|
|
|
|
#define IRQ_SERIAL 0x0080
|
|
|
|
#define IRQ_DMA0 0x0100
|
|
|
|
#define IRQ_DMA1 0x0200
|
|
|
|
#define IRQ_DMA2 0x0400
|
|
|
|
#define IRQ_DMA3 0x0800
|
|
|
|
#define IRQ_KEYPAD 0x1000
|
|
|
|
#define IRQ_GAMEPAK 0x2000
|
2009-05-21 17:48:31 +02:00
|
|
|
|
|
|
|
typedef enum
|
|
|
|
{
|
2021-08-15 21:07:20 +02:00
|
|
|
// CPU status & registers
|
2009-05-21 17:48:31 +02:00
|
|
|
REG_SP = 13,
|
|
|
|
REG_LR = 14,
|
|
|
|
REG_PC = 15,
|
2021-08-28 17:50:25 +02:00
|
|
|
REG_CPSR = 16,
|
|
|
|
CPU_MODE = 17,
|
|
|
|
CPU_HALT_STATE = 18,
|
2022-01-26 19:03:14 +01:00
|
|
|
REG_ARCH_COUNT = 19,
|
|
|
|
|
|
|
|
// This is saved separately
|
|
|
|
REG_BUS_VALUE = 19,
|
2021-08-15 21:07:20 +02:00
|
|
|
|
|
|
|
// Dynarec signaling and spilling
|
|
|
|
// (Not really part of the CPU state)
|
2021-08-28 17:50:25 +02:00
|
|
|
REG_N_FLAG = 20,
|
|
|
|
REG_Z_FLAG = 21,
|
|
|
|
REG_C_FLAG = 22,
|
|
|
|
REG_V_FLAG = 23,
|
2021-08-15 21:07:20 +02:00
|
|
|
CHANGED_PC_STATUS = 24,
|
|
|
|
COMPLETED_FRAME = 25,
|
|
|
|
OAM_UPDATED = 26,
|
|
|
|
REG_SAVE = 27,
|
|
|
|
REG_SAVE2 = 28,
|
|
|
|
REG_SAVE3 = 29,
|
|
|
|
REG_SAVE4 = 30,
|
|
|
|
REG_SAVE5 = 31,
|
|
|
|
|
2021-10-29 22:09:22 +02:00
|
|
|
/* Machine defined storage */
|
|
|
|
REG_USERDEF = 32,
|
|
|
|
|
2021-08-15 21:07:20 +02:00
|
|
|
REG_MAX = 64
|
2009-05-21 17:48:31 +02:00
|
|
|
} ext_reg_numbers;
|
|
|
|
|
|
|
|
extern u32 instruction_count;
|
|
|
|
|
2011-09-05 18:31:58 +02:00
|
|
|
void execute_arm(u32 cycles);
|
2023-04-14 01:41:55 +02:00
|
|
|
void check_and_raise_interrupts(void);
|
|
|
|
cpu_alert_type check_interrupt(void);
|
|
|
|
cpu_alert_type flag_interrupt(irq_type irq_raised);
|
2011-09-03 00:26:33 +02:00
|
|
|
void set_cpu_mode(cpu_mode_type new_mode);
|
2009-05-21 17:48:31 +02:00
|
|
|
|
2021-03-06 21:15:22 +01:00
|
|
|
u32 function_cc execute_load_u8(u32 address);
|
|
|
|
u32 function_cc execute_load_u16(u32 address);
|
|
|
|
u32 function_cc execute_load_u32(u32 address);
|
|
|
|
u32 function_cc execute_load_s8(u32 address);
|
|
|
|
u32 function_cc execute_load_s16(u32 address);
|
|
|
|
void function_cc execute_store_u8(u32 address, u32 source);
|
|
|
|
void function_cc execute_store_u16(u32 address, u32 source);
|
|
|
|
void function_cc execute_store_u32(u32 address, u32 source);
|
2021-11-02 23:16:47 +01:00
|
|
|
void function_cc execute_store_aligned_u32(u32 address, u32 source);
|
2021-09-03 01:01:37 +02:00
|
|
|
u32 execute_arm_translate(u32 cycles);
|
2014-12-20 09:14:38 +01:00
|
|
|
void init_translater(void);
|
2021-08-24 17:15:27 +02:00
|
|
|
unsigned cpu_write_savestate(u8* dst);
|
|
|
|
bool cpu_read_savestate(const u8 *src);
|
2009-05-21 17:48:31 +02:00
|
|
|
|
2021-03-06 21:15:22 +01:00
|
|
|
u8 function_cc *block_lookup_address_arm(u32 pc);
|
|
|
|
u8 function_cc *block_lookup_address_thumb(u32 pc);
|
|
|
|
u8 function_cc *block_lookup_address_dual(u32 pc);
|
2022-01-05 16:32:42 +01:00
|
|
|
bool translate_block_arm(u32 pc, bool ram_region);
|
|
|
|
bool translate_block_thumb(u32 pc, bool ram_region);
|
2009-05-21 17:48:31 +02:00
|
|
|
|
2021-11-05 18:23:05 +01:00
|
|
|
#if defined(MMAP_JIT_CACHE)
|
2014-12-09 09:54:33 +01:00
|
|
|
extern u8* rom_translation_cache;
|
|
|
|
extern u8* ram_translation_cache;
|
2015-11-04 15:46:27 +01:00
|
|
|
#elif defined(_3DS)
|
|
|
|
#define rom_translation_cache ((u8*)0x02000000 - ROM_TRANSLATION_CACHE_SIZE)
|
|
|
|
#define ram_translation_cache (rom_translation_cache - RAM_TRANSLATION_CACHE_SIZE)
|
|
|
|
extern u8* rom_translation_cache_ptr;
|
|
|
|
extern u8* ram_translation_cache_ptr;
|
2016-08-08 00:31:21 +02:00
|
|
|
#elif defined(VITA)
|
|
|
|
extern u8* rom_translation_cache;
|
|
|
|
extern u8* ram_translation_cache;
|
|
|
|
extern int sceBlock;
|
2014-12-09 09:54:33 +01:00
|
|
|
#else
|
2009-05-21 17:48:31 +02:00
|
|
|
extern u8 rom_translation_cache[ROM_TRANSLATION_CACHE_SIZE];
|
|
|
|
extern u8 ram_translation_cache[RAM_TRANSLATION_CACHE_SIZE];
|
2014-12-09 09:54:33 +01:00
|
|
|
#endif
|
2009-05-21 17:48:31 +02:00
|
|
|
extern u8 *rom_translation_ptr;
|
|
|
|
extern u8 *ram_translation_ptr;
|
|
|
|
|
|
|
|
#define MAX_TRANSLATION_GATES 8
|
|
|
|
|
|
|
|
extern u32 idle_loop_target_pc;
|
|
|
|
extern u32 translation_gate_targets;
|
|
|
|
extern u32 translation_gate_target_pc[MAX_TRANSLATION_GATES];
|
|
|
|
|
2021-10-30 22:54:51 +02:00
|
|
|
extern u32 rom_branch_hash[ROM_BRANCH_HASH_SIZE];
|
2009-05-21 17:48:31 +02:00
|
|
|
|
2014-12-20 09:14:38 +01:00
|
|
|
void flush_translation_cache_rom(void);
|
|
|
|
void flush_translation_cache_ram(void);
|
|
|
|
void dump_translation_cache(void);
|
2021-03-30 21:06:52 +02:00
|
|
|
void init_caches(void);
|
2023-03-03 20:59:08 +01:00
|
|
|
void init_emitter(bool);
|
2021-09-10 00:30:55 +02:00
|
|
|
void init_bios_hooks(void);
|
2009-05-21 17:48:31 +02:00
|
|
|
|
|
|
|
extern u32 reg_mode[7][7];
|
|
|
|
extern u32 spsr[6];
|
|
|
|
|
2023-01-11 20:44:56 +01:00
|
|
|
extern const u32 cpu_modes[16];
|
|
|
|
extern const u32 cpsr_masks[4][2];
|
|
|
|
extern const u32 spsr_masks[4];
|
2009-05-21 17:48:31 +02:00
|
|
|
|
|
|
|
extern u32 memory_region_access_read_u8[16];
|
|
|
|
extern u32 memory_region_access_read_s8[16];
|
|
|
|
extern u32 memory_region_access_read_u16[16];
|
|
|
|
extern u32 memory_region_access_read_s16[16];
|
|
|
|
extern u32 memory_region_access_read_u32[16];
|
|
|
|
extern u32 memory_region_access_write_u8[16];
|
|
|
|
extern u32 memory_region_access_write_u16[16];
|
|
|
|
extern u32 memory_region_access_write_u32[16];
|
|
|
|
extern u32 memory_reads_u8;
|
|
|
|
extern u32 memory_reads_s8;
|
|
|
|
extern u32 memory_reads_u16;
|
|
|
|
extern u32 memory_reads_s16;
|
|
|
|
extern u32 memory_reads_u32;
|
|
|
|
extern u32 memory_writes_u8;
|
|
|
|
extern u32 memory_writes_u16;
|
|
|
|
extern u32 memory_writes_u32;
|
|
|
|
|
2014-12-20 09:14:38 +01:00
|
|
|
void init_cpu(void);
|
2009-05-21 17:48:31 +02:00
|
|
|
void move_reg();
|
|
|
|
|
|
|
|
#endif
|