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

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

?? reg_add_sub.c

?? 內核是系統的心臟
?? C
字號:
/*---------------------------------------------------------------------------+
 |  reg_add_sub.c                                                            |
 |                                                                           |
 | Functions to add or subtract two registers and put the result in a third. |
 |                                                                           |
 | Copyright (C) 1992,1993                                                   |
 |                       W. Metzenthen, 22 Parker St, Ormond, Vic 3163,      |
 |                       Australia.  E-mail   billm@vaxc.cc.monash.edu.au    |
 |                                                                           |
 |                                                                           |
 +---------------------------------------------------------------------------*/

/*---------------------------------------------------------------------------+
 | For each function, the destination may be any FPU_REG, including one of   |
 | the source FPU_REGs.                                                      |
 +---------------------------------------------------------------------------*/

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


int reg_add(FPU_REG const *a, FPU_REG const *b, FPU_REG *dest, int control_w)
{
  char saved_sign = dest->sign;
  int diff;
  
  if ( !(a->tag | b->tag) )
    {
      /* Both registers are valid */
      if (!(a->sign ^ b->sign))
	{
	  /* signs are the same */
	  dest->sign = a->sign;
	  if ( reg_u_add(a, b, dest, control_w) )
	    {
	      dest->sign = saved_sign;
	      return 1;
	    }
	  return 0;
	}
      
      /* The signs are different, so do a subtraction */
      diff = a->exp - b->exp;
      if (!diff)
	{
	  diff = a->sigh - b->sigh;  /* Works only if ms bits are identical */
	  if (!diff)
	    {
	      diff = a->sigl > b->sigl;
	      if (!diff)
		diff = -(a->sigl < b->sigl);
	    }
	}
      
      if (diff > 0)
	{
	  dest->sign = a->sign;
	  if ( reg_u_sub(a, b, dest, control_w) )
	    {
	      dest->sign = saved_sign;
	      return 1;
	    }
	}
      else if ( diff == 0 )
	{
#ifdef DENORM_OPERAND
	  if ( (b->tag == TW_Valid) && (b->exp <= EXP_UNDER) &&
	      denormal_operand() )
	    return 1;
#endif DENORM_OPERAND
	  reg_move(&CONST_Z, dest);
	  /* sign depends upon rounding mode */
	  dest->sign = ((control_w & CW_RC) != RC_DOWN)
	    ? SIGN_POS : SIGN_NEG;
	}
      else
	{
	  dest->sign = b->sign;
	  if ( reg_u_sub(b, a, dest, control_w) )
	    {
	      dest->sign = saved_sign;
	      return 1;
	    }
	}
      return 0;
    }
  else
    {
      if ( (a->tag == TW_NaN) || (b->tag == TW_NaN) )
	{ return real_2op_NaN(a, b, dest); }
      else if (a->tag == TW_Zero)
	{
	  if (b->tag == TW_Zero)
	    {
	      char different_signs = a->sign ^ b->sign;
	      /* Both are zero, result will be zero. */
	      reg_move(a, dest);
	      if (different_signs)
		{
		  /* Signs are different. */
		  /* Sign of answer depends upon rounding mode. */
		  dest->sign = ((control_w & CW_RC) != RC_DOWN)
		    ? SIGN_POS : SIGN_NEG;
		}
	    }
	  else
	    {
#ifdef DENORM_OPERAND
	      if ( (b->tag == TW_Valid) && (b->exp <= EXP_UNDER) &&
		  denormal_operand() )
		return 1;
#endif DENORM_OPERAND
	      reg_move(b, dest);
	    }
	  return 0;
	}
      else if (b->tag == TW_Zero)
	{
#ifdef DENORM_OPERAND
	  if ( (a->tag == TW_Valid) && (a->exp <= EXP_UNDER) &&
	      denormal_operand() )
	    return 1;
#endif DENORM_OPERAND
	  reg_move(a, dest); return 0;
	}
      else if (a->tag == TW_Infinity)
	{
	  if (b->tag != TW_Infinity)
	    {
#ifdef DENORM_OPERAND
	      if ( (b->tag == TW_Valid) && (b->exp <= EXP_UNDER) &&
		  denormal_operand() )
		return 1;
#endif DENORM_OPERAND
	      reg_move(a, dest); return 0;
	    }
	  if (a->sign == b->sign)
	    {
	      /* They are both + or - infinity */
	      reg_move(a, dest); return 0;
	    }
	  return arith_invalid(dest);	/* Infinity-Infinity is undefined. */
	}
      else if (b->tag == TW_Infinity)
	{
#ifdef DENORM_OPERAND
	  if ( (a->tag == TW_Valid) && (a->exp <= EXP_UNDER) &&
	      denormal_operand() )
	    return 1;
#endif DENORM_OPERAND
	  reg_move(b, dest); return 0;
	}
    }
#ifdef PARANOID
  EXCEPTION(EX_INTERNAL|0x101);
#endif
  return 1;
}


/* Subtract b from a.  (a-b) -> dest */
int reg_sub(FPU_REG const *a, FPU_REG const *b, FPU_REG *dest, int control_w)
{
  char saved_sign = dest->sign;
  int diff;

  if ( !(a->tag | b->tag) )
    {
      /* Both registers are valid */
      diff = a->exp - b->exp;
      if (!diff)
	{
	  diff = a->sigh - b->sigh;  /* Works only if ms bits are identical */
	  if (!diff)
	    {
	      diff = a->sigl > b->sigl;
	      if (!diff)
		diff = -(a->sigl < b->sigl);
	    }
	}

      switch (a->sign*2 + b->sign)
	{
	case 0: /* P - P */
	case 3: /* N - N */
	  if (diff > 0)
	    {
	      /* |a| > |b| */
	      dest->sign = a->sign;
	      if ( reg_u_sub(a, b, dest, control_w) )
		{
		  dest->sign = saved_sign;
		  return 1;
		}
	      return 0;
	    }
	  else if ( diff == 0 )
	    {
#ifdef DENORM_OPERAND
	      if ( (b->tag == TW_Valid) && (b->exp <= EXP_UNDER) &&
		  denormal_operand() )
		return 1;
#endif DENORM_OPERAND
	      reg_move(&CONST_Z, dest);
	      /* sign depends upon rounding mode */
	      dest->sign = ((control_w & CW_RC) != RC_DOWN)
		? SIGN_POS : SIGN_NEG;
	    }
	  else
	    {
	      dest->sign = a->sign ^ SIGN_POS^SIGN_NEG;
	      if ( reg_u_sub(b, a, dest, control_w) )
		{
		  dest->sign = saved_sign;
		  return 1;
		}
	    }
	  break;
	case 1: /* P - N */
	  dest->sign = SIGN_POS;
	  if ( reg_u_add(a, b, dest, control_w) )
	    {
	      dest->sign = saved_sign;
	      return 1;
	    }
	  break;
	case 2: /* N - P */
	  dest->sign = SIGN_NEG;
	  if ( reg_u_add(a, b, dest, control_w) )
	    {
	      dest->sign = saved_sign;
	      return 1;
	    }
	  break;
	}
      return 0;
    }
  else
    {
      if ( (a->tag == TW_NaN) || (b->tag == TW_NaN) )
	{ return real_2op_NaN(b, a, dest); }
      else if (b->tag == TW_Zero)
	{ 
	  if (a->tag == TW_Zero)
	    {
	      char same_signs = !(a->sign ^ b->sign);
	      /* Both are zero, result will be zero. */
	      reg_move(a, dest); /* Answer for different signs. */
	      if (same_signs)
		{
		  /* Sign depends upon rounding mode */
		  dest->sign = ((control_w & CW_RC) != RC_DOWN)
		    ? SIGN_POS : SIGN_NEG;
		}
	    }
	  else
	    {
#ifdef DENORM_OPERAND
	      if ( (a->tag == TW_Valid) && (a->exp <= EXP_UNDER) &&
		  denormal_operand() )
		return 1;
#endif DENORM_OPERAND
	      reg_move(a, dest);
	    }
	  return 0;
	}
      else if (a->tag == TW_Zero)
	{
#ifdef DENORM_OPERAND
	  if ( (b->tag == TW_Valid) && (b->exp <= EXP_UNDER) &&
	      denormal_operand() )
	    return 1;
#endif DENORM_OPERAND
	  reg_move(b, dest);
	  dest->sign ^= SIGN_POS^SIGN_NEG;
	  return 0;
	}
      else if (a->tag == TW_Infinity)
	{
	  if (b->tag != TW_Infinity)
	    {
#ifdef DENORM_OPERAND
	      if ( (b->tag == TW_Valid) && (b->exp <= EXP_UNDER) &&
		  denormal_operand() )
		return 1;
#endif DENORM_OPERAND
	      reg_move(a, dest); return 0;
	    }
	  /* Both args are Infinity */
	  if (a->sign == b->sign)
	    {
	      /* Infinity-Infinity is undefined. */
	      return arith_invalid(dest);
	    }
	  reg_move(a, dest);
	  return 0;
	}
      else if (b->tag == TW_Infinity)
	{
#ifdef DENORM_OPERAND
	  if ( (a->tag == TW_Valid) && (a->exp <= EXP_UNDER) &&
	      denormal_operand() )
	    return 1;
#endif DENORM_OPERAND
	  reg_move(b, dest);
	  dest->sign ^= SIGN_POS^SIGN_NEG;
	  return 0;
	}
    }
#ifdef PARANOID
  EXCEPTION(EX_INTERNAL|0x110);
#endif
  return 1;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本一区二区成人| 制服丝袜亚洲精品中文字幕| 免费久久精品视频| 丝袜美腿亚洲色图| 久久99精品国产.久久久久| 免费成人在线网站| 国产在线播放一区二区三区| 国产一区二区三区最好精华液| 国产伦精品一区二区三区视频青涩 | 欧美一级电影网站| 日韩精品综合一本久道在线视频| 欧美大片在线观看| 日本一区二区三区四区在线视频| 国产精品久久久久久久蜜臀| 亚洲免费观看视频| 日本亚洲免费观看| 国产激情一区二区三区桃花岛亚洲| 国产精品亚洲第一区在线暖暖韩国| 成人高清伦理免费影院在线观看| 色婷婷亚洲一区二区三区| 欧美午夜免费电影| 精品免费国产一区二区三区四区| 中文字幕不卡在线| 午夜视频在线观看一区| 狠狠色2019综合网| 91视频一区二区三区| 欧美日韩电影一区| 久久久久久久综合狠狠综合| 亚洲人快播电影网| 天天色图综合网| 九九九精品视频| 91色.com| 欧美videos中文字幕| **性色生活片久久毛片| 免费日本视频一区| 91免费版在线| 久久久一区二区三区捆绑**| 亚洲综合久久久| 国产成人av一区二区| 在线不卡的av| 亚洲欧美一区二区三区久本道91| 日韩有码一区二区三区| 成人黄动漫网站免费app| 91麻豆精品国产91久久久久久| 中文字幕乱码日本亚洲一区二区| 日本一区中文字幕| 91久久精品网| 国产精品高潮久久久久无| 日本不卡在线视频| 在线一区二区三区四区五区| 亚洲国产精品av| 美女性感视频久久| 欧美亚洲国产一区二区三区va | 日本一区二区三区国色天香| 日韩精品一区第一页| 91日韩精品一区| 久久久777精品电影网影网| 天堂影院一区二区| 欧美午夜不卡视频| 亚洲免费色视频| av不卡免费电影| 国产精品福利av| 成人的网站免费观看| 国产欧美视频一区二区| 激情五月激情综合网| 日韩欧美一卡二卡| 亚洲香肠在线观看| 在线观看一区日韩| 亚洲一二三四久久| 欧美日韩亚洲国产综合| 国产精品久久一级| av在线播放一区二区三区| 《视频一区视频二区| www.在线欧美| 一区二区视频免费在线观看| 91在线高清观看| 亚洲伦在线观看| 91久久精品日日躁夜夜躁欧美| 一区二区成人在线观看| 在线免费观看日韩欧美| 午夜精品久久久久久久久久久 | 亚洲人成精品久久久久久| 99精品一区二区三区| 亚洲欧洲日韩一区二区三区| 91日韩在线专区| 午夜精品爽啪视频| 精品国产乱码久久久久久夜甘婷婷 | 国产精品欧美综合在线| www.欧美.com| 亚洲精品免费电影| 欧美精品少妇一区二区三区| 亚洲高清免费视频| 欧美一二三区精品| 国产精品一区二区在线看| 亚洲欧洲精品一区二区精品久久久| 色天天综合色天天久久| 免费在线观看精品| 欧美国产日韩在线观看| 91小视频免费看| 毛片av一区二区三区| 日本一区二区免费在线| 欧美伊人精品成人久久综合97| 欧美aⅴ一区二区三区视频| 欧美国产日韩在线观看| 欧美午夜不卡视频| 日本一道高清亚洲日美韩| 国产精品色噜噜| 欧美精品久久99久久在免费线| 国产资源在线一区| 夜夜嗨av一区二区三区中文字幕| 欧美大片一区二区三区| 日本精品裸体写真集在线观看| 麻豆精品视频在线观看免费| 亚洲欧洲日韩在线| 欧美v国产在线一区二区三区| 色综合久久久网| 国产一区二区导航在线播放| 午夜精品影院在线观看| 亚洲视频在线观看三级| 精品国产亚洲在线| 欧美高清精品3d| 99国产精品国产精品毛片| 久久99日本精品| 香蕉成人伊视频在线观看| 国产精品婷婷午夜在线观看| 日韩一级大片在线观看| 欧美午夜电影一区| 一本到三区不卡视频| 成人一道本在线| 国内成人精品2018免费看| 日韩高清不卡在线| 一二三四社区欧美黄| 亚洲欧洲一区二区在线播放| 久久精品亚洲一区二区三区浴池| 欧美一区二区在线观看| 欧美日韩国产小视频在线观看| 99视频精品在线| 国产成人av影院| 国产精品99精品久久免费| 麻豆精品视频在线观看免费 | 国产精品污网站| 亚洲精品在线三区| 日韩精品中文字幕在线一区| 91精品婷婷国产综合久久竹菊| 在线观看亚洲专区| 日本高清无吗v一区| 91麻豆精东视频| 色噜噜夜夜夜综合网| 91久久免费观看| 欧美三片在线视频观看| 欧美三级资源在线| 欧美日韩精品专区| 欧美一区二区观看视频| 日韩亚洲欧美在线观看| 欧美电影免费观看高清完整版在线观看| 欧美精品亚洲二区| 精品av久久707| 国产日韩av一区| 亚洲欧洲av在线| 综合亚洲深深色噜噜狠狠网站| 中文字幕亚洲成人| 亚洲一区中文在线| 日韩av一级电影| 精品一区二区久久| 成人午夜电影久久影院| 91亚洲资源网| 欧美一区二区三区视频在线观看 | 亚洲综合在线免费观看| 一区二区三区在线高清| 亚洲h在线观看| 狠狠色狠狠色综合系列| 成人动漫在线一区| 欧美精品777| 欧美经典一区二区| 一区二区在线观看视频| 免费在线观看日韩欧美| 成人国产精品免费观看动漫| 91行情网站电视在线观看高清版| 欧美日韩精品一区二区三区 | 成人激情开心网| 欧美视频在线播放| 国产午夜精品久久| 一区二区三区四区国产精品| 美女www一区二区| 91在线小视频| 精品不卡在线视频| 亚洲成人一二三| 成人免费视频网站在线观看| 欧美日韩在线一区二区| 欧美精品一区男女天堂| 亚洲永久精品国产| 成人国产精品视频| 精品美女一区二区| 亚洲成a天堂v人片| 成人ar影院免费观看视频| 欧美一区二区视频观看视频| 亚洲精品欧美激情| 国产黑丝在线一区二区三区| 在线成人高清不卡| 一区二区免费在线播放|