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

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

?? ipsec_sha1.c

?? ipsec_sha1的C源碼。我們已經用于測試SHA1的erilog
?? C
字號:
/* * RCSID $Id: ipsec_sha1.c,v 1.5 1999/12/13 13:59:13 rgb Exp $ *//* * The rest of the code is derived from sha1.c by Steve Reid, which is * public domain. * Minor cosmetic changes to accomodate it in the Linux kernel by ji. */#include <asm/byteorder.h>#include <linux/string.h>#include "ipsec_sha1.h"#if defined(rol)#undef rol#endif#define SHA1HANDSOFF#define rol(value, bits) (((value) << (bits)) | ((value) >> (32 - (bits))))/* blk0() and blk() perform the initial expand. *//* I got the idea of expanding during the round function from SSLeay */#ifdef __LITTLE_ENDIAN#define blk0(i) (block->l[i] = (rol(block->l[i],24)&0xFF00FF00) \    |(rol(block->l[i],8)&0x00FF00FF))#else#define blk0(i) block->l[i]#endif#define blk(i) (block->l[i&15] = rol(block->l[(i+13)&15]^block->l[(i+8)&15] \    ^block->l[(i+2)&15]^block->l[i&15],1))/* (R0+R1), R2, R3, R4 are the different operations used in SHA1 */#define R0(v,w,x,y,z,i) z+=((w&(x^y))^y)+blk0(i)+0x5A827999+rol(v,5);w=rol(w,30);#define R1(v,w,x,y,z,i) z+=((w&(x^y))^y)+blk(i)+0x5A827999+rol(v,5);w=rol(w,30);#define R2(v,w,x,y,z,i) z+=(w^x^y)+blk(i)+0x6ED9EBA1+rol(v,5);w=rol(w,30);#define R3(v,w,x,y,z,i) z+=(((w|x)&y)|(w&x))+blk(i)+0x8F1BBCDC+rol(v,5);w=rol(w,30);#define R4(v,w,x,y,z,i) z+=(w^x^y)+blk(i)+0xCA62C1D6+rol(v,5);w=rol(w,30);/* Hash a single 512-bit block. This is the core of the algorithm. */void SHA1Transform(__u32 state[5], __u8 buffer[64]){__u32 a, b, c, d, e;typedef union {    unsigned char c[64];    __u32 l[16];} CHAR64LONG16;CHAR64LONG16* block;#ifdef SHA1HANDSOFFstatic unsigned char workspace[64];    block = (CHAR64LONG16*)workspace;    memcpy(block, buffer, 64);#else    block = (CHAR64LONG16*)buffer;#endif    /* Copy context->state[] to working vars */    a = state[0];    b = state[1];    c = state[2];    d = state[3];    e = state[4];    /* 4 rounds of 20 operations each. Loop unrolled. */    R0(a,b,c,d,e, 0); R0(e,a,b,c,d, 1); R0(d,e,a,b,c, 2); R0(c,d,e,a,b, 3);    R0(b,c,d,e,a, 4); R0(a,b,c,d,e, 5); R0(e,a,b,c,d, 6); R0(d,e,a,b,c, 7);    R0(c,d,e,a,b, 8); R0(b,c,d,e,a, 9); R0(a,b,c,d,e,10); R0(e,a,b,c,d,11);    R0(d,e,a,b,c,12); R0(c,d,e,a,b,13); R0(b,c,d,e,a,14); R0(a,b,c,d,e,15);    R1(e,a,b,c,d,16); R1(d,e,a,b,c,17); R1(c,d,e,a,b,18); R1(b,c,d,e,a,19);    R2(a,b,c,d,e,20); R2(e,a,b,c,d,21); R2(d,e,a,b,c,22); R2(c,d,e,a,b,23);    R2(b,c,d,e,a,24); R2(a,b,c,d,e,25); R2(e,a,b,c,d,26); R2(d,e,a,b,c,27);    R2(c,d,e,a,b,28); R2(b,c,d,e,a,29); R2(a,b,c,d,e,30); R2(e,a,b,c,d,31);    R2(d,e,a,b,c,32); R2(c,d,e,a,b,33); R2(b,c,d,e,a,34); R2(a,b,c,d,e,35);    R2(e,a,b,c,d,36); R2(d,e,a,b,c,37); R2(c,d,e,a,b,38); R2(b,c,d,e,a,39);    R3(a,b,c,d,e,40); R3(e,a,b,c,d,41); R3(d,e,a,b,c,42); R3(c,d,e,a,b,43);    R3(b,c,d,e,a,44); R3(a,b,c,d,e,45); R3(e,a,b,c,d,46); R3(d,e,a,b,c,47);    R3(c,d,e,a,b,48); R3(b,c,d,e,a,49); R3(a,b,c,d,e,50); R3(e,a,b,c,d,51);    R3(d,e,a,b,c,52); R3(c,d,e,a,b,53); R3(b,c,d,e,a,54); R3(a,b,c,d,e,55);    R3(e,a,b,c,d,56); R3(d,e,a,b,c,57); R3(c,d,e,a,b,58); R3(b,c,d,e,a,59);    R4(a,b,c,d,e,60); R4(e,a,b,c,d,61); R4(d,e,a,b,c,62); R4(c,d,e,a,b,63);    R4(b,c,d,e,a,64); R4(a,b,c,d,e,65); R4(e,a,b,c,d,66); R4(d,e,a,b,c,67);    R4(c,d,e,a,b,68); R4(b,c,d,e,a,69); R4(a,b,c,d,e,70); R4(e,a,b,c,d,71);    R4(d,e,a,b,c,72); R4(c,d,e,a,b,73); R4(b,c,d,e,a,74); R4(a,b,c,d,e,75);    R4(e,a,b,c,d,76); R4(d,e,a,b,c,77); R4(c,d,e,a,b,78); R4(b,c,d,e,a,79);    /* Add the working vars back into context.state[] */    state[0] += a;    state[1] += b;    state[2] += c;    state[3] += d;    state[4] += e;    /* Wipe variables */    a = b = c = d = e = 0;}/* SHA1Init - Initialize new context */void SHA1Init(SHA1_CTX* context){    /* SHA1 initialization constants */    context->state[0] = 0x67452301;    context->state[1] = 0xEFCDAB89;    context->state[2] = 0x98BADCFE;    context->state[3] = 0x10325476;    context->state[4] = 0xC3D2E1F0;    context->count[0] = context->count[1] = 0;}/* Run your data through this. */void SHA1Update(SHA1_CTX* context, unsigned char* data, __u32 len){__u32 i, j;    j = context->count[0];    if ((context->count[0] += len << 3) < j)	context->count[1]++;    context->count[1] += (len>>29);    j = (j >> 3) & 63;    if ((j + len) > 63) {        memcpy(&context->buffer[j], data, (i = 64-j));        SHA1Transform(context->state, context->buffer);        for ( ; i + 63 < len; i += 64) {            SHA1Transform(context->state, &data[i]);        }        j = 0;    }    else i = 0;    memcpy(&context->buffer[j], &data[i], len - i);}/* Add padding and return the message digest. */void SHA1Final(unsigned char digest[20], SHA1_CTX* context){__u32 i, j;unsigned char finalcount[8];    for (i = 0; i < 8; i++) {        finalcount[i] = (unsigned char)((context->count[(i >= 4 ? 0 : 1)]         >> ((3-(i & 3)) * 8) ) & 255);  /* Endian independent */    }    SHA1Update(context, (unsigned char *)"\200", 1);    while ((context->count[0] & 504) != 448) {        SHA1Update(context, (unsigned char *)"\0", 1);    }    SHA1Update(context, finalcount, 8);  /* Should cause a SHA1Transform() */    for (i = 0; i < 20; i++) {        digest[i] = (unsigned char)         ((context->state[i>>2] >> ((3-(i & 3)) * 8) ) & 255);    }    /* Wipe variables */    i = j = 0;    memset(context->buffer, 0, 64);    memset(context->state, 0, 20);    memset(context->count, 0, 8);    memset(&finalcount, 0, 8);#ifdef SHA1HANDSOFF  /* make SHA1Transform overwrite its own static vars */    SHA1Transform(context->state, context->buffer);#endif}/* * $Log: ipsec_sha1.c,v $ * Revision 1.5  1999/12/13 13:59:13  rgb * Quick fix to argument size to Update bugs. * * Revision 1.4  1999/04/11 00:29:00  henry * GPL boilerplate * * Revision 1.3  1999/04/06 04:54:27  rgb * Fix/Add RCSID Id: and Log: bits to make PHMDs happy.  This includes * patch shell fixes. * * Revision 1.2  1999/01/22 06:55:50  rgb * 64-bit clean-up. * * Revision 1.1  1998/06/18 21:27:50  henry * move sources from klips/src to klips/net/ipsec, to keep stupid * kernel-build scripts happier in the presence of symlinks * * Revision 1.2  1998/04/23 20:54:04  rgb * Fixed md5 and sha1 include file nesting issues, to be cleaned up when * verified. * * Revision 1.1  1998/04/09 03:06:11  henry * sources moved up from linux/net/ipsec * * Revision 1.1.1.1  1998/04/08 05:35:05  henry * RGB's ipsec-0.8pre2.tar.gz ipsec-0.8 * * Revision 0.4  1997/01/15 01:28:15  ji * New transform * * */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线免费av一区| 成人免费看片app下载| 中文字幕亚洲视频| 国产视频亚洲色图| 久久综合久色欧美综合狠狠| 欧美一级在线观看| 欧美一区国产二区| 日韩欧美高清在线| 久久久久99精品国产片| 中文字幕视频一区二区三区久| 国产欧美综合色| 日韩伦理av电影| 一区二区三区精密机械公司| 亚洲一级二级三级| 天天色天天爱天天射综合| 日本午夜一本久久久综合| 青青草国产精品亚洲专区无| 激情综合网天天干| 国产精华液一区二区三区| 成人av免费观看| 在线一区二区三区做爰视频网站| 欧美午夜片在线观看| 日韩一区二区三区av| 国产婷婷色一区二区三区四区| 国产精品女上位| 亚洲在线视频免费观看| 另类的小说在线视频另类成人小视频在线 | 日韩国产一区二| 久久国产精品99精品国产| 国产a精品视频| 在线免费一区三区| 91精品视频网| 久久美女高清视频| 亚洲综合av网| 国产美女精品人人做人人爽| 色综合色综合色综合色综合色综合| 欧美日韩电影一区| 国产精品国模大尺度视频| 午夜电影一区二区| 粉嫩久久99精品久久久久久夜| 欧美综合久久久| 中文字幕欧美区| 日韩av在线免费观看不卡| 99re6这里只有精品视频在线观看| 欧美午夜免费电影| 亚洲成a人在线观看| 国产精品综合在线视频| 欧美日韩欧美一区二区| 国产精品久久久久久久浪潮网站 | 欧美人xxxx| 亚洲欧洲日产国产综合网| 老司机精品视频线观看86| 在线免费观看成人短视频| 国产精品欧美精品| 国产一区二区三区香蕉| 69堂国产成人免费视频| 一二三区精品视频| 成人黄色片在线观看| 久久精品人人做| 捆绑调教一区二区三区| 欧美精品免费视频| 亚洲v中文字幕| 在线观看一区二区视频| 中文字幕免费不卡在线| 国产麻豆午夜三级精品| 日韩免费电影网站| 日本亚洲视频在线| 91精品福利在线一区二区三区| 有码一区二区三区| 欧美性受xxxx黑人xyx性爽| 亚洲视频网在线直播| 99re这里只有精品视频首页| 国产欧美日韩视频一区二区| 国产精品亚洲成人| 国产日韩欧美一区二区三区综合| 国产在线国偷精品免费看| 精品国产乱码91久久久久久网站| 欧美96一区二区免费视频| 91精品久久久久久久99蜜桃| 日本中文字幕不卡| 欧美本精品男人aⅴ天堂| 九九**精品视频免费播放| 久久婷婷久久一区二区三区| 国产一区二区精品久久| 欧美国产激情二区三区 | 亚洲综合清纯丝袜自拍| 在线视频综合导航| 亚洲成a人片在线观看中文| 欧美顶级少妇做爰| 精品在线你懂的| 欧美极品xxx| 91久久线看在观草草青青| 伊人色综合久久天天人手人婷| 欧美艳星brazzers| 蜜臀av亚洲一区中文字幕| 久久久国产午夜精品 | 日韩毛片高清在线播放| 欧美视频一区在线观看| 日韩电影在线免费看| 久久伊人蜜桃av一区二区| 99在线视频精品| 天天色天天操综合| 久久久精品欧美丰满| 色老综合老女人久久久| 激情六月婷婷久久| 国产色综合久久| 欧美亚洲一区二区三区四区| 久久超级碰视频| 一区二区三区在线免费观看| 日韩三级在线免费观看| 97国产一区二区| 久久精品国产免费| 亚洲视频1区2区| 精品国产凹凸成av人导航| 91麻豆免费在线观看| 日韩福利电影在线| 亚洲天堂av老司机| 久久综合视频网| 在线观看91精品国产麻豆| 从欧美一区二区三区| 丝袜a∨在线一区二区三区不卡| 欧美韩国日本综合| 欧美一区二区人人喊爽| 色综合天天综合网天天狠天天| 国产精品一区二区在线看| 亚洲精品视频在线观看免费| 日韩一区二区中文字幕| 色欧美88888久久久久久影院| 国产在线不卡一区| 蜜桃av一区二区| 亚洲一区二区三区影院| 国产精品美女久久久久久久 | 久久久国际精品| 777a∨成人精品桃花网| 色噜噜夜夜夜综合网| 国产风韵犹存在线视精品| 老司机精品视频在线| 五月天激情综合| 亚洲国产日韩a在线播放| 亚洲另类在线视频| 中文字幕+乱码+中文字幕一区| 精品噜噜噜噜久久久久久久久试看 | 欧美精品一区二区三区蜜桃| 欧美日韩在线不卡| 欧美亚洲一区二区在线| 欧洲人成人精品| 在线看日本不卡| 在线免费观看成人短视频| 91在线码无精品| aaa欧美大片| 99麻豆久久久国产精品免费优播| 国产99一区视频免费| 国产精品一区二区男女羞羞无遮挡| 免费人成在线不卡| 久久99精品久久只有精品| 久久精品久久精品| 国产精品一区一区| 夫妻av一区二区| 91视频免费播放| 在线免费精品视频| 88在线观看91蜜桃国自产| 91精品国产欧美一区二区18| 日韩精品一区二区三区四区视频| 91精品国产色综合久久不卡电影 | 日韩美女一区二区三区| 欧美videos中文字幕| 久久综合久久综合久久综合| 久久久久免费观看| 中文字幕在线观看不卡| 亚洲综合丁香婷婷六月香| 日韩黄色在线观看| 国产一区二区三区在线观看精品 | 日本久久一区二区三区| 欧美日韩五月天| 欧美tickling挠脚心丨vk| 久久综合九色欧美综合狠狠| 国产精品欧美久久久久一区二区| 亚洲男人的天堂在线观看| 午夜a成v人精品| 国产传媒日韩欧美成人| 色综合中文字幕| 欧美成人免费网站| 国产精品欧美经典| 亚洲va欧美va国产va天堂影院| 美国欧美日韩国产在线播放| 高清beeg欧美| 在线观看91视频| 国产丝袜美腿一区二区三区| 亚洲女厕所小便bbb| 极品少妇xxxx精品少妇| 91成人看片片| 欧美精品一区二区三区蜜臀| 一区二区三区资源| 久草精品在线观看| 欧美性生活影院| 日本一区二区三区国色天香| 亚洲18色成人| 91麻豆精东视频| 久久久精品天堂| 美腿丝袜亚洲色图|