2 FUJITSU FM Towns Emulator 'eFMTowns'
4 Author : Kyuma.Ohta <whatisthis.sowhat _at_ gmail.com>
10 #ifndef _TOWNS_MEMORY_H_
11 #define _TOWNS_MEMORY_H_
14 #include "../../common.h"
15 #include "../memory.h"
16 #include "./towns_common.h"
18 #define SIG_FMTOWNS_MACHINE_ID 1
19 #define SIG_MEMORY_EXTNMI 2
22 // 00000000 - 000fffff : SYSTEM RAM PAGE 0 (Similar to FMR-50).
23 // 00100000 - 3fffffff : EXTRA RAM (for i386 native mode.Page size is 1MB.)
24 // 40000000 - 7fffffff : External I/O BOX.Not accessible.
25 // 80000000 - bfffffff : VRAM (Reserved 01020000H bytes with earlier Towns.)
26 // c0000000 - c21fffff : ROM card and dictionaly/font/DOS ROMs.
27 // c2200000 - c2200fff : PCM RAM (Banked).
28 // c2201000 - fffbffff : Reserved.
29 // FFFC0000 - FFFFFFFF : Towns System ROM.
33 TOWNS_MEMORY_NORMAL = 0,
34 TOWNS_MEMORY_FMR_VRAM,
35 TOWNS_MEMORY_FMR_TEXT,
36 TOWNS_MEMORY_FMR_VRAM_RESERVE,
37 TOWNS_MEMORY_SPRITE_ANKCG1,
40 TOWNS_MEMORY_MMIO_0CC,
42 TOWNS_MEMORY_TYPE_EXT_MMIO,
43 TOWNS_MEMORY_TYPE_LEARN_RAM,
44 TOWNS_MEMORY_TYPE_WAVERAM,
47 // Please set from config
48 #define TOWNS_EXTRAM_PAGES 6
60 class TOWNS_MEMORY : public MEMORY
64 DEVICE* d_sprite; // 0x81000000 - 0x8101ffff ?
65 DEVICE* d_romcard[2]; // 0xc0000000 - 0xc0ffffff / 0xc1000000 - 0xc1ffffff
66 DEVICE* d_pcm; // 0xc2200000 - 0xc2200fff
82 outputs_t outputs_ram_wait;
83 outputs_t outputs_rom_wait;
96 uint8_t ram_page0[0xc0000]; // 0x00000000 - 0x000bffff : RAM
97 uint8_t ram_pagec[0x10000]; // 0x000c0000 - 0x000cffff : URA? RAM
98 uint8_t ram_paged[0x20000]; // 0x000d0000 - 0x000effff : RAM
99 uint8_t ram_pagef[0x10000]; // 0x000f0000 - 0x000fffff : RAM
101 uint8_t *extra_ram; // 0x00100000 - (0x3fffffff) : Size is defined by extram_size;
102 uint32_t extram_size;
103 uint32_t cpu_clock_val;
104 uint32_t vram_wait_val;
105 uint32_t mem_wait_val;
107 uint8_t wait_register;
113 bool nmi_vector_protect;
118 uint32_t vram_size; // Normally 512KB.
122 uint8_t reg_misc3; // 0024
123 uint8_t reg_misc4; // 0025
124 virtual void set_wait_values();
125 virtual void config_page_c0();
126 virtual void config_page_d0_e0();
127 virtual void config_page_f8_rom();
128 virtual void config_page00();
129 virtual void update_machine_features();
131 virtual void __FASTCALL write_fmr_ports8(uint32_t addr, uint32_t data);
132 virtual uint8_t __FASTCALL read_fmr_ports8(uint32_t addr);
133 virtual void __FASTCALL write_sys_ports8(uint32_t addr, uint32_t data);
134 virtual uint8_t __FASTCALL read_sys_ports8(uint32_t addr);
137 TOWNS_MEMORY(VM_TEMPLATE* parent_vm, EMU_TEMPLATE* parent_emu) : MEMORY(parent_vm, parent_emu) {
138 set_device_name(_T("FMTOWNS_MEMORY"));
140 extram_size = 0x00200000; // Basically 2MB
146 d_romcard[0] = d_romcard[1] = NULL;
163 initialize_output_signals(&outputs_ram_wait);
164 initialize_output_signals(&outputs_rom_wait);
165 // Note: machine id must set before initialize() from set_context_machine_id() by VM::VM().
166 // machine_id = 0x0100; // FM-Towns 1,2
167 // machine_id = 0x0200 // FM-Towns 1F/2F/1H/2H
168 // machine_id = 0x0300 // FM-Towns UX10/UX20/UX40
169 // machine_id = 0x0400 // FM-Towns 10F/20F/40H/80H
170 // machine_id = 0x0500 // FM-Towns2 CX10/CX20/CX40/CX100
171 // machine_id = 0x0600 // FM-Towns2 UG10/UG20/UG40/UG80
172 // machine_id = 0x0700 // FM-Towns2 HR20/HR100/HR200
173 // machine_id = 0x0800 // FM-Towns2 HG20/HG40/HG100
174 // machine_id = 0x0900 // FM-Towns2 UR20/UR40/UR80
175 // machine_id = 0x0b00 // FM-Towns2 MA20/MA170/MA340
176 // machine_id = 0x0c00 // FM-Towns2 MX20/MX170/MX340
177 // machine_id = 0x0d00 // FM-Towns2 ME20/ME170
178 // machine_id = 0x0f00 // FM-Towns2 MF20/MF170/Fresh
179 machine_id = 0x0100; // FM-Towns 1,2
181 // Note: cpu id must set before initialize() from set_context_cpu_id() by VM::VM().
182 // cpu_id = 0x00; // 80286.
183 // cpu_id = 0x01; // 80386DX.
184 // cpu_id = 0x02; // 80486SX/DX.
185 // cpu_id = 0x03; // 80386SX.
186 cpu_id = 0x01; // 80386DX.
196 virtual void __FASTCALL write_io8(uint32_t addr, uint32_t data);
197 virtual void __FASTCALL write_io8w(uint32_t addr, uint32_t data, int *wait);
199 virtual uint32_t __FASTCALL read_io8(uint32_t addr);
200 virtual uint32_t __FASTCALL read_io8w(uint32_t addr, int *wait);
202 virtual void __FASTCALL write_memory_mapped_io8(uint32_t addr, uint32_t data);
203 virtual uint32_t __FASTCALL read_memory_mapped_io8(uint32_t addr);
204 virtual void __FASTCALL write_memory_mapped_io8w(uint32_t addr, uint32_t data, int *wait);
205 virtual uint32_t __FASTCALL read_memory_mapped_io8w(uint32_t addr, int *wait);
206 virtual void __FASTCALL write_memory_mapped_io16(uint32_t addr, uint32_t data);
207 virtual uint32_t __FASTCALL read_memory_mapped_io16(uint32_t addr);
208 virtual void __FASTCALL write_memory_mapped_io16w(uint32_t addr, uint32_t data, int *wait);
209 virtual uint32_t __FASTCALL read_memory_mapped_io16w(uint32_t addr, int *wait);
211 virtual void __FASTCALL write_signal(int id, uint32_t data, uint32_t mask);
212 virtual uint32_t __FASTCALL read_signal(int ch);
214 //void event_frame();
215 virtual void __FASTCALL set_intr_line(bool line, bool pending, uint32_t bit);
217 bool process_state(FILEIO* state_fio, bool loading);
220 void set_extra_ram_size(uint32_t megabytes)
223 uint32_t minimum = 2;
224 switch(machine_id & 0xff00) {
226 case 0x0100: // Towns Model 1/2
229 case 0x0200: // TOWNS 2F/2H
230 case 0x0400: // TOWNS 10F/10H/20F/20H
231 limit = 8; // 2MB + 2MB x 3
233 case 0x0300: // TOWNS2 UX
234 case 0x0600: // TOWNS2 UG
235 limit = 9; // 2MB + 4MB x 2? - 1MB
237 case 0x0500: // TOWNS2 CX
238 case 0x0800: // TOWNS2 HG
239 limit = 15; // 8MB x 2 - 1MB?
241 case 0x0700: // TOWNS2 HR
242 case 0x0900: // TOWNS2 UR
243 case 0x0B00: // TOWNS2 MA
244 case 0x0C00: // TOWNS2 MX
245 case 0x0D00: // TOWNS2 ME
246 case 0x0F00: // TOWNS2 MF/Fresh
247 limit = 31; // 16MB x 2 - 1MB?
250 if(megabytes > limit) megabytes = limit;
251 if(megabytes < minimum) megabytes = minimum;
252 extram_size = megabytes << 20;
254 void set_context_cpu(I386* device)
258 void set_context_dmac(DEVICE* device)
262 void set_context_vram(DEVICE* device)
266 void set_context_system_rom(DEVICE* device)
270 void set_context_font_rom(DEVICE* device)
274 void set_context_font_20pix_rom(DEVICE* device)
276 d_font_20pix = device;
278 void set_context_dictionary(DEVICE* device)
280 d_dictionary = device;
282 void set_context_msdos(DEVICE* device)
286 void set_context_timer(DEVICE* device)
290 void set_context_sprite(DEVICE* device)
294 void set_context_crtc(DEVICE* device)
298 void set_context_romcard(DEVICE* device, int num)
300 d_romcard[num & 1] = device;
302 void set_context_pcm(DEVICE* device)
306 void set_context_serial_rom(DEVICE* device)
308 d_serialrom = device;
310 void set_context_planevram(DEVICE *dev)
314 void set_context_iccard(DEVICE* device, int num)
316 if((num >= 0) && (num < 2)) {
317 d_iccard[num] = device;
320 void set_machine_id(uint16_t val)
322 machine_id = val & 0xfff8;
324 void set_cpu_id(uint16_t val)