⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sem.c

📁 这个是LINUX下的GDB调度工具的源码
💻 C
📖 第 1 页 / 共 5 页
字号:
// 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 + -