2 Skelton for retropc emulator
4 Author : Takeda.Toshiya
18 #define IO_ADDR_MAX 0x100
20 #define IO_ADDR_MASK (IO_ADDR_MAX - 1)
22 class IO : public DEVICE
31 } wr_table[IO_ADDR_MAX];
37 bool value_registered;
39 } rd_table[IO_ADDR_MAX];
41 void write_port8(uint32 addr, uint32 data, bool is_dma);
42 uint32 read_port8(uint32 addr, bool is_dma);
43 void write_port16(uint32 addr, uint32 data, bool is_dma);
44 uint32 read_port16(uint32 addr, bool is_dma);
45 void write_port32(uint32 addr, uint32 data, bool is_dma);
46 uint32 read_port32(uint32 addr, bool is_dma);
49 IO(VM* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
51 memset(wr_table, 0, sizeof(wr_table));
52 memset(rd_table, 0, sizeof(rd_table));
54 // vm->dummy must be generated first !
55 for(int i = 0; i < IO_ADDR_MAX; i++) {
56 wr_table[i].dev = rd_table[i].dev = vm->dummy;
57 wr_table[i].addr = rd_table[i].addr = i;
66 void write_io8(uint32 addr, uint32 data);
67 uint32 read_io8(uint32 addr);
68 void write_io16(uint32 addr, uint32 data);
69 uint32 read_io16(uint32 addr);
70 void write_io32(uint32 addr, uint32 data);
71 uint32 read_io32(uint32 addr);
72 void write_io8w(uint32 addr, uint32 data, int* wait);
73 uint32 read_io8w(uint32 addr, int* wait);
74 void write_io16w(uint32 addr, uint32 data, int* wait);
75 uint32 read_io16w(uint32 addr, int* wait);
76 void write_io32w(uint32 addr, uint32 data, int* wait);
77 uint32 read_io32w(uint32 addr, int* wait);
78 void write_dma_io8(uint32 addr, uint32 data);
79 uint32 read_dma_io8(uint32 addr);
80 void write_dma_io16(uint32 addr, uint32 data);
81 uint32 read_dma_io16(uint32 addr);
82 void write_dma_io32(uint32 addr, uint32 data);
83 uint32 read_dma_io32(uint32 addr);
84 void save_state(FILEIO* state_fio);
85 bool load_state(FILEIO* state_fio);
88 void set_iomap_single_r(uint32 addr, DEVICE* device);
89 void set_iomap_single_w(uint32 addr, DEVICE* device);
90 void set_iomap_single_rw(uint32 addr, DEVICE* device);
91 void set_iomap_alias_r(uint32 addr, DEVICE* device, uint32 alias);
92 void set_iomap_alias_w(uint32 addr, DEVICE* device, uint32 alias);
93 void set_iomap_alias_rw(uint32 addr, DEVICE* device, uint32 alias);
94 void set_iomap_range_r(uint32 s, uint32 e, DEVICE* device);
95 void set_iomap_range_w(uint32 s, uint32 e, DEVICE* device);
96 void set_iomap_range_rw(uint32 s, uint32 e, DEVICE* device);
98 void set_iovalue_single_r(uint32 addr, uint32 value);
99 void set_iovalue_range_r(uint32 s, uint32 e, uint32 value);
100 void set_flipflop_single_rw(uint32 addr, uint32 value);
101 void set_flipflop_range_rw(uint32 s, uint32 e, uint32 value);
103 void set_iowait_single_r(uint32 addr, int wait);
104 void set_iowait_single_w(uint32 addr, int wait);
105 void set_iowait_single_rw(uint32 addr, int wait);
106 void set_iowait_range_r(uint32 s, uint32 e, int wait);
107 void set_iowait_range_w(uint32 s, uint32 e, int wait);
108 void set_iowait_range_rw(uint32 s, uint32 e, int wait);