OSDN Git Service

[General][VM][Qt] Merge upstream 2015-08-05 .
[csp-qt/common_source_project-fm7.git] / source / src / vm / fmr50 / timer.h
1 /*
2         FUJITSU FMR-50 Emulator 'eFMR-50'
3         FUJITSU FMR-60 Emulator 'eFMR-60'
4
5         Author : Takeda.Toshiya
6         Date   : 2008.04.30 -
7
8         [ timer ]
9 */
10
11 #ifndef _TIMER_H_
12 #define _TIMER_H_
13
14 #include "../vm.h"
15 #include "../../emu.h"
16 #include "../device.h"
17
18 #define SIG_TIMER_CH0   0
19 #define SIG_TIMER_CH1   1
20 #define SIG_TIMER_RTC   2
21
22 class TIMER : public DEVICE
23 {
24 private:
25         DEVICE *d_pcm, *d_pic, *d_rtc;
26         
27         uint16 free_run_counter;
28         uint8 intr_reg, rtc_data;
29         bool tmout0, tmout1;
30         void update_intr();
31         
32 public:
33         TIMER(VM* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu) {}
34         ~TIMER() {}
35         
36         // common functions
37         void initialize();
38         void write_io8(uint32 addr, uint32 data);
39         uint32 read_io8(uint32 addr);
40         void write_signal(int id, uint32 data, uint32 mask);
41         void save_state(FILEIO* state_fio);
42         bool load_state(FILEIO* state_fio);
43         
44         // unique functions
45         void set_context_pcm(DEVICE* device)
46         {
47                 d_pcm = device;
48         }
49         void set_context_pic(DEVICE* device)
50         {
51                 d_pic = device;
52         }
53         void set_context_rtc(DEVICE* device)
54         {
55                 d_rtc = device;
56         }
57 };
58
59 #endif
60