2 TOSHIBA EX-80 Emulator 'eEX-80'
4 Author : Takeda.Toshiya
14 #define SET_BANK(s, e, w, r) { \
15 int sb = (s) >> 10, eb = (e) >> 10; \
16 for(int i = sb; i <= eb; i++) { \
20 wbank[i] = (w) + 0x400 * (i - sb); \
25 rbank[i] = (r) + 0x400 * (i - sb); \
30 void MEMORY::initialize()
32 memset(mon, 0xff, sizeof(mon));
33 memset(prom1, 0xff, sizeof(prom1));
34 memset(prom2, 0xff, sizeof(prom2));
35 memset(ram, 0, sizeof(ram));
38 FILEIO* fio = new FILEIO();
39 if(fio->Fopen(create_local_path(_T("MON.ROM")), FILEIO_READ_BINARY)) {
40 fio->Fread(mon, sizeof(mon), 1);
43 if(fio->Fopen(create_local_path(_T("PROM1.ROM")), FILEIO_READ_BINARY)) {
44 fio->Fread(prom1, sizeof(prom1), 1);
47 if(fio->Fopen(create_local_path(_T("PROM2.ROM")), FILEIO_READ_BINARY)) {
48 fio->Fread(prom2, sizeof(prom2), 1);
54 SET_BANK(0x0000, 0x07ff, wdmy, mon );
55 SET_BANK(0x0800, 0x0bff, wdmy, prom1);
56 SET_BANK(0x0c00, 0x0fff, wdmy, prom2);
57 SET_BANK(0x1000, 0x7fff, wdmy, rdmy);
58 SET_BANK(0x8000, 0x87ff, ram, ram );
59 SET_BANK(0x8800, 0xffff, wdmy, rdmy);
62 void MEMORY::write_data8(uint32_t addr, uint32_t data)
65 wbank[addr >> 10][addr & 0x3ff] = data;
68 uint32_t MEMORY::read_data8(uint32_t addr)
71 return rbank[addr >> 10][addr & 0x3ff];
74 uint32_t MEMORY::fetch_op(uint32_t addr, int *wait)
76 if((config.dipswitch & 1) && d_cpu->read_signal(SIG_I8080_INTE)) {
77 d_cpu->write_signal(SIG_I8080_INTR, 1, 1);
80 return read_data8(addr);
83 void MEMORY::load_binary(const _TCHAR* file_path)
85 FILEIO* fio = new FILEIO();
86 if(fio->Fopen(file_path, FILEIO_READ_BINARY)) {
87 fio->Fread(ram, sizeof(ram), 1);
93 void MEMORY::save_binary(const _TCHAR* file_path)
95 FILEIO* fio = new FILEIO();
96 if(fio->Fopen(file_path, FILEIO_WRITE_BINARY)) {
97 fio->Fwrite(ram, sizeof(ram), 1);
103 #define STATE_VERSION 1
105 bool MEMORY::process_state(FILEIO* state_fio, bool loading)
107 if(!state_fio->StateCheckUint32(STATE_VERSION)) {
110 if(!state_fio->StateCheckInt32(this_device_id)) {
113 state_fio->StateBuffer(ram, sizeof(ram), 1);