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

📄 semx-switch.c

📁 这个是LINUX下的GDB调度工具的源码
💻 C
📖 第 1 页 / 共 5 页
字号:
  SEM_BRANCH_FINI (vpc);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BLEZ) : /* blez $src2,$disp16 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_beq.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BLTZ) : /* bltz $src2,$disp16 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_beq.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BNEZ) : /* bnez $src2,$disp16 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_beq.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BL8) : /* bl.s $disp8 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl8.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BL24) : /* bl.l $disp24 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl24.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BCL8) : /* bcl.s $disp8 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl8.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  vpc = SEM_NEXT_VPC (sem_arg, pc, 2);if (CPU (h_cond)) {{  {    SI opval = ADDSI (ANDSI (pc, -4), 4);    CPU (h_gr[((UINT) 14)]) = opval;    written |= (1 << 3);    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  {    USI opval = FLD (i_disp8);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 4);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}}  abuf->written = written;  SEM_BRANCH_FINI (vpc);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BCL24) : /* bcl.l $disp24 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl24.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (CPU (h_cond)) {{  {    SI opval = ADDSI (pc, 4);    CPU (h_gr[((UINT) 14)]) = opval;    written |= (1 << 3);    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  {    USI opval = FLD (i_disp24);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 4);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}}  abuf->written = written;  SEM_BRANCH_FINI (vpc);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BNC8) : /* bnc.s $disp8 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl8.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BNC24) : /* bnc.l $disp24 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl24.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BNE) : /* bne $src1,$src2,$disp16 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_beq.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BRA8) : /* bra.s $disp8 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl8.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BRA24) : /* bra.l $disp24 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl24.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BNCL8) : /* bncl.s $disp8 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl8.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  vpc = SEM_NEXT_VPC (sem_arg, pc, 2);if (NOTBI (CPU (h_cond))) {{  {    SI opval = ADDSI (ANDSI (pc, -4), 4);    CPU (h_gr[((UINT) 14)]) = opval;    written |= (1 << 3);    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  {    USI opval = FLD (i_disp8);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 4);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}}  abuf->written = written;  SEM_BRANCH_FINI (vpc);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BNCL24) : /* bncl.l $disp24 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_bl24.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  SEM_BRANCH_INIT  vpc = SEM_NEXT_VPC (sem_arg, pc, 4);if (NOTBI (CPU (h_cond))) {{  {    SI opval = ADDSI (pc, 4);    CPU (h_gr[((UINT) 14)]) = opval;    written |= (1 << 3);    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  {    USI opval = FLD (i_disp24);    SEM_BRANCH_VIA_CACHE (current_cpu, sem_arg, opval, vpc);    written |= (1 << 4);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }}}  abuf->written = written;  SEM_BRANCH_FINI (vpc);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_CMP) : /* cmp $src1,$src2 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_st_plus.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  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);  }#undef FLD}  NEXT (vpc);  CASE (sem, INSN_CMPI) : /* cmpi $src2,$simm16 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_st_d.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  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);  }#undef FLD}  NEXT (vpc);  CASE (sem, INSN_CMPU) : /* cmpu $src1,$src2 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_st_plus.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  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);  }#undef FLD}  NEXT (vpc);  CASE (sem, INSN_CMPUI) : /* cmpui $src2,$simm16 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_st_d.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  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);  }#undef FLD}  NEXT (vpc);  CASE (sem, INSN_CMPEQ) : /* cmpeq $src1,$src2 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_st_plus.f  int UNUSED written = 0;

⌨️ 快捷键说明

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