📄 sem-switch.c
字号:
// OBSOLETE }// OBSOLETE {// OBSOLETE HI opval = tmp_tmp;// OBSOLETE SETMEMHI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_ANDB) : /* andb $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 QI tmp_tmp;// OBSOLETE tmp_tmp = ANDQI (GETMEMQI (current_cpu, pc, * FLD (i_Ri)), * FLD (i_Rj));// OBSOLETE {// 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 QI opval = tmp_tmp;// OBSOLETE SETMEMQI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_ORM) : /* or $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 SI tmp_tmp;// OBSOLETE tmp_tmp = ORSI (GETMEMSI (current_cpu, pc, * FLD (i_Ri)), * FLD (i_Rj));// OBSOLETE {// OBSOLETE {// OBSOLETE BI opval = EQSI (tmp_tmp, 0);// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = LTSI (tmp_tmp, 0);// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE {// OBSOLETE SI opval = tmp_tmp;// OBSOLETE SETMEMSI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_ORH) : /* orh $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 HI tmp_tmp;// OBSOLETE tmp_tmp = ORHI (GETMEMHI (current_cpu, pc, * FLD (i_Ri)), * FLD (i_Rj));// OBSOLETE {// OBSOLETE {// OBSOLETE BI opval = EQHI (tmp_tmp, 0);// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = LTHI (tmp_tmp, 0);// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE {// OBSOLETE HI opval = tmp_tmp;// OBSOLETE SETMEMHI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_ORB) : /* orb $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 QI tmp_tmp;// OBSOLETE tmp_tmp = ORQI (GETMEMQI (current_cpu, pc, * FLD (i_Ri)), * FLD (i_Rj));// OBSOLETE {// 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 QI opval = tmp_tmp;// OBSOLETE SETMEMQI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_EORM) : /* eor $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 SI tmp_tmp;// OBSOLETE tmp_tmp = XORSI (GETMEMSI (current_cpu, pc, * FLD (i_Ri)), * FLD (i_Rj));// OBSOLETE {// OBSOLETE {// OBSOLETE BI opval = EQSI (tmp_tmp, 0);// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = LTSI (tmp_tmp, 0);// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE {// OBSOLETE SI opval = tmp_tmp;// OBSOLETE SETMEMSI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_EORH) : /* eorh $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 HI tmp_tmp;// OBSOLETE tmp_tmp = XORHI (GETMEMHI (current_cpu, pc, * FLD (i_Ri)), * FLD (i_Rj));// OBSOLETE {// OBSOLETE {// OBSOLETE BI opval = EQHI (tmp_tmp, 0);// OBSOLETE CPU (h_zbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE }// OBSOLETE {// OBSOLETE BI opval = LTHI (tmp_tmp, 0);// OBSOLETE CPU (h_nbit) = opval;// OBSOLETE TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE {// OBSOLETE HI opval = tmp_tmp;// OBSOLETE SETMEMHI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_EORB) : /* eorb $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 QI tmp_tmp;// OBSOLETE tmp_tmp = XORQI (GETMEMQI (current_cpu, pc, * FLD (i_Ri)), * FLD (i_Rj));// OBSOLETE {// 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 QI opval = tmp_tmp;// OBSOLETE SETMEMQI (current_cpu, pc, * FLD (i_Ri), opval);// OBSOLETE TRACE_RESULT (current_cpu, abuf, "memory", 'x', opval);// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE NEXT (vpc);// OBSOLETE // OBSOLETE CASE (sem, INSN_BANDL) : /* bandl $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 = ANDQI (ORQI (FLD (f_u4), 240), 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_BORL) : /* borl $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 = ORQI (FLD (f_u4), 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_BEORL) : /* beorl $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 (FLD (f_u4), 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_BANDH) : /* bandh $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 = ANDQI (ORQI (SLLQI (FLD (f_u4), 4), 15), 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_BORH) : /* borh $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);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -