mirror of https://github.com/bsnes-emu/bsnes.git
37 lines
830 B
C++
37 lines
830 B
C++
//ARMv3 (ARM60)
|
|
|
|
struct ArmDSP : Processor::ARM, Cothread {
|
|
#include "registers.hpp"
|
|
|
|
ArmDSP();
|
|
~ArmDSP();
|
|
|
|
static auto Enter() -> void;
|
|
auto boot() -> void;
|
|
auto main() -> void;
|
|
|
|
auto step(uint clocks) -> void override;
|
|
auto bus_idle() -> void override;
|
|
auto bus_read(uint mode, uint32 addr) -> uint32 override;
|
|
auto bus_write(uint mode, uint32 addr, uint32 word) -> void override;
|
|
|
|
auto mmio_read(uint24 addr, uint8 data) -> uint8;
|
|
auto mmio_write(uint24 addr, uint8 data) -> void;
|
|
|
|
auto init() -> void;
|
|
auto load() -> void;
|
|
auto unload() -> void;
|
|
auto power() -> void;
|
|
auto reset() -> void;
|
|
auto resetARM() -> void;
|
|
|
|
auto firmware() const -> nall::vector<uint8>;
|
|
auto serialize(serializer&) -> void;
|
|
|
|
uint8* programROM;
|
|
uint8* dataROM;
|
|
uint8* programRAM;
|
|
};
|
|
|
|
extern ArmDSP armdsp;
|