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

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

?? out-i386.c

?? 這是完整的gcc源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
	case 'R':	  fprintf (file, "%s", RP);	  return;	case 'z':	  /* this is the size of op from size of operand */	  switch (GET_MODE_SIZE (GET_MODE (x)))	    {	    case 2:	      PUT_OP_SIZE ('W', 'w', file);	      return;	    case 4:	      if (GET_MODE (x) == SFmode)		{		  PUT_OP_SIZE ('S', 's', file);		  return;		}	      else		PUT_OP_SIZE ('L', 'l', file);	      return;	    case 8:	      if (!FP_REG_P (x)) PUT_OP_SIZE ('Q', 'l', file);	      return;	    case 1:	      PUT_OP_SIZE ('B', 'b', file);	      return;	    }	}    }  if (GET_CODE (x) == REG)    {      PRINT_REG (x, code, file);    }  else if (GET_CODE (x) == MEM)    {      PRINT_PTR (x, file);      if (CONSTANT_ADDRESS_P (XEXP (x, 0)))	output_addr_const (file, XEXP (x, 0));      else	output_address (XEXP (x, 0));    }  else if (GET_CODE (x) == CONST_DOUBLE && GET_MODE (x) == SFmode)    {      union { double d; int i[2]; } u;      union { float f; int i; } u1;      u.i[0] = CONST_DOUBLE_LOW (x);      u.i[1] = CONST_DOUBLE_HIGH (x);      u1.f = u.d;      if (code == 'f')        fprintf (file, "%.22e", u1.f);      else        {	  PRINT_IMMED_PREFIX (file);	  fprintf (file, "0x%x", u1.i);	}    }  else if (GET_CODE (x) == CONST_DOUBLE && GET_MODE (x) == DFmode)    {      union { double d; int i[2]; } u;      u.i[0] = CONST_DOUBLE_LOW (x);      u.i[1] = CONST_DOUBLE_HIGH (x);      fprintf (file, "%.22e", u.d);    }  else     {      if (code != 'c')	{	  if (GET_CODE (x) == CONST_INT)	    PRINT_IMMED_PREFIX (file);	  else if (GET_CODE (x) == CONST || GET_CODE (x) == SYMBOL_REF		   || GET_CODE (x) == LABEL_REF)	    PRINT_OFFSET_PREFIX (file);	}      output_addr_const (file, x);    }}/* Print a memory operand whose address is ADDR.  */voidprint_operand_address (file, addr)     FILE *file;     register rtx addr;{  register rtx reg1, reg2, breg, ireg;  rtx offset;  switch (GET_CODE (addr))    {    case REG:      ADDR_BEG (file);      fprintf (file, "%se", RP);      fputs (hi_reg_name[REGNO (addr)], file);      ADDR_END (file);      break;    case PLUS:      reg1 = 0;      reg2 = 0;      ireg = 0;      breg = 0;      offset = 0;      if (CONSTANT_ADDRESS_P (XEXP (addr, 0)))	{	  offset = XEXP (addr, 0);	  addr = XEXP (addr, 1);	}      else if (CONSTANT_ADDRESS_P (XEXP (addr, 1)))	{	  offset = XEXP (addr, 1);	  addr = XEXP (addr, 0);	}      if (GET_CODE (addr) != PLUS) ;      else if (GET_CODE (XEXP (addr, 0)) == MULT)	{	  reg1 = XEXP (addr, 0);	  addr = XEXP (addr, 1);	}      else if (GET_CODE (XEXP (addr, 1)) == MULT)	{	  reg1 = XEXP (addr, 1);	  addr = XEXP (addr, 0);	}      else if (GET_CODE (XEXP (addr, 0)) == REG)	{	  reg1 = XEXP (addr, 0);	  addr = XEXP (addr, 1);	}      else if (GET_CODE (XEXP (addr, 1)) == REG)	{	  reg1 = XEXP (addr, 1);	  addr = XEXP (addr, 0);	}      if (GET_CODE (addr) == REG || GET_CODE (addr) == MULT)	{	  if (reg1 == 0) reg1 = addr;	  else reg2 = addr;	  addr = 0;	}      if (offset != 0)	{	  if (addr != 0) abort ();	  addr = offset;	}      if ((reg1 && GET_CODE (reg1) == MULT)	  || (reg2 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg2))))	{	  breg = reg2;	  ireg = reg1;	}      else if (reg1 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg1)))	{	  breg = reg1;	  ireg = reg2;	}      if (ireg != 0 || breg != 0)	{	  int scale = 1;	  if (addr != 0)	    {	      if (GET_CODE (addr) == LABEL_REF)		output_asm_label (addr);	      else		output_addr_const (file, addr);	    }  	  if (ireg != 0 && GET_CODE (ireg) == MULT)	    {	      scale = INTVAL (XEXP (ireg, 1));	      ireg = XEXP (ireg, 0);	    }	  /* output breg+ireg*scale */	  PRINT_B_I_S (breg, ireg, scale, file);	  break;	}    case MULT:      {	int scale;	if (GET_CODE (XEXP (addr, 0)) == CONST_INT)	  {	    scale = INTVAL (XEXP (addr, 0));	    ireg = XEXP (addr, 1);	  }	else	  {	    scale = INTVAL (XEXP (addr, 1));	    ireg = XEXP (addr, 0);	  }	output_addr_const (file, const0_rtx);	PRINT_B_I_S ((rtx) 0, ireg, scale, file);      }      break;    default:      if (GET_CODE (addr) == CONST_INT	  && INTVAL (addr) < 0x8000	  && INTVAL (addr) >= -0x8000)	fprintf (file, "%d", INTVAL (addr));      else	output_addr_const (file, addr);    }}/* Set the cc_status for the results of an insn whose pattern is EXP.   On the 80386, we assume that only test and compare insns, as well   as SI, HI, & DI mode ADD, SUB, NEG, AND, IOR, XOR, ASHIFT, LSHIFT,   ASHIFTRT, and LSHIFTRT instructions set the condition codes usefully.   Also, we assume that jumps and moves don't affect the condition codes.   All else, clobbers the condition codes, by assumption.   We assume that ALL add, minus, etc. instructions effect the condition   codes.  This MUST be consistent with i386.md.  */notice_update_cc (exp)     rtx exp;{  if (GET_CODE (exp) == SET)    {      /* Jumps do not alter the cc's.  */      if (SET_DEST (exp) == pc_rtx)	return;      /* Moving register or memory into a register:	 it doesn't alter the cc's, but it might invalidate	 the RTX's which we remember the cc's came from.	 (Note that moving a constant 0 or 1 MAY set the cc's).  */      if (REG_P (SET_DEST (exp))	  && (REG_P (SET_SRC (exp)) || GET_CODE (SET_SRC (exp)) == MEM))	{	  if (cc_status.value1	      && reg_overlap_mentioned_p (SET_DEST (exp), cc_status.value1))	    cc_status.value1 = 0;	  if (cc_status.value2	      && reg_overlap_mentioned_p (SET_DEST (exp), cc_status.value2))	    cc_status.value2 = 0;	  return;	}      /* Moving register into memory doesn't alter the cc's.	 It may invalidate the RTX's which we remember the cc's came from.  */      if (GET_CODE (SET_DEST (exp)) == MEM && REG_P (SET_SRC (exp)))	{	  if (cc_status.value1 && GET_CODE (cc_status.value1) == MEM)	    cc_status.value1 = 0;	  if (cc_status.value2 && GET_CODE (cc_status.value2) == MEM)	    cc_status.value2 = 0;	  return;	}      /* Function calls clobber the cc's.  */      else if (GET_CODE (SET_SRC (exp)) == CALL)	{	  CC_STATUS_INIT;	  return;	}      /* Tests and compares set the cc's in predictable ways.  */      else if (SET_DEST (exp) == cc0_rtx)	{	  CC_STATUS_INIT;	  cc_status.value1 = SET_SRC (exp);	  return;	}      /* Certain instructions effect the condition codes. */      else if (GET_MODE (SET_SRC (exp)) == SImode	       || GET_MODE (SET_SRC (exp)) == HImode	       || GET_MODE (SET_SRC (exp)) == QImode)	switch (GET_CODE (SET_SRC (exp)))	  {	  case ASHIFTRT: case LSHIFTRT:	  case ASHIFT: case LSHIFT:	    /* Shifts on the 386 don't set the condition codes if the	       shift count is zero. */	    if (GET_CODE (XEXP (SET_SRC (exp), 1)) != CONST_INT)	      {		CC_STATUS_INIT;		break;	      }	    /* We assume that the CONST_INT is non-zero (this rtx would	       have been deleted if it were zero. */	  case PLUS: case MINUS: case NEG:	  case AND: case IOR: case XOR:	    cc_status.flags = CC_NO_OVERFLOW;	    cc_status.value1 = SET_SRC (exp);	    cc_status.value2 = SET_DEST (exp);	    break;	  default:	    CC_STATUS_INIT;	  }      else	{	  CC_STATUS_INIT;	}    }  else if (GET_CODE (exp) == PARALLEL	   && GET_CODE (XVECEXP (exp, 0, 0)) == SET)    {      if (SET_DEST (XVECEXP (exp, 0, 0)) == pc_rtx)	return;      if (SET_DEST (XVECEXP (exp, 0, 0)) == cc0_rtx)	{	  CC_STATUS_INIT;	  cc_status.value1 = SET_SRC (XVECEXP (exp, 0, 0));	  return;	}      CC_STATUS_INIT;    }  else    {      CC_STATUS_INIT;    }}/* Nonzero if the top of the fpu stack dies in this insn.  */inttop_dead_p (insn)     rtx insn;{  extern int optimize;  if (optimize)    return (find_regno_note (insn, REG_DEAD, FIRST_FLOAT_REG)	    || find_regno_note (insn, REG_DEAD, FIRST_FLOAT_REG + 1));  if (GET_CODE (insn) == CALL_INSN)    return call_top_dead_p (insn);  return fp_top_dead_p1 (insn);}/* Following is used after a call_value insn   if obey_regdecls there will not be the REG_DEAD notes   to go by (there won't be any cross jumping to worry about   either), and we depend on seeing if the FP_TOP is used   in the next two insn's.  Otherwise we depend on the   REG_DEAD notes.   */static intcall_top_dead_p (insn)     rtx insn;{  int i;  for (i = 0; i < 3; i++)    {      insn = NEXT_INSN (insn);      if (insn == 0)	return 1;      if (GET_CODE (insn) == NOTE || GET_CODE (insn) == CODE_LABEL)	continue;      if (GET_CODE (insn) == BARRIER)	abort ();      if (GET_CODE (PATTERN (insn)) == SET	  && SET_DEST (PATTERN (insn)) != stack_pointer_rtx)	return (!(mentions_fp_top (SET_SRC (PATTERN (insn)))));      if (GET_CODE (PATTERN (insn)) == CALL)	return 1;      if (GET_CODE (PATTERN (insn)) == USE)	return (! FP_REG_P (XEXP (PATTERN (insn), 0)));    }  return 1;}/* Return 1 if current val of fpu top-of-stack appears unused   in rest of this basic block and also through a jump insn.   This is called from top_dead_p and from fp_call_internal.  */static intfp_top_dead_p1 (insn)     rtx insn;{  extern int optimize;  int past_jump = 0;  for (insn = NEXT_INSN (insn); insn; insn = NEXT_INSN (insn))    {      switch (GET_CODE (insn))	{	case CALL_INSN:	  /* Function calls clobber this value, so it's dead.  */	  return 1;	case JUMP_INSN:	  /* Follow one jump in case of cross-jumping,	     which could insert such a jump into one basic block.  */	  if (! optimize)	    /* Can't use JUMP_LABEL, but there's no cross-jumping either.  */	    return 1;	  if (JUMP_LABEL (insn) == 0)	    return 1;	  /* Don't scan past a jump and another jump.  */	  if (past_jump)	    return 1;	  past_jump = 1;	  insn = JUMP_LABEL (insn);	case CODE_LABEL:	  if (! optimize)	    return 1;	  break;	case INSN:	  if (GET_CODE (PATTERN (insn)) == SET)	    {	      if ((mentions_fp_top (SET_SRC (PATTERN (insn)))))		return 0;	      else if (mentions_fp_top (SET_DEST (PATTERN (insn))))		return 1;	    }	  else if (mentions_fp_top (PATTERN (insn)))	    return 0;	  break;	}    }  return 1;}/* Return 1 if X involves an FPU register.  */static intmentions_fp_top (x)     rtx x;{  register RTX_CODE code;  code = GET_CODE (x);  switch (code)    {    case LABEL_REF:    case SYMBOL_REF:    case CONST_INT:    case CONST:    case CC0:    case PC:    case CLOBBER:    case MEM:      return 0;    case REG:      return FP_REGNO_P (REGNO (x));    }  /* Recursively scan the operands of this expression.  */  {    register char *fmt = GET_RTX_FORMAT (code);    register int i;    for (i = GET_RTX_LENGTH (code) - 1; i >= 0; i--)      {	if (fmt[i] == 'e')	  {	    if (mentions_fp_top (XEXP (x, i)))	      return 1;	  }	if (fmt[i] == 'E')	  {	    register int j;	    for (j = 0; j < XVECLEN (x, i); j++)	      if (mentions_fp_top (XVECEXP (x, i, j)))		return 1;	  }      }  }  return 0;}/* Some asm-dependent functions. */#ifdef MASM#include "masm386.c"#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲视频网在线直播| 色综合久久综合网欧美综合网 | 国产视频一区二区三区在线观看| 久久精品国产秦先生| 欧美va在线播放| 国产精品1区2区| 亚洲欧美日韩久久| 欧美精品一卡二卡| 国内精品写真在线观看| 亚洲欧洲精品一区二区三区| 精品视频全国免费看| 麻豆91精品91久久久的内涵| 国产色一区二区| 在线一区二区三区四区五区 | 国产乱码精品一区二区三区av| 精品99999| 91一区二区三区在线观看| 一个色综合网站| 日韩视频免费观看高清在线视频| 国产精品主播直播| 欧美三级午夜理伦三级中视频| 99久久综合精品| 偷拍亚洲欧洲综合| gogogo免费视频观看亚洲一| 亚洲色图清纯唯美| 日韩一区二区三区免费观看| av欧美精品.com| 日韩中文字幕亚洲一区二区va在线| 精品三级在线观看| 91福利国产成人精品照片| 国产真实精品久久二三区| 亚洲一区二区精品3399| 久久久99精品免费观看不卡| 欧美综合亚洲图片综合区| 国产美女视频91| 亚洲国产另类av| 亚洲国产电影在线观看| 欧美一区三区二区| 色综合中文字幕国产| 天天影视色香欲综合网老头| 亚洲欧洲日韩av| 精品国产乱码久久久久久久| 色婷婷亚洲一区二区三区| 精品系列免费在线观看| 天堂影院一区二区| 亚洲男同性恋视频| 欧美国产激情一区二区三区蜜月| 777xxx欧美| 欧美日韩国产一区二区三区地区| 成人午夜视频在线| 国产又粗又猛又爽又黄91精品| 亚洲一区二区三区四区五区中文| 国产婷婷色一区二区三区| 日韩一级完整毛片| 欧美精品一卡两卡| 欧美色视频在线| 欧美综合亚洲图片综合区| 91小视频在线观看| 风间由美一区二区av101| 国产在线国偷精品免费看| 欧美96一区二区免费视频| 午夜精品视频一区| 亚洲一级二级在线| 亚洲专区一二三| 一区二区三区在线观看视频| 亚洲免费在线看| 亚洲天天做日日做天天谢日日欢 | 在线观看日韩一区| 一本在线高清不卡dvd| 成人美女视频在线看| 国产成人一级电影| 国产.欧美.日韩| 国产98色在线|日韩| 国产二区国产一区在线观看| 国产成人鲁色资源国产91色综 | 亚洲麻豆国产自偷在线| 亚洲欧洲美洲综合色网| 亚洲视频你懂的| 亚洲一区二区在线免费观看视频 | 激情五月播播久久久精品| 美国一区二区三区在线播放| 免费看黄色91| 国产精品77777| 国产成人av电影免费在线观看| 国产成人综合在线观看| 成人看片黄a免费看在线| 成人国产精品视频| 一本到不卡免费一区二区| 欧美在线免费视屏| 91精品啪在线观看国产60岁| 欧美大肚乱孕交hd孕妇| 久久久久久久久久电影| 亚洲欧洲综合另类在线| 亚洲成人福利片| 激情成人综合网| av电影天堂一区二区在线| 欧美亚洲国产一区二区三区| 91.麻豆视频| 国产亚洲短视频| 亚洲老司机在线| 五月天欧美精品| 激情图区综合网| 一本大道久久a久久精二百| 制服丝袜亚洲播放| 国产日韩v精品一区二区| 亚洲私人黄色宅男| 蜜臀va亚洲va欧美va天堂| 高清beeg欧美| 欧美午夜精品一区| 久久综合给合久久狠狠狠97色69| 国产精品电影院| 亚洲成人激情av| 成人h动漫精品一区二区| 欧美伦理电影网| 中文字幕欧美日韩一区| 午夜精品久久久久久久| 国产精品一二三四区| 欧洲国内综合视频| 久久久久久久av麻豆果冻| 亚洲线精品一区二区三区八戒| 激情久久五月天| 欧美日韩久久久一区| 国产精品无圣光一区二区| 午夜久久电影网| 91丨九色丨国产丨porny| 欧美xxx久久| 一区二区三区四区视频精品免费 | 亚洲综合网站在线观看| 久久99九九99精品| 色婷婷av一区二区三区之一色屋| 久久久久久99久久久精品网站| 一片黄亚洲嫩模| 丰满亚洲少妇av| 精品国产第一区二区三区观看体验| 亚洲狼人国产精品| 成人av综合在线| 久久女同互慰一区二区三区| 日本va欧美va精品| 欧美亚洲图片小说| 亚洲欧美另类在线| 不卡一区二区三区四区| 精品国产乱码久久久久久老虎| 午夜久久久久久电影| 欧洲精品中文字幕| 亚洲激情一二三区| av不卡在线播放| 国产精品三级电影| 国产麻豆精品在线观看| 日韩精品一区在线观看| 欧美aaaaaa午夜精品| 69av一区二区三区| 天天操天天色综合| 欧美日韩免费观看一区三区| 亚洲男女一区二区三区| 不卡一区二区在线| 1000精品久久久久久久久| 成人免费视频一区二区| 日本一区二区久久| 懂色中文一区二区在线播放| 欧美国产日韩亚洲一区| 成人中文字幕合集| 欧美极品少妇xxxxⅹ高跟鞋| 国产精品66部| 国产精品美女久久久久aⅴ| 国产福利一区在线| 欧美激情一区二区在线| 国产成人精品三级麻豆| 国产日韩一级二级三级| 国产成人啪免费观看软件| 国产欧美日韩视频一区二区| 福利电影一区二区| 1024国产精品| 欧美吞精做爰啪啪高潮| 亚洲成av人片www| 欧美高清激情brazzers| 久久国产精品99精品国产| 亚洲精品一线二线三线| 国产成人在线视频网站| 最新日韩在线视频| 欧美日韩一区精品| 青娱乐精品在线视频| 久久综合狠狠综合久久激情| 成人国产精品免费| 亚洲黄色小视频| 91精品国产一区二区| 国产一区二区免费看| 欧美激情一区二区三区四区| 色狠狠桃花综合| 日韩电影在线免费看| 国产亚洲欧美一区在线观看| 91在线码无精品| 视频一区中文字幕| 国产嫩草影院久久久久| 色综合久久综合网97色综合| 视频在线在亚洲| 国产精品美女久久久久久2018| 91精品办公室少妇高潮对白| 免费成人性网站| 国产精品美女久久久久aⅴ | 国产午夜精品理论片a级大结局|