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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? reg_compare.c

?? 內核是系統的心臟
?? C
字號:
/*---------------------------------------------------------------------------+
 |  reg_compare.c                                                            |
 |                                                                           |
 | Compare two floating point registers                                      |
 |                                                                           |
 | Copyright (C) 1992,1993,1994                                              |
 |                       W. Metzenthen, 22 Parker St, Ormond, Vic 3163,      |
 |                       Australia.  E-mail   billm@vaxc.cc.monash.edu.au    |
 |                                                                           |
 |                                                                           |
 +---------------------------------------------------------------------------*/

/*---------------------------------------------------------------------------+
 | compare() is the core FPU_REG comparison function                         |
 +---------------------------------------------------------------------------*/

#include "fpu_system.h"
#include "exception.h"
#include "fpu_emu.h"
#include "control_w.h"
#include "status_w.h"


int compare(FPU_REG const *b)
{
  int diff;

  if ( FPU_st0_ptr->tag | b->tag )
    {
      if ( FPU_st0_ptr->tag == TW_Zero )
	{
	  if ( b->tag == TW_Zero ) return COMP_A_eq_B;
	  if ( b->tag == TW_Valid )
	    {
	      return ((b->sign == SIGN_POS) ? COMP_A_lt_B : COMP_A_gt_B)
#ifdef DENORM_OPERAND
		| ((b->exp <= EXP_UNDER) ?
		   COMP_Denormal : 0)
#endif DENORM_OPERAND
		  ;
	    }
	}
      else if ( b->tag == TW_Zero )
	{
	  if ( FPU_st0_ptr->tag == TW_Valid )
	    {
	      return ((FPU_st0_ptr->sign == SIGN_POS) ? COMP_A_gt_B
		      : COMP_A_lt_B)
#ifdef DENORM_OPERAND
		| ((FPU_st0_ptr->exp <= EXP_UNDER )
		   ? COMP_Denormal : 0 )
#endif DENORM_OPERAND
		  ;
	    }
	}

      if ( FPU_st0_ptr->tag == TW_Infinity )
	{
	  if ( (b->tag == TW_Valid) || (b->tag == TW_Zero) )
	    {
	      return ((FPU_st0_ptr->sign == SIGN_POS) ? COMP_A_gt_B
		      : COMP_A_lt_B)
#ifdef DENORM_OPERAND
	      | (((b->tag == TW_Valid) && (b->exp <= EXP_UNDER)) ?
		COMP_Denormal : 0 )
#endif DENORM_OPERAND
;
	    }
	  else if ( b->tag == TW_Infinity )
	    {
	      /* The 80486 book says that infinities can be equal! */
	      return (FPU_st0_ptr->sign == b->sign) ? COMP_A_eq_B :
		((FPU_st0_ptr->sign == SIGN_POS) ? COMP_A_gt_B : COMP_A_lt_B);
	    }
	  /* Fall through to the NaN code */
	}
      else if ( b->tag == TW_Infinity )
	{
	  if ( (FPU_st0_ptr->tag == TW_Valid) || (FPU_st0_ptr->tag == TW_Zero) )
	    {
	      return ((b->sign == SIGN_POS) ? COMP_A_lt_B : COMP_A_gt_B)
#ifdef DENORM_OPERAND
		| (((FPU_st0_ptr->tag == TW_Valid)
		    && (FPU_st0_ptr->exp <= EXP_UNDER)) ?
		   COMP_Denormal : 0)
#endif DENORM_OPERAND
		  ;
	    }
	  /* Fall through to the NaN code */
	}

      /* The only possibility now should be that one of the arguments
	 is a NaN */
      if ( (FPU_st0_ptr->tag == TW_NaN) || (b->tag == TW_NaN) )
	{
	  if ( ((FPU_st0_ptr->tag == TW_NaN) && !(FPU_st0_ptr->sigh & 0x40000000))
	      || ((b->tag == TW_NaN) && !(b->sigh & 0x40000000)) )
	    /* At least one arg is a signaling NaN */
	    return COMP_No_Comp | COMP_SNaN | COMP_NaN;
	  else
	    /* Neither is a signaling NaN */
	    return COMP_No_Comp | COMP_NaN;
	}
      
      EXCEPTION(EX_Invalid);
    }
  
#ifdef PARANOID
  if (!(FPU_st0_ptr->sigh & 0x80000000)) EXCEPTION(EX_Invalid);
  if (!(b->sigh & 0x80000000)) EXCEPTION(EX_Invalid);
#endif PARANOID

  
  if (FPU_st0_ptr->sign != b->sign)
    {
      return ((FPU_st0_ptr->sign == SIGN_POS) ? COMP_A_gt_B : COMP_A_lt_B)
#ifdef DENORM_OPERAND
	|
	  ( ((FPU_st0_ptr->exp <= EXP_UNDER) || (b->exp <= EXP_UNDER)) ?
	   COMP_Denormal : 0)
#endif DENORM_OPERAND
	    ;
    }

  diff = FPU_st0_ptr->exp - b->exp;
  if ( diff == 0 )
    {
      diff = FPU_st0_ptr->sigh - b->sigh;  /* Works only if ms bits are
					      identical */
      if ( diff == 0 )
	{
	diff = FPU_st0_ptr->sigl > b->sigl;
	if ( diff == 0 )
	  diff = -(FPU_st0_ptr->sigl < b->sigl);
	}
    }

  if ( diff > 0 )
    {
      return ((FPU_st0_ptr->sign == SIGN_POS) ? COMP_A_gt_B : COMP_A_lt_B)
#ifdef DENORM_OPERAND
	|
	  ( ((FPU_st0_ptr->exp <= EXP_UNDER) || (b->exp <= EXP_UNDER)) ?
	   COMP_Denormal : 0)
#endif DENORM_OPERAND
	    ;
    }
  if ( diff < 0 )
    {
      return ((FPU_st0_ptr->sign == SIGN_POS) ? COMP_A_lt_B : COMP_A_gt_B)
#ifdef DENORM_OPERAND
	|
	  ( ((FPU_st0_ptr->exp <= EXP_UNDER) || (b->exp <= EXP_UNDER)) ?
	   COMP_Denormal : 0)
#endif DENORM_OPERAND
	    ;
    }

  return COMP_A_eq_B
#ifdef DENORM_OPERAND
    |
      ( ((FPU_st0_ptr->exp <= EXP_UNDER) || (b->exp <= EXP_UNDER)) ?
       COMP_Denormal : 0)
#endif DENORM_OPERAND
	;

}


/* This function requires that st(0) is not empty */
int compare_st_data(void)
{
  int f, c;

  c = compare(&FPU_loaded_data);

  if (c & COMP_NaN)
    {
      EXCEPTION(EX_Invalid);
      f = SW_C3 | SW_C2 | SW_C0;
    }
  else
    switch (c & 7)
      {
      case COMP_A_lt_B:
	f = SW_C0;
	break;
      case COMP_A_eq_B:
	f = SW_C3;
	break;
      case COMP_A_gt_B:
	f = 0;
	break;
      case COMP_No_Comp:
	f = SW_C3 | SW_C2 | SW_C0;
	break;
#ifdef PARANOID
      default:
	EXCEPTION(EX_INTERNAL|0x121);
	f = SW_C3 | SW_C2 | SW_C0;
	break;
#endif PARANOID
      }
  setcc(f);
  if (c & COMP_Denormal)
    {
      return denormal_operand();
    }
  return 0;
}


static int compare_st_st(int nr)
{
  int f, c;

  if ( !NOT_EMPTY_0 || !NOT_EMPTY(nr) )
    {
      setcc(SW_C3 | SW_C2 | SW_C0);
      /* Stack fault */
      EXCEPTION(EX_StackUnder);
      return !(control_word & CW_Invalid);
    }

  c = compare(&st(nr));
  if (c & COMP_NaN)
    {
      setcc(SW_C3 | SW_C2 | SW_C0);
      EXCEPTION(EX_Invalid);
      return !(control_word & CW_Invalid);
    }
  else
    switch (c & 7)
      {
      case COMP_A_lt_B:
	f = SW_C0;
	break;
      case COMP_A_eq_B:
	f = SW_C3;
	break;
      case COMP_A_gt_B:
	f = 0;
	break;
      case COMP_No_Comp:
	f = SW_C3 | SW_C2 | SW_C0;
	break;
#ifdef PARANOID
      default:
	EXCEPTION(EX_INTERNAL|0x122);
	f = SW_C3 | SW_C2 | SW_C0;
	break;
#endif PARANOID
      }
  setcc(f);
  if (c & COMP_Denormal)
    {
      return denormal_operand();
    }
  return 0;
}


static int compare_u_st_st(int nr)
{
  int f, c;

  if ( !NOT_EMPTY_0 || !NOT_EMPTY(nr) )
    {
      setcc(SW_C3 | SW_C2 | SW_C0);
      /* Stack fault */
      EXCEPTION(EX_StackUnder);
      return !(control_word & CW_Invalid);
    }

  c = compare(&st(nr));
  if (c & COMP_NaN)
    {
      setcc(SW_C3 | SW_C2 | SW_C0);
      if (c & COMP_SNaN)       /* This is the only difference between
				  un-ordered and ordinary comparisons */
	{
	  EXCEPTION(EX_Invalid);
	  return !(control_word & CW_Invalid);
	}
      return 0;
    }
  else
    switch (c & 7)
      {
      case COMP_A_lt_B:
	f = SW_C0;
	break;
      case COMP_A_eq_B:
	f = SW_C3;
	break;
      case COMP_A_gt_B:
	f = 0;
	break;
      case COMP_No_Comp:
	f = SW_C3 | SW_C2 | SW_C0;
	break;
#ifdef PARANOID
      default:
	EXCEPTION(EX_INTERNAL|0x123);
	f = SW_C3 | SW_C2 | SW_C0;
	break;
#endif PARANOID
      }
  setcc(f);
  if (c & COMP_Denormal)
    {
      return denormal_operand();
    }
  return 0;
}

/*---------------------------------------------------------------------------*/

void fcom_st()
{
  /* fcom st(i) */
  compare_st_st(FPU_rm);
}


void fcompst()
{
  /* fcomp st(i) */
  if ( !compare_st_st(FPU_rm) )
    pop();
}


void fcompp()
{
  /* fcompp */
  if (FPU_rm != 1)
    {
      FPU_illegal();
      return;
    }
  if ( !compare_st_st(1) )
    {
      pop(); FPU_st0_ptr = &st(0);
      pop();
    }
}


void fucom_()
{
  /* fucom st(i) */
  compare_u_st_st(FPU_rm);

}


void fucomp()
{
  /* fucomp st(i) */
  if ( !compare_u_st_st(FPU_rm) )
    pop();
}


void fucompp()
{
  /* fucompp */
  if (FPU_rm == 1)
    {
      if ( !compare_u_st_st(1) )
	{
	  pop(); FPU_st0_ptr = &st(0);
	  pop();
	}
    }
  else
    FPU_illegal();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区国产精华| 成人欧美一区二区三区白人| 欧美调教femdomvk| 欧美一级精品大片| 国产欧美一区二区三区在线看蜜臀| 久久久蜜臀国产一区二区| 国产欧美日韩在线观看| 中文字幕在线播放不卡一区| 亚洲欧美国产三级| 久久精品国产亚洲一区二区三区 | 丝袜亚洲另类丝袜在线| 精品写真视频在线观看| av网站一区二区三区| 欧美色老头old∨ideo| 2020国产精品久久精品美国| 亚洲一区二区四区蜜桃| 国产呦精品一区二区三区网站| 欧洲国内综合视频| 亚洲欧洲精品一区二区三区| 日韩一区欧美二区| 色香蕉久久蜜桃| 国产日韩欧美a| 狠狠色综合播放一区二区| 色噜噜狠狠成人中文综合| 国产精品美女久久久久久久久| 久久疯狂做爰流白浆xx| 欧美日韩夫妻久久| 一区二区三区中文字幕电影| 国产ts人妖一区二区| 精品国产91洋老外米糕| 蜜臀精品久久久久久蜜臀 | 国产精品麻豆视频| 国产一区二区三区四| 精品久久国产97色综合| 麻豆国产精品官网| 精品国产伦一区二区三区免费 | 91久久精品国产91性色tv| 综合久久国产九一剧情麻豆| 国产a精品视频| 中文字幕一区日韩精品欧美| 99久久99久久久精品齐齐| 亚洲视频在线观看一区| 正在播放亚洲一区| 欧美精品一区二区三区一线天视频 | 337p亚洲精品色噜噜| 国产乱码精品1区2区3区| 亚洲综合精品久久| 制服丝袜av成人在线看| 日韩成人午夜电影| 欧美白人最猛性xxxxx69交| 免费成人你懂的| 久久久久88色偷偷免费| 成人在线视频一区二区| 亚洲女与黑人做爰| 欧美日韩1234| 激情综合色播激情啊| 久久久亚洲精品一区二区三区| 国产99久久久国产精品| 亚洲视频一区在线观看| 欧美裸体一区二区三区| 国产成人av影院| 午夜国产精品一区| 中文字幕不卡在线| 欧美va日韩va| 成人av动漫网站| 成人午夜电影小说| 久久精品国产一区二区| 欧美aaaaaa午夜精品| 日韩国产欧美在线视频| 一区二区三区四区五区视频在线观看| 精品国产一区二区精华| 欧美成人一区二区三区在线观看| 欧美日韩久久不卡| 欧美日韩一区二区在线视频| 99精品视频在线观看| av电影在线观看不卡| 97国产一区二区| 91免费版在线| 色婷婷精品久久二区二区蜜臂av| 99久久精品99国产精品| 成人黄色小视频在线观看| 成人午夜激情片| 色综合天天综合在线视频| 92精品国产成人观看免费| 在线视频亚洲一区| 欧美日本一区二区| 欧美丝袜第三区| 欧美国产禁国产网站cc| 久久亚洲私人国产精品va媚药| 成人国产一区二区三区精品| 国产91精品一区二区麻豆网站| 欧美肥胖老妇做爰| 天堂久久一区二区三区| 欧美在线短视频| 亚洲一级在线观看| 欧美日韩成人高清| 婷婷中文字幕一区三区| 成人av网站在线观看| 精品久久久久一区| 婷婷开心久久网| 成人不卡免费av| 在线观看91精品国产麻豆| 亚洲品质自拍视频| 粉嫩一区二区三区在线看| 日韩欧美区一区二| 亚洲a一区二区| 成人av在线电影| 精品1区2区在线观看| 免费精品视频最新在线| 欧美日韩二区三区| 亚洲一区欧美一区| 欧美亚洲综合另类| 亚洲精品综合在线| 91在线精品秘密一区二区| 国产精品日韩成人| av激情成人网| 一区二区不卡在线播放| 欧美日韩视频在线一区二区| 亚洲国产va精品久久久不卡综合| 国产精品一区二区不卡| 日韩一级欧美一级| 久久精品国内一区二区三区| 欧美不卡一区二区三区四区| 麻豆精品视频在线观看| 欧美成va人片在线观看| 国产成人夜色高潮福利影视| 欧美激情在线一区二区| 91福利在线观看| 免费成人av资源网| 国产精品蜜臀av| 欧美狂野另类xxxxoooo| 蜜桃91丨九色丨蝌蚪91桃色| 精品免费日韩av| 国产做a爰片久久毛片| 国产亚洲成年网址在线观看| 国产91对白在线观看九色| 久久久99精品免费观看| 99国产精品久久久久| 日韩国产欧美在线视频| 国产性色一区二区| 在线成人免费观看| 国产mv日韩mv欧美| 久久成人羞羞网站| 亚洲一区二区欧美日韩| 中文字幕av一区 二区| 日韩一区二区在线免费观看| 色欲综合视频天天天| 丁香另类激情小说| 国产一区二区三区精品视频| 午夜天堂影视香蕉久久| 国产精品成人网| 国产精品美女久久福利网站| 久久精品一区二区三区不卡牛牛 | 欧洲一区在线电影| 99在线热播精品免费| 色偷偷一区二区三区| 国产成人免费视频一区| 亚洲成人免费在线观看| 中文字幕亚洲在| 国产精品久久久久久福利一牛影视| 欧美精品 日韩| 欧美日韩卡一卡二| 在线观看日韩电影| 91黄色激情网站| 波多野结衣视频一区| 国产成人免费视频网站| 成人高清伦理免费影院在线观看| 韩日欧美一区二区三区| 国产精品一区二区免费不卡 | 大尺度一区二区| 国产麻豆精品久久一二三| 黄色资源网久久资源365| 国产原创一区二区| 丰满亚洲少妇av| 97久久人人超碰| 欧美色区777第一页| 欧美男生操女生| 日韩视频一区二区三区在线播放| 日韩欧美国产一区二区三区| 久久久久9999亚洲精品| 国产精品福利一区二区三区| 亚洲色图欧洲色图| 日韩福利视频导航| 成人免费毛片高清视频| 国产一区视频网站| 91在线porny国产在线看| 91极品视觉盛宴| 精品区一区二区| 亚洲理论在线观看| 六月婷婷色综合| 91蜜桃免费观看视频| 精品对白一区国产伦| 伊人婷婷欧美激情| 国产九九视频一区二区三区| 色菇凉天天综合网| 久久在线免费观看| 日韩va欧美va亚洲va久久| aaa亚洲精品| 久久久五月婷婷| 激情欧美一区二区三区在线观看|