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

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

?? md5.c

?? wizfwtools: tools for developing firmware images for Beyonwiz embedded devices (www.beyonwiz.com)
?? C
字號:
/* * This code implements the MD5 message-digest algorithm. * The algorithm is due to Ron Rivest.  This code was * written by Colin Plumb in 1993, no copyright is claimed. * This code is in the public domain; do with it what you wish. * * Equivalent code is available from RSA Data Security, Inc. * This code has been tested against that, and is equivalent, * except that you don't need to include two pages of legalese * with every copy. * * To compute the message digest of a chunk of bytes, declare an * MD5Context structure, pass it to MD5Init, call MD5Update as * needed on buffers full of bytes, and then call MD5Final, which * will fill a supplied 16-byte array with the digest. *//* This code was modified in 1997 by Jim Kingdon of Cyclic Software to   not require an integer type which is exactly 32 bits.  This work   draws on the changes for the same purpose by Tatu Ylonen   <ylo@cs.hut.fi> as part of SSH, but since I didn't actually use   that code, there is no copyright issue.  I hereby disclaim   copyright in any changes I have made; this code remains in the   public domain.  *//* Note regarding cvs_* namespace: this avoids potential conflicts   with libraries such as some versions of Kerberos.  No particular   need to worry about whether the system supplies an MD5 library, as   this file is only about 3k of object code.  */#ifdef HAVE_CONFIG_H#include "config.h"#endif#include <string.h>	/* for memcpy() and memset() *//* Add prototype support.  */#ifndef PROTO#if defined (USE_PROTOTYPES) ? USE_PROTOTYPES : defined (__STDC__)#define PROTO(ARGS) ARGS#else#define PROTO(ARGS) ()#endif#endif#include "md5.h"/* Little-endian byte-swapping routines.  Note that these do not   depend on the size of datatypes such as cvs_uint32, nor do they require   us to detect the endianness of the machine we are running on.  It   is possible they should be macros for speed, but I would be   surprised if they were a performance bottleneck for MD5.  */static cvs_uint32getu32 (addr)     const unsigned char *addr;{	return (((((unsigned long)addr[3] << 8) | addr[2]) << 8)		| addr[1]) << 8 | addr[0];}voidputu32 (data, addr)     cvs_uint32 data;     unsigned char *addr;{	addr[0] = (unsigned char)data;	addr[1] = (unsigned char)(data >> 8);	addr[2] = (unsigned char)(data >> 16);	addr[3] = (unsigned char)(data >> 24);}/* * Start MD5 accumulation.  Set bit count to 0 and buffer to mysterious * initialization constants. */voidcvs_MD5Init (ctx)     struct cvs_MD5Context *ctx;{	ctx->buf[0] = 0x67452301;	ctx->buf[1] = 0xefcdab89;	ctx->buf[2] = 0x98badcfe;	ctx->buf[3] = 0x10325476;	ctx->bits[0] = 0;	ctx->bits[1] = 0;}/* * Update context to reflect the concatenation of another buffer full * of bytes. */voidcvs_MD5Update (ctx, buf, len)     struct cvs_MD5Context *ctx;     unsigned char const *buf;     unsigned len;{	cvs_uint32 t;	/* Update bitcount */	t = ctx->bits[0];	if ((ctx->bits[0] = (t + ((cvs_uint32)len << 3)) & 0xffffffff) < t)		ctx->bits[1]++;	/* Carry from low to high */	ctx->bits[1] += len >> 29;	t = (t >> 3) & 0x3f;	/* Bytes already in shsInfo->data */	/* Handle any leading odd-sized chunks */	if ( t ) {		unsigned char *p = ctx->in + t;		t = 64-t;		if (len < t) {			memcpy(p, buf, len);			return;		}		memcpy(p, buf, t);		cvs_MD5Transform (ctx->buf, ctx->in);		buf += t;		len -= t;	}	/* Process data in 64-byte chunks */	while (len >= 64) {		memcpy(ctx->in, buf, 64);		cvs_MD5Transform (ctx->buf, ctx->in);		buf += 64;		len -= 64;	}	/* Handle any remaining bytes of data. */	memcpy(ctx->in, buf, len);}/* * Final wrapup - pad to 64-byte boundary with the bit pattern  * 1 0* (64-bit count of bits processed, MSB-first) */voidcvs_MD5Final (digest, ctx)     unsigned char digest[16];     struct cvs_MD5Context *ctx;{	unsigned count;	unsigned char *p;	/* Compute number of bytes mod 64 */	count = (ctx->bits[0] >> 3) & 0x3F;	/* Set the first char of padding to 0x80.  This is safe since there is	   always at least one byte free */	p = ctx->in + count;	*p++ = 0x80;	/* Bytes of padding needed to make 64 bytes */	count = 64 - 1 - count;	/* Pad out to 56 mod 64 */	if (count < 8) {		/* Two lots of padding:  Pad the first block to 64 bytes */		memset(p, 0, count);		cvs_MD5Transform (ctx->buf, ctx->in);		/* Now fill the next block with 56 bytes */		memset(ctx->in, 0, 56);	} else {		/* Pad block to 56 bytes */		memset(p, 0, count-8);	}	/* Append length in bits and transform */	putu32(ctx->bits[0], ctx->in + 56);	putu32(ctx->bits[1], ctx->in + 60);	cvs_MD5Transform (ctx->buf, ctx->in);	putu32(ctx->buf[0], digest);	putu32(ctx->buf[1], digest + 4);	putu32(ctx->buf[2], digest + 8);	putu32(ctx->buf[3], digest + 12);	memset(ctx, 0, sizeof(ctx));	/* In case it's sensitive */}#ifndef ASM_MD5/* The four core functions - F1 is optimized somewhat *//* #define F1(x, y, z) (x & y | ~x & z) */#define F1(x, y, z) (z ^ (x & (y ^ z)))#define F2(x, y, z) F1(z, x, y)#define F3(x, y, z) (x ^ y ^ z)#define F4(x, y, z) (y ^ (x | ~z))/* This is the central step in the MD5 algorithm. */#define MD5STEP(f, w, x, y, z, data, s) \	( w += f(x, y, z) + data, w &= 0xffffffff, w = w<<s | w>>(32-s), w += x )/* * The core of the MD5 algorithm, this alters an existing MD5 hash to * reflect the addition of 16 longwords of new data.  MD5Update blocks * the data and converts bytes into longwords for this routine. */voidcvs_MD5Transform (buf, inraw)     cvs_uint32 buf[4];     const unsigned char inraw[64];{	register cvs_uint32 a, b, c, d;	cvs_uint32 in[16];	int i;	for (i = 0; i < 16; ++i)		in[i] = getu32 (inraw + 4 * i);	a = buf[0];	b = buf[1];	c = buf[2];	d = buf[3];	MD5STEP(F1, a, b, c, d, in[ 0]+0xd76aa478,  7);	MD5STEP(F1, d, a, b, c, in[ 1]+0xe8c7b756, 12);	MD5STEP(F1, c, d, a, b, in[ 2]+0x242070db, 17);	MD5STEP(F1, b, c, d, a, in[ 3]+0xc1bdceee, 22);	MD5STEP(F1, a, b, c, d, in[ 4]+0xf57c0faf,  7);	MD5STEP(F1, d, a, b, c, in[ 5]+0x4787c62a, 12);	MD5STEP(F1, c, d, a, b, in[ 6]+0xa8304613, 17);	MD5STEP(F1, b, c, d, a, in[ 7]+0xfd469501, 22);	MD5STEP(F1, a, b, c, d, in[ 8]+0x698098d8,  7);	MD5STEP(F1, d, a, b, c, in[ 9]+0x8b44f7af, 12);	MD5STEP(F1, c, d, a, b, in[10]+0xffff5bb1, 17);	MD5STEP(F1, b, c, d, a, in[11]+0x895cd7be, 22);	MD5STEP(F1, a, b, c, d, in[12]+0x6b901122,  7);	MD5STEP(F1, d, a, b, c, in[13]+0xfd987193, 12);	MD5STEP(F1, c, d, a, b, in[14]+0xa679438e, 17);	MD5STEP(F1, b, c, d, a, in[15]+0x49b40821, 22);	MD5STEP(F2, a, b, c, d, in[ 1]+0xf61e2562,  5);	MD5STEP(F2, d, a, b, c, in[ 6]+0xc040b340,  9);	MD5STEP(F2, c, d, a, b, in[11]+0x265e5a51, 14);	MD5STEP(F2, b, c, d, a, in[ 0]+0xe9b6c7aa, 20);	MD5STEP(F2, a, b, c, d, in[ 5]+0xd62f105d,  5);	MD5STEP(F2, d, a, b, c, in[10]+0x02441453,  9);	MD5STEP(F2, c, d, a, b, in[15]+0xd8a1e681, 14);	MD5STEP(F2, b, c, d, a, in[ 4]+0xe7d3fbc8, 20);	MD5STEP(F2, a, b, c, d, in[ 9]+0x21e1cde6,  5);	MD5STEP(F2, d, a, b, c, in[14]+0xc33707d6,  9);	MD5STEP(F2, c, d, a, b, in[ 3]+0xf4d50d87, 14);	MD5STEP(F2, b, c, d, a, in[ 8]+0x455a14ed, 20);	MD5STEP(F2, a, b, c, d, in[13]+0xa9e3e905,  5);	MD5STEP(F2, d, a, b, c, in[ 2]+0xfcefa3f8,  9);	MD5STEP(F2, c, d, a, b, in[ 7]+0x676f02d9, 14);	MD5STEP(F2, b, c, d, a, in[12]+0x8d2a4c8a, 20);	MD5STEP(F3, a, b, c, d, in[ 5]+0xfffa3942,  4);	MD5STEP(F3, d, a, b, c, in[ 8]+0x8771f681, 11);	MD5STEP(F3, c, d, a, b, in[11]+0x6d9d6122, 16);	MD5STEP(F3, b, c, d, a, in[14]+0xfde5380c, 23);	MD5STEP(F3, a, b, c, d, in[ 1]+0xa4beea44,  4);	MD5STEP(F3, d, a, b, c, in[ 4]+0x4bdecfa9, 11);	MD5STEP(F3, c, d, a, b, in[ 7]+0xf6bb4b60, 16);	MD5STEP(F3, b, c, d, a, in[10]+0xbebfbc70, 23);	MD5STEP(F3, a, b, c, d, in[13]+0x289b7ec6,  4);	MD5STEP(F3, d, a, b, c, in[ 0]+0xeaa127fa, 11);	MD5STEP(F3, c, d, a, b, in[ 3]+0xd4ef3085, 16);	MD5STEP(F3, b, c, d, a, in[ 6]+0x04881d05, 23);	MD5STEP(F3, a, b, c, d, in[ 9]+0xd9d4d039,  4);	MD5STEP(F3, d, a, b, c, in[12]+0xe6db99e5, 11);	MD5STEP(F3, c, d, a, b, in[15]+0x1fa27cf8, 16);	MD5STEP(F3, b, c, d, a, in[ 2]+0xc4ac5665, 23);	MD5STEP(F4, a, b, c, d, in[ 0]+0xf4292244,  6);	MD5STEP(F4, d, a, b, c, in[ 7]+0x432aff97, 10);	MD5STEP(F4, c, d, a, b, in[14]+0xab9423a7, 15);	MD5STEP(F4, b, c, d, a, in[ 5]+0xfc93a039, 21);	MD5STEP(F4, a, b, c, d, in[12]+0x655b59c3,  6);	MD5STEP(F4, d, a, b, c, in[ 3]+0x8f0ccc92, 10);	MD5STEP(F4, c, d, a, b, in[10]+0xffeff47d, 15);	MD5STEP(F4, b, c, d, a, in[ 1]+0x85845dd1, 21);	MD5STEP(F4, a, b, c, d, in[ 8]+0x6fa87e4f,  6);	MD5STEP(F4, d, a, b, c, in[15]+0xfe2ce6e0, 10);	MD5STEP(F4, c, d, a, b, in[ 6]+0xa3014314, 15);	MD5STEP(F4, b, c, d, a, in[13]+0x4e0811a1, 21);	MD5STEP(F4, a, b, c, d, in[ 4]+0xf7537e82,  6);	MD5STEP(F4, d, a, b, c, in[11]+0xbd3af235, 10);	MD5STEP(F4, c, d, a, b, in[ 2]+0x2ad7d2bb, 15);	MD5STEP(F4, b, c, d, a, in[ 9]+0xeb86d391, 21);	buf[0] += a;	buf[1] += b;	buf[2] += c;	buf[3] += d;}#endif#ifdef TEST/* Simple test program.  Can use it to manually run the tests from   RFC1321 for example.  */#include <stdio.h>intmain (int argc, char **argv){	struct cvs_MD5Context context;	unsigned char checksum[16];	int i;	int j;	if (argc < 2)	{		fprintf (stderr, "usage: %s string-to-hash\n", argv[0]);		exit (1);	}	for (j = 1; j < argc; ++j)	{		printf ("MD5 (\"%s\") = ", argv[j]);		cvs_MD5Init (&context);		cvs_MD5Update (&context, argv[j], strlen (argv[j]));		cvs_MD5Final (checksum, &context);		for (i = 0; i < 16; i++)		{			printf ("%02x", (unsigned int) checksum[i]);		}		printf ("\n");	}	return 0;}#endif /* TEST */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合一个色综合亚洲| 91首页免费视频| 亚洲人成精品久久久久| 欧美精品久久久久久久多人混战| 国产黄色精品网站| 亚洲成人免费av| 国产精品三级视频| 欧美一区二区三区在线| 99re这里只有精品首页| 麻豆免费精品视频| 亚洲国产婷婷综合在线精品| 中文av一区二区| 日韩精品专区在线影院观看| 色综合久久天天综合网| 国产成人h网站| 另类小说色综合网站| 亚洲蜜臀av乱码久久精品| 国产午夜亚洲精品不卡| 欧美一二三区在线观看| 欧美午夜寂寞影院| 99精品视频在线播放观看| 国产精品正在播放| 蜜臀av性久久久久蜜臀aⅴ流畅| 一区二区成人在线观看| 一区在线观看免费| 国产精品天干天干在线综合| 精品国产亚洲一区二区三区在线观看| 欧美性xxxxxxxx| 欧美成人一区二区| 欧美丝袜丝交足nylons图片| 97se亚洲国产综合自在线不卡| 国产+成+人+亚洲欧洲自线| 精品一区二区日韩| 久久99热这里只有精品| 蜜桃精品视频在线| 日韩福利视频网| 日韩vs国产vs欧美| 日韩黄色免费网站| 日本vs亚洲vs韩国一区三区二区| 午夜免费久久看| 性感美女久久精品| 午夜成人免费视频| 日韩中文字幕一区二区三区| 亚洲v中文字幕| 日本少妇一区二区| 久久精品二区亚洲w码| 久久99日本精品| 国产九色sp调教91| 成人性色生活片| 不卡av在线网| 色婷婷久久久综合中文字幕 | 亚洲午夜日本在线观看| 一区二区在线看| 亚洲成人免费在线观看| 天堂成人国产精品一区| 免费成人你懂的| 国产乱码精品一区二区三区av| 国产成人午夜99999| 成人动漫中文字幕| 在线影院国内精品| 国产精品成人在线观看| 一区二区三区电影在线播| 亚洲一二三区视频在线观看| 三级亚洲高清视频| 国产一区不卡视频| 91免费国产在线| 91精品在线观看入口| 26uuu久久天堂性欧美| 久久综合九色综合97婷婷女人| 免费在线观看日韩欧美| 亚洲一区av在线| 日韩av午夜在线观看| 国产乱人伦精品一区二区在线观看| 国产成人免费高清| 色av一区二区| 日韩丝袜美女视频| 国产精品伦一区二区三级视频| 亚洲美女偷拍久久| 免费视频一区二区| 成人一级黄色片| 欧美午夜精品久久久久久超碰 | 26uuu国产在线精品一区二区| 国产精品乱人伦| 午夜亚洲福利老司机| 国产成人啪免费观看软件 | 欧美三级韩国三级日本一级| 日韩精品中文字幕一区二区三区| 国产精品婷婷午夜在线观看| 午夜精品久久久久久久99水蜜桃| 国产在线精品一区二区不卡了| 色哟哟精品一区| 欧美精品一区二区久久婷婷 | 亚洲欧洲性图库| 婷婷激情综合网| 成人app网站| 欧美mv日韩mv国产网站app| 亚洲女子a中天字幕| 精品一区二区三区视频| 91黄色激情网站| 日本一区二区三区国色天香 | 日韩久久久久久| 亚洲制服欧美中文字幕中文字幕| 国产在线视频精品一区| 欧美视频三区在线播放| 综合久久一区二区三区| 韩国精品在线观看| 欧美日韩一级视频| 综合久久国产九一剧情麻豆| 紧缚捆绑精品一区二区| 欧美绝品在线观看成人午夜影视| 天天色 色综合| 91理论电影在线观看| 精品91自产拍在线观看一区| 亚洲电影视频在线| 91丨porny丨首页| 国产精品污网站| 国产在线国偷精品免费看| 欧美日韩精品三区| 一区二区在线观看视频| 波多野洁衣一区| 欧美激情一区二区在线| 狠狠色丁香久久婷婷综合_中| 欧美放荡的少妇| 亚洲大片精品永久免费| 在线亚洲+欧美+日本专区| 国产精品动漫网站| 成人久久久精品乱码一区二区三区| 日韩免费高清电影| 日韩国产欧美视频| 欧美精品vⅰdeose4hd| 亚洲国产成人91porn| 91福利小视频| 亚洲午夜免费视频| 欧美午夜精品免费| 亚洲综合免费观看高清完整版在线| 91原创在线视频| 国产精品久久久久久户外露出| 成人性生交大片| 国产精品久久久久久久久免费丝袜| 国产suv精品一区二区6| 国产欧美一区二区三区在线老狼| 国产激情一区二区三区四区| 久久久精品天堂| 成人自拍视频在线| 国产精品毛片大码女人| 97久久超碰国产精品| 一区二区三区在线观看国产| 欧美日韩久久不卡| 日本不卡在线视频| 26uuu另类欧美| 成人美女在线观看| 亚洲自拍偷拍网站| 在线不卡欧美精品一区二区三区| 免费看精品久久片| 久久婷婷色综合| gogo大胆日本视频一区| 亚洲精品免费在线| 91麻豆精品91久久久久同性| 精品一区二区在线视频| 中文字幕的久久| 在线精品亚洲一区二区不卡| 日韩电影在线观看一区| 久久网站热最新地址| 91性感美女视频| 青草av.久久免费一区| 久久精品视频一区二区三区| 99在线视频精品| 首页综合国产亚洲丝袜| 久久精品一区二区三区不卡牛牛 | 亚洲高清免费视频| 欧美另类久久久品| 国产一区在线看| 中文字幕一区二区三区在线播放| 91视频免费播放| 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产激情视频一区二区在线观看 | 韩国成人福利片在线播放| 欧美一区二区三区四区五区 | 欧美猛男男办公室激情| 激情另类小说区图片区视频区| 久久久久久99久久久精品网站| 成人动漫中文字幕| 亚洲成在人线免费| 欧美国产欧美亚州国产日韩mv天天看完整| 成人激情视频网站| 亚洲国产一区二区a毛片| 欧美一卡二卡三卡| 国产成人啪免费观看软件| 亚洲激情图片qvod| 欧美一区三区四区| 色综合咪咪久久| 男人的天堂久久精品| 欧美经典三级视频一区二区三区| 欧美日韩国产123区| 国产黄色精品视频| 亚洲黄色在线视频| 91精品国产高清一区二区三区蜜臀| 99国产精品久久久久| 日韩不卡一二三区| 日韩美女精品在线|