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

📄 sem.c

📁 这个是LINUX下的GDB调度工具的源码
💻 C
📖 第 1 页 / 共 5 页
字号:
  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (EQSI (* FLD (i_src1), * FLD (i_src2))) {  {    USI opval = FLD (i_disp16);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 3);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* beqz: beqz $src2,$disp16 */static SEM_PCSEM_FN_NAME (m32rbf,beqz) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_beq.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (EQSI (* FLD (i_src2), 0)) {  {    USI opval = FLD (i_disp16);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bgez: bgez $src2,$disp16 */static SEM_PCSEM_FN_NAME (m32rbf,bgez) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_beq.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (GESI (* FLD (i_src2), 0)) {  {    USI opval = FLD (i_disp16);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bgtz: bgtz $src2,$disp16 */static SEM_PCSEM_FN_NAME (m32rbf,bgtz) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_beq.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (GTSI (* FLD (i_src2), 0)) {  {    USI opval = FLD (i_disp16);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* blez: blez $src2,$disp16 */static SEM_PCSEM_FN_NAME (m32rbf,blez) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_beq.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (LESI (* FLD (i_src2), 0)) {  {    USI opval = FLD (i_disp16);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bltz: bltz $src2,$disp16 */static SEM_PCSEM_FN_NAME (m32rbf,bltz) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_beq.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (LTSI (* FLD (i_src2), 0)) {  {    USI opval = FLD (i_disp16);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bnez: bnez $src2,$disp16 */static SEM_PCSEM_FN_NAME (m32rbf,bnez) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_beq.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (NESI (* FLD (i_src2), 0)) {  {    USI opval = FLD (i_disp16);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bl8: bl.s $disp8 */static SEM_PCSEM_FN_NAME (m32rbf,bl8) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_bl8.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 2);{  {    SI opval = ADDSI (ANDSI (pc, -4), 4);    CPU (h_gr[((UINT) 14)]) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  {    USI opval = FLD (i_disp8);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bl24: bl.l $disp24 */static SEM_PCSEM_FN_NAME (m32rbf,bl24) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_bl24.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);{  {    SI opval = ADDSI (pc, 4);    CPU (h_gr[((UINT) 14)]) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  {    USI opval = FLD (i_disp24);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bnc8: bnc.s $disp8 */static SEM_PCSEM_FN_NAME (m32rbf,bnc8) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_bl8.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 2);if (NOTBI (CPU (h_cond))) {  {    USI opval = FLD (i_disp8);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bnc24: bnc.l $disp24 */static SEM_PCSEM_FN_NAME (m32rbf,bnc24) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_bl24.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (NOTBI (CPU (h_cond))) {  {    USI opval = FLD (i_disp24);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bne: bne $src1,$src2,$disp16 */static SEM_PCSEM_FN_NAME (m32rbf,bne) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_beq.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (NESI (* FLD (i_src1), * FLD (i_src2))) {  {    USI opval = FLD (i_disp16);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 3);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}  abuf->written = written;  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bra8: bra.s $disp8 */static SEM_PCSEM_FN_NAME (m32rbf,bra8) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_bl8.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 2);  {    USI opval = FLD (i_disp8);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* bra24: bra.l $disp24 */static SEM_PCSEM_FN_NAME (m32rbf,bra24) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_bl24.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);  {    USI opval = FLD (i_disp24);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* cmp: cmp $src1,$src2 */static SEM_PCSEM_FN_NAME (m32rbf,cmp) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_st_plus.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 2);  {    BI opval = LTSI (* FLD (i_src1), * FLD (i_src2));    CPU (h_cond) = opval;    TRACE_RESULT (current_cpu, abuf, "cond", 'x', opval);  }  return vpc;#undef FLD}/* cmpi: cmpi $src2,$simm16 */static SEM_PCSEM_FN_NAME (m32rbf,cmpi) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_st_d.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);  {    BI opval = LTSI (* FLD (i_src2), FLD (f_simm16));    CPU (h_cond) = opval;    TRACE_RESULT (current_cpu, abuf, "cond", 'x', opval);  }  return vpc;#undef FLD}/* cmpu: cmpu $src1,$src2 */static SEM_PCSEM_FN_NAME (m32rbf,cmpu) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_st_plus.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 2);  {    BI opval = LTUSI (* FLD (i_src1), * FLD (i_src2));    CPU (h_cond) = opval;    TRACE_RESULT (current_cpu, abuf, "cond", 'x', opval);  }  return vpc;#undef FLD}/* cmpui: cmpui $src2,$simm16 */static SEM_PCSEM_FN_NAME (m32rbf,cmpui) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_st_d.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);  {    BI opval = LTUSI (* FLD (i_src2), FLD (f_simm16));    CPU (h_cond) = opval;    TRACE_RESULT (current_cpu, abuf, "cond", 'x', opval);  }  return vpc;#undef FLD}/* div: div $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,div) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_add.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (NESI (* FLD (i_sr), 0)) {  {    SI opval = DIVSI (* FLD (i_dr), * FLD (i_sr));    * FLD (i_dr) = opval;    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }}  abuf->written = written;  return vpc;#undef FLD}/* divu: divu $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,divu) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_add.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (NESI (* FLD (i_sr), 0)) {  {    SI opval = UDIVSI (* FLD (i_dr), * FLD (i_sr));    * FLD (i_dr) = opval;    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }}  abuf->written = written;  return vpc;#undef FLD}/* rem: rem $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,rem) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_add.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (NESI (* FLD (i_sr), 0)) {  {    SI opval = MODSI (* FLD (i_dr), * FLD (i_sr));    * FLD (i_dr) = opval;    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }}  abuf->written = written;  return vpc;#undef FLD}/* remu: remu $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,remu) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_add.f  ARGBUF *abuf = SEM_ARGBUF (sem_arg);  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_PC vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (NESI (* FLD (i_sr), 0)) {  {    SI opval = UMODSI (* FLD (i_dr), * FLD (i_sr));    * FLD (i_dr) = opval;    written |= (1 << 2);    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }}  abuf->written = written;  return vpc;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -