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

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

?? bn_mul.c

?? openssl包含TLS
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* crypto/bn/bn_mul.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 "cryptlib.h"#include "bn_lcl.h"#ifdef BN_RECURSION/* Karatsuba recursive multiplication algorithm * (cf. Knuth, The Art of Computer Programming, Vol. 2) *//* r is 2*n2 words in size, * a and b are both n2 words in size. * n2 must be a power of 2. * We multiply and return the result. * t must be 2*n2 words in size * We calculate * a[0]*b[0] * a[0]*b[0]+a[1]*b[1]+(a[0]-a[1])*(b[1]-b[0]) * a[1]*b[1] */void bn_mul_recursive(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b, int n2,	     BN_ULONG *t)	{	int n=n2/2,c1,c2;	unsigned int neg,zero;	BN_ULONG ln,lo,*p;# ifdef BN_COUNT	printf(" bn_mul_recursive %d * %d\n",n2,n2);# endif# ifdef BN_MUL_COMBA#  if 0	if (n2 == 4)		{		bn_mul_comba4(r,a,b);		return;		}#  endif	if (n2 == 8)		{		bn_mul_comba8(r,a,b);		return; 		}# endif /* BN_MUL_COMBA */	if (n2 < BN_MUL_RECURSIVE_SIZE_NORMAL)		{		/* This should not happen */		bn_mul_normal(r,a,n2,b,n2);		return;		}	/* r=(a[0]-a[1])*(b[1]-b[0]) */	c1=bn_cmp_words(a,&(a[n]),n);	c2=bn_cmp_words(&(b[n]),b,n);	zero=neg=0;	switch (c1*3+c2)		{	case -4:		bn_sub_words(t,      &(a[n]),a,      n); /* - */		bn_sub_words(&(t[n]),b,      &(b[n]),n); /* - */		break;	case -3:		zero=1;		break;	case -2:		bn_sub_words(t,      &(a[n]),a,      n); /* - */		bn_sub_words(&(t[n]),&(b[n]),b,      n); /* + */		neg=1;		break;	case -1:	case 0:	case 1:		zero=1;		break;	case 2:		bn_sub_words(t,      a,      &(a[n]),n); /* + */		bn_sub_words(&(t[n]),b,      &(b[n]),n); /* - */		neg=1;		break;	case 3:		zero=1;		break;	case 4:		bn_sub_words(t,      a,      &(a[n]),n);		bn_sub_words(&(t[n]),&(b[n]),b,      n);		break;		}# ifdef BN_MUL_COMBA	if (n == 4)		{		if (!zero)			bn_mul_comba4(&(t[n2]),t,&(t[n]));		else			memset(&(t[n2]),0,8*sizeof(BN_ULONG));				bn_mul_comba4(r,a,b);		bn_mul_comba4(&(r[n2]),&(a[n]),&(b[n]));		}	else if (n == 8)		{		if (!zero)			bn_mul_comba8(&(t[n2]),t,&(t[n]));		else			memset(&(t[n2]),0,16*sizeof(BN_ULONG));				bn_mul_comba8(r,a,b);		bn_mul_comba8(&(r[n2]),&(a[n]),&(b[n]));		}	else# endif /* BN_MUL_COMBA */		{		p= &(t[n2*2]);		if (!zero)			bn_mul_recursive(&(t[n2]),t,&(t[n]),n,p);		else			memset(&(t[n2]),0,n2*sizeof(BN_ULONG));		bn_mul_recursive(r,a,b,n,p);		bn_mul_recursive(&(r[n2]),&(a[n]),&(b[n]),n,p);		}	/* t[32] holds (a[0]-a[1])*(b[1]-b[0]), c1 is the sign	 * r[10] holds (a[0]*b[0])	 * r[32] holds (b[1]*b[1])	 */	c1=(int)(bn_add_words(t,r,&(r[n2]),n2));	if (neg) /* if t[32] is negative */		{		c1-=(int)(bn_sub_words(&(t[n2]),t,&(t[n2]),n2));		}	else		{		/* Might have a carry */		c1+=(int)(bn_add_words(&(t[n2]),&(t[n2]),t,n2));		}	/* t[32] holds (a[0]-a[1])*(b[1]-b[0])+(a[0]*b[0])+(a[1]*b[1])	 * r[10] holds (a[0]*b[0])	 * r[32] holds (b[1]*b[1])	 * c1 holds the carry bits	 */	c1+=(int)(bn_add_words(&(r[n]),&(r[n]),&(t[n2]),n2));	if (c1)		{		p= &(r[n+n2]);		lo= *p;		ln=(lo+c1)&BN_MASK2;		*p=ln;		/* The overflow will stop before we over write		 * words we should not overwrite */		if (ln < (BN_ULONG)c1)			{			do	{				p++;				lo= *p;				ln=(lo+1)&BN_MASK2;				*p=ln;				} while (ln == 0);			}		}	}/* n+tn is the word length * t needs to be n*4 is size, as does r */void bn_mul_part_recursive(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b, int tn,	     int n, BN_ULONG *t)	{	int i,j,n2=n*2;	int c1,c2,neg,zero;	BN_ULONG ln,lo,*p;# ifdef BN_COUNT	printf(" bn_mul_part_recursive %d * %d\n",tn+n,tn+n);# endif	if (n < 8)		{		i=tn+n;		bn_mul_normal(r,a,i,b,i);		return;		}	/* r=(a[0]-a[1])*(b[1]-b[0]) */	c1=bn_cmp_words(a,&(a[n]),n);	c2=bn_cmp_words(&(b[n]),b,n);	zero=neg=0;	switch (c1*3+c2)		{	case -4:		bn_sub_words(t,      &(a[n]),a,      n); /* - */		bn_sub_words(&(t[n]),b,      &(b[n]),n); /* - */		break;	case -3:		zero=1;		/* break; */	case -2:		bn_sub_words(t,      &(a[n]),a,      n); /* - */		bn_sub_words(&(t[n]),&(b[n]),b,      n); /* + */		neg=1;		break;	case -1:	case 0:	case 1:		zero=1;		/* break; */	case 2:		bn_sub_words(t,      a,      &(a[n]),n); /* + */		bn_sub_words(&(t[n]),b,      &(b[n]),n); /* - */		neg=1;		break;	case 3:		zero=1;		/* break; */	case 4:		bn_sub_words(t,      a,      &(a[n]),n);		bn_sub_words(&(t[n]),&(b[n]),b,      n);		break;		}		/* The zero case isn't yet implemented here. The speedup		   would probably be negligible. */# if 0	if (n == 4)		{		bn_mul_comba4(&(t[n2]),t,&(t[n]));		bn_mul_comba4(r,a,b);		bn_mul_normal(&(r[n2]),&(a[n]),tn,&(b[n]),tn);		memset(&(r[n2+tn*2]),0,sizeof(BN_ULONG)*(n2-tn*2));		}	else# endif	if (n == 8)		{		bn_mul_comba8(&(t[n2]),t,&(t[n]));		bn_mul_comba8(r,a,b);		bn_mul_normal(&(r[n2]),&(a[n]),tn,&(b[n]),tn);		memset(&(r[n2+tn*2]),0,sizeof(BN_ULONG)*(n2-tn*2));		}	else		{		p= &(t[n2*2]);		bn_mul_recursive(&(t[n2]),t,&(t[n]),n,p);		bn_mul_recursive(r,a,b,n,p);		i=n/2;		/* If there is only a bottom half to the number,		 * just do it */		j=tn-i;		if (j == 0)			{			bn_mul_recursive(&(r[n2]),&(a[n]),&(b[n]),i,p);			memset(&(r[n2+i*2]),0,sizeof(BN_ULONG)*(n2-i*2));			}		else if (j > 0) /* eg, n == 16, i == 8 and tn == 11 */				{				bn_mul_part_recursive(&(r[n2]),&(a[n]),&(b[n]),					j,i,p);				memset(&(r[n2+tn*2]),0,					sizeof(BN_ULONG)*(n2-tn*2));				}		else /* (j < 0) eg, n == 16, i == 8 and tn == 5 */			{			memset(&(r[n2]),0,sizeof(BN_ULONG)*n2);			if (tn < BN_MUL_RECURSIVE_SIZE_NORMAL)				{				bn_mul_normal(&(r[n2]),&(a[n]),tn,&(b[n]),tn);				}			else				{				for (;;)					{					i/=2;					if (i < tn)						{						bn_mul_part_recursive(&(r[n2]),							&(a[n]),&(b[n]),							tn-i,i,p);						break;						}					else if (i == tn)						{						bn_mul_recursive(&(r[n2]),							&(a[n]),&(b[n]),							i,p);						break;						}					}				}			}		}	/* t[32] holds (a[0]-a[1])*(b[1]-b[0]), c1 is the sign	 * r[10] holds (a[0]*b[0])	 * r[32] holds (b[1]*b[1])	 */	c1=(int)(bn_add_words(t,r,&(r[n2]),n2));	if (neg) /* if t[32] is negative */		{		c1-=(int)(bn_sub_words(&(t[n2]),t,&(t[n2]),n2));		}	else		{		/* Might have a carry */		c1+=(int)(bn_add_words(&(t[n2]),&(t[n2]),t,n2));		}	/* t[32] holds (a[0]-a[1])*(b[1]-b[0])+(a[0]*b[0])+(a[1]*b[1])	 * r[10] holds (a[0]*b[0])	 * r[32] holds (b[1]*b[1])	 * c1 holds the carry bits	 */	c1+=(int)(bn_add_words(&(r[n]),&(r[n]),&(t[n2]),n2));	if (c1)		{		p= &(r[n+n2]);		lo= *p;		ln=(lo+c1)&BN_MASK2;		*p=ln;		/* The overflow will stop before we over write		 * words we should not overwrite */		if (ln < (BN_ULONG)c1)			{			do	{				p++;				lo= *p;				ln=(lo+1)&BN_MASK2;				*p=ln;				} while (ln == 0);			}		}	}/* a and b must be the same size, which is n2. * r needs to be n2 words and t needs to be n2*2 */void bn_mul_low_recursive(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b, int n2,	     BN_ULONG *t)	{	int n=n2/2;# ifdef BN_COUNT	printf(" bn_mul_low_recursive %d * %d\n",n2,n2);# endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品不卡在线视频| 精品在线免费观看| 久久久久高清精品| 久久久亚洲国产美女国产盗摄| 日韩码欧中文字| 亚洲美女淫视频| 日韩伦理av电影| 久久99国产乱子伦精品免费| 91女人视频在线观看| 色综合久久综合| 欧美色男人天堂| 日韩欧美在线观看一区二区三区| 日韩午夜小视频| 亚洲一区二区高清| 久久精品国产免费看久久精品| 精品一区二区三区香蕉蜜桃| 色av成人天堂桃色av| 欧美性色黄大片手机版| 日韩免费在线观看| 欧美国产综合色视频| 一区二区三区在线高清| 蜜臀久久久久久久| 男人的天堂久久精品| 在线影院国内精品| 亚洲色图欧洲色图婷婷| 国产精品夜夜爽| 91豆麻精品91久久久久久| 国产精品国产三级国产aⅴ无密码| 亚洲柠檬福利资源导航| 激情都市一区二区| 91在线精品一区二区| 欧美久久久影院| 国产亚洲一区二区三区在线观看 | 国产亚洲欧美色| 国产专区欧美精品| 日韩理论片中文av| 99在线热播精品免费| 欧美日韩国产综合一区二区 | 久88久久88久久久| 日韩一区二区三| 日本vs亚洲vs韩国一区三区 | 在线一区二区三区四区五区| 综合色天天鬼久久鬼色| 91福利在线免费观看| 亚洲一二三四区不卡| 欧美三级电影一区| 视频一区二区三区中文字幕| 成人免费高清视频在线观看| 在线不卡一区二区| 日本午夜一本久久久综合| 色婷婷综合久久久久中文| 一区二区三区在线高清| 欧美日韩日日骚| 久久成人羞羞网站| 久久久久国产一区二区三区四区| 不卡区在线中文字幕| 日韩精品专区在线| 成人午夜电影网站| 一区二区三区毛片| 日韩欧美不卡在线观看视频| 国产精品18久久久久久久久| 欧美色综合久久| 免费成人av资源网| 国产精品乱码一区二区三区软件| 国产一区视频网站| 欧美成人aa大片| 蜜臀av国产精品久久久久| 精品99一区二区| 91香蕉视频在线| 日本在线播放一区二区三区| 国产亚洲欧美一区在线观看| 91豆麻精品91久久久久久| 精品一区精品二区高清| 最新久久zyz资源站| 国产一区二区三区免费| 成人欧美一区二区三区| 日韩欧美二区三区| 色哟哟国产精品| 91麻豆视频网站| 日本伊人午夜精品| 尤物在线观看一区| 色婷婷综合视频在线观看| 久久福利视频一区二区| 亚洲欧美日韩一区| 国产无一区二区| 日韩欧美精品在线| 欧美伊人久久久久久午夜久久久久| 国产精品一二二区| 喷白浆一区二区| 亚洲资源在线观看| 国产精品日韩成人| 日韩精品一区二区三区视频在线观看| 91影院在线观看| 国产精品亚洲专一区二区三区| 亚洲国产欧美日韩另类综合| 69堂精品视频| 国产精品77777竹菊影视小说| 日韩在线卡一卡二| 亚洲国产日产av| 一色屋精品亚洲香蕉网站| 久久亚洲影视婷婷| 国产成人综合在线播放| 蜜桃av噜噜一区| 香蕉乱码成人久久天堂爱免费| 日韩精品最新网址| 欧美美女一区二区在线观看| 色婷婷一区二区三区四区| 成人av在线看| 风间由美一区二区av101| 亚洲高清视频在线| 亚洲综合清纯丝袜自拍| 亚洲欧美精品午睡沙发| 亚洲欧美影音先锋| 亚洲视频一区在线观看| 亚洲精品视频免费看| 亚洲欧美一区二区三区孕妇| 亚洲丝袜自拍清纯另类| 亚洲欧洲日产国产综合网| 国产精品欧美极品| 最新成人av在线| 一区二区在线观看视频| 一卡二卡欧美日韩| 亚洲成年人影院| 日韩精品视频网站| 另类综合日韩欧美亚洲| 久久99久久99| 国产精品18久久久久| 成人综合婷婷国产精品久久| 91色综合久久久久婷婷| 欧美日韩中文字幕一区二区| 欧美日韩国产高清一区二区三区 | 7777女厕盗摄久久久| 91精品国产一区二区三区| 波多野结衣91| 色噜噜夜夜夜综合网| 在线精品观看国产| av午夜一区麻豆| 日本道精品一区二区三区| 欧美在线一区二区| 日韩三级高清在线| 久久精品亚洲乱码伦伦中文| 亚洲天堂av老司机| 午夜精品久久久久影视| 一区二区三区日本| 日韩电影在线一区二区| 国产剧情一区二区三区| 色婷婷av一区二区三区gif | 久久精品无码一区二区三区| 亚洲欧洲日韩综合一区二区| 亚洲成人一二三| 久久99精品久久久久久动态图| 丰满岳乱妇一区二区三区| 色94色欧美sute亚洲线路二| 欧美一区二区黄| 国产精品久久久久久久浪潮网站| 一级女性全黄久久生活片免费| 久久成人免费电影| 91蝌蚪porny| 精品成人一区二区三区四区| 综合久久久久久| 国产在线播精品第三| 91啪在线观看| 久久亚洲欧美国产精品乐播| 一区二区三区中文在线| 国产麻豆精品久久一二三| 欧美最猛性xxxxx直播| 国产欧美一区二区在线| 国产女人水真多18毛片18精品视频| 亚洲国产sm捆绑调教视频| 国产精品香蕉一区二区三区| 欧美高清视频www夜色资源网| 国产精品免费人成网站| 麻豆精品视频在线观看| 欧美午夜视频网站| 中文字幕在线不卡| 国产成人精品亚洲日本在线桃色 | 久久久久久免费毛片精品| 亚洲成在线观看| 色综合久久久久久久久久久| 久久青草欧美一区二区三区| 青草av.久久免费一区| 欧美影院精品一区| 亚洲免费在线视频| 成人app在线观看| 久久久久国产成人精品亚洲午夜| 免费观看在线综合| 欧美日韩精品一区二区在线播放 | 91免费看片在线观看| 国产午夜精品久久| 国产精品一区久久久久| 日韩天堂在线观看| 日韩精品一二三四| 欧美日韩在线综合| 亚洲一区在线观看免费| 91麻豆国产在线观看| 亚洲天堂2014| 色综合久久久久久久| 一区二区三区四区高清精品免费观看 | 国产精品影视在线观看| 精品欧美一区二区三区精品久久|