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

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

?? twofish.c

?? 最新版本的加密解密算法庫
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* LibTomCrypt, modular cryptographic library -- Tom St Denis * * LibTomCrypt is a library that provides various cryptographic * algorithms in a highly modular and flexible manner. * * The library is free for all purposes without any express * guarantee it works. * * Tom St Denis, tomstdenis@iahu.ca, http://libtomcrypt.org *//* Implementation of Twofish by Tom St Denis */#include "mycrypt.h"#ifdef TWOFISH/* first TWOFISH_ALL_TABLES must ensure TWOFISH_TABLES is defined */#ifdef TWOFISH_ALL_TABLES#ifndef TWOFISH_TABLES#define TWOFISH_TABLES#endif#endifconst struct _cipher_descriptor twofish_desc ={    "twofish",    7,    16, 32, 16, 16,    &twofish_setup,    &twofish_ecb_encrypt,    &twofish_ecb_decrypt,    &twofish_test,    &twofish_keysize};/* the two polynomials */#define MDS_POLY          0x169#define RS_POLY           0x14D/* The 4x4 MDS Linear Transform */static const unsigned char MDS[4][4] = {    { 0x01, 0xEF, 0x5B, 0x5B },    { 0x5B, 0xEF, 0xEF, 0x01 },    { 0xEF, 0x5B, 0x01, 0xEF },    { 0xEF, 0x01, 0xEF, 0x5B }};/* The 4x8 RS Linear Transform */static const unsigned char RS[4][8] = {    { 0x01, 0xA4, 0x55, 0x87, 0x5A, 0x58, 0xDB, 0x9E },    { 0xA4, 0x56, 0x82, 0xF3, 0X1E, 0XC6, 0X68, 0XE5 },    { 0X02, 0XA1, 0XFC, 0XC1, 0X47, 0XAE, 0X3D, 0X19 },    { 0XA4, 0X55, 0X87, 0X5A, 0X58, 0XDB, 0X9E, 0X03 }};/* sbox usage orderings */static const unsigned char qord[4][5] = {   { 1, 1, 0, 0, 1 },   { 0, 1, 1, 0, 0 },   { 0, 0, 0, 1, 1 },   { 1, 0, 1, 1, 0 }};#ifdef TWOFISH_TABLES#include "twofish_tab.c"#define sbox(i, x) ((ulong32)SBOX[i][(x)&255])#else/* The Q-box tables */static const unsigned char qbox[2][4][16] = {{   { 0x8, 0x1, 0x7, 0xD, 0x6, 0xF, 0x3, 0x2, 0x0, 0xB, 0x5, 0x9, 0xE, 0xC, 0xA, 0x4 },   { 0xE, 0XC, 0XB, 0X8, 0X1, 0X2, 0X3, 0X5, 0XF, 0X4, 0XA, 0X6, 0X7, 0X0, 0X9, 0XD },   { 0XB, 0XA, 0X5, 0XE, 0X6, 0XD, 0X9, 0X0, 0XC, 0X8, 0XF, 0X3, 0X2, 0X4, 0X7, 0X1 },   { 0XD, 0X7, 0XF, 0X4, 0X1, 0X2, 0X6, 0XE, 0X9, 0XB, 0X3, 0X0, 0X8, 0X5, 0XC, 0XA }},{   { 0X2, 0X8, 0XB, 0XD, 0XF, 0X7, 0X6, 0XE, 0X3, 0X1, 0X9, 0X4, 0X0, 0XA, 0XC, 0X5 },   { 0X1, 0XE, 0X2, 0XB, 0X4, 0XC, 0X3, 0X7, 0X6, 0XD, 0XA, 0X5, 0XF, 0X9, 0X0, 0X8 },   { 0X4, 0XC, 0X7, 0X5, 0X1, 0X6, 0X9, 0XA, 0X0, 0XE, 0XD, 0X8, 0X2, 0XB, 0X3, 0XF },   { 0xB, 0X9, 0X5, 0X1, 0XC, 0X3, 0XD, 0XE, 0X6, 0X4, 0X7, 0XF, 0X2, 0X0, 0X8, 0XA }}};/* computes S_i[x] */#ifdef CLEAN_STACKstatic ulong32 _sbox(int i, ulong32 x)#elsestatic ulong32 sbox(int i, ulong32 x)#endif{   unsigned char a0,b0,a1,b1,a2,b2,a3,b3,a4,b4,y;   /* a0,b0 = [x/16], x mod 16 */   a0 = (unsigned char)((x>>4)&15);   b0 = (unsigned char)((x)&15);   /* a1 = a0 ^ b0 */   a1 = a0 ^ b0;   /* b1 = a0 ^ ROR(b0, 1) ^ 8a0 */   b1 = (a0 ^ ((b0<<3)|(b0>>1)) ^ (a0<<3)) & 15;   /* a2,b2 = t0[a1], t1[b1] */   a2 = qbox[i][0][(int)a1];   b2 = qbox[i][1][(int)b1];   /* a3 = a2 ^ b2 */   a3 = a2 ^ b2;   /* b3 = a2 ^ ROR(b2, 1) ^ 8a2 */   b3 = (a2 ^ ((b2<<3)|(b2>>1)) ^ (a2<<3)) & 15;   /* a4,b4 = t2[a3], t3[b3] */   a4 = qbox[i][2][(int)a3];   b4 = qbox[i][3][(int)b3];   /* y = 16b4 + a4 */   y = (b4 << 4) + a4;   /* return result */   return (ulong32)y;}#ifdef CLEAN_STACKstatic ulong32 sbox(int i, ulong32 x){   ulong32 y;   y = _sbox(i, x);   burn_stack(sizeof(unsigned char) * 11);   return y;}#endif /* CLEAN_STACK */#endif /* TWOFISH_TABLES *//* computes ab mod p */static ulong32 gf_mult(ulong32 a, ulong32 b, ulong32 p){   ulong32 result, B[2], P[2];   P[1] = p;   B[1] = b;   result = P[0] = B[0] = 0;   /* unrolled branchless GF multiplier */   result ^= B[a&1]; a >>= 1;  B[1] = P[B[1]>>7] ^ (B[1] << 1);    result ^= B[a&1]; a >>= 1;  B[1] = P[B[1]>>7] ^ (B[1] << 1);    result ^= B[a&1]; a >>= 1;  B[1] = P[B[1]>>7] ^ (B[1] << 1);    result ^= B[a&1]; a >>= 1;  B[1] = P[B[1]>>7] ^ (B[1] << 1);    result ^= B[a&1]; a >>= 1;  B[1] = P[B[1]>>7] ^ (B[1] << 1);    result ^= B[a&1]; a >>= 1;  B[1] = P[B[1]>>7] ^ (B[1] << 1);    result ^= B[a&1]; a >>= 1;  B[1] = P[B[1]>>7] ^ (B[1] << 1);    result ^= B[a&1];    return result;}/* computes [y0 y1 y2 y3] = MDS . [x0] */#ifndef TWOFISH_TABLESstatic ulong32 mds_column_mult(unsigned char in, int col){   ulong32 x01, x5B, xEF;   x01 = in;   x5B = gf_mult(in, 0x5B, MDS_POLY);   xEF = gf_mult(in, 0xEF, MDS_POLY);   switch (col) {       case 0:          return (x01 << 0 ) |                 (x5B << 8 ) |                 (xEF << 16) |                 (xEF << 24);       case 1:          return (xEF << 0 ) |                 (xEF << 8 ) |                 (x5B << 16) |                 (x01 << 24);       case 2:          return (x5B << 0 ) |                 (xEF << 8 ) |                 (x01 << 16) |                 (xEF << 24);       case 3:          return (x5B << 0 ) |                 (x01 << 8 ) |                 (xEF << 16) |                 (x5B << 24);   }   /* avoid warnings, we'd never get here normally but just to calm compiler warnings... */   return 0;}#else /* !TWOFISH_TABLES */#define mds_column_mult(x, i) mds_tab[i][x]#endif /* TWOFISH_TABLES *//* Computes [y0 y1 y2 y3] = MDS . [x0 x1 x2 x3] */static void mds_mult(const unsigned char *in, unsigned char *out){  int x;  ulong32 tmp;  for (tmp = x = 0; x < 4; x++) {      tmp ^= mds_column_mult(in[x], x);  }  STORE32L(tmp, out);}#ifdef TWOFISH_ALL_TABLES/* computes [y0 y1 y2 y3] = RS . [x0 x1 x2 x3 x4 x5 x6 x7] */static void rs_mult(const unsigned char *in, unsigned char *out){   ulong32 tmp;   tmp = rs_tab0[in[0]] ^ rs_tab1[in[1]] ^ rs_tab2[in[2]] ^ rs_tab3[in[3]] ^         rs_tab4[in[4]] ^ rs_tab5[in[5]] ^ rs_tab6[in[6]] ^ rs_tab7[in[7]];   STORE32L(tmp, out);}#else /* !TWOFISH_ALL_TABLES *//* computes [y0 y1 y2 y3] = RS . [x0 x1 x2 x3 x4 x5 x6 x7] */static void rs_mult(const unsigned char *in, unsigned char *out){  int x, y;  for (x = 0; x < 4; x++) {      out[x] = 0;      for (y = 0; y < 8; y++) {          out[x] ^= gf_mult(in[y], RS[x][y], RS_POLY);      }  }}#endif/* computes h(x) */static void h_func(const unsigned char *in, unsigned char *out, unsigned char *M, int k, int offset){  int x;  unsigned char y[4];  for (x = 0; x < 4; x++) {      y[x] = in[x]; }  switch (k) {     case 4:            y[0] = (unsigned char)(sbox(1, (ulong32)y[0]) ^ M[4 * (6 + offset) + 0]);            y[1] = (unsigned char)(sbox(0, (ulong32)y[1]) ^ M[4 * (6 + offset) + 1]);            y[2] = (unsigned char)(sbox(0, (ulong32)y[2]) ^ M[4 * (6 + offset) + 2]);            y[3] = (unsigned char)(sbox(1, (ulong32)y[3]) ^ M[4 * (6 + offset) + 3]);     case 3:            y[0] = (unsigned char)(sbox(1, (ulong32)y[0]) ^ M[4 * (4 + offset) + 0]);            y[1] = (unsigned char)(sbox(1, (ulong32)y[1]) ^ M[4 * (4 + offset) + 1]);            y[2] = (unsigned char)(sbox(0, (ulong32)y[2]) ^ M[4 * (4 + offset) + 2]);            y[3] = (unsigned char)(sbox(0, (ulong32)y[3]) ^ M[4 * (4 + offset) + 3]);     case 2:            y[0] = (unsigned char)(sbox(1, sbox(0, sbox(0, (ulong32)y[0]) ^ M[4 * (2 + offset) + 0]) ^ M[4 * (0 + offset) + 0]));            y[1] = (unsigned char)(sbox(0, sbox(0, sbox(1, (ulong32)y[1]) ^ M[4 * (2 + offset) + 1]) ^ M[4 * (0 + offset) + 1]));            y[2] = (unsigned char)(sbox(1, sbox(1, sbox(0, (ulong32)y[2]) ^ M[4 * (2 + offset) + 2]) ^ M[4 * (0 + offset) + 2]));            y[3] = (unsigned char)(sbox(0, sbox(1, sbox(1, (ulong32)y[3]) ^ M[4 * (2 + offset) + 3]) ^ M[4 * (0 + offset) + 3]));  }  mds_mult(y, out);}#ifndef TWOFISH_SMALL/* for GCC we don't use pointer aliases */#if defined(__GNUC__)    #define S1 key->twofish.S[0]    #define S2 key->twofish.S[1]    #define S3 key->twofish.S[2]    #define S4 key->twofish.S[3]#endif/* the G function */#define g_func(x, dum)  (S1[byte(x,0)] ^ S2[byte(x,1)] ^ S3[byte(x,2)] ^ S4[byte(x,3)])#define g1_func(x, dum) (S2[byte(x,0)] ^ S3[byte(x,1)] ^ S4[byte(x,2)] ^ S1[byte(x,3)])#else#ifdef CLEAN_STACKstatic ulong32 _g_func(ulong32 x, symmetric_key *key)#elsestatic ulong32 g_func(ulong32 x, symmetric_key *key)#endif{   unsigned char g, i, y, z;   ulong32 res;   res = 0;   for (y = 0; y < 4; y++) {       z = key->twofish.start;       /* do unkeyed substitution */       g = sbox(qord[y][z++], (x >> (8*y)) & 255);       /* first subkey */       i = 0;       /* do key mixing+sbox until z==5 */       while (z != 5) {          g = g ^ key->twofish.S[4*i++ + y];          g = sbox(qord[y][z++], g);       }       /* multiply g by a column of the MDS */       res ^= mds_column_mult(g, y);   }   return res;}#define g1_func(x, key) g_func(ROL(x, 8), key)#ifdef CLEAN_STACKstatic ulong32 g_func(ulong32 x, symmetric_key *key){    ulong32 y;    y = _g_func(x, key);    burn_stack(sizeof(unsigned char) * 4 + sizeof(ulong32));    return y;}#endif /* CLEAN_STACK */#endif /* TWOFISH_SMALL */#ifdef CLEAN_STACKstatic int _twofish_setup(const unsigned char *key, int keylen, int num_rounds, symmetric_key *skey)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美专区在线观看一区| 日本一区二区视频在线| 欧美激情一区二区在线| 亚洲一区二区三区视频在线| 国产九色精品成人porny| 欧美日韩在线一区二区| 中文av一区二区| 久久精品国产成人一区二区三区| 不卡欧美aaaaa| 久久久亚洲国产美女国产盗摄 | 蜜桃一区二区三区四区| www.视频一区| 欧美激情一区二区三区蜜桃视频| 青草国产精品久久久久久| 欧美亚洲另类激情小说| 亚洲天堂成人在线观看| 成人免费视频caoporn| 欧美大黄免费观看| 免费成人在线网站| 91精品国产综合久久久久久漫画 | 日韩欧美高清dvd碟片| 亚洲福利视频导航| 欧美日韩性生活| 亚洲午夜免费福利视频| 在线视频你懂得一区二区三区| 国产精品免费丝袜| 成人精品国产免费网站| 国产视频一区在线播放| 国产一区视频导航| 国产欧美日韩另类视频免费观看| 国产精品自拍网站| 久久综合色婷婷| 国产成人精品免费一区二区| 久久久99精品久久| 丰满放荡岳乱妇91ww| 中文字幕一区日韩精品欧美| 91在线国内视频| 亚洲精品成人少妇| 欧美午夜不卡视频| 日本三级亚洲精品| 精品国产一区二区国模嫣然| 国产麻豆一精品一av一免费 | 成人国产精品免费观看视频| 亚洲国产成人私人影院tom| 99久久精品免费看国产 | 中文文精品字幕一区二区| 成人午夜激情片| 亚洲尤物视频在线| 欧美一区二区精品在线| 捆绑变态av一区二区三区| 久久综合九色综合欧美就去吻| 国产精品一区在线| 亚洲视频综合在线| 欧美老年两性高潮| 国产一区美女在线| 亚洲人成精品久久久久久| 777久久久精品| 国产成人欧美日韩在线电影| 亚洲手机成人高清视频| 欧美日韩一区视频| 国产寡妇亲子伦一区二区| 一区二区三区四区高清精品免费观看| 欧美性猛交xxxxxxxx| 久久精品国产99国产精品| 国产欧美久久久精品影院| 欧洲av一区二区嗯嗯嗯啊| 蜜臂av日日欢夜夜爽一区| 日韩一区欧美一区| 日韩精品一区二区三区中文精品| 国产精品影视在线观看| 亚洲大片在线观看| 国产精品人妖ts系列视频| 欧美丰满少妇xxxxx高潮对白| 国产高清亚洲一区| 午夜av一区二区| 国产精品黄色在线观看| 欧美一级生活片| 日本道色综合久久| 国产精品一区二区x88av| 日韩高清在线电影| 18欧美亚洲精品| 精品乱人伦小说| 欧美视频日韩视频在线观看| www.av精品| 韩国毛片一区二区三区| 亚洲精品国产视频| 国产女人aaa级久久久级 | 另类小说综合欧美亚洲| 亚洲人成网站精品片在线观看| 精品1区2区在线观看| 欧美精品一二三四| 色哟哟欧美精品| 国产suv精品一区二区883| 蜜臀av性久久久久蜜臀aⅴ | 亚洲精品v日韩精品| www国产精品av| 91精品国产综合久久久久久漫画| 色综合久久久久综合体 | 国产精品一区二区你懂的| 午夜电影久久久| 偷拍自拍另类欧美| 亚洲一区二区av在线| 伊人一区二区三区| 亚洲欧美日韩系列| 亚洲婷婷综合色高清在线| 国产清纯在线一区二区www| 久久婷婷国产综合国色天香| 日韩欧美国产一区二区三区| 91精品国产综合久久久久久漫画| 欧美在线看片a免费观看| 91国产视频在线观看| 不卡视频一二三四| 99久久精品久久久久久清纯| 97se亚洲国产综合在线| 色综合久久久久综合体| 色综合 综合色| 欧美手机在线视频| 欧美精品vⅰdeose4hd| 91麻豆精品国产91久久久使用方法| 欧美亚洲自拍偷拍| 欧美日本韩国一区二区三区视频| 欧美无人高清视频在线观看| 欧美夫妻性生活| 精品国产伦一区二区三区观看方式| 精品美女在线观看| 亚洲国产高清aⅴ视频| 综合激情成人伊人| 亚洲成人一区二区在线观看| 麻豆精品一区二区综合av| 国产一区二区三区日韩| 白白色亚洲国产精品| 色婷婷av一区二区三区之一色屋| 欧美这里有精品| 日韩视频免费观看高清在线视频| 久久午夜羞羞影院免费观看| 国产精品网站在线播放| 亚洲精品乱码久久久久久黑人| 午夜久久福利影院| 韩国理伦片一区二区三区在线播放| 国产成人av影院| 欧美日韩在线电影| 精品对白一区国产伦| 亚洲色图在线视频| 婷婷激情综合网| 国产高清不卡二三区| 色综合久久中文综合久久97| 欧美一级在线免费| 18成人在线观看| 日本sm残虐另类| 91伊人久久大香线蕉| 日韩女优视频免费观看| 日韩毛片一二三区| 男男视频亚洲欧美| 色综合天天天天做夜夜夜夜做| 欧美高清视频一二三区| 亚洲欧洲av另类| 韩国v欧美v日本v亚洲v| 日本电影欧美片| 国产日韩一级二级三级| 天堂久久一区二区三区| 99视频热这里只有精品免费| 欧美一区二区三区啪啪| 亚洲欧美一区二区三区国产精品 | 欧美日韩综合色| 久久精品视频一区二区三区| 亚洲国产精品一区二区久久| 风间由美中文字幕在线看视频国产欧美 | 在线免费视频一区二区| wwwwww.欧美系列| 亚洲成人免费看| 99精品黄色片免费大全| 久久亚区不卡日本| 久久激情五月激情| 欧美老肥妇做.爰bbww视频| 综合久久久久综合| 国产精品一区二区x88av| 欧美成人一区二区| 天堂午夜影视日韩欧美一区二区| 色呦呦国产精品| 中文字幕在线观看不卡视频| 国产精品一二三在| 26uuu亚洲综合色欧美| 青青草伊人久久| 666欧美在线视频| 五月天激情小说综合| 欧美亚洲日本一区| 一级日本不卡的影视| 色综合欧美在线视频区| 亚洲私人黄色宅男| 成人午夜在线播放| 国产丝袜欧美中文另类| 国产乱码精品1区2区3区| 日韩欧美中文一区| 蜜桃一区二区三区在线观看| 欧美一级理论性理论a| 麻豆国产91在线播放| 精品国产一区二区三区不卡 | 九一九一国产精品| 日韩一区二区电影在线| 久久国内精品自在自线400部|