2 Skelton for retropc emulator
5 Author : Takeda.Toshiya
8 [ MB8877 / MB8876 / MB8866 / MB89311 ]
18 #define SIG_MB8877_ACCESS 0
19 #define SIG_MB8877_DRIVEREG 1
20 #define SIG_MB8877_SIDEREG 2
21 #define SIG_MB8877_MOTOR 3
26 class MB8877 : public DEVICE
30 outputs_t outputs_irq;
31 outputs_t outputs_drq;
35 NOISE* d_noise_head_down;
36 NOISE* d_noise_head_up;
53 int next_trans_position;
54 int bytes_before_2nd_drq;
55 int next_am1_position;
61 uint8_t status, status_tmp;
62 uint8_t cmdreg, cmdreg_tmp;
73 void cancel_my_event(int event);
74 void register_my_event(int event, double usec);
75 void register_seek_event();
76 void register_drq_event(int bytes);
77 void register_lost_event(int bytes);
95 uint32_t prev_drq_clock;
96 uint32_t seekend_clock;
100 bool invert_registers;
101 bool type_fm77av_2dd;
108 bool mb8877_no_busy_after_seek;
112 int get_cur_position();
113 double get_usec_to_start_trans(bool first_sector);
114 double get_usec_to_next_trans_pos(bool delay);
115 double get_usec_to_detect_index_hole(int count, bool delay);
118 uint8_t search_track();
119 uint8_t search_sector();
120 uint8_t search_addr();
129 void cmd_readdata(bool first_sector);
130 void cmd_writedata(bool first_sector);
132 void cmd_readtrack();
133 void cmd_writetrack();
138 void update_head_flag(int drv, bool head_load);
141 void set_irq(bool val);
142 void set_drq(bool val);
145 MB8877(VM* parent_vm, EMU* parent_emu) : DEVICE(parent_vm, parent_emu)
147 initialize_output_signals(&outputs_irq);
148 initialize_output_signals(&outputs_drq);
150 d_noise_head_down = NULL;
151 d_noise_head_up = NULL;
154 fdc_debug_log = invert_registers = type_fm77av_2dd = false;
155 type_mb8866 = type_mb89311 = false;
156 type_x1 = type_fm7 = type_fmr50 = type_fmr60 = false;
157 mb8877_no_busy_after_seek = false;
159 _drive_mask = _max_drive - 1;
160 //#if defined(HAS_MB89311)
161 // set_device_name(_T("MB89311 FDC"));
162 //#elif defined(HAS_MB8866)
163 // set_device_name(_T("MB8866 FDC"));
164 //#elif defined(HAS_MB8876)
165 // set_device_name(_T("MB8876 FDC"));
167 // set_device_name(_T("MB8877 FDC"));
176 void write_io8(uint32_t addr, uint32_t data);
177 uint32_t read_io8(uint32_t addr);
178 void write_dma_io8(uint32_t addr, uint32_t data);
179 uint32_t read_dma_io8(uint32_t addr);
180 void write_signal(int id, uint32_t data, uint32_t mask);
181 uint32_t read_signal(int ch);
182 void event_callback(int event_id, int err);
183 void update_config();
184 void save_state(FILEIO* state_fio);
185 bool load_state(FILEIO* state_fio);
188 void set_context_irq(DEVICE* device, int id, uint32_t mask)
190 register_output_signal(&outputs_irq, device, id, mask);
192 void set_context_drq(DEVICE* device, int id, uint32_t mask)
194 register_output_signal(&outputs_drq, device, id, mask);
196 void set_context_noise_seek(NOISE* device)
198 d_noise_seek = device;
200 NOISE* get_context_noise_seek()
204 void set_context_noise_head_down(NOISE* device)
206 d_noise_head_down = device;
208 NOISE* get_context_noise_head_down()
210 return d_noise_head_down;
212 void set_context_noise_head_up(NOISE* device)
214 d_noise_head_up = device;
216 NOISE* get_context_noise_head_up()
218 return d_noise_head_up;
220 DISK* get_disk_handler(int drv)
224 void open_disk(int drv, const _TCHAR* file_path, int bank);
225 void close_disk(int drv);
226 bool is_disk_inserted(int drv);
227 void is_disk_protected(int drv, bool value);
228 bool is_disk_protected(int drv);
229 void set_drive_type(int drv, uint8_t type);
230 uint8_t get_drive_type(int drv);
231 void set_drive_rpm(int drv, int rpm);
232 void set_drive_mfm(int drv, bool mfm);
233 void set_track_size(int drv, int size);
234 uint8_t fdc_status();