OSDN Git Service

[VM][STATE] Use namespace {VMNAME} to separate per VMs.
[csp-qt/common_source_project-fm7.git] / source / src / vm / qc10 / memory.h
1 /*
2         EPSON QC-10 Emulator 'eQC-10'
3
4         Author : Takeda.Toshiya
5         Date   : 2008.02.15 -
6
7         [ memory ]
8 */
9
10 #ifndef _MEMORY_H_
11 #define _MEMORY_H_
12
13 #include "../vm.h"
14 #include "../../emu.h"
15 #include "../device.h"
16
17 #define SIG_MEMORY_PCM          0
18 #define SIG_MEMORY_FDC_IRQ      1
19 #define SIG_MEMORY_MOTOR        2
20
21 class UPD765A;
22
23 namespace QC10 {
24
25 class MEMORY : public DEVICE
26 {
27 private:
28         DEVICE *d_pit, *d_pcm;
29         UPD765A *d_fdc;
30         
31         uint8_t* rbank[32];
32         uint8_t* wbank[32];
33         uint8_t wdmy[0x10000];
34         uint8_t rdmy[0x10000];
35         uint8_t ipl[0x2000];
36         uint8_t ram[0x40000];
37         uint8_t cmos[0x800];
38         uint32_t cmos_crc32;
39         uint8_t bank, psel, csel;
40         void update_map();
41         
42         bool pcm_on, pcm_cont, pcm_pit;
43         void update_pcm();
44         
45         bool fdc_irq, motor;
46         
47 public:
48         MEMORY(VM_TEMPLATE* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
49         {
50                 set_device_name(_T("Memory Bus"));
51         }
52         ~MEMORY() {}
53         
54         // common functions
55         void initialize();
56         void release();
57         void reset();
58         void write_data8(uint32_t addr, uint32_t data);
59         uint32_t read_data8(uint32_t addr);
60         void write_io8(uint32_t addr, uint32_t data);
61         uint32_t read_io8(uint32_t addr);
62         void write_signal(int id, uint32_t data, uint32_t mask);
63         bool process_state(FILEIO* state_fio, bool loading);
64         
65         // unique functions
66         void set_context_pit(DEVICE* device)
67         {
68                 d_pit = device;
69         }
70         void set_context_pcm(DEVICE* device)
71         {
72                 d_pcm = device;
73         }
74         void set_context_fdc(UPD765A* device)
75         {
76                 d_fdc = device;
77         }
78 };
79
80 }
81 #endif
82