📄 sem-switch.c
字号:
// OBSOLETE // OBSOLETE {// OBSOLETE QI opval = ORQI (SLLQI (FLD (f_u4), 4), GETMEMQI (current_cpu, pc, * FLD (i_Ri)));// OBSOLETE SETMEMQI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_BEORH) : /* beorh $u4,@$Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE QI opval = XORQI (SLLQI (FLD (f_u4), 4), GETMEMQI (current_cpu, pc, * FLD (i_Ri)));// OBSOLETE SETMEMQI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_BTSTL) : /* btstl $u4,@$Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE QI tmp_tmp;// OBSOLETE tmp_tmp = ANDQI (FLD (f_u4), GETMEMQI (current_cpu, pc, * FLD (i_Ri)));// OBSOLETE {// OBSOLETE BI opval = EQQI (tmp_tmp, 0);// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = 0;// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_BTSTH) : /* btsth $u4,@$Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE QI tmp_tmp;// OBSOLETE tmp_tmp = ANDQI (SLLQI (FLD (f_u4), 4), GETMEMQI (current_cpu, pc, * FLD (i_Ri)));// OBSOLETE {// OBSOLETE BI opval = EQQI (tmp_tmp, 0);// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = LTQI (tmp_tmp, 0);// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_MUL) : /* mul $Rj,$Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.sfmt_str13.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE DI tmp_tmp;// OBSOLETE tmp_tmp = MULDI (EXTSIDI (* FLD (i_Rj)), EXTSIDI (* FLD (i_Ri)));// OBSOLETE {// OBSOLETE SI opval = TRUNCDISI (tmp_tmp);// OBSOLETE SET_H_DR (((UINT) 5), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE SI opval = TRUNCDISI (SRLDI (tmp_tmp, 32));// OBSOLETE SET_H_DR (((UINT) 4), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = LTSI (GET_H_DR (((UINT) 5)), 0);// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = EQDI (tmp_tmp, MAKEDI (0, 0));// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = ORIF (GTDI (tmp_tmp, MAKEDI (0, 2147483647)), LTDI (tmp_tmp, NEGDI (MAKEDI (0, 0x80000000))));// OBSOLETE CPU (h_vbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "vbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_MULU) : /* mulu $Rj,$Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.sfmt_str13.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE DI tmp_tmp;// OBSOLETE tmp_tmp = MULDI (ZEXTSIDI (* FLD (i_Rj)), ZEXTSIDI (* FLD (i_Ri)));// OBSOLETE {// OBSOLETE SI opval = TRUNCDISI (tmp_tmp);// OBSOLETE SET_H_DR (((UINT) 5), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE SI opval = TRUNCDISI (SRLDI (tmp_tmp, 32));// OBSOLETE SET_H_DR (((UINT) 4), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = LTSI (GET_H_DR (((UINT) 4)), 0);// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = EQSI (GET_H_DR (((UINT) 5)), 0);// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = NESI (GET_H_DR (((UINT) 4)), 0);// OBSOLETE CPU (h_vbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "vbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_MULH) : /* mulh $Rj,$Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.sfmt_str13.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE {// OBSOLETE SI opval = MULHI (TRUNCSIHI (* FLD (i_Rj)), TRUNCSIHI (* FLD (i_Ri)));// OBSOLETE SET_H_DR (((UINT) 5), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = LTSI (GET_H_DR (((UINT) 5)), 0);// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = GESI (GET_H_DR (((UINT) 5)), 0);// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_MULUH) : /* muluh $Rj,$Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.sfmt_str13.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE {// OBSOLETE SI opval = MULSI (ANDSI (* FLD (i_Rj), 65535), ANDSI (* FLD (i_Ri), 65535));// OBSOLETE SET_H_DR (((UINT) 5), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = LTSI (GET_H_DR (((UINT) 5)), 0);// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = GESI (GET_H_DR (((UINT) 5)), 0);// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_DIV0S) : /* div0s $Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.sfmt_mov2dr.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE {// OBSOLETE BI opval = LTSI (GET_H_DR (((UINT) 5)), 0);// OBSOLETE CPU (h_d0bit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "d0bit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = XORBI (CPU (h_d0bit), LTSI (* FLD (i_Ri), 0));// OBSOLETE CPU (h_d1bit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "d1bit", 'x', opval);// OBSOLETE }// OBSOLETE if (NEBI (CPU (h_d0bit), 0)) {// OBSOLETE {// OBSOLETE SI opval = 0xffffffff;// OBSOLETE SET_H_DR (((UINT) 4), opval);// OBSOLETE written |= (1 << 5);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE } else {// OBSOLETE {// OBSOLETE SI opval = 0;// OBSOLETE SET_H_DR (((UINT) 4), opval);// OBSOLETE written |= (1 << 5);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE abuf->written = written;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_DIV0U) : /* div0u $Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.fmt_empty.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE {// OBSOLETE BI opval = 0;// OBSOLETE CPU (h_d0bit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "d0bit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = 0;// OBSOLETE CPU (h_d1bit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "d1bit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE SI opval = 0;// OBSOLETE SET_H_DR (((UINT) 4), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_DIV1) : /* div1 $Ri */// OBSOLETE {// OBSOLETE SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE #define FLD(f) abuf->fields.sfmt_mov2dr.f// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE // OBSOLETE {// OBSOLETE SI tmp_tmp;// OBSOLETE {// OBSOLETE SI opval = SLLSI (GET_H_DR (((UINT) 4)), 1);// OBSOLETE SET_H_DR (((UINT) 4), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE if (LTSI (GET_H_DR (((UINT) 5)), 0)) {// OBSOLETE {// OBSOLETE SI opval = ADDSI (GET_H_DR (((UINT) 4)), 1);// OBSOLETE SET_H_DR (((UINT) 4), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE {// OBSOLETE SI opval = SLLSI (GET_H_DR (((UINT) 5)), 1);// OBSOLETE SET_H_DR (((UINT) 5), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "dr", 'x', opval);// OBSOLETE }// OBSOLETE if (EQBI (CPU (h_d1bit), 1)) {// OB
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -