OSDN Git Service

[VM][General] Merge upstream 2016-03-01. (Pahse 1).
[csp-qt/common_source_project-fm7.git] / source / src / vm / i8259.h
1 /*
2         Skelton for retropc emulator
3
4         Author : Takeda.Toshiya
5         Date   : 2005.06.10-
6
7         [ i8259 ]
8 */
9
10 #ifndef _I8259_H_
11 #define _I8259_H_
12
13 #include "vm.h"
14 #include "../emu.h"
15 #include "device.h"
16
17 /*
18         NOTE: I8259_MAX_CHIPS shoud be 1 or 2
19 */
20
21 #define SIG_I8259_IR0   0
22 #define SIG_I8259_IR1   1
23 #define SIG_I8259_IR2   2
24 #define SIG_I8259_IR3   3
25 #define SIG_I8259_IR4   4
26 #define SIG_I8259_IR5   5
27 #define SIG_I8259_IR6   6
28 #define SIG_I8259_IR7   7
29 #define SIG_I8259_CHIP0 0
30 #define SIG_I8259_CHIP1 8
31 //#define SIG_I8259_CHIP2       16
32 //#define SIG_I8259_CHIP3       24
33
34 #define I8259_ADDR_CHIP0        0
35 #define I8259_ADDR_CHIP1        2
36 //#define I8259_ADDR_CHIP2      4
37 //#define I8259_ADDR_CHIP3      6
38
39 class I8259 : public DEVICE
40 {
41 private:
42         DEVICE* d_cpu;
43         
44         struct {
45                 uint8_t imr, isr, irr, irr_tmp, prio;
46                 uint8_t icw1, icw2, icw3, icw4, ocw3;
47                 uint8_t icw2_r, icw3_r, icw4_r;
48                 int irr_tmp_id;
49         } pic[I8259_MAX_CHIPS];
50         int req_chip, req_level;
51         uint8_t req_bit;
52         
53         void update_intr();
54         
55 public:
56         I8259(VM* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
57         {
58                 d_cpu = NULL;
59         }
60         ~I8259() {}
61         
62         // common functions
63         void initialize();
64         void reset();
65         void write_io8(uint32_t addr, uint32_t data);
66         uint32_t read_io8(uint32_t addr);
67         void write_signal(int id, uint32_t data, uint32_t mask);
68         uint32_t read_signal(int id);
69         void event_callback(int event_id, int err);
70         void save_state(FILEIO* state_fio);
71         bool load_state(FILEIO* state_fio);
72         const _TCHAR *get_device_name()
73         {
74                 return _T("8259");
75         }
76         
77         // interrupt common functions
78         void set_intr_line(bool line, bool pending, uint32_t bit)
79         {
80                 // request from Z80 familly
81                 write_signal(bit, line ? 1 : 0, 1);
82         }
83         uint32_t get_intr_ack();
84         
85         // unique functions
86         void set_context_cpu(DEVICE* device)
87         {
88                 d_cpu = device;
89         }
90 };
91
92 #endif
93