OSDN Git Service

f059c66bda55a36aa96a691c9d0f3916d6846d61
[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 class MEMORY : public DEVICE
24 {
25 private:
26         DEVICE *d_pit, *d_pcm;
27         UPD765A *d_fdc;
28         
29         uint8_t* rbank[32];
30         uint8_t* wbank[32];
31         uint8_t wdmy[0x10000];
32         uint8_t rdmy[0x10000];
33         uint8_t ipl[0x2000];
34         uint8_t ram[0x40000];
35         uint8_t cmos[0x800];
36         uint32_t cmos_crc32;
37         uint8_t bank, psel, csel;
38         void update_map();
39         
40         bool pcm_on, pcm_cont, pcm_pit;
41         void update_pcm();
42         
43         bool fdc_irq, motor;
44         
45 public:
46         MEMORY(VM_TEMPLATE* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
47         {
48                 set_device_name(_T("Memory Bus"));
49         }
50         ~MEMORY() {}
51         
52         // common functions
53         void initialize();
54         void release();
55         void reset();
56         void write_data8(uint32_t addr, uint32_t data);
57         uint32_t read_data8(uint32_t addr);
58         void write_io8(uint32_t addr, uint32_t data);
59         uint32_t read_io8(uint32_t addr);
60         void write_signal(int id, uint32_t data, uint32_t mask);
61         void decl_state();
62         void save_state(FILEIO* state_fio);
63         bool load_state(FILEIO* state_fio);
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 #endif
81