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

📄 sem-switch.c

📁 这个是LINUX下的GDB调度工具的源码
💻 C
📖 第 1 页 / 共 5 页
字号:
{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_add.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  vpc = SEM_NEXT_VPC (sem_arg, pc, 2);{  SI temp0;BI temp1;  temp0 = ADDSI (* FLD (i_dr), * FLD (i_sr));  temp1 = ADDOFSI (* FLD (i_dr), * FLD (i_sr), 0);  {    SI opval = temp0;    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  {    BI opval = temp1;    CPU (h_cond) = opval;    TRACE_RESULT (current_cpu, abuf, "cond", 'x', opval);  }}#undef FLD}  NEXT (vpc);  CASE (sem, INSN_ADDV3) : /* addv3 $dr,$sr,$simm16 */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_add3.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  vpc = SEM_NEXT_VPC (sem_arg, pc, 4);{  SI temp0;BI temp1;  temp0 = ADDSI (* FLD (i_sr), FLD (f_simm16));  temp1 = ADDOFSI (* FLD (i_sr), FLD (f_simm16), 0);  {    SI opval = temp0;    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  {    BI opval = temp1;    CPU (h_cond) = opval;    TRACE_RESULT (current_cpu, abuf, "cond", 'x', opval);  }}#undef FLD}  NEXT (vpc);  CASE (sem, INSN_ADDX) : /* addx $dr,$sr */{  SEM_ARG sem_arg = SEM_SEM_ARG (vpc, sc);  ARGBUF *abuf = SEM_ARGBUF (sem_arg);#define FLD(f) abuf->fields.sfmt_add.f  int UNUSED written = 0;  IADDR UNUSED pc = abuf->addr;  vpc = SEM_NEXT_VPC (sem_arg, pc, 2);{  SI temp0;BI temp1;  temp0 = ADDCSI (* FLD (i_dr), * FLD (i_sr), CPU (h_cond));  temp1 = ADDCFSI (* FLD (i_dr), * FLD (i_sr), CPU (h_cond));  {    SI opval = temp0;    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  {    BI opval = temp1;    CPU (h_cond) = opval;    TRACE_RESULT (current_cpu, abuf, "cond", 'x', opval);  }}#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BC8) : /* bc.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)) {  {    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_BC24) : /* bc.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)) {  {    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_BEQ) : /* beq $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 (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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BEQZ) : /* beqz $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 (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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BGEZ) : /* bgez $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 (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);#undef FLD}  NEXT (vpc);  CASE (sem, INSN_BGTZ) : /* bgtz $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 (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);#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_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_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

⌨️ 快捷键说明

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