OSDN Git Service

[VM][WIP] Use namespace to devices per VMs.
[csp-qt/common_source_project-fm7.git] / source / src / vm / mz700 / memory.h
index 5bbacc5..5b89f0b 100644 (file)
-/*\r
-       SHARP MZ-700 Emulator 'EmuZ-700'\r
-       SHARP MZ-800 Emulator 'EmuZ-800'\r
-       SHARP MZ-1500 Emulator 'EmuZ-1500'\r
-\r
-       Author : Takeda.Toshiya\r
-       Date   : 2008.06.05 -\r
-\r
-       [ memory ]\r
-*/\r
-\r
-#ifndef _MEMORY_H_\r
-#define _MEMORY_H_\r
-\r
-#include "../vm.h"\r
-#include "../../emu.h"\r
-#include "../device.h"\r
-\r
-#if defined(_MZ800)\r
-class DISPLAY;\r
-#endif\r
-\r
-class MEMORY : public DEVICE\r
-{\r
-private:\r
-       DEVICE *d_cpu, *d_pit, *d_pio;\r
-#if defined(_MZ800)\r
-       DEVICE *d_pio_int;\r
-#endif\r
-       \r
-       // memory\r
-       uint8* rbank[32];\r
-       uint8* wbank[32];\r
-       uint8 wdmy[0x800];\r
-       uint8 rdmy[0x800];\r
-       \r
-       uint8 ipl[0x1000];      // IPL 4KB\r
-#if defined(_MZ800)\r
-       uint8 ext[0x2000];      // MZ-800 IPL 8KB\r
-#elif defined(_MZ1500)\r
-       uint8 ext[0x1800];      // MZ-1500 EXT 6KB\r
-#endif\r
-       uint8 font[0x1000];     // CGROM 4KB\r
-#if defined(_MZ1500)\r
-       uint8 pcg[0x6000];      // MZ-1500 PCG 8KB * 3\r
-#endif\r
-       uint8 ram[0x10000];     // Main RAM 64KB\r
-#if defined(_MZ800)\r
-       uint8 vram[0x8000];     // MZ-800 VRAM 32KB\r
-#else\r
-       uint8 vram[0x1000];     // MZ-700/1500 VRAM 4KB\r
-#endif\r
-       uint8 mem_bank;\r
-#if defined(_MZ800)\r
-       uint8 wf, rf;\r
-       uint8 dmd;\r
-       uint32 vram_addr_top;\r
-       bool is_mz800;\r
-#elif defined(_MZ1500)\r
-       uint8 pcg_bank;\r
-#endif\r
-       \r
-       void update_map_low();\r
-       void update_map_middle();\r
-       void update_map_high();\r
-#if defined(_MZ800)\r
-       int vram_page_mask(uint8 f);\r
-       int vram_addr(int addr);\r
-#endif\r
-       \r
-       // crtc\r
-#if defined(_MZ800)\r
-       uint16 sof;\r
-       uint8 sw, ssa, sea;\r
-       uint8 palette_sw, palette[4], palette16[16];\r
-#elif defined(_MZ1500)\r
-       uint8 priority, palette[8];\r
-#endif\r
-       bool blink, tempo;\r
-       bool hblank, hsync;\r
-       bool vblank, vsync;\r
-#if defined(_MZ700) || defined(_MZ1500)\r
-       bool hblank_vram;\r
-#endif\r
-#if defined(_MZ1500)\r
-       bool hblank_pcg;\r
-#endif\r
-       void set_vblank(bool val);\r
-       void set_hblank(bool val);\r
-       \r
-       // renderer\r
-#if defined(_MZ800)\r
-       uint8 screen[200][640];\r
-       scrntype palette_mz800_pc[16];\r
-#else\r
-       uint8 screen[200][320];\r
-#endif\r
-       scrntype palette_pc[8];\r
-       \r
-#if defined(_MZ800)\r
-       void draw_line_320x200_2bpp(int v);\r
-       void draw_line_320x200_4bpp(int v);\r
-       void draw_line_640x200_1bpp(int v);\r
-       void draw_line_640x200_2bpp(int v);\r
-       void draw_line_mz700(int v);\r
-#else\r
-       void draw_line(int v);\r
-#endif\r
-       \r
-public:\r
-       MEMORY(VM* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu) {}\r
-       ~MEMORY() {}\r
-       \r
-       // common functions\r
-       void initialize();\r
-       void reset();\r
-#if defined(_MZ800)\r
-       void update_config();\r
-#endif\r
-       void event_vline(int v, int clock);\r
-       void event_callback(int event_id, int err);\r
-       void write_data8(uint32 addr, uint32 data);\r
-       uint32 read_data8(uint32 addr);\r
-       void write_data8w(uint32 addr, uint32 data, int* wait);\r
-       uint32 read_data8w(uint32 addr, int* wait);\r
-       void write_io8(uint32 addr, uint32 data);\r
-#if defined(_MZ800)\r
-       uint32 read_io8(uint32 addr);\r
-#endif\r
-       void save_state(FILEIO* state_fio);\r
-       bool load_state(FILEIO* state_fio);\r
-       \r
-       // unitque functions\r
-       void set_context_cpu(DEVICE* device)\r
-       {\r
-               d_cpu = device;\r
-       }\r
-       void set_context_pit(DEVICE* device)\r
-       {\r
-               d_pit = device;\r
-       }\r
-       void set_context_pio(DEVICE* device)\r
-       {\r
-               d_pio = device;\r
-       }\r
-#if defined(_MZ800)\r
-       void set_context_pio_int(DEVICE* device)\r
-       {\r
-               d_pio_int = device;\r
-       }\r
-#endif\r
-       void draw_screen();\r
-};\r
-\r
-#endif\r
-\r
+/*
+       SHARP MZ-700 Emulator 'EmuZ-700'
+       SHARP MZ-800 Emulator 'EmuZ-800'
+       SHARP MZ-1500 Emulator 'EmuZ-1500'
+
+       Author : Takeda.Toshiya
+       Date   : 2008.06.05 -
+
+       [ memory ]
+*/
+
+#ifndef _MZ700_MEMORY_H_
+#define _MZ700_MEMORY_H_
+
+#include "../vm.h"
+#include "../../emu.h"
+#include "../device.h"
+
+#if defined(_MZ800)
+class DISPLAY;
+#endif
+
+namespace MZ700 {
+       
+class MEMORY : public DEVICE
+{
+private:
+       DEVICE *d_cpu, *d_pit, *d_pio;
+#if defined(_MZ800)
+       DEVICE *d_pio_int;
+#endif
+       
+       // memory
+       uint8_t* rbank[32];
+       uint8_t* wbank[32];
+       uint8_t wdmy[0x800];
+       uint8_t rdmy[0x800];
+       
+       uint8_t ipl[0x1000];    // IPL 4KB
+#if defined(_MZ800)
+       uint8_t ext[0x2000];    // MZ-800 IPL 8KB
+#elif defined(_MZ1500)
+       uint8_t ext[0x1800];    // MZ-1500 EXT 6KB
+#endif
+       uint8_t font[0x1000];   // CGROM 4KB
+#if defined(_MZ700)
+       uint8_t pcg[0x1000];    // PCG-700 2KB + Lower CGROM 2KB
+#elif defined(_MZ1500)
+       uint8_t pcg[0x6000];    // MZ-1500 PCG 8KB * 3
+#endif
+       uint8_t ram[0x10000];   // Main RAM 64KB
+#if defined(_MZ800)
+       uint8_t vram[0x8000];   // MZ-800 VRAM 32KB
+#else
+       uint8_t vram[0x1000];   // MZ-700/1500 VRAM 4KB
+#endif
+       uint8_t mem_bank;
+#if defined(_MZ700)
+       uint8_t pcg_data;
+       uint8_t pcg_addr;
+       uint8_t pcg_ctrl;
+#elif defined(_MZ800)
+       uint8_t wf, rf;
+       uint8_t dmd;
+       uint32_t vram_addr_top;
+       bool is_mz800;
+#elif defined(_MZ1500)
+       uint8_t pcg_bank;
+#endif
+       
+       void update_map_low();
+       void update_map_middle();
+       void update_map_high();
+#if defined(_MZ800)
+       int vram_page_mask(uint8_t f);
+       int vram_addr(int addr);
+#endif
+       
+       // crtc
+#if defined(_MZ800)
+       uint16_t sof;
+       uint8_t sw, ssa, sea;
+       uint8_t palette_sw, palette[4], palette16[16];
+#elif defined(_MZ1500)
+       uint8_t priority, palette[8];
+#endif
+       bool blink, tempo;
+       bool hblank, hsync;
+       bool vblank, vsync;
+#if defined(_MZ700) || defined(_MZ1500)
+       bool hblank_vram;
+#endif
+#if defined(_MZ1500)
+       bool hblank_pcg;
+#endif
+       void set_vblank(bool val);
+       void set_hblank(bool val);
+       
+       // renderer
+#if defined(_MZ800)
+       uint8_t screen[200][640];
+       scrntype_t palette_mz800_pc[16];
+#else
+       uint8_t screen[200][320];
+#endif
+       scrntype_t palette_pc[8];
+       
+#if defined(_MZ800)
+       void draw_line_320x200_2bpp(int v);
+       void draw_line_320x200_4bpp(int v);
+       void draw_line_640x200_1bpp(int v);
+       void draw_line_640x200_2bpp(int v);
+       void draw_line_mz700(int v);
+#else
+       void draw_line(int v);
+#endif
+       
+public:
+       MEMORY(VM_TEMPLATE* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
+       {
+               set_device_name(_T("Memory Bus"));
+       }
+       ~MEMORY() {}
+       
+       // common functions
+       void initialize();
+       void reset();
+#if defined(_MZ800)
+       void update_config();
+#endif
+       void event_vline(int v, int clock);
+       void event_callback(int event_id, int err);
+       void write_data8(uint32_t addr, uint32_t data);
+       uint32_t read_data8(uint32_t addr);
+       void write_data8w(uint32_t addr, uint32_t data, int* wait);
+       uint32_t read_data8w(uint32_t addr, int* wait);
+       void write_io8(uint32_t addr, uint32_t data);
+#if defined(_MZ800)
+       uint32_t read_io8(uint32_t addr);
+#endif
+       bool process_state(FILEIO* state_fio, bool loading);
+       
+       // unique functions
+       void set_context_cpu(DEVICE* device)
+       {
+               d_cpu = device;
+       }
+       void set_context_pit(DEVICE* device)
+       {
+               d_pit = device;
+       }
+       void set_context_pio(DEVICE* device)
+       {
+               d_pio = device;
+       }
+#if defined(_MZ800)
+       void set_context_pio_int(DEVICE* device)
+       {
+               d_pio_int = device;
+       }
+#endif
+       void draw_screen();
+};
+
+}
+#endif
+