亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? out-i860.c

?? 這是完整的gcc源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號(hào):
/* Subroutines for insn-output.c for Intel 860   Copyright (C) 1989 Free Software Foundation, Inc.   Derived from out-sparc.c.This file is part of GNU CC.GNU CC is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation; either version 1, or (at your option)any later version.GNU CC is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with GNU CC; see the file COPYING.  If not, write tothe Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  *//* Global variables for machine-dependend things.  *//* This should go away if we pass floats to regs via   the stack instead of the frame, and if we learn how   to renumber all the registers when we don't do a save (hard!).  */extern int frame_pointer_needed;static rtx find_addr_reg ();/* Return non-zero only if OP is a register of mode MODE,   or const0_rtx.  */intreg_or_0_operand (op, mode)     rtx op;     enum machine_mode mode;{  return (op == const0_rtx || register_operand (op, mode)	  || op == CONST0_RTX (mode));}/* Return non-zero if this pattern, can be evaluated safely, even if it   was not asked for.  */intsafe_insn_src_p (op, mode)     rtx op;     enum machine_mode mode;{  /* Just experimenting.  */  /* No floating point src is safe if it contains an arithmetic     operation, since that operation may trap.  */  switch (GET_CODE (op))    {    case CONST_INT:    case LABEL_REF:    case SYMBOL_REF:    case CONST:      return 1;    case REG:      return 1;    case MEM:      return CONSTANT_ADDRESS_P (XEXP (op, 0));      /* We never need to negate or complement constants.  */    case NEG:      return (mode != SFmode && mode != DFmode);    case NOT:    case ZERO_EXTEND:      return 1;    case EQ:    case NE:    case LT:    case GT:    case LE:    case GE:    case LTU:    case GTU:    case LEU:    case GEU:    case MINUS:    case PLUS:      return (mode != SFmode && mode != DFmode);    case AND:    case IOR:    case XOR:    case LSHIFT:    case ASHIFT:    case ASHIFTRT:    case LSHIFTRT:      if ((GET_CODE (XEXP (op, 0)) == CONST_INT && ! SMALL_INT (XEXP (op, 0)))	  || (GET_CODE (XEXP (op, 1)) == CONST_INT && ! SMALL_INT (XEXP (op, 1))))	return 0;      return 1;    default:      return 0;    }}/* Return 1 if REG is clobbered in IN.   Return 2 if REG is used in IN.    Return 3 if REG is both used and clobbered in IN.   Return 0 if neither.  */static intreg_clobbered_p (reg, in)     rtx reg;     rtx in;{  register enum rtx_code code;  if (in == 0)    return 0;  code = GET_CODE (in);  if (code == SET || code == CLOBBER)    {      rtx dest = SET_DEST (in);      int set = 0;      int used = 0;      while (GET_CODE (dest) == STRICT_LOW_PART	     || GET_CODE (dest) == SUBREG	     || GET_CODE (dest) == SIGN_EXTRACT	     || GET_CODE (dest) == ZERO_EXTRACT)	dest = XEXP (dest, 0);      if (dest == reg)	set = 1;      else if (GET_CODE (dest) == REG	       && refers_to_regno_p (REGNO (reg),				     REGNO (reg) + HARD_REGNO_NREGS (reg, GET_MODE (reg)),				     SET_DEST (in), 0))	{	  set = 1;	  /* Anything that sets just part of the register	     is considered using as well as setting it.	     But note that a straight SUBREG of a single-word value	     clobbers the entire value.   */	  if (dest != SET_DEST (in)	      && ! (GET_CODE (SET_DEST (in)) == SUBREG		    || UNITS_PER_WORD >= GET_MODE_SIZE (GET_MODE (dest))))	    used = 1;	}      if (code == SET)	{	  if (set)	    used = refers_to_regno_p (REGNO (reg),				      REGNO (reg) + HARD_REGNO_NREGS (reg, GET_MODE (reg)),				      SET_SRC (in), 0);	  else	    used = refers_to_regno_p (REGNO (reg),				      REGNO (reg) + HARD_REGNO_NREGS (reg, GET_MODE (reg)),				      in, 0);	}      return set + used * 2;    }  if (refers_to_regno_p (REGNO (reg),			 REGNO (reg) + HARD_REGNO_NREGS (reg, GET_MODE (reg)),			 in, 0))    return 2;  return 0;}/* Return non-zero if OP can be written to without screwing up   GCC's model of what's going on.  It is assumed that this operand   appears in the dest position of a SET insn in a conditional   branch's delay slot.  AFTER is the label to start looking from.  */intoperand_clobbered_before_used_after (op, after)     rtx op;     rtx after;{  extern char call_used_regs[];  /* Just experimenting.  */  if (GET_CODE (op) == CC0)    return 1;  if (GET_CODE (op) == REG)    {      rtx insn;      if (op == stack_pointer_rtx)	return 0;      /* Scan forward from the label, to see if the value of OP	 is clobbered before the first use.  */      for (insn = NEXT_INSN (after); insn; insn = NEXT_INSN (insn))	{	  if (GET_CODE (insn) == NOTE)	    continue;	  if (GET_CODE (insn) == INSN	      || GET_CODE (insn) == JUMP_INSN	      || GET_CODE (insn) == CALL_INSN)	    {	      switch (reg_clobbered_p (op, PATTERN (insn)))		{		default:		  return 0;		case 1:		  return 1;		case 0:		  break;		}	    }	  /* If we reach another label without clobbering OP,	     then we cannot safely write it here.  */	  else if (GET_CODE (insn) == CODE_LABEL)	    return 0;	  if (GET_CODE (insn) == JUMP_INSN)	    {	      if (condjump_p (insn))		return 0;	      /* This is a jump insn which has already		 been mangled.  We can't tell what it does.  */	      if (GET_CODE (PATTERN (insn)) == PARALLEL)		return 0;	      if (! JUMP_LABEL (insn))		return 0;	      /* Keep following jumps.  */	      insn = JUMP_LABEL (insn);	    }	}      return 1;    }  /* In both of these cases, the first insn executed     for this op will be a orh whatever%h,r0,r31,     which is tolerable.  */  if (GET_CODE (op) == MEM)    return (CONSTANT_ADDRESS_P (XEXP (op, 0)));  return 0;}/* Return non-zero if this pattern, as a source to a "SET",   is known to yield an instruction of unit size.  */intsingle_insn_src_p (op, mode)     rtx op;     enum machine_mode mode;{  switch (GET_CODE (op))    {    case CONST_INT:      /* This is not always a single insn src, technically,	 but output_delayed_branch knows how to deal with it.  */      return 1;    case SYMBOL_REF:    case CONST:      /* This is not a single insn src, technically,	 but output_delayed_branch knows how to deal with it.  */      return 1;    case REG:      return 1;    case MEM:      return 1;      /* We never need to negate or complement constants.  */    case NEG:      return (mode != DFmode);    case NOT:    case ZERO_EXTEND:      return 1;    case PLUS:    case MINUS:      /* Detect cases that require multiple instructions.  */      if (CONSTANT_P (XEXP (op, 1))	  && !(GET_CODE (XEXP (op, 1)) == CONST_INT	       && SMALL_INT (XEXP (op, 1))))	return 0;    case EQ:    case NE:    case LT:    case GT:    case LE:    case GE:    case LTU:    case GTU:    case LEU:    case GEU:      /* Not doing floating point, since they probably	 take longer than the branch slot they might fill.  */      return (mode != SFmode && mode != DFmode);    case AND:      if (GET_CODE (XEXP (op, 1)) == NOT)	{	  rtx arg = XEXP (XEXP (op, 1), 0);	  if (CONSTANT_P (arg)	      && !(GET_CODE (arg) == CONST_INT		   && (SMALL_INT (arg)		       || INTVAL (arg) & 0xffff == 0)))	    return 0;	}    case IOR:    case XOR:      /* Both small and round numbers take one instruction;	 others take two.  */      if (CONSTANT_P (XEXP (op, 1))	  && !(GET_CODE (XEXP (op, 1)) == CONST_INT	       && (SMALL_INT (XEXP (op, 1))		   || INTVAL (XEXP (op, 1)) & 0xffff == 0)))	return 0;    case LSHIFT:    case ASHIFT:    case ASHIFTRT:    case LSHIFTRT:      return 1;    case SUBREG:      if (SUBREG_WORD (op) != 0)	return 0;      return single_insn_src_p (SUBREG_REG (op), mode);      /* Not doing floating point, since they probably	 take longer than the branch slot they might fill.  */    case FLOAT_EXTEND:    case FLOAT_TRUNCATE:    case FLOAT:    case FIX:    case UNSIGNED_FLOAT:    case UNSIGNED_FIX:      return 0;    default:      return 0;    }}/* Nonzero only if this *really* is a single insn operand.  */intstrict_single_insn_op_p (op, mode)     rtx op;     enum machine_mode mode;{  if (mode == VOIDmode)    mode = GET_MODE (op);  switch (GET_CODE (op))    {    case CC0:      return 1;    case CONST_INT:      if (SMALL_INT (op))	return 1;      /* We can put this set insn into delay slot, because this is one	 insn; `orh'.  */      if ((INTVAL (op) & 0xffff) == 0)	return 1;      return 0;    case SYMBOL_REF:      return 0;    case REG:#if 0      /* This loses when moving an freg to a general reg.  */      return HARD_REGNO_NREGS (REGNO (op), mode) == 1;#endif      return (mode != DFmode && mode != DImode);    case MEM:      if (! CONSTANT_ADDRESS_P (XEXP (op, 0)))	return (mode != DFmode && mode != DImode);      return 0;      /* We never need to negate or complement constants.  */    case NEG:      return (mode != DFmode);    case NOT:    case ZERO_EXTEND:      return 1;    case PLUS:    case MINUS:      /* Detect cases that require multiple instructions.  */      if (CONSTANT_P (XEXP (op, 1))	  && !(GET_CODE (XEXP (op, 1)) == CONST_INT	       && SMALL_INT (XEXP (op, 1))))	return 0;    case EQ:    case NE:    case LT:    case GT:    case LE:    case GE:    case LTU:    case GTU:    case LEU:    case GEU:      return 1;    case AND:      if (GET_CODE (XEXP (op, 1)) == NOT)	{	  rtx arg = XEXP (XEXP (op, 1), 0);	  if (CONSTANT_P (arg)	      && !(GET_CODE (arg) == CONST_INT		   && (SMALL_INT (arg)		       || INTVAL (arg) & 0xffff == 0)))	    return 0;	}    case IOR:    case XOR:      /* Both small and round numbers take one instruction;	 others take two.  */      if (CONSTANT_P (XEXP (op, 1))	  && !(GET_CODE (XEXP (op, 1)) == CONST_INT	       && (SMALL_INT (XEXP (op, 1))		   || INTVAL (XEXP (op, 1)) & 0xffff == 0)))	return 0;    case LSHIFT:    case ASHIFT:    case ASHIFTRT:    case LSHIFTRT:      return 1;    case SUBREG:      if (SUBREG_WORD (op) != 0)	return 0;      return strict_single_insn_op_p (SUBREG_REG (op), mode);    case SIGN_EXTEND:      if (GET_CODE (XEXP (op, 0)) == MEM	  && ! CONSTANT_ADDRESS_P (XEXP (XEXP (op, 0), 0)))	return 1;      return 0;      /* Not doing floating point, since they probably	 take longer than the branch slot they might fill.  */    case FLOAT_EXTEND:    case FLOAT_TRUNCATE:    case FLOAT:    case FIX:    case UNSIGNED_FLOAT:    case UNSIGNED_FIX:      return 0;    default:      return 0;    }}/* Return truth value of whether OP is a relational operator.  */intrelop (op, mode)     rtx op;     enum machine_mode mode;{  switch (GET_CODE (op))    {    case EQ:    case NE:    case GT:    case GE:    case LT:    case LE:    case GTU:    case GEU:    case LTU:    case LEU:      return 1;    }  return 0;}/* Return truth value of whether OP can be used as an operands in a three   address add/subtract insn (such as add %o1,7,%l2) of mode MODE.  */intarith_operand (op, mode)     rtx op;     enum machine_mode mode;{  return (register_operand (op, mode)	  || (GET_CODE (op) == CONST_INT && SMALL_INT (op)));}/* Return 1 if OP is a valid first operand for a logical insn of mode MODE.  */intlogic_operand (op, mode)     rtx op;     enum machine_mode mode;{  return (register_operand (op, mode)	  || (GET_CODE (op) == CONST_INT && LOGIC_INT (op)));}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产精品黑人久久久| 亚洲三级在线播放| 中文字幕+乱码+中文字幕一区| 国产精品视频免费看| 亚洲一二三四久久| 国产成人aaaa| 欧美成人乱码一区二区三区| 亚洲欧美一区二区三区极速播放| 精品一区二区综合| 欧美日韩一区久久| 三级精品在线观看| 91视频观看视频| 国产亚洲欧美在线| 久久激五月天综合精品| 欧美日韩精品欧美日韩精品一综合| 亚洲国产高清在线| 国产精品538一区二区在线| 91.成人天堂一区| 亚洲国产另类精品专区| 99r精品视频| 国产精品久久久爽爽爽麻豆色哟哟| 蜜臀久久久久久久| 4438x亚洲最大成人网| 亚洲乱码国产乱码精品精可以看| 成人中文字幕合集| 中文字幕精品一区二区三区精品| 极品美女销魂一区二区三区免费| 91 com成人网| 青草国产精品久久久久久| 欧美精品高清视频| 视频在线观看一区二区三区| 欧美体内she精高潮| 亚洲色欲色欲www| 99re视频精品| 亚洲精品写真福利| 欧美亚洲一区三区| 天天做天天摸天天爽国产一区| 欧美色男人天堂| 石原莉奈在线亚洲二区| 欧美一区二区三区四区久久| 日韩va亚洲va欧美va久久| 欧美一级一区二区| 久久99国产精品成人| 精品对白一区国产伦| 国产成人免费xxxxxxxx| 国产精品理论片在线观看| 99久久精品免费看国产免费软件| 色婷婷精品大视频在线蜜桃视频| 一区二区三区**美女毛片| 成人动漫一区二区在线| 中文字幕视频一区| 一本到三区不卡视频| 亚洲动漫第一页| 6080午夜不卡| 国产精品一区二区三区四区| 国产精品天天摸av网| 91小视频免费观看| 手机精品视频在线观看| 精品国产一区二区三区久久影院| 国产不卡视频在线观看| 一区二区三区四区精品在线视频| 欧美性xxxxxx少妇| 国产美女久久久久| 亚洲黄色小说网站| 欧美精品一区二区三区很污很色的| 国产·精品毛片| 一卡二卡欧美日韩| 夜夜嗨av一区二区三区中文字幕| 国产成人免费av在线| 亚洲欧美综合另类在线卡通| 欧美最新大片在线看| 久久精品国产秦先生| 日韩一区在线看| 日韩一级片网址| 99视频一区二区| 老鸭窝一区二区久久精品| 国产精品久久久久久久久搜平片| 欧美精品乱码久久久久久| 国产成人亚洲综合a∨猫咪| 亚洲一区中文日韩| 国产日韩欧美精品电影三级在线| 欧美视频自拍偷拍| 成人国产精品免费观看视频| 99精品欧美一区二区三区综合在线| 亚洲成人av在线电影| 亚洲国产岛国毛片在线| 日韩一区二区精品在线观看| 91久久国产最好的精华液| 国产精品888| 美国毛片一区二区三区| 亚洲愉拍自拍另类高清精品| 国产婷婷色一区二区三区在线| 欧美午夜视频网站| 色综合天天综合网天天狠天天| 国产九九视频一区二区三区| 五月婷婷欧美视频| 亚洲精品国产a久久久久久| 国产日韩精品久久久| 欧美精品一区二区三区蜜臀| 91精品国产黑色紧身裤美女| 欧美在线影院一区二区| 色综合久久中文字幕| 成人国产一区二区三区精品| 国产一区二区三区高清播放| 蓝色福利精品导航| 日韩激情一区二区| 欧美aⅴ一区二区三区视频| 亚洲尤物在线视频观看| 自拍偷拍国产亚洲| 亚洲素人一区二区| 国产精品毛片久久久久久久| 国产丝袜欧美中文另类| 国产调教视频一区| 国产精品日韩精品欧美在线| 久久先锋资源网| 国产欧美一区二区精品婷婷| 国产亚洲va综合人人澡精品| 国产日韩欧美精品在线| 国产精品久久久久久久久搜平片| 欧美国产日韩亚洲一区| 国产精品网站导航| 亚洲三级小视频| 亚洲综合一二三区| 天天操天天色综合| 麻豆高清免费国产一区| 久久电影网电视剧免费观看| 国产精品一区二区果冻传媒| 国产69精品久久久久777| 99国产精品国产精品久久| 日本乱码高清不卡字幕| 欧美剧情片在线观看| 日韩精品一区国产麻豆| 久久久国产精华| 国产精品久久二区二区| 亚洲免费av高清| 日本亚洲欧美天堂免费| 国产精品自拍三区| 97se狠狠狠综合亚洲狠狠| 欧美日免费三级在线| 7777精品伊人久久久大香线蕉超级流畅 | 国产精品久久久久久户外露出| 国产精品久久免费看| 亚洲另类在线一区| 美国一区二区三区在线播放| 国产a区久久久| 欧美日韩一本到| www国产精品av| 亚洲乱码国产乱码精品精98午夜| 久久精品国产免费| 肉丝袜脚交视频一区二区| 国产一区二区三区蝌蚪| 日本韩国精品在线| 精品成人免费观看| 亚洲精品成a人| 国产一区二区不卡| 国产精品美女www爽爽爽| 亚洲狠狠丁香婷婷综合久久久| 天堂一区二区在线| 成人综合婷婷国产精品久久蜜臀| 91高清视频免费看| 国产欧美一区二区在线观看| 亚洲欧洲制服丝袜| 国产成人精品亚洲777人妖| 欧美日韩一区 二区 三区 久久精品| 欧美精品一区二区三区一线天视频| 亚洲精品一卡二卡| 国产激情视频一区二区在线观看| 欧美在线免费播放| 欧美国产日韩a欧美在线观看| 日本系列欧美系列| 色88888久久久久久影院按摩| 国产亚洲欧美一级| 免费日本视频一区| 欧美三级电影网| **欧美大码日韩| 国产激情视频一区二区在线观看| 69精品人人人人| 亚洲一区二区三区视频在线| 国产成人精品在线看| 欧美大肚乱孕交hd孕妇| 亚洲一级二级在线| 色综合久久88色综合天天| 国产亚洲综合av| 精品一区二区三区在线观看| 欧美剧情片在线观看| 亚洲午夜激情网页| 一本一道久久a久久精品| 国产日韩欧美激情| 国产精品综合一区二区| 精品少妇一区二区三区日产乱码 | 欧美日韩www| 欧美日韩精品欧美日韩精品一 | 日本不卡免费在线视频| 色婷婷av一区| 亚洲精品老司机| 一本久久综合亚洲鲁鲁五月天 | 国产馆精品极品| 久久久一区二区三区| 韩国一区二区视频| 精品国产一区二区三区不卡|