📄 sem.c
字号:
// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* bandl: bandl $u4,@$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,bandl) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* borl: borl $u4,@$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,borl) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* beorl: beorl $u4,@$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,beorl) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* bandh: bandh $u4,@$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,bandh) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* borh: borh $u4,@$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,borh) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* beorh: beorh $u4,@$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,beorh) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* btstl: btstl $u4,@$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,btstl) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* btsth: btsth $u4,@$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,btsth) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_addi.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* mul: mul $Rj,$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,mul) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_str13.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* mulu: mulu $Rj,$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,mulu) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_str13.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* mulh: mulh $Rj,$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,mulh) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_str13.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* muluh: muluh $Rj,$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,muluh) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_str13.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* div0s: div0s $Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,div0s) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_mov2dr.f// OBSOLETE ARGBUF *abuf = SEM_ARGBUF (sem_arg);// OBSOLETE int UNUSED written = 0;// OBSOLETE IADDR UNUSED pc = abuf->addr;// OBSOLETE SEM_PC 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 }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -