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

📄 sem.c

📁 这个是LINUX下的GDB调度工具的源码
💻 C
📖 第 1 页 / 共 5 页
字号:
  {    DI opval = SRADI (SLLDI (MULDI (EXTSIDI (* FLD (i_src1)), EXTHIDI (TRUNCSIHI (SRASI (* FLD (i_src2), 16)))), 8), 8);    SET_H_ACCUM (opval);    TRACE_RESULT (current_cpu, abuf, "accum", 'D', opval);  }  return vpc;#undef FLD}/* mulwlo: mulwlo $src1,$src2 */static SEM_PCSEM_FN_NAME (m32rbf,mulwlo) (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);  {    DI opval = SRADI (SLLDI (MULDI (EXTSIDI (* FLD (i_src1)), EXTHIDI (TRUNCSIHI (* FLD (i_src2)))), 8), 8);    SET_H_ACCUM (opval);    TRACE_RESULT (current_cpu, abuf, "accum", 'D', opval);  }  return vpc;#undef FLD}/* mv: mv $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,mv) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_ld_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);  {    SI opval = * FLD (i_sr);    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* mvfachi: mvfachi $dr */static SEM_PCSEM_FN_NAME (m32rbf,mvfachi) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_seth.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);  {    SI opval = TRUNCDISI (SRADI (GET_H_ACCUM (), 32));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* mvfaclo: mvfaclo $dr */static SEM_PCSEM_FN_NAME (m32rbf,mvfaclo) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_seth.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);  {    SI opval = TRUNCDISI (GET_H_ACCUM ());    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* mvfacmi: mvfacmi $dr */static SEM_PCSEM_FN_NAME (m32rbf,mvfacmi) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_seth.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);  {    SI opval = TRUNCDISI (SRADI (GET_H_ACCUM (), 16));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* mvfc: mvfc $dr,$scr */static SEM_PCSEM_FN_NAME (m32rbf,mvfc) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_ld_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);  {    SI opval = GET_H_CR (FLD (f_r2));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* mvtachi: mvtachi $src1 */static SEM_PCSEM_FN_NAME (m32rbf,mvtachi) (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);  {    DI opval = ORDI (ANDDI (GET_H_ACCUM (), MAKEDI (0, 0xffffffff)), SLLDI (EXTSIDI (* FLD (i_src1)), 32));    SET_H_ACCUM (opval);    TRACE_RESULT (current_cpu, abuf, "accum", 'D', opval);  }  return vpc;#undef FLD}/* mvtaclo: mvtaclo $src1 */static SEM_PCSEM_FN_NAME (m32rbf,mvtaclo) (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);  {    DI opval = ORDI (ANDDI (GET_H_ACCUM (), MAKEDI (0xffffffff, 0)), ZEXTSIDI (* FLD (i_src1)));    SET_H_ACCUM (opval);    TRACE_RESULT (current_cpu, abuf, "accum", 'D', opval);  }  return vpc;#undef FLD}/* mvtc: mvtc $sr,$dcr */static SEM_PCSEM_FN_NAME (m32rbf,mvtc) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_ld_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);  {    USI opval = * FLD (i_sr);    SET_H_CR (FLD (f_r1), opval);    TRACE_RESULT (current_cpu, abuf, "cr", 'x', opval);  }  return vpc;#undef FLD}/* neg: neg $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,neg) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_ld_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);  {    SI opval = NEGSI (* FLD (i_sr));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* nop: nop */static SEM_PCSEM_FN_NAME (m32rbf,nop) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.fmt_empty.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);PROFILE_COUNT_FILLNOPS (current_cpu, abuf->addr);  return vpc;#undef FLD}/* not: not $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,not) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_ld_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);  {    SI opval = INVSI (* FLD (i_sr));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* rac: rac */static SEM_PCSEM_FN_NAME (m32rbf,rac) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.fmt_empty.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);{  DI tmp_tmp1;  tmp_tmp1 = SLLDI (GET_H_ACCUM (), 1);  tmp_tmp1 = ADDDI (tmp_tmp1, MAKEDI (0, 32768));  {    DI opval = (GTDI (tmp_tmp1, MAKEDI (32767, 0xffff0000))) ? (MAKEDI (32767, 0xffff0000)) : (LTDI (tmp_tmp1, MAKEDI (0xffff8000, 0))) ? (MAKEDI (0xffff8000, 0)) : (ANDDI (tmp_tmp1, MAKEDI (0xffffffff, 0xffff0000)));    SET_H_ACCUM (opval);    TRACE_RESULT (current_cpu, abuf, "accum", 'D', opval);  }}  return vpc;#undef FLD}/* rach: rach */static SEM_PCSEM_FN_NAME (m32rbf,rach) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.fmt_empty.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);{  DI tmp_tmp1;  tmp_tmp1 = ANDDI (GET_H_ACCUM (), MAKEDI (16777215, 0xffffffff));if (ANDIF (GEDI (tmp_tmp1, MAKEDI (16383, 0x80000000)), LEDI (tmp_tmp1, MAKEDI (8388607, 0xffffffff)))) {  tmp_tmp1 = MAKEDI (16383, 0x80000000);} else {if (ANDIF (GEDI (tmp_tmp1, MAKEDI (8388608, 0)), LEDI (tmp_tmp1, MAKEDI (16760832, 0)))) {  tmp_tmp1 = MAKEDI (16760832, 0);} else {  tmp_tmp1 = ANDDI (ADDDI (GET_H_ACCUM (), MAKEDI (0, 1073741824)), MAKEDI (0xffffffff, 0x80000000));}}  tmp_tmp1 = SLLDI (tmp_tmp1, 1);  {    DI opval = SRADI (SLLDI (tmp_tmp1, 7), 7);    SET_H_ACCUM (opval);    TRACE_RESULT (current_cpu, abuf, "accum", 'D', opval);  }}  return vpc;#undef FLD}/* rte: rte */static SEM_PCSEM_FN_NAME (m32rbf,rte) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.fmt_empty.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 = ANDSI (GET_H_CR (((UINT) 6)), -4);    SEM_BRANCH_VIA_ADDR (current_cpu, sem_arg, opval, vpc);    TRACE_RESULT (current_cpu, abuf, "pc", 'x', opval);  }  {    USI opval = GET_H_CR (((UINT) 14));    SET_H_CR (((UINT) 6), opval);    TRACE_RESULT (current_cpu, abuf, "cr", 'x', opval);  }  {    UQI opval = CPU (h_bpsw);    SET_H_PSW (opval);    TRACE_RESULT (current_cpu, abuf, "psw", 'x', opval);  }  {    UQI opval = CPU (h_bbpsw);    CPU (h_bpsw) = opval;    TRACE_RESULT (current_cpu, abuf, "bpsw", 'x', opval);  }}  SEM_BRANCH_FINI (vpc);  return vpc;#undef FLD}/* seth: seth $dr,$hash$hi16 */static SEM_PCSEM_FN_NAME (m32rbf,seth) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_seth.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);  {    SI opval = SLLSI (FLD (f_hi16), 16);    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* sll: sll $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,sll) (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, 2);  {    SI opval = SLLSI (* FLD (i_dr), ANDSI (* FLD (i_sr), 31));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* sll3: sll3 $dr,$sr,$simm16 */static SEM_PCSEM_FN_NAME (m32rbf,sll3) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_add3.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);  {    SI opval = SLLSI (* FLD (i_sr), ANDSI (FLD (f_simm16), 31));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* slli: slli $dr,$uimm5 */static SEM_PCSEM_FN_NAME (m32rbf,slli) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_slli.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);  {    SI opval = SLLSI (* FLD (i_dr), FLD (f_uimm5));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* sra: sra $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,sra) (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, 2);  {    SI opval = SRASI (* FLD (i_dr), ANDSI (* FLD (i_sr), 31));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* sra3: sra3 $dr,$sr,$simm16 */static SEM_PCSEM_FN_NAME (m32rbf,sra3) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_add3.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);  {    SI opval = SRASI (* FLD (i_sr), ANDSI (FLD (f_simm16), 31));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* srai: srai $dr,$uimm5 */static SEM_PCSEM_FN_NAME (m32rbf,srai) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_slli.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);  {    SI opval = SRASI (* FLD (i_dr), FLD (f_uimm5));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* srl: srl $dr,$sr */static SEM_PCSEM_FN_NAME (m32rbf,srl) (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, 2);  {    SI opval = SRLSI (* FLD (i_dr), ANDSI (* FLD (i_sr), 31));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}/* srl3: srl3 $dr,$sr,$simm16 */static SEM_PCSEM_FN_NAME (m32rbf,srl3) (SIM_CPU *current_cpu, SEM_ARG sem_arg){#define FLD(f) abuf->fields.sfmt_add3.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);  {    SI opval = SRLSI (* FLD (i_sr), ANDSI (FLD (f_simm16), 31));    * FLD (i_dr) = opval;    TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);  }  return vpc;#undef FLD}

⌨️ 快捷键说明

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