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

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

?? bn_div.c

?? openssl包含TLS
?? C
字號:
/* crypto/bn/bn_div.c *//* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) * All rights reserved. * * This package is an SSL implementation written * by Eric Young (eay@cryptsoft.com). * The implementation was written so as to conform with Netscapes SSL. *  * This library is free for commercial and non-commercial use as long as * the following conditions are aheared to.  The following conditions * apply to all code found in this distribution, be it the RC4, RSA, * lhash, DES, etc., code; not just the SSL code.  The SSL documentation * included with this distribution is covered by the same copyright terms * except that the holder is Tim Hudson (tjh@cryptsoft.com). *  * Copyright remains Eric Young's, and as such any Copyright notices in * the code are not to be removed. * If this package is used in a product, Eric Young should be given attribution * as the author of the parts of the library used. * This can be in the form of a textual message at program startup or * in documentation (online or textual) provided with the package. *  * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software *    must display the following acknowledgement: *    "This product includes cryptographic software written by *     Eric Young (eay@cryptsoft.com)" *    The word 'cryptographic' can be left out if the rouines from the library *    being used are not cryptographic related :-). * 4. If you include any Windows specific code (or a derivative thereof) from  *    the apps directory (application code) you must include an acknowledgement: *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)" *  * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. *  * The licence and distribution terms for any publically available version or * derivative of this code cannot be changed.  i.e. this code cannot simply be * copied and put under another distribution licence * [including the GNU Public Licence.] */#include <stdio.h>#include <openssl/bn.h>#include "cryptlib.h"#include "bn_lcl.h"/* The old slow way */#if 0int BN_div(BIGNUM *dv, BIGNUM *rem, const BIGNUM *m, const BIGNUM *d,	   BN_CTX *ctx)	{	int i,nm,nd;	int ret = 0;	BIGNUM *D;	bn_check_top(m);	bn_check_top(d);	if (BN_is_zero(d))		{		BNerr(BN_F_BN_DIV,BN_R_DIV_BY_ZERO);		return(0);		}	if (BN_ucmp(m,d) < 0)		{		if (rem != NULL)			{ if (BN_copy(rem,m) == NULL) return(0); }		if (dv != NULL) BN_zero(dv);		return(1);		}	BN_CTX_start(ctx);	D = BN_CTX_get(ctx);	if (dv == NULL) dv = BN_CTX_get(ctx);	if (rem == NULL) rem = BN_CTX_get(ctx);	if (D == NULL || dv == NULL || rem == NULL)		goto end;	nd=BN_num_bits(d);	nm=BN_num_bits(m);	if (BN_copy(D,d) == NULL) goto end;	if (BN_copy(rem,m) == NULL) goto end;	/* The next 2 are needed so we can do a dv->d[0]|=1 later	 * since BN_lshift1 will only work once there is a value :-) */	BN_zero(dv);	bn_wexpand(dv,1);	dv->top=1;	if (!BN_lshift(D,D,nm-nd)) goto end;	for (i=nm-nd; i>=0; i--)		{		if (!BN_lshift1(dv,dv)) goto end;		if (BN_ucmp(rem,D) >= 0)			{			dv->d[0]|=1;			if (!BN_usub(rem,rem,D)) goto end;			}/* CAN IMPROVE (and have now :=) */		if (!BN_rshift1(D,D)) goto end;		}	rem->neg=BN_is_zero(rem)?0:m->neg;	dv->neg=m->neg^d->neg;	ret = 1; end:	BN_CTX_end(ctx);	return(ret);	}#else#if !defined(OPENSSL_NO_ASM) && !defined(OPENSSL_NO_INLINE_ASM) \    && !defined(PEDANTIC) && !defined(BN_DIV3W)# if defined(__GNUC__) && __GNUC__>=2#  if defined(__i386) || defined (__i386__)   /*    * There were two reasons for implementing this template:    * - GNU C generates a call to a function (__udivdi3 to be exact)    *   in reply to ((((BN_ULLONG)n0)<<BN_BITS2)|n1)/d0 (I fail to    *   understand why...);    * - divl doesn't only calculate quotient, but also leaves    *   remainder in %edx which we can definitely use here:-)    *    *					<appro@fy.chalmers.se>    */#  define bn_div_words(n0,n1,d0)		\	({  asm volatile (			\		"divl	%4"			\		: "=a"(q), "=d"(rem)		\		: "a"(n1), "d"(n0), "g"(d0)	\		: "cc");			\	    q;					\	})#  define REMAINDER_IS_ALREADY_CALCULATED#  elif defined(__x86_64) && defined(SIXTY_FOUR_BIT_LONG)   /*    * Same story here, but it's 128-bit by 64-bit division. Wow!    *					<appro@fy.chalmers.se>    */#  define bn_div_words(n0,n1,d0)		\	({  asm volatile (			\		"divq	%4"			\		: "=a"(q), "=d"(rem)		\		: "a"(n1), "d"(n0), "g"(d0)	\		: "cc");			\	    q;					\	})#  define REMAINDER_IS_ALREADY_CALCULATED#  endif /* __<cpu> */# endif /* __GNUC__ */#endif /* OPENSSL_NO_ASM *//* BN_div computes  dv := num / divisor,  rounding towards zero, and sets up * rm  such that  dv*divisor + rm = num  holds. * Thus: *     dv->neg == num->neg ^ divisor->neg  (unless the result is zero) *     rm->neg == num->neg                 (unless the remainder is zero) * If 'dv' or 'rm' is NULL, the respective value is not returned. */int BN_div(BIGNUM *dv, BIGNUM *rm, const BIGNUM *num, const BIGNUM *divisor,	   BN_CTX *ctx)	{	int norm_shift,i,j,loop;	BIGNUM *tmp,wnum,*snum,*sdiv,*res;	BN_ULONG *resp,*wnump;	BN_ULONG d0,d1;	int num_n,div_n;	bn_check_top(num);	bn_check_top(divisor);	if (BN_is_zero(divisor))		{		BNerr(BN_F_BN_DIV,BN_R_DIV_BY_ZERO);		return(0);		}	if (BN_ucmp(num,divisor) < 0)		{		if (rm != NULL)			{ if (BN_copy(rm,num) == NULL) return(0); }		if (dv != NULL) BN_zero(dv);		return(1);		}	BN_CTX_start(ctx);	tmp=BN_CTX_get(ctx);	snum=BN_CTX_get(ctx);	sdiv=BN_CTX_get(ctx);	if (dv == NULL)		res=BN_CTX_get(ctx);	else	res=dv;	if (sdiv == NULL || res == NULL) goto err;	tmp->neg=0;	/* First we normalise the numbers */	norm_shift=BN_BITS2-((BN_num_bits(divisor))%BN_BITS2);	if (!(BN_lshift(sdiv,divisor,norm_shift))) goto err;	sdiv->neg=0;	norm_shift+=BN_BITS2;	if (!(BN_lshift(snum,num,norm_shift))) goto err;	snum->neg=0;	div_n=sdiv->top;	num_n=snum->top;	loop=num_n-div_n;	/* Lets setup a 'window' into snum	 * This is the part that corresponds to the current	 * 'area' being divided */	BN_init(&wnum);	wnum.d=	 &(snum->d[loop]);	wnum.top= div_n;	wnum.dmax= snum->dmax+1; /* a bit of a lie */	/* Get the top 2 words of sdiv */	/* i=sdiv->top; */	d0=sdiv->d[div_n-1];	d1=(div_n == 1)?0:sdiv->d[div_n-2];	/* pointer to the 'top' of snum */	wnump= &(snum->d[num_n-1]);	/* Setup to 'res' */	res->neg= (num->neg^divisor->neg);	if (!bn_wexpand(res,(loop+1))) goto err;	res->top=loop;	resp= &(res->d[loop-1]);	/* space for temp */	if (!bn_wexpand(tmp,(div_n+1))) goto err;	if (BN_ucmp(&wnum,sdiv) >= 0)		{		if (!BN_usub(&wnum,&wnum,sdiv)) goto err;		*resp=1;		res->d[res->top-1]=1;		}	else		res->top--;	if (res->top == 0)		res->neg = 0;	resp--;	for (i=0; i<loop-1; i++)		{		BN_ULONG q,l0;#if defined(BN_DIV3W) && !defined(OPENSSL_NO_ASM)		BN_ULONG bn_div_3_words(BN_ULONG*,BN_ULONG,BN_ULONG);		q=bn_div_3_words(wnump,d1,d0);#else		BN_ULONG n0,n1,rem=0;		n0=wnump[0];		n1=wnump[-1];		if (n0 == d0)			q=BN_MASK2;		else 			/* n0 < d0 */			{#ifdef BN_LLONG			BN_ULLONG t2;#if defined(BN_LLONG) && defined(BN_DIV2W) && !defined(bn_div_words)			q=(BN_ULONG)(((((BN_ULLONG)n0)<<BN_BITS2)|n1)/d0);#else			q=bn_div_words(n0,n1,d0);#ifdef BN_DEBUG_LEVITTE			fprintf(stderr,"DEBUG: bn_div_words(0x%08X,0x%08X,0x%08\X) -> 0x%08X\n",				n0, n1, d0, q);#endif#endif#ifndef REMAINDER_IS_ALREADY_CALCULATED			/*			 * rem doesn't have to be BN_ULLONG. The least we			 * know it's less that d0, isn't it?			 */			rem=(n1-q*d0)&BN_MASK2;#endif			t2=(BN_ULLONG)d1*q;			for (;;)				{				if (t2 <= ((((BN_ULLONG)rem)<<BN_BITS2)|wnump[-2]))					break;				q--;				rem += d0;				if (rem < d0) break; /* don't let rem overflow */				t2 -= d1;				}#else /* !BN_LLONG */			BN_ULONG t2l,t2h,ql,qh;			q=bn_div_words(n0,n1,d0);#ifdef BN_DEBUG_LEVITTE			fprintf(stderr,"DEBUG: bn_div_words(0x%08X,0x%08X,0x%08\X) -> 0x%08X\n",				n0, n1, d0, q);#endif#ifndef REMAINDER_IS_ALREADY_CALCULATED			rem=(n1-q*d0)&BN_MASK2;#endif#if defined(BN_UMULT_LOHI)			BN_UMULT_LOHI(t2l,t2h,d1,q);#elif defined(BN_UMULT_HIGH)			t2l = d1 * q;			t2h = BN_UMULT_HIGH(d1,q);#else			t2l=LBITS(d1); t2h=HBITS(d1);			ql =LBITS(q);  qh =HBITS(q);			mul64(t2l,t2h,ql,qh); /* t2=(BN_ULLONG)d1*q; */#endif			for (;;)				{				if ((t2h < rem) ||					((t2h == rem) && (t2l <= wnump[-2])))					break;				q--;				rem += d0;				if (rem < d0) break; /* don't let rem overflow */				if (t2l < d1) t2h--; t2l -= d1;				}#endif /* !BN_LLONG */			}#endif /* !BN_DIV3W */		l0=bn_mul_words(tmp->d,sdiv->d,div_n,q);		wnum.d--; wnum.top++;		tmp->d[div_n]=l0;		for (j=div_n+1; j>0; j--)			if (tmp->d[j-1]) break;		tmp->top=j;		j=wnum.top;		if (!BN_sub(&wnum,&wnum,tmp)) goto err;		snum->top=snum->top+wnum.top-j;		if (wnum.neg)			{			q--;			j=wnum.top;			if (!BN_add(&wnum,&wnum,sdiv)) goto err;			snum->top+=wnum.top-j;			}		*(resp--)=q;		wnump--;		}	if (rm != NULL)		{		/* Keep a copy of the neg flag in num because if rm==num		 * BN_rshift() will overwrite it.		 */		int neg = num->neg;		BN_rshift(rm,snum,norm_shift);		if (!BN_is_zero(rm))			rm->neg = neg;		}	BN_CTX_end(ctx);	return(1);err:	BN_CTX_end(ctx);	return(0);	}#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久777色| 成人av资源在线观看| 亚洲欧美日韩小说| 中日韩免费视频中文字幕| 久久久久久99精品| 久久亚洲一区二区三区明星换脸| 日韩欧美在线影院| 精品福利在线导航| www国产亚洲精品久久麻豆| 精品成a人在线观看| 日韩精品一区二区三区在线观看| 日韩精品一区国产麻豆| 日韩欧美国产三级| 久久久久久久久伊人| 欧美激情一区二区三区在线| 国产精品无人区| 亚洲天堂久久久久久久| 亚洲一区二区三区免费视频| 亚洲电影第三页| 精品一区二区三区在线视频| 国产原创一区二区三区| yourporn久久国产精品| 91一区二区在线| 7777精品伊人久久久大香线蕉的 | 欧美变态凌虐bdsm| 国产日产欧美一区二区三区| 国产精品久久久久三级| 亚洲成人一区二区在线观看| 九九在线精品视频| 99re8在线精品视频免费播放| 欧美日韩在线亚洲一区蜜芽| 欧美大白屁股肥臀xxxxxx| 国产女主播一区| 亚洲激情在线播放| 爽好久久久欧美精品| 国产精品中文字幕一区二区三区| 色综合久久88色综合天天6 | 久久久国产精品午夜一区ai换脸| 国产精品嫩草影院com| 亚洲国产成人精品视频| 国产一区二区免费看| 日本二三区不卡| 精品久久久久久久久久久久包黑料 | 久久99精品国产| 91网站在线播放| 久久精品欧美一区二区三区麻豆| 亚洲精品高清视频在线观看| 国产麻豆午夜三级精品| 欧美va亚洲va国产综合| 中文字幕亚洲区| 免费人成精品欧美精品| 91美女在线视频| 久久久久国产成人精品亚洲午夜| 五月婷婷色综合| 99在线精品观看| 国产亚洲短视频| 久久国产生活片100| 欧美日韩一区小说| 亚洲欧洲在线观看av| 国产高清不卡二三区| 精品理论电影在线观看| 日韩av一区二区三区四区| 99精品欧美一区二区蜜桃免费| 精品国产免费一区二区三区香蕉| 图片区小说区国产精品视频| 欧美在线你懂的| 亚洲欧洲综合另类在线| 91免费视频观看| 中文字幕一区二区三区在线播放| 国产精品一区二区久久不卡| 精品欧美一区二区久久| 男女激情视频一区| 欧美一区二区三区在线观看 | 精品欧美一区二区三区精品久久 | 亚洲国产婷婷综合在线精品| a级高清视频欧美日韩| 国产欧美日韩综合精品一区二区| 成人av影视在线观看| 久久精品视频一区二区三区| 国内欧美视频一区二区| 精品理论电影在线| 国产曰批免费观看久久久| 久久精子c满五个校花| 国产成人综合在线| 综合电影一区二区三区| 91在线免费看| 亚洲成a人片综合在线| 欧美精选一区二区| 裸体一区二区三区| wwww国产精品欧美| 成人av电影免费观看| 亚洲男同性视频| 欧美精品欧美精品系列| 蜜桃久久精品一区二区| 国产亚洲va综合人人澡精品| www.99精品| 亚洲第一会所有码转帖| 日韩亚洲欧美中文三级| 国产麻豆一精品一av一免费| 椎名由奈av一区二区三区| 欧洲人成人精品| 日本成人在线看| 欧美国产丝袜视频| 色婷婷激情久久| 久久精品国产精品亚洲红杏 | 亚洲精品乱码久久久久久| 欧美三级视频在线观看| 国产一区二区精品久久| 亚洲欧美日韩国产成人精品影院 | 欧美一区日韩一区| 国产高清精品在线| 亚洲宅男天堂在线观看无病毒| 制服丝袜亚洲播放| 成人午夜短视频| 日韩经典中文字幕一区| 国产精品免费av| 欧美不卡一区二区三区四区| 色偷偷久久一区二区三区| 国产一区二区免费视频| 婷婷成人激情在线网| 国产精品久久久久久久久晋中| 欧美日韩精品福利| 91网址在线看| 国产福利一区二区三区视频在线| 九九久久精品视频| 午夜久久久久久| 亚洲欧洲三级电影| 国产午夜一区二区三区| 欧美一区二区三区四区五区| 99精品黄色片免费大全| 国产乱淫av一区二区三区| 三级欧美在线一区| 亚洲一区二区中文在线| 欧美国产精品专区| 精品国产区一区| 日韩限制级电影在线观看| 欧美日韩午夜在线视频| aaa国产一区| 成人中文字幕在线| 国产一区二区成人久久免费影院| 蜜臀av一区二区在线观看| 亚洲动漫第一页| 一区二区免费看| 亚洲乱码中文字幕| 国产精品对白交换视频| 久久蜜臀中文字幕| 久久美女艺术照精彩视频福利播放| 欧美疯狂性受xxxxx喷水图片| 日本精品视频一区二区| 色综合视频一区二区三区高清| 高清成人在线观看| 国产一区不卡精品| 99免费精品在线| 99久久亚洲一区二区三区青草 | 天天影视色香欲综合网老头| 亚洲尤物视频在线| 亚洲综合在线观看视频| 亚洲综合免费观看高清完整版在线| 欧美激情一区二区三区四区| 中文文精品字幕一区二区| 国产区在线观看成人精品 | 色综合天天狠狠| 欧美系列日韩一区| 欧美三级中文字幕在线观看| 91精品黄色片免费大全| 日韩视频免费直播| 日韩免费性生活视频播放| 日韩精品一区二区三区中文精品| 久久综合九色综合久久久精品综合 | 欧美a级一区二区| 狠狠色丁香婷婷综合久久片| 激情综合色综合久久综合| 国产高清视频一区| 91美女片黄在线观看| 欧美日韩在线三区| 日韩视频免费观看高清在线视频| 久久精品一区二区三区不卡 | 欧美三级一区二区| 欧美一级免费大片| 久久久综合精品| 1区2区3区国产精品| 亚洲国产精品天堂| 久久99精品久久久久| 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 欧美性大战xxxxx久久久| 欧美久久久久久蜜桃| 国产视频911| 亚洲午夜羞羞片| 国产一二精品视频| 色婷婷精品大在线视频| 精品少妇一区二区三区日产乱码| 中文字幕不卡在线观看| 亚洲成av人片在www色猫咪| 国产精品一区二区x88av| a亚洲天堂av| 欧美xxxxx牲另类人与| 最新成人av在线| 久久精品99国产精品日本| www.亚洲免费av| 精品国产一区二区三区久久影院|