OSDN Git Service

7ae17e6968d41220da8ad3f6543b57210b94d318
[csp-qt/common_source_project-fm7.git] / source / src / vm / phc25 / memory.cpp
1 /*
2         SANYO PHC-25 Emulator 'ePHC-25'
3         SEIKO MAP-1010 Emulator 'eMAP-1010'
4
5         Author : Takeda.Toshiya
6         Date   : 2010.08.03-
7
8         [ memory ]
9 */
10
11 #include "./memory.h"
12
13 #define SET_BANK(s, e, w, r) { \
14         int sb = (s) >> 11, eb = (e) >> 11; \
15         for(int i = sb; i <= eb; i++) { \
16                 if((w) == wdmy) { \
17                         wbank[i] = wdmy; \
18                 } else { \
19                         wbank[i] = (w) + 0x800 * (i - sb); \
20                 } \
21                 if((r) == rdmy) { \
22                         rbank[i] = rdmy; \
23                 } else { \
24                         rbank[i] = (r) + 0x800 * (i - sb); \
25                 } \
26         } \
27 }
28
29 void PHC25_MEMORY::initialize()
30 {
31         memset(rom, 0xff, sizeof(rom));
32         memset(rdmy, 0xff, sizeof(rdmy));
33         
34         // load rom image
35         FILEIO* fio = new FILEIO();
36         if(fio->Fopen(create_local_path(_T("BASIC.ROM")), FILEIO_READ_BINARY)) {
37                 fio->Fread(rom, sizeof(rom), 1);
38                 fio->Fclose();
39         }
40         delete fio;
41         
42         // set memory map
43 #ifdef _MAP1010
44         SET_BANK(0x0000, 0x5fff, wdmy, rom );
45         SET_BANK(0x6000, 0x77ff, vram, vram);
46         SET_BANK(0x7800, 0x7fff, wdmy, rdmy);
47         SET_BANK(0x8000, 0xffff, ram,  ram );
48 #else
49         SET_BANK(0x0000, 0x5fff, wdmy, rom );
50         SET_BANK(0x6000, 0x77ff, vram, vram);
51         SET_BANK(0x7800, 0xbfff, wdmy, rdmy);
52         SET_BANK(0xc000, 0xffff, ram,  ram );
53 #endif
54 }
55
56 void PHC25_MEMORY::reset()
57 {
58         memset(ram, 0, sizeof(ram));
59         memset(vram, 0, sizeof(vram));
60 }
61
62 void PHC25_MEMORY::write_data8(uint32_t addr, uint32_t data)
63 {
64         addr &= 0xffff;
65 #ifdef _MAP1010
66         if(0x7800 <= addr && addr < 0x8000) {
67                 // memory mapped i/o
68                 return;
69         }
70 #endif
71         wbank[addr >> 11][addr & 0x7ff] = data;
72 }
73
74 uint32_t PHC25_MEMORY::read_data8(uint32_t addr)
75 {
76         addr &= 0xffff;
77 #ifdef _MAP1010
78         if(0x7800 <= addr && addr < 0x7860) {
79                 return d_kbd->read_io8(addr);
80         } else if(0x7860 <= addr && addr < 0x8000) {
81                 // memory mapped i/o
82                 return 0xff;
83         }
84 #endif
85         return rbank[addr >> 11][addr & 0x7ff];
86 }
87
88 #define STATE_VERSION   1
89
90 bool PHC25_MEMORY::process_state(FILEIO* state_fio, bool loading)
91 {
92         if(!state_fio->StateCheckUint32(STATE_VERSION)) {
93                 return false;
94         }
95         if(!state_fio->StateCheckInt32(this_device_id)) {
96                 return false;
97         }
98         state_fio->StateBuffer(ram, sizeof(ram), 1);
99         state_fio->StateBuffer(vram, sizeof(vram), 1);
100         return true;
101 }