// device-level overrides protected override void device_start() { m_diexec = GetClassInterface <device_execute_interface_i8257>(); LOG("{0}\n", "device_start"); //FUNCNAME); // set our instruction counter set_icountptr(m_icountRef); // resolve callbacks m_out_hrq_cb.resolve_safe(); m_out_tc_cb.resolve_safe(); m_in_memr_cb.resolve_safe(0); m_out_memw_cb.resolve_safe(); foreach (var cb in m_in_ior_cb) { cb.resolve_safe(0); } foreach (var cb in m_out_iow_cb) { cb.resolve_safe(); } foreach (var cb in m_out_dack_cb) { cb.resolve_safe(); } // state saving save_item(m_msb, "m_msb"); save_item(m_hreq, "m_hreq"); save_item(m_hack, "m_hack"); save_item(m_ready, "m_ready"); save_item(m_state, "m_state"); save_item(m_current_channel, "m_current_channel"); save_item(m_last_channel, "m_last_channel"); save_item(m_transfer_mode, "m_transfer_mode"); save_item(m_status, "m_status"); save_item(m_request, "m_request"); save_item(m_channel[0].m_address, "m_channel[0].m_address"); save_item(m_channel[0].m_count, "m_channel[0].m_count"); save_item(m_channel[0].m_mode, "m_channel[0].m_mode"); save_item(m_channel[1].m_address, "m_channel[1].m_address"); save_item(m_channel[1].m_count, "m_channel[1].m_count"); save_item(m_channel[1].m_mode, "m_channel[1].m_mode"); save_item(m_channel[2].m_address, "m_channel[2].m_address"); save_item(m_channel[2].m_count, "m_channel[2].m_count"); save_item(m_channel[2].m_mode, "m_channel[2].m_mode"); save_item(m_channel[3].m_address, "m_channel[3].m_address"); save_item(m_channel[3].m_count, "m_channel[3].m_count"); save_item(m_channel[3].m_mode, "m_channel[3].m_mode"); }
//uint8_t pa_r(); //uint8_t acka_r(); //uint8_t pb_r(); //uint8_t ackb_r(); //DECLARE_WRITE_LINE_MEMBER( pc2_w ); //DECLARE_WRITE_LINE_MEMBER( pc4_w ); //DECLARE_WRITE_LINE_MEMBER( pc6_w ); // device-level overrides protected override void device_resolve_objects() { // resolve callbacks m_in_pa_cb.resolve_safe(0); m_in_pb_cb.resolve_safe(0); m_in_pc_cb.resolve_safe(0); m_out_pa_cb.resolve_safe(); m_out_pb_cb.resolve_safe(); m_out_pc_cb.resolve_safe(); m_tri_pa_cb.resolve_safe(0xff); m_tri_pb_cb.resolve_safe(0xff); }
// device-level overrides //------------------------------------------------- // device_start - device-specific startup //------------------------------------------------- protected override void device_start() { /* resolve our read/write callbacks */ m_k.resolve_safe(0); foreach (devcb_read8 cb in m_in) { cb.resolve_safe(0); } m_p.resolve_safe(); m_irq_cleared_timer = machine().scheduler().timer_alloc(irq_clear); //timer_expired_delegate(FUNC(namco_53xx_device::irq_clear), this)); save_item(m_portO, "m_portO"); }
} //template <std::size_t Port> auto write_r() { return m_write_r[Port].bind(); } // SI: serial input //auto read_si() { return m_read_si.bind(); } // SO: serial output //auto write_so() { return m_write_so.bind(); } //static void set_pla(device_t &device, UINT8 *pla) { downcast<mb88_cpu_device &>(device).m_PLA = pla; } //DECLARE_WRITE_LINE_MEMBER( clock_w ); //void data_4bit(address_map &map); //void data_5bit(address_map &map); //void data_6bit(address_map &map); //void data_7bit(address_map &map); //void program_10bit(address_map &map); //void program_11bit(address_map &map); //void program_9bit(address_map &map); // device-level overrides /*************************************************************************** * INITIALIZATION AND SHUTDOWN ***************************************************************************/ protected override void device_start() { m_dimemory = GetClassInterface <device_memory_interface_mb88>(); m_diexec = GetClassInterface <device_execute_interface_mb88>(); m_distate = GetClassInterface <device_state_interface_mb88>(); m_program = m_dimemory.space(AS_PROGRAM); m_cache = m_program.cache(0, 0, (int)endianness_t.ENDIANNESS_BIG); m_data = m_dimemory.space(AS_DATA); m_read_k.resolve_safe(0); m_write_o.resolve_safe(); m_write_p.resolve_safe(); foreach (var cb in m_read_r) { cb.resolve_safe(0); } foreach (var cb in m_write_r) { cb.resolve_safe(); } m_read_si.resolve_safe(0); m_write_so.resolve_safe(); m_serial = machine().scheduler().timer_alloc(serial_timer); //timer_expired_delegate(FUNC(mb88_cpu_device::serial_timer), this)); m_ctr = 0; save_item(m_PC, "m_PC"); save_item(m_PA, "m_PA"); save_item(m_SP[0], "m_SP[0]"); save_item(m_SP[1], "m_SP[1]"); save_item(m_SP[2], "m_SP[2]"); save_item(m_SP[3], "m_SP[3]"); save_item(m_SI, "m_SI"); save_item(m_A, "m_A"); save_item(m_X, "m_X"); save_item(m_Y, "m_Y"); save_item(m_st, "m_st"); save_item(m_zf, "m_zf"); save_item(m_cf, "m_cf"); save_item(m_vf, "m_vf"); save_item(m_sf, "m_sf"); save_item(m_nf, "m_nf"); save_item(m_pio, "m_pio"); save_item(m_TH, "m_TH"); save_item(m_TL, "m_TL"); save_item(m_TP, "m_TP"); save_item(m_ctr, "m_ctr"); save_item(m_SB, "m_SB"); save_item(m_SBcount, "m_SBcount"); save_item(m_pending_interrupt, "m_pending_interrupt"); m_distate.state_add(MB88_PC, "PC", m_PC).formatstr("%02X"); m_distate.state_add(MB88_PA, "PA", m_PA).formatstr("%02X"); m_distate.state_add(MB88_SI, "SI", m_SI).formatstr("%01X"); m_distate.state_add(MB88_A, "A", m_A).formatstr("%01X"); m_distate.state_add(MB88_X, "X", m_X).formatstr("%01X"); m_distate.state_add(MB88_Y, "Y", m_Y).formatstr("%01X"); m_distate.state_add(MB88_PIO, "PIO", m_pio).formatstr("%02X"); m_distate.state_add(MB88_TH, "TH", m_TH).formatstr("%01X"); m_distate.state_add(MB88_TL, "TL", m_TL).formatstr("%01X"); m_distate.state_add(MB88_SB, "SB", m_SB).formatstr("%01X"); m_distate.state_add(STATE_GENPC, "GENPC", m_debugger_pc).callimport().callexport().noshow(); m_distate.state_add(STATE_GENPCBASE, "CURPC", m_debugger_pc).callimport().callexport().noshow(); m_distate.state_add(STATE_GENFLAGS, "GENFLAGS", m_debugger_flags).callimport().callexport().formatstr("%6s").noshow(); set_icountptr(m_icountRef); }