mirror of https://github.com/bsnes-emu/bsnes.git
62 lines
1.9 KiB
C++
62 lines
1.9 KiB
C++
#ifndef PROCESSOR_ARM_HPP
|
|
#define PROCESSOR_ARM_HPP
|
|
|
|
namespace Processor {
|
|
|
|
//Supported Models:
|
|
//* ARMv3 (ST018)
|
|
//* ARMv4 (ARM7TDMI)
|
|
|
|
struct ARM {
|
|
enum : unsigned { Byte = 8, Half = 16, Word = 32 };
|
|
enum : bool { Nonsequential = 0, Sequential = 1 };
|
|
|
|
#include "registers.hpp"
|
|
#include "instructions-arm.hpp"
|
|
#include "instructions-thumb.hpp"
|
|
#include "disassembler.hpp"
|
|
|
|
virtual auto step(unsigned clocks) -> void = 0;
|
|
virtual auto bus_idle(uint32 addr) -> void = 0;
|
|
virtual auto bus_read(uint32 addr, uint32 size, bool mode) -> uint32 = 0;
|
|
virtual auto bus_load(uint32 addr, uint32 size, bool mode) -> uint32 = 0;
|
|
virtual auto bus_write(uint32 addr, uint32 size, bool mode, uint32 word) -> void = 0;
|
|
virtual auto bus_store(uint32 addr, uint32 size, bool mode, uint32 word) -> void = 0;
|
|
|
|
//arm.cpp
|
|
auto power() -> void;
|
|
auto exec() -> void;
|
|
auto idle() -> void;
|
|
auto read(uint32 addr, uint32 size, bool mode) -> uint32;
|
|
auto load(uint32 addr, uint32 size, bool mode) -> uint32;
|
|
auto write(uint32 addr, uint32 size, bool mode, uint32 word) -> void;
|
|
auto store(uint32 addr, uint32 size, bool mode, uint32 word) -> void;
|
|
auto vector(uint32 addr, Processor::Mode mode) -> void;
|
|
|
|
//algorithms.cpp
|
|
auto condition(uint4 condition) -> bool;
|
|
auto bit(uint32 result) -> uint32;
|
|
auto add(uint32 source, uint32 modify, bool carry) -> uint32;
|
|
auto sub(uint32 source, uint32 modify, bool carry) -> uint32;
|
|
auto mul(uint32 product, uint32 multiplicand, uint32 multiplier) -> uint32;
|
|
auto lsl(uint32 source, uint8 shift) -> uint32;
|
|
auto lsr(uint32 source, uint8 shift) -> uint32;
|
|
auto asr(uint32 source, uint8 shift) -> uint32;
|
|
auto ror(uint32 source, uint8 shift) -> uint32;
|
|
auto rrx(uint32 source) -> uint32;
|
|
|
|
//step.cpp
|
|
auto arm_step() -> void;
|
|
auto thumb_step() -> void;
|
|
|
|
//serialization.cpp
|
|
auto serialize(serializer&) -> void;
|
|
|
|
bool trace{false};
|
|
uintmax_t instructions{0};
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|