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

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

?? sha1.c

?? matrix ssl代碼
?? C
字號(hào):
/*
 *	sha1.c
 *	Release $Name: MATRIXSSL_1_8_3_OPEN $
 *
 *	SHA1 hash implementation
 */
/*
 *	Copyright (c) PeerSec Networks, 2002-2007. All Rights Reserved.
 *	The latest version of this code is available at http://www.matrixssl.org
 *
 *	This software is open source; you can redistribute it and/or modify
 *	it under the terms of the GNU General Public License as published by
 *	the Free Software Foundation; either version 2 of the License, or
 *	(at your option) any later version.
 *
 *	This General Public License does NOT permit incorporating this software 
 *	into proprietary programs.  If you are unable to comply with the GPL, a 
 *	commercial license for this software may be purchased from PeerSec Networks
 *	at http://www.peersec.com
 *	
 *	This program is distributed in WITHOUT ANY WARRANTY; without even the 
 *	implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 
 *	See the GNU General Public License for more details.
 *	
 *	You should have received a copy of the GNU General Public License
 *	along with this program; if not, write to the Free Software
 *	Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *	http://www.gnu.org/copyleft/gpl.html
 */
/******************************************************************************/

#include "../cryptoLayer.h"

#define F0(x,y,z)	(z ^ (x & (y ^ z)))
#define F1(x,y,z)	(x ^ y ^ z)
#define F2(x,y,z)	((x & y) | (z & (x | y)))
#define F3(x,y,z)	(x ^ y ^ z)

#ifdef CLEAN_STACK
static void _sha1_compress(hash_state *md)
#else
static void sha1_compress(hash_state *md)
#endif /* CLEAN STACK */
{
	unsigned long	a,b,c,d,e,W[80],i;
#ifdef SMALL_CODE
	ulong32			t;
#endif

	sslAssert(md != NULL);

/*
	copy the state into 512-bits into W[0..15]
 */
	for (i = 0; i < 16; i++) {
		LOAD32H(W[i], md->sha1.buf + (4*i));
	}

/*
	copy state
 */
	a = md->sha1.state[0];
	b = md->sha1.state[1];
	c = md->sha1.state[2];
	d = md->sha1.state[3];
	e = md->sha1.state[4];

/*
	expand it
 */
	for (i = 16; i < 80; i++) {
		W[i] = ROL(W[i-3] ^ W[i-8] ^ W[i-14] ^ W[i-16], 1); 
	}

/*
	compress
 */
	/* round one */
	#define FF0(a,b,c,d,e,i) e = (ROLc(a, 5) + F0(b,c,d) + e + W[i] + 0x5a827999UL); b = ROLc(b, 30);
	#define FF1(a,b,c,d,e,i) e = (ROLc(a, 5) + F1(b,c,d) + e + W[i] + 0x6ed9eba1UL); b = ROLc(b, 30);
	#define FF2(a,b,c,d,e,i) e = (ROLc(a, 5) + F2(b,c,d) + e + W[i] + 0x8f1bbcdcUL); b = ROLc(b, 30);
	#define FF3(a,b,c,d,e,i) e = (ROLc(a, 5) + F3(b,c,d) + e + W[i] + 0xca62c1d6UL); b = ROLc(b, 30);

#ifdef SMALL_CODE
	for (i = 0; i < 20; ) {
		FF0(a,b,c,d,e,i++); t = e; e = d; d = c; c = b; b = a; a = t;
	}

	for (; i < 40; ) {
		FF1(a,b,c,d,e,i++); t = e; e = d; d = c; c = b; b = a; a = t;
	}

	for (; i < 60; ) {
		FF2(a,b,c,d,e,i++); t = e; e = d; d = c; c = b; b = a; a = t;
	}

	for (; i < 80; ) {
		FF3(a,b,c,d,e,i++); t = e; e = d; d = c; c = b; b = a; a = t;
	}
#else /* SMALL_CODE */
	for (i = 0; i < 20; ) {
		FF0(a,b,c,d,e,i++);
		FF0(e,a,b,c,d,i++);
		FF0(d,e,a,b,c,i++);
		FF0(c,d,e,a,b,i++);
		FF0(b,c,d,e,a,i++);
	}

	/* round two */
	for (; i < 40; ) {
		FF1(a,b,c,d,e,i++);
		FF1(e,a,b,c,d,i++);
		FF1(d,e,a,b,c,i++);
		FF1(c,d,e,a,b,i++);
		FF1(b,c,d,e,a,i++);
	}

	/* round three */
	for (; i < 60; ) {
		FF2(a,b,c,d,e,i++);
		FF2(e,a,b,c,d,i++);
		FF2(d,e,a,b,c,i++);
		FF2(c,d,e,a,b,i++);
		FF2(b,c,d,e,a,i++);
	}

	/* round four */
	for (; i < 80; ) {
		FF3(a,b,c,d,e,i++);
		FF3(e,a,b,c,d,i++);
		FF3(d,e,a,b,c,i++);
		FF3(c,d,e,a,b,i++);
		FF3(b,c,d,e,a,i++);
		}
#endif /* SMALL_CODE */

	#undef FF0
	#undef FF1
	#undef FF2
	#undef FF3

/*
	store
 */
	md->sha1.state[0] = md->sha1.state[0] + a;
	md->sha1.state[1] = md->sha1.state[1] + b;
	md->sha1.state[2] = md->sha1.state[2] + c;
	md->sha1.state[3] = md->sha1.state[3] + d;
	md->sha1.state[4] = md->sha1.state[4] + e;
}

#ifdef CLEAN_STACK
static void sha1_compress(hash_state *md)
{
	_sha1_compress(md);
	psBurnStack(sizeof(unsigned long) * 87);
}
#endif /* CLEAN_STACK */

void matrixSha1Init(hash_state * md)
{
	sslAssert(md != NULL);
	md->sha1.state[0] = 0x67452301UL;
	md->sha1.state[1] = 0xefcdab89UL;
	md->sha1.state[2] = 0x98badcfeUL;
	md->sha1.state[3] = 0x10325476UL;
	md->sha1.state[4] = 0xc3d2e1f0UL;
	md->sha1.curlen = 0;
#ifdef USE_INT64
	md->sha1.length = 0;
#else
	md->sha1.lengthHi = 0;
	md->sha1.lengthLo = 0;
#endif /* USE_INT64 */
}

void matrixSha1Update(hash_state * md, const unsigned char *buf, unsigned long len)
{
	unsigned long n;

	sslAssert(md != NULL);
	sslAssert(buf != NULL);
	while (len > 0) {
		n = MIN(len, (64 - md->sha1.curlen));
		memcpy(md->sha1.buf + md->sha1.curlen, buf, (size_t)n);
		md->sha1.curlen		+= n;
		buf					+= n;
		len					-= n;

		/* is 64 bytes full? */
		if (md->sha1.curlen == 64) {
			sha1_compress(md);
#ifdef USE_INT64
			md->sha1.length += 512;
#else
			n = (md->sha1.lengthLo + 512) & 0xFFFFFFFFL;
			if (n < md->sha1.lengthLo) {
				md->sha1.lengthHi++;
			}
			md->sha1.lengthLo = n;
#endif /* USE_INT64 */
			md->sha1.curlen = 0;
		}
	}
}

int32 matrixSha1Final(hash_state * md, unsigned char *hash)
{
	int32 i;
#ifndef USE_INT64
	unsigned long	n;
#endif
	sslAssert(md != NULL);
	if (md->sha1.curlen >= sizeof(md->sha1.buf) || hash == NULL) {
		return -1;
	}

/*
	increase the length of the message
 */
#ifdef USE_INT64
	md->sha1.length += md->sha1.curlen << 3;
#else
	n = (md->sha1.lengthLo + (md->sha1.curlen << 3)) & 0xFFFFFFFFL;
	if (n < md->sha1.lengthLo) {
		md->sha1.lengthHi++;
	}
	md->sha1.lengthHi += (md->sha1.curlen >> 29);
	md->sha1.lengthLo = n;
#endif /* USE_INT64 */

/*
	append the '1' bit
 */
	md->sha1.buf[md->sha1.curlen++] = (unsigned char)0x80;

/*
	if the length is currently above 56 bytes we append zeros then compress.
	Then we can fall back to padding zeros and length encoding like normal.
 */
	if (md->sha1.curlen > 56) {
		while (md->sha1.curlen < 64) {
			md->sha1.buf[md->sha1.curlen++] = (unsigned char)0;
		}
		sha1_compress(md);
		md->sha1.curlen = 0;
	}

/*
	pad upto 56 bytes of zeroes
 */
	while (md->sha1.curlen < 56) {
		md->sha1.buf[md->sha1.curlen++] = (unsigned char)0;
	}

/*
	store length
 */
#ifdef USE_INT64
	STORE64H(md->sha1.length, md->sha1.buf+56);
#else
	STORE32H(md->sha1.lengthHi, md->sha1.buf+56);
	STORE32H(md->sha1.lengthLo, md->sha1.buf+60);
#endif /* USE_INT64 */
	sha1_compress(md);

/*
	copy output
 */
	for (i = 0; i < 5; i++) {
		STORE32H(md->sha1.state[i], hash+(4*i));
	}
#ifdef CLEAN_STACK
	psZeromem(md, sizeof(hash_state));
#endif /* CLEAN_STACK */
	return 20;
}

#ifdef PEERSEC_TEST

int32  matrixSha1Test()
{
	static const struct {
		char *msg;
		unsigned char hash[20];
	} tests[] = {
		{ "abc",
		{ 0xa9, 0x99, 0x3e, 0x36, 0x47, 0x06, 0x81, 0x6a,
			0xba, 0x3e, 0x25, 0x71, 0x78, 0x50, 0xc2, 0x6c,
			0x9c, 0xd0, 0xd8, 0x9d }
		},
		{ "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq",
		{ 0x84, 0x98, 0x3E, 0x44, 0x1C, 0x3B, 0xD2, 0x6E,
			0xBA, 0xAE, 0x4A, 0xA1, 0xF9, 0x51, 0x29, 0xE5,
			0xE5, 0x46, 0x70, 0xF1 }
		}
	};

	int32 i;
	unsigned char tmp[20];
	hash_state md;

	for (i = 0; i < (int32)(sizeof(tests) / sizeof(tests[0]));  i++) {
		matrixSha1Init(&md);
		matrixSha1Update(&md, (unsigned char*)tests[i].msg, (unsigned long)strlen(tests[i].msg));
		matrixSha1Final(&md, tmp);
		if (memcmp(tmp, tests[i].hash, 20) != 0) {
			return CRYPT_FAIL_TESTVECTOR;
		}
	}
	return CRYPT_OK;
}
#endif /* PEERSEC_TEST */


/******************************************************************************/

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丰满少妇久久久久久久| 91成人网在线| 亚洲一区二区精品3399| 久久婷婷成人综合色| 欧美日韩视频在线观看一区二区三区| 国内精品自线一区二区三区视频| 亚洲女同ⅹxx女同tv| 久久久不卡网国产精品一区| 欧美亚男人的天堂| a在线播放不卡| 久久av资源站| 日韩av午夜在线观看| 亚洲精选视频在线| 国产午夜精品福利| 欧美草草影院在线视频| 欧美日韩中文字幕精品| 91啪九色porn原创视频在线观看| 久久爱www久久做| 五月天一区二区| 亚洲精品免费电影| 亚洲三级视频在线观看| 国产日韩成人精品| 26uuu国产在线精品一区二区| 这里只有精品免费| 欧美日韩一区二区电影| 色av综合在线| 91免费观看国产| www.成人在线| 成人永久免费视频| 国产成人在线色| 国内精品不卡在线| 久久99国内精品| 国内精品自线一区二区三区视频| 日本在线不卡一区| 日韩国产精品久久| 男女激情视频一区| 久久精品国产亚洲5555| 蜜桃av噜噜一区| 精品一区二区三区免费| 免费视频一区二区| 狠狠v欧美v日韩v亚洲ⅴ| 久国产精品韩国三级视频| 免费的成人av| 国产一区二区三区在线观看免费| 国产在线不卡视频| 国产成人综合亚洲网站| 国产suv一区二区三区88区| 国产成人精品一区二区三区网站观看| 国产一区二区三区四区在线观看| 国产精品一区二区久久不卡| 国产精品66部| 99视频国产精品| 91国产免费看| 9191成人精品久久| 日韩欧美国产电影| 久久综合99re88久久爱| 国产日韩精品一区二区三区 | 久久精品国产**网站演员| 蜜臀av国产精品久久久久 | 亚洲麻豆国产自偷在线| 性感美女久久精品| 九一九一国产精品| 欧美美女bb生活片| 波波电影院一区二区三区| av日韩在线网站| 在线观看日韩电影| 日韩一级欧美一级| 久久久777精品电影网影网 | 成人午夜激情影院| 91麻豆精品一区二区三区| 欧美色中文字幕| 欧美不卡视频一区| 中文字幕一区二区视频| 亚洲一区二区三区小说| 久久精品国产77777蜜臀| 成人性视频免费网站| 欧美在线观看一区二区| 精品久久久久香蕉网| 亚洲欧美综合网| 首页亚洲欧美制服丝腿| 粉嫩嫩av羞羞动漫久久久| 日本韩国欧美三级| 精品国产91洋老外米糕| 一区二区在线免费| 激情综合亚洲精品| 99视频国产精品| 精品少妇一区二区三区日产乱码| 国产精品毛片a∨一区二区三区| 亚洲一区二区三区三| 国产精品一二三区在线| 欧美日韩亚洲综合一区二区三区| 久久美女艺术照精彩视频福利播放| 亚洲精品网站在线观看| 国产一区二区三区日韩| 欧美日韩三级一区| 国产精品久久三| 麻豆精品视频在线观看| 日本精品裸体写真集在线观看| 精品国产在天天线2019| 亚洲高清免费观看高清完整版在线观看| 精品在线免费视频| 欧美日韩在线三区| 一区在线观看视频| 国产一区二区三区四区五区入口| 欧美日韩国产高清一区二区 | 久久久久99精品一区| 亚洲一区二三区| 成人黄页在线观看| 久久久噜噜噜久噜久久综合| 天天综合色天天综合| 在线看一区二区| 一色桃子久久精品亚洲| 国产精品2024| 精品国产乱码久久久久久影片| 午夜一区二区三区视频| 99re8在线精品视频免费播放| 久久精品免视看| 久久99国产精品免费网站| 中文字幕在线观看不卡视频| 精品一区二区三区免费| 日韩精品一区二| 日韩电影在线一区| 欧美片网站yy| 亚洲不卡在线观看| 欧美三级视频在线观看| 亚洲综合清纯丝袜自拍| 色视频成人在线观看免| 亚洲色图视频网站| 99久久婷婷国产综合精品| 国产精品无圣光一区二区| 国产高清不卡二三区| 国产无一区二区| 成人精品小蝌蚪| 欧美激情一区二区三区在线| 国产成人免费在线视频| 国产午夜亚洲精品羞羞网站| 激情国产一区二区 | 亚洲精品国产精品乱码不99| 懂色av一区二区三区蜜臀| 国产女人水真多18毛片18精品视频| 欧美性猛交xxxxxx富婆| 成人欧美一区二区三区| 99久久精品国产一区| 最新国产精品久久精品| av一本久道久久综合久久鬼色| 国产精品国产三级国产aⅴ入口| 懂色av中文一区二区三区| 中文久久乱码一区二区| 99国产精品久久久久久久久久| 中文字幕亚洲区| 色天天综合色天天久久| 亚洲图片自拍偷拍| 欧美一区二区三区的| 精品亚洲国内自在自线福利| 国产日产欧美一区二区视频| 成人性生交大片免费| 亚洲欧美日韩一区| 欧美人与禽zozo性伦| 蜜桃视频免费观看一区| 久久九九国产精品| 91在线云播放| 亚洲chinese男男1069| 日韩精品一区二区三区视频| 国产91色综合久久免费分享| 亚洲少妇屁股交4| 91精品国产91久久综合桃花| 激情欧美日韩一区二区| 日韩美女精品在线| 欧美福利视频一区| 国产精品夜夜嗨| 亚洲精品国产视频| 日韩亚洲国产中文字幕欧美| 高清久久久久久| 亚洲图片有声小说| 国产天堂亚洲国产碰碰| 色噜噜狠狠色综合中国| 久久不见久久见免费视频1| 国产精品福利一区二区| 欧美一区二区免费观在线| 丁香婷婷深情五月亚洲| 亚洲国产日韩av| 精品国产乱码久久久久久影片| 91视频在线观看| 国产一区二区三区不卡在线观看 | 中文av一区特黄| 精品视频一区三区九区| 国产高清不卡一区| 日韩精品一二区| 亚洲人成精品久久久久久| 日韩亚洲欧美成人一区| 色偷偷久久一区二区三区| 国产一区二区三区精品视频| 亚洲v日本v欧美v久久精品| 国产肉丝袜一区二区| 欧美丰满嫩嫩电影| 99久久婷婷国产综合精品 | 欧美视频一区在线| 懂色av一区二区三区免费观看| 免费在线看一区| 亚洲高清免费观看|