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

📄 sem.c

📁 这个是LINUX下的GDB调度工具的源码
💻 C
📖 第 1 页 / 共 5 页
字号:
// OBSOLETE /* Simulator instruction semantics for fr30bf.// OBSOLETE // OBSOLETE THIS FILE IS MACHINE GENERATED WITH CGEN.// OBSOLETE // OBSOLETE Copyright 1996, 1997, 1998, 1999, 2000, 2001 Free Software Foundation, Inc.// OBSOLETE // OBSOLETE This file is part of the GNU simulators.// OBSOLETE // OBSOLETE This program is free software; you can redistribute it and/or modify// OBSOLETE it under the terms of the GNU General Public License as published by// OBSOLETE the Free Software Foundation; either version 2, or (at your option)// OBSOLETE any later version.// OBSOLETE // OBSOLETE This program is distributed in the hope that it will be useful,// OBSOLETE but WITHOUT ANY WARRANTY; without even the implied warranty of// OBSOLETE MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the// OBSOLETE GNU General Public License for more details.// OBSOLETE // OBSOLETE You should have received a copy of the GNU General Public License along// OBSOLETE with this program; if not, write to the Free Software Foundation, Inc.,// OBSOLETE 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.// OBSOLETE // OBSOLETE */// OBSOLETE // OBSOLETE #define WANT_CPU fr30bf// OBSOLETE #define WANT_CPU_FR30BF// OBSOLETE // OBSOLETE #include "sim-main.h"// OBSOLETE #include "cgen-mem.h"// OBSOLETE #include "cgen-ops.h"// OBSOLETE // OBSOLETE #undef GET_ATTR// OBSOLETE #if defined (__STDC__) || defined (ALMOST_STDC) || defined (HAVE_STRINGIZE)// OBSOLETE #define GET_ATTR(cpu, num, attr) CGEN_ATTR_VALUE (NULL, abuf->idesc->attrs, CGEN_INSN_##attr)// OBSOLETE #else// OBSOLETE #define GET_ATTR(cpu, num, attr) CGEN_ATTR_VALUE (NULL, abuf->idesc->attrs, CGEN_INSN_/**/attr)// OBSOLETE #endif// OBSOLETE // OBSOLETE /* This is used so that we can compile two copies of the semantic code,// OBSOLETE    one with full feature support and one without that runs fast(er).// OBSOLETE    FAST_P, when desired, is defined on the command line, -DFAST_P=1.  */// OBSOLETE #if FAST_P// OBSOLETE #define SEM_FN_NAME(cpu,fn) XCONCAT3 (cpu,_semf_,fn)// OBSOLETE #undef TRACE_RESULT// OBSOLETE #define TRACE_RESULT(cpu, abuf, name, type, val)// OBSOLETE #else// OBSOLETE #define SEM_FN_NAME(cpu,fn) XCONCAT3 (cpu,_sem_,fn)// OBSOLETE #endif// OBSOLETE // OBSOLETE /* x-invalid: --invalid-- */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,x_invalid) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.fmt_empty.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, 0);// OBSOLETE // OBSOLETE   {// OBSOLETE     /* Update the recorded pc in the cpu state struct.// OBSOLETE        Only necessary for WITH_SCACHE case, but to avoid the// OBSOLETE        conditional compilation ....  */// OBSOLETE     SET_H_PC (pc);// OBSOLETE     /* Virtual insns have zero size.  Overwrite vpc with address of next insn// OBSOLETE        using the default-insn-bitsize spec.  When executing insns in parallel// OBSOLETE        we may want to queue the fault and continue execution.  */// OBSOLETE     vpc = SEM_NEXT_VPC (sem_arg, pc, 2);// OBSOLETE     vpc = sim_engine_invalid_insn (current_cpu, pc, vpc);// OBSOLETE   }// OBSOLETE // OBSOLETE   return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* x-after: --after-- */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,x_after) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.fmt_empty.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, 0);// OBSOLETE // OBSOLETE   {// OBSOLETE #if WITH_SCACHE_PBB_FR30BF// OBSOLETE     fr30bf_pbb_after (current_cpu, sem_arg);// OBSOLETE #endif// OBSOLETE   }// OBSOLETE // OBSOLETE   return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* x-before: --before-- */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,x_before) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.fmt_empty.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, 0);// OBSOLETE // OBSOLETE   {// OBSOLETE #if WITH_SCACHE_PBB_FR30BF// OBSOLETE     fr30bf_pbb_before (current_cpu, sem_arg);// OBSOLETE #endif// OBSOLETE   }// OBSOLETE // OBSOLETE   return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* x-cti-chain: --cti-chain-- */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,x_cti_chain) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.fmt_empty.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, 0);// OBSOLETE // OBSOLETE   {// OBSOLETE #if WITH_SCACHE_PBB_FR30BF// OBSOLETE #ifdef DEFINE_SWITCH// OBSOLETE     vpc = fr30bf_pbb_cti_chain (current_cpu, sem_arg,// OBSOLETE 			       pbb_br_type, pbb_br_npc);// OBSOLETE     BREAK (sem);// OBSOLETE #else// OBSOLETE     /* FIXME: Allow provision of explicit ifmt spec in insn spec.  */// OBSOLETE     vpc = fr30bf_pbb_cti_chain (current_cpu, sem_arg,// OBSOLETE 			       CPU_PBB_BR_TYPE (current_cpu),// OBSOLETE 			       CPU_PBB_BR_NPC (current_cpu));// OBSOLETE #endif// OBSOLETE #endif// OBSOLETE   }// OBSOLETE // OBSOLETE   return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* x-chain: --chain-- */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,x_chain) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.fmt_empty.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, 0);// OBSOLETE // OBSOLETE   {// OBSOLETE #if WITH_SCACHE_PBB_FR30BF// OBSOLETE     vpc = fr30bf_pbb_chain (current_cpu, sem_arg);// OBSOLETE #ifdef DEFINE_SWITCH// OBSOLETE     BREAK (sem);// OBSOLETE #endif// OBSOLETE #endif// OBSOLETE   }// OBSOLETE // OBSOLETE   return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* x-begin: --begin-- */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,x_begin) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.fmt_empty.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, 0);// OBSOLETE // OBSOLETE   {// OBSOLETE #if WITH_SCACHE_PBB_FR30BF// OBSOLETE #if defined DEFINE_SWITCH || defined FAST_P// OBSOLETE     /* In the switch case FAST_P is a constant, allowing several optimizations// OBSOLETE        in any called inline functions.  */// OBSOLETE     vpc = fr30bf_pbb_begin (current_cpu, FAST_P);// OBSOLETE #else// OBSOLETE #if 0 /* cgen engine can't handle dynamic fast/full switching yet.  */// OBSOLETE     vpc = fr30bf_pbb_begin (current_cpu, STATE_RUN_FAST_P (CPU_STATE (current_cpu)));// OBSOLETE #else// OBSOLETE     vpc = fr30bf_pbb_begin (current_cpu, 0);// OBSOLETE #endif// OBSOLETE #endif// OBSOLETE #endif// OBSOLETE   }// OBSOLETE // OBSOLETE   return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* add: add $Rj,$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,add) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_add.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 = ADDOFSI (* FLD (i_Ri), * FLD (i_Rj), 0);// OBSOLETE     CPU (h_vbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "vbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     BI opval = ADDCFSI (* FLD (i_Ri), * FLD (i_Rj), 0);// OBSOLETE     CPU (h_cbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "cbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     SI opval = ADDSI (* FLD (i_Ri), * FLD (i_Rj));// OBSOLETE     * FLD (i_Ri) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);// OBSOLETE   }// OBSOLETE {// OBSOLETE   {// OBSOLETE     BI opval = EQSI (* FLD (i_Ri), 0);// OBSOLETE     CPU (h_zbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     BI opval = LTSI (* FLD (i_Ri), 0);// OBSOLETE     CPU (h_nbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE   }// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE   return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* addi: add $u4,$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,addi) (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   {// OBSOLETE     BI opval = ADDOFSI (* FLD (i_Ri), FLD (f_u4), 0);// OBSOLETE     CPU (h_vbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "vbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     BI opval = ADDCFSI (* FLD (i_Ri), FLD (f_u4), 0);// OBSOLETE     CPU (h_cbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "cbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     SI opval = ADDSI (* FLD (i_Ri), FLD (f_u4));// OBSOLETE     * FLD (i_Ri) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);// OBSOLETE   }// OBSOLETE {// OBSOLETE   {// OBSOLETE     BI opval = EQSI (* FLD (i_Ri), 0);// OBSOLETE     CPU (h_zbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     BI opval = LTSI (* FLD (i_Ri), 0);// OBSOLETE     CPU (h_nbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE   }// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE   return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* add2: add2 $m4,$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,add2) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_add2.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 = ADDOFSI (* FLD (i_Ri), FLD (f_m4), 0);// OBSOLETE     CPU (h_vbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "vbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     BI opval = ADDCFSI (* FLD (i_Ri), FLD (f_m4), 0);// OBSOLETE     CPU (h_cbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "cbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     SI opval = ADDSI (* FLD (i_Ri), FLD (f_m4));// OBSOLETE     * FLD (i_Ri) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);// OBSOLETE   }// OBSOLETE {// OBSOLETE   {// OBSOLETE     BI opval = EQSI (* FLD (i_Ri), 0);// OBSOLETE     CPU (h_zbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     BI opval = LTSI (* FLD (i_Ri), 0);// OBSOLETE     CPU (h_nbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "nbit", 'x', opval);// OBSOLETE   }// OBSOLETE }// OBSOLETE }// OBSOLETE // OBSOLETE   return vpc;// OBSOLETE #undef FLD// OBSOLETE }// OBSOLETE // OBSOLETE /* addc: addc $Rj,$Ri */// OBSOLETE // OBSOLETE static SEM_PC// OBSOLETE SEM_FN_NAME (fr30bf,addc) (SIM_CPU *current_cpu, SEM_ARG sem_arg)// OBSOLETE {// OBSOLETE #define FLD(f) abuf->fields.sfmt_add.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   SI tmp_tmp;// OBSOLETE   tmp_tmp = ADDCSI (* FLD (i_Ri), * FLD (i_Rj), CPU (h_cbit));// OBSOLETE   {// OBSOLETE     BI opval = ADDOFSI (* FLD (i_Ri), * FLD (i_Rj), CPU (h_cbit));// OBSOLETE     CPU (h_vbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "vbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     BI opval = ADDCFSI (* FLD (i_Ri), * FLD (i_Rj), CPU (h_cbit));// OBSOLETE     CPU (h_cbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "cbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {// OBSOLETE     SI opval = tmp_tmp;// OBSOLETE     * FLD (i_Ri) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "gr", 'x', opval);// OBSOLETE   }// OBSOLETE {// OBSOLETE   {// OBSOLETE     BI opval = EQSI (* FLD (i_Ri), 0);// OBSOLETE     CPU (h_zbit) = opval;// OBSOLETE     TRACE_RESULT (current_cpu, abuf, "zbit", 'x', opval);// OBSOLETE   }// OBSOLETE   {

⌨️ 快捷键说明

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