static CPU_INIT( i860 ) { i860_state_t *cpustate = get_safe_token(device); cpustate->device = device; cpustate->program = device->space(AS_PROGRAM); reset_i860(cpustate); i860_set_pin(device, DEC_PIN_BUS_HOLD, 0); i860_set_pin(device, DEC_PIN_RESET, 0); cpustate->single_stepping = 0; state_save_register_device_item_array(device, 0, cpustate->iregs); state_save_register_device_item_array(device, 0, cpustate->cregs); state_save_register_device_item_array(device, 0, cpustate->frg); state_save_register_device_item(device, 0, cpustate->pc); }
void i860_cpu_device::device_start() { m_program = &space(AS_PROGRAM); reset_i860(); i860_set_pin(DEC_PIN_BUS_HOLD, 0); i860_set_pin(DEC_PIN_RESET, 0); m_single_stepping = 0; save_item(NAME(m_iregs)); save_item(NAME(m_cregs)); save_item(NAME(m_frg)); save_item(NAME(m_pc)); state_add( I860_PC, "PC", m_pc).formatstr("%08X"); state_add( I860_FIR, "FIR", m_cregs[CR_FIR]).formatstr("%08X"); state_add( I860_PSR, "PSR", m_cregs[CR_PSR]).formatstr("%08X"); state_add( I860_DIRBASE, "DIRBASE", m_cregs[CR_DIRBASE]).formatstr("%08X"); state_add( I860_DB, "DB", m_cregs[CR_DB]).formatstr("%08X"); state_add( I860_FSR, "FSR", m_cregs[CR_FSR]).formatstr("%08X"); state_add( I860_EPSR, "EPSR", m_cregs[CR_EPSR]).formatstr("%08X"); state_add( I860_R0, "R0", m_iregs[0]).formatstr("%08X"); state_add( I860_R1, "R1", m_iregs[1]).formatstr("%08X"); state_add( I860_R2, "R2", m_iregs[2]).formatstr("%08X"); state_add( I860_R3, "R3", m_iregs[3]).formatstr("%08X"); state_add( I860_R4, "R4", m_iregs[4]).formatstr("%08X"); state_add( I860_R5, "R5", m_iregs[5]).formatstr("%08X"); state_add( I860_R6, "R6", m_iregs[6]).formatstr("%08X"); state_add( I860_R7, "R7", m_iregs[7]).formatstr("%08X"); state_add( I860_R8, "R8", m_iregs[8]).formatstr("%08X"); state_add( I860_R9, "R9", m_iregs[9]).formatstr("%08X"); state_add( I860_R10, "R10", m_iregs[10]).formatstr("%08X"); state_add( I860_R11, "R11", m_iregs[11]).formatstr("%08X"); state_add( I860_R12, "R12", m_iregs[12]).formatstr("%08X"); state_add( I860_R13, "R13", m_iregs[13]).formatstr("%08X"); state_add( I860_R14, "R14", m_iregs[14]).formatstr("%08X"); state_add( I860_R15, "R15", m_iregs[15]).formatstr("%08X"); state_add( I860_R16, "R16", m_iregs[16]).formatstr("%08X"); state_add( I860_R17, "R17", m_iregs[17]).formatstr("%08X"); state_add( I860_R18, "R18", m_iregs[18]).formatstr("%08X"); state_add( I860_R19, "R19", m_iregs[19]).formatstr("%08X"); state_add( I860_R20, "R20", m_iregs[20]).formatstr("%08X"); state_add( I860_R21, "R21", m_iregs[21]).formatstr("%08X"); state_add( I860_R22, "R22", m_iregs[22]).formatstr("%08X"); state_add( I860_R23, "R23", m_iregs[23]).formatstr("%08X"); state_add( I860_R24, "R24", m_iregs[24]).formatstr("%08X"); state_add( I860_R25, "R25", m_iregs[25]).formatstr("%08X"); state_add( I860_R26, "R26", m_iregs[26]).formatstr("%08X"); state_add( I860_R27, "R27", m_iregs[27]).formatstr("%08X"); state_add( I860_R28, "R28", m_iregs[28]).formatstr("%08X"); state_add( I860_R29, "R29", m_iregs[29]).formatstr("%08X"); state_add( I860_R30, "R30", m_iregs[30]).formatstr("%08X"); state_add( I860_R31, "R31", m_iregs[31]).formatstr("%08X"); state_add( I860_F0, "F0", m_freg[0]).callimport().callexport().formatstr("%08X"); state_add( I860_F1, "F1", m_freg[1]).callimport().callexport().formatstr("%08X"); state_add( I860_F2, "F2", m_freg[2]).callimport().callexport().formatstr("%08X"); state_add( I860_F3, "F3", m_freg[3]).callimport().callexport().formatstr("%08X"); state_add( I860_F4, "F4", m_freg[4]).callimport().callexport().formatstr("%08X"); state_add( I860_F5, "F5", m_freg[5]).callimport().callexport().formatstr("%08X"); state_add( I860_F6, "F6", m_freg[6]).callimport().callexport().formatstr("%08X"); state_add( I860_F7, "F7", m_freg[7]).callimport().callexport().formatstr("%08X"); state_add( I860_F8, "F8", m_freg[8]).callimport().callexport().formatstr("%08X"); state_add( I860_F9, "F9", m_freg[9]).callimport().callexport().formatstr("%08X"); state_add( I860_F10, "F10", m_freg[10]).callimport().callexport().formatstr("%08X"); state_add( I860_F11, "F11", m_freg[11]).callimport().callexport().formatstr("%08X"); state_add( I860_F12, "F12", m_freg[12]).callimport().callexport().formatstr("%08X"); state_add( I860_F13, "F13", m_freg[13]).callimport().callexport().formatstr("%08X"); state_add( I860_F14, "F14", m_freg[14]).callimport().callexport().formatstr("%08X"); state_add( I860_F15, "F15", m_freg[15]).callimport().callexport().formatstr("%08X"); state_add( I860_F16, "F16", m_freg[16]).callimport().callexport().formatstr("%08X"); state_add( I860_F17, "F17", m_freg[17]).callimport().callexport().formatstr("%08X"); state_add( I860_F18, "F18", m_freg[18]).callimport().callexport().formatstr("%08X"); state_add( I860_F19, "F19", m_freg[19]).callimport().callexport().formatstr("%08X"); state_add( I860_F20, "F20", m_freg[20]).callimport().callexport().formatstr("%08X"); state_add( I860_F21, "F21", m_freg[21]).callimport().callexport().formatstr("%08X"); state_add( I860_F22, "F22", m_freg[22]).callimport().callexport().formatstr("%08X"); state_add( I860_F23, "F23", m_freg[23]).callimport().callexport().formatstr("%08X"); state_add( I860_F24, "F24", m_freg[24]).callimport().callexport().formatstr("%08X"); state_add( I860_F25, "F25", m_freg[25]).callimport().callexport().formatstr("%08X"); state_add( I860_F26, "F26", m_freg[26]).callimport().callexport().formatstr("%08X"); state_add( I860_F27, "F27", m_freg[27]).callimport().callexport().formatstr("%08X"); state_add( I860_F28, "F28", m_freg[28]).callimport().callexport().formatstr("%08X"); state_add( I860_F29, "F29", m_freg[29]).callimport().callexport().formatstr("%08X"); state_add( I860_F30, "F30", m_freg[30]).callimport().callexport().formatstr("%08X"); state_add( I860_F31, "F31", m_freg[31]).callimport().callexport().formatstr("%08X"); state_add(STATE_GENPC, "curpc", m_pc).noshow(); m_icountptr = &m_icount; }
void i860_cpu_device::device_reset() { reset_i860(); }
static CPU_RESET( i860 ) { i860_state_t *cpustate = get_safe_token(device); reset_i860(cpustate); }