2 NEC PC-9801 Emulator 'ePC-9801'
3 NEC PC-9801E/F/M Emulator 'ePC-9801E'
4 NEC PC-98DO Emulator 'ePC-98DO'
6 Author : Takeda.Toshiya
16 #include "../upd765a.h"
17 #include "../../fileio.h"
23 #if defined(SUPPORT_2HD_FDD_IF)
24 for(int i = 0; i < MAX_DRIVE; i++) {
25 d_fdc_2hd->set_drive_type(i, DRIVE_TYPE_2HD);
29 #if defined(SUPPORT_2DD_FDD_IF)
30 for(int i = 0; i < MAX_DRIVE; i++) {
31 d_fdc_2dd->set_drive_type(i, DRIVE_TYPE_2DD);
35 #if defined(SUPPORT_2HD_2DD_FDD_IF)
36 for(int i = 0; i < 4; i++) {
37 d_fdc->set_drive_type(i, DRIVE_TYPE_2HD);
45 void FLOPPY::write_io8(uint32 addr, uint32 data)
47 switch(addr & 0xffff) {
48 #if defined(SUPPORT_2HD_FDD_IF)
50 d_fdc_2hd->write_io8(0, data);
53 d_fdc_2hd->write_io8(1, data);
56 if(!(ctrlreg_2hd & 0x80) && (data & 0x80)) {
59 d_fdc_2hd->write_signal(SIG_UPD765A_FREADY, data, 0x40);
63 #if defined(SUPPORT_2DD_FDD_IF)
65 d_fdc_2dd->write_io8(0, data);
68 d_fdc_2dd->write_io8(1, data);
71 if(!(ctrlreg_2dd & 0x80) && (data & 0x80)) {
76 cancel_event(this, timer_id);
78 register_event(this, EVENT_TIMER, 100000, false, &timer_id);
80 d_fdc_2dd->write_signal(SIG_UPD765A_MOTOR, data, 0x08);
84 #if defined(SUPPORT_2HD_2DD_FDD_IF)
87 if(((addr >> 4) & 1) == (modereg & 1)) {
88 d_fdc->write_io8(0, data);
93 if(((addr >> 4) & 1) == (modereg & 1)) {
94 d_fdc->write_io8(1, data);
99 if(((addr >> 4) & 1) == (modereg & 1)) {
100 if(!(ctrlreg & 0x80) && (data & 0x80)) {
103 if(!(addr == 0xcc && !(data & 0x20))) {
104 d_fdc->write_signal(SIG_UPD765A_FREADY, data, 0x40);
108 cancel_event(this, timer_id);
110 register_event(this, EVENT_TIMER, 100000, false, &timer_id);
113 // d_fdc->write_signal(SIG_UPD765A_MOTOR, data, 0x08);
119 if(!(modereg & 2) && (data & 2)) {
120 d_fdc->set_drive_type(0, DRIVE_TYPE_2HD);
121 d_fdc->set_drive_type(1, DRIVE_TYPE_2HD);
122 } else if((modereg & 2) && !(data & 2)) {
123 d_fdc->set_drive_type(0, DRIVE_TYPE_2DD);
124 d_fdc->set_drive_type(1, DRIVE_TYPE_2DD);
132 uint32 FLOPPY::read_io8(uint32 addr)
134 switch(addr & 0xffff) {
135 #if defined(SUPPORT_2HD_FDD_IF)
137 return d_fdc_2hd->read_io8(0);
139 return d_fdc_2hd->read_io8(1);
140 #if !defined(_PC9801)
142 return 0x5f; // 0x40 ???
145 #if defined(SUPPORT_2DD_FDD_IF)
147 return d_fdc_2dd->read_io8(0);
149 return d_fdc_2dd->read_io8(1);
151 return (d_fdc_2dd->disk_inserted() ? 0x10 : 0) | 0x6f; // 0x60 ???
153 #if defined(SUPPORT_2HD_2DD_FDD_IF)
156 if(((addr >> 4) & 1) == (modereg & 1)) {
157 return d_fdc->read_io8(0);
162 if(((addr >> 4) & 1) == (modereg & 1)) {
163 return d_fdc->read_io8(1);
172 return 0xf8 | (modereg & 3);
175 return (d_fdc->disk_inserted() ? 0x10 : 0) | 0x64; // 0x60 ???
180 return 0xff;//addr & 0xff;
183 void FLOPPY::write_signal(int id, uint32 data, uint32 mask)
186 #if defined(SUPPORT_2HD_FDD_IF)
187 case SIG_FLOPPY_2HD_IRQ:
188 d_pic->write_signal(SIG_I8259_CHIP1 | SIG_I8259_IR3, data, mask);
190 case SIG_FLOPPY_2HD_DRQ:
191 d_dma->write_signal(SIG_I8237_CH2, data, mask);
194 #if defined(SUPPORT_2DD_FDD_IF)
195 case SIG_FLOPPY_2DD_IRQ:
196 d_pic->write_signal(SIG_I8259_CHIP1 | SIG_I8259_IR2, data, mask);
198 case SIG_FLOPPY_2DD_DRQ:
199 d_dma->write_signal(SIG_I8237_CH3, data, mask);
202 #if defined(SUPPORT_2HD_2DD_FDD_IF)
205 d_pic->write_signal(SIG_I8259_CHIP1 | SIG_I8259_IR3, data, mask);
207 d_pic->write_signal(SIG_I8259_CHIP1 | SIG_I8259_IR2, data, mask);
212 d_dma->write_signal(SIG_I8237_CH2, data, mask);
214 d_dma->write_signal(SIG_I8237_CH3, data, mask);
221 void FLOPPY::event_callback(int event_id, int err)
223 #if defined(SUPPORT_2DD_FDD_IF)
224 if(ctrlreg_2dd & 4) {
225 d_pic->write_signal(SIG_I8259_CHIP1 | SIG_I8259_IR2, 1, 1);
228 #if defined(SUPPORT_2HD_2DD_FDD_IF)
230 d_pic->write_signal(SIG_I8259_CHIP1 | SIG_I8259_IR2, 1, 1);
237 #define STATE_VERSION 1
239 void FLOPPY::save_state(FILEIO* state_fio)
241 state_fio->FputUint32(STATE_VERSION);
242 state_fio->FputInt32(this_device_id);
244 #if defined(SUPPORT_2HD_FDD_IF)
245 state_fio->FputUint8(ctrlreg_2hd);
247 #if defined(SUPPORT_2DD_FDD_IF)
248 state_fio->FputUint8(ctrlreg_2dd);
250 #if defined(SUPPORT_2HD_2DD_FDD_IF)
251 state_fio->FputUint8(ctrlreg);
252 state_fio->FputUint8(modereg);
254 state_fio->FputInt32(timer_id);
257 bool FLOPPY::load_state(FILEIO* state_fio)
259 if(state_fio->FgetUint32() != STATE_VERSION) {
262 if(state_fio->FgetInt32() != this_device_id) {
265 #if defined(SUPPORT_2HD_FDD_IF)
266 ctrlreg_2hd = state_fio->FgetUint8();
268 #if defined(SUPPORT_2DD_FDD_IF)
269 ctrlreg_2dd = state_fio->FgetUint8();
271 #if defined(SUPPORT_2HD_2DD_FDD_IF)
272 ctrlreg = state_fio->FgetUint8();
273 modereg = state_fio->FgetUint8();
275 timer_id = state_fio->FgetInt32();