OSDN Git Service

[VM][STATE][MZ2500][MZ700][MZ80K] Apply new state framework to some VMs.
[csp-qt/common_source_project-fm7.git] / source / src / vm / mz700 / memory.h
1 /*
2         SHARP MZ-700 Emulator 'EmuZ-700'
3         SHARP MZ-800 Emulator 'EmuZ-800'
4         SHARP MZ-1500 Emulator 'EmuZ-1500'
5
6         Author : Takeda.Toshiya
7         Date   : 2008.06.05 -
8
9         [ memory ]
10 */
11
12 #ifndef _MEMORY_H_
13 #define _MEMORY_H_
14
15 #include "../vm.h"
16 #include "../../emu.h"
17 #include "../device.h"
18
19 #if defined(_MZ800)
20 class DISPLAY;
21 #endif
22
23 class MEMORY : public DEVICE
24 {
25 private:
26         DEVICE *d_cpu, *d_pit, *d_pio;
27 #if defined(_MZ800)
28         DEVICE *d_pio_int;
29 #endif
30         
31         // memory
32         uint8_t* rbank[32];
33         uint8_t* wbank[32];
34         uint8_t wdmy[0x800];
35         uint8_t rdmy[0x800];
36         
37         uint8_t ipl[0x1000];    // IPL 4KB
38 #if defined(_MZ800)
39         uint8_t ext[0x2000];    // MZ-800 IPL 8KB
40 #elif defined(_MZ1500)
41         uint8_t ext[0x1800];    // MZ-1500 EXT 6KB
42 #endif
43         uint8_t font[0x1000];   // CGROM 4KB
44 #if defined(_MZ700)
45         uint8_t pcg[0x1000];    // PCG-700 2KB + Lower CGROM 2KB
46 #elif defined(_MZ1500)
47         uint8_t pcg[0x6000];    // MZ-1500 PCG 8KB * 3
48 #endif
49         uint8_t ram[0x10000];   // Main RAM 64KB
50 #if defined(_MZ800)
51         uint8_t vram[0x8000];   // MZ-800 VRAM 32KB
52 #else
53         uint8_t vram[0x1000];   // MZ-700/1500 VRAM 4KB
54 #endif
55         uint8_t mem_bank;
56 #if defined(_MZ700)
57         uint8_t pcg_data;
58         uint8_t pcg_addr;
59         uint8_t pcg_ctrl;
60 #elif defined(_MZ800)
61         uint8_t wf, rf;
62         uint8_t dmd;
63         uint32_t vram_addr_top;
64         bool is_mz800;
65 #elif defined(_MZ1500)
66         uint8_t pcg_bank;
67 #endif
68         
69         void update_map_low();
70         void update_map_middle();
71         void update_map_high();
72 #if defined(_MZ800)
73         int vram_page_mask(uint8_t f);
74         int vram_addr(int addr);
75 #endif
76         
77         // crtc
78 #if defined(_MZ800)
79         uint16_t sof;
80         uint8_t sw, ssa, sea;
81         uint8_t palette_sw, palette[4], palette16[16];
82 #elif defined(_MZ1500)
83         uint8_t priority, palette[8];
84 #endif
85         bool blink, tempo;
86         bool hblank, hsync;
87         bool vblank, vsync;
88 #if defined(_MZ700) || defined(_MZ1500)
89         bool hblank_vram;
90 #endif
91 #if defined(_MZ1500)
92         bool hblank_pcg;
93 #endif
94         void set_vblank(bool val);
95         void set_hblank(bool val);
96         
97         // renderer
98 #if defined(_MZ800)
99         uint8_t screen[200][640];
100         scrntype_t palette_mz800_pc[16];
101 #else
102         uint8_t screen[200][320];
103 #endif
104         scrntype_t palette_pc[8];
105         
106 #if defined(_MZ800)
107         void draw_line_320x200_2bpp(int v);
108         void draw_line_320x200_4bpp(int v);
109         void draw_line_640x200_1bpp(int v);
110         void draw_line_640x200_2bpp(int v);
111         void draw_line_mz700(int v);
112 #else
113         void draw_line(int v);
114 #endif
115         
116 public:
117         MEMORY(VM* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
118         {
119                 set_device_name(_T("Memory Bus"));
120         }
121         ~MEMORY() {}
122         
123         // common functions
124         void initialize();
125         void reset();
126 #if defined(_MZ800)
127         void update_config();
128 #endif
129         void event_vline(int v, int clock);
130         void event_callback(int event_id, int err);
131         void write_data8(uint32_t addr, uint32_t data);
132         uint32_t read_data8(uint32_t addr);
133         void write_data8w(uint32_t addr, uint32_t data, int* wait);
134         uint32_t read_data8w(uint32_t addr, int* wait);
135         void write_io8(uint32_t addr, uint32_t data);
136 #if defined(_MZ800)
137         uint32_t read_io8(uint32_t addr);
138 #endif
139         void decl_state();
140         void save_state(FILEIO* state_fio);
141         bool load_state(FILEIO* state_fio);
142         
143         // unique functions
144         void set_context_cpu(DEVICE* device)
145         {
146                 d_cpu = device;
147         }
148         void set_context_pit(DEVICE* device)
149         {
150                 d_pit = device;
151         }
152         void set_context_pio(DEVICE* device)
153         {
154                 d_pio = device;
155         }
156 #if defined(_MZ800)
157         void set_context_pio_int(DEVICE* device)
158         {
159                 d_pio_int = device;
160         }
161 #endif
162         void draw_screen();
163 };
164
165 #endif
166