2 YAMAHA YIS Emulator 'eYIS'
4 Author : Takeda.Toshiya
11 #include "../../emu.h"
12 #include "../device.h"
17 #include "../memory.h"
18 #include "../am9511.h"
21 #include "../mb8877.h"
22 #include "../mc6820.h"
23 #include "../mc6844.h"
24 #include "../mc6850.h"
25 #include "../msm58321.h"
29 #include "../debugger.h"
39 // ----------------------------------------------------------------------------
41 // ----------------------------------------------------------------------------
43 VM::VM(EMU* parent_emu) : emu(parent_emu)
46 first_device = last_device = NULL;
47 dummy = new DEVICE(this, emu); // must be 1st device
48 event = new EVENT(this, emu); // must be 2nd device
50 cpu = new M6502(this, emu); // YM-2002
51 io = new IO(this, emu);
52 memory = new MEMORY(this, emu);
53 apu = new AM9511(this, emu);
54 beep = new BEEP(this, emu);
55 fdc = new MB8877(this, emu);
56 fdc->set_context_noise_seek(new NOISE(this, emu));
57 fdc->set_context_noise_head_down(new NOISE(this, emu));
58 fdc->set_context_noise_head_up(new NOISE(this, emu));
59 pia = new MC6820(this, emu); // MB8874
60 dma = new MC6844(this, emu); // HD46504
61 acia1 = new MC6850(this, emu); // MB8863
62 acia2 = new MC6850(this, emu);
63 rtc = new MSM58321(this, emu); // MSM5832RS
65 calendar = new CALENDAR(this, emu);
66 display = new DISPLAY(this, emu);
67 floppy = new FLOPPY(this, emu);
68 keyboard = new KEYBOARD(this, emu);
69 mapper = new MAPPER(this, emu);
70 sound = new SOUND(this, emu);
73 event->set_context_cpu(cpu);
74 event->set_context_sound(beep);
75 event->set_context_sound(fdc->get_context_noise_seek());
76 event->set_context_sound(fdc->get_context_noise_head_down());
77 event->set_context_sound(fdc->get_context_noise_head_up());
79 fdc->set_context_drq(dma, SIG_MC6844_TX_RQ_0, 1);
80 dma->set_context_memory(memory);
81 dma->set_context_ch0(fdc);
83 calendar->set_context_rtc(rtc);
84 floppy->set_context_fdc(fdc);
85 keyboard->set_context_cpu(cpu);
86 mapper->set_context_memory(memory);
87 sound->set_context_beep(beep);
90 cpu->set_context_mem(memory);
91 cpu->set_context_intr(dummy);
93 cpu->set_context_debugger(new DEBUGGER(this, emu));
97 memory->read_bios(_T("BIOS.ROM"), rom, sizeof(rom));
98 // $0000-$efff will be mapped in mapper class
99 memory->set_memory_mapped_io_rw(0xf000, 0xf0ff, io);
100 memory->set_memory_r(0xf100, 0xffff, rom + 0x100);
103 io->set_iomap_range_rw(0xf000, 0xf016, dma);
104 io->set_iomap_range_rw(0xf020, 0xf023, fdc);
105 io->set_iomap_single_w(0xf024, floppy);
106 io->set_iomap_single_rw(0xf030, keyboard);
107 io->set_iomap_single_r(0xf031, keyboard);
108 io->set_iomap_range_w(0xf031, 0xf032, sound);
109 io->set_iomap_range_rw(0xf034, 0xf035, apu);
110 io->set_iomap_range_rw(0xf036, 0xf037, calendar);
111 io->set_iomap_range_rw(0xf038, 0xf03b, pia);
112 io->set_iomap_range_rw(0xf03c, 0xf03d, acia1);
113 io->set_iomap_range_rw(0xf03e, 0xf03f, acia2);
114 io->set_iomap_range_rw(0xf040, 0xf04b, display);
115 io->set_iomap_range_rw(0xf04f, 0xf05f, mapper);
116 // io->set_iomap_range_rw(0xf060, 0xf06f, keyboard);
118 // initialize all devices
119 for(DEVICE* device = first_device; device; device = device->next_device) {
120 device->initialize();
122 for(int i = 0; i < MAX_DRIVE; i++) {
123 fdc->set_drive_type(i, DRIVE_TYPE_2DD); // 1DD
124 fdc->set_track_size(i, 6238);
130 // delete all devices
131 for(DEVICE* device = first_device; device;) {
132 DEVICE *next_device = device->next_device;
135 device = next_device;
139 DEVICE* VM::get_device(int id)
141 for(DEVICE* device = first_device; device; device = device->next_device) {
142 if(device->this_device_id == id) {
149 // ----------------------------------------------------------------------------
150 // drive virtual machine
151 // ----------------------------------------------------------------------------
156 for(DEVICE* device = first_device; device; device = device->next_device) {
166 // ----------------------------------------------------------------------------
168 // ----------------------------------------------------------------------------
171 DEVICE *VM::get_cpu(int index)
180 // ----------------------------------------------------------------------------
182 // ----------------------------------------------------------------------------
184 void VM::draw_screen()
186 display->draw_screen();
189 // ----------------------------------------------------------------------------
191 // ----------------------------------------------------------------------------
193 void VM::initialize_sound(int rate, int samples)
195 // init sound manager
196 event->initialize_sound(rate, samples);
199 beep->initialize_sound(rate, 49152 / 0x80, 8000);
202 uint16_t* VM::create_sound(int* extra_frames)
204 return event->create_sound(extra_frames);
207 int VM::get_sound_buffer_ptr()
209 return event->get_sound_buffer_ptr();
212 #ifdef USE_SOUND_VOLUME
213 void VM::set_sound_device_volume(int ch, int decibel_l, int decibel_r)
216 beep->set_volume(0, decibel_l, decibel_r);
218 fdc->get_context_noise_seek()->set_volume(0, decibel_l, decibel_r);
219 fdc->get_context_noise_head_down()->set_volume(0, decibel_l, decibel_r);
220 fdc->get_context_noise_head_up()->set_volume(0, decibel_l, decibel_r);
225 // ----------------------------------------------------------------------------
227 // ----------------------------------------------------------------------------
229 void VM::key_down(int code, bool repeat)
232 keyboard->key_down(code);
236 void VM::key_up(int code)
240 bool VM::get_caps_locked()
242 return keyboard->get_caps_locked();
245 bool VM::get_kana_locked()
247 return keyboard->get_kana_locked();
250 // ----------------------------------------------------------------------------
252 // ----------------------------------------------------------------------------
254 void VM::open_floppy_disk(int drv, const _TCHAR* file_path, int bank)
256 fdc->open_disk(drv, file_path, bank);
259 void VM::close_floppy_disk(int drv)
261 fdc->close_disk(drv);
264 bool VM::is_floppy_disk_inserted(int drv)
266 return fdc->is_disk_inserted(drv);
269 void VM::is_floppy_disk_protected(int drv, bool value)
271 fdc->is_disk_protected(drv, value);
274 bool VM::is_floppy_disk_protected(int drv)
276 return fdc->is_disk_protected(drv);
279 uint32_t VM::is_floppy_disk_accessed()
281 return fdc->read_signal(0);
284 bool VM::is_frame_skippable()
286 return event->is_frame_skippable();
289 void VM::update_config()
291 for(DEVICE* device = first_device; device; device = device->next_device) {
292 device->update_config();
296 #define STATE_VERSION 2
298 void VM::save_state(FILEIO* state_fio)
300 state_fio->FputUint32(STATE_VERSION);
302 for(DEVICE* device = first_device; device; device = device->next_device) {
303 device->save_state(state_fio);
307 bool VM::load_state(FILEIO* state_fio)
309 if(state_fio->FgetUint32() != STATE_VERSION) {
312 for(DEVICE* device = first_device; device; device = device->next_device) {
313 if(!device->load_state(state_fio)) {