OSDN Git Service

5e49d7687d48d1e549fe65ec965e20355a45133c
[csp-qt/common_source_project-fm7.git] / source / src / vm / pc100 / crtc.h
1 /*
2         NEC PC-100 Emulator 'ePC-100'
3
4         Author : Takeda.Toshiya
5         Date   : 2008.07.14 -
6
7         [ crtc ]
8 */
9
10 #ifndef _CRTC_H_
11 #define _CRTC_H_
12
13 #include "../vm.h"
14 #include "../../emu.h"
15 #include "../device.h"
16
17 #define SIG_CRTC_BITMASK_LOW    0
18 #define SIG_CRTC_BITMASK_HIGH   1
19 #define SIG_CRTC_VRAM_PLANE     2
20
21 class CRTC : public DEVICE
22 {
23 private:
24         DEVICE *d_pic;
25         
26         scrntype_t palette_pc[16];
27         uint16_t palette[16];
28         uint8_t sel, regs[8];
29         uint16_t vs, cmd;
30         
31         uint8_t vram[0x80000];  // VRAM 128KB * 4planes
32         uint32_t shift, maskl, maskh, busl, bush;
33         uint32_t write_plane, read_plane;
34         
35         void update_palette(int num);
36         
37 public:
38         CRTC(VM_TEMPLATE* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
39         {
40                 set_device_name(_T("CRTC"));
41         }
42         ~CRTC() {}
43         
44         // common functions
45         void initialize();
46         void event_vline(int v, int clock);
47         void write_io8(uint32_t addr, uint32_t data);
48         uint32_t read_io8(uint32_t addr);
49         void write_memory_mapped_io8(uint32_t addr, uint32_t data);
50         uint32_t read_memory_mapped_io8(uint32_t addr);
51         void write_memory_mapped_io16(uint32_t addr, uint32_t data);
52         uint32_t read_memory_mapped_io16(uint32_t addr);
53         void write_signal(int id, uint32_t data, uint32_t mask);
54         bool process_state(FILEIO* state_fio, bool loading);
55         
56         // unique functions
57         void set_context_pic(DEVICE* device)
58         {
59                 d_pic = device;
60         }
61         void draw_screen();
62 };
63
64 #endif
65