2 Skelton for retropc emulator
4 Author : Takeda.Toshiya
17 #define SIG_MC6844_TX_RQ_0 0
18 #define SIG_MC6844_TX_RQ_1 1
19 #define SIG_MC6844_TX_RQ_2 2
20 #define SIG_MC6844_TX_RQ_3 3
22 class MC6844 : public DEVICE
30 pair_t byte_count_reg;
31 uint8_t channel_ctrl_reg;
34 uint8_t priority_ctrl_reg;
35 uint8_t interrupt_ctrl_reg;
36 uint8_t data_chain_reg;
38 outputs_t outputs_irq;
40 void transfer(int ch);
44 MC6844(VM_TEMPLATE* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
46 // TIP: if((DEVICE::prev_device == NULL) || (DEVICE::this_device_id == 0)) DEVICE must be DUMMY.
47 // And, at this device, should not be FIRST DEVICE. 20170613 Ohta.
49 while((__dev->prev_device != NULL) && (__dev->this_device_id > 0)) {
50 __dev = __dev->prev_device;
53 // for(int i = 0; i < 4; i++) {
54 // dma[i].device = vm->dummy;
56 // d_memory = vm->dummy;
57 for(int i = 0; i < 4; i++) {
58 dma[i].device = __dev;
61 initialize_output_signals(&outputs_irq);
62 set_device_name(_T("MC6844 DMAC"));
68 void write_io8(uint32_t addr, uint32_t data);
69 uint32_t read_io8(uint32_t addr);
70 void write_signal(int id, uint32_t data, uint32_t mask);
71 bool process_state(FILEIO* state_fio, bool loading);
74 void set_context_memory(DEVICE* device)
78 void set_context_ch0(DEVICE* device)
80 dma[0].device = device;
82 void set_context_ch1(DEVICE* device)
84 dma[1].device = device;
86 void set_context_ch2(DEVICE* device)
88 dma[2].device = device;
90 void set_context_ch3(DEVICE* device)
92 dma[3].device = device;