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

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

?? aeskey.c

?? 一個(gè)用vc編寫的aes算法實(shí)現(xiàn)
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*
 ---------------------------------------------------------------------------
 Copyright (c) 1998-2006, Brian Gladman, Worcester, UK. All rights reserved.

 LICENSE TERMS

 The free distribution and use of this software in both source and binary
 form is allowed (with or without changes) provided that:

   1. distributions of this source code include the above copyright
      notice, this list of conditions and the following disclaimer;

   2. distributions in binary form include the above copyright
      notice, this list of conditions and the following disclaimer
      in the documentation and/or other associated materials;

   3. the copyright holder's name is not used to endorse products
      built using this software without specific written permission.

 ALTERNATIVELY, provided that this notice is retained in full, this product
 may be distributed under the terms of the GNU General Public License (GPL),
 in which case the provisions of the GPL apply INSTEAD OF those given above.

 DISCLAIMER

 This software is provided 'as is' with no explicit or implied warranties
 in respect of its properties, including, but not limited to, correctness
 and/or fitness for purpose.
 ---------------------------------------------------------------------------
 Issue 09/09/2006
*/

#include "aesopt.h"
#include "aestab.h"

#ifdef USE_VIA_ACE_IF_PRESENT
#  include "aes_via_ace.h"
#endif

#if defined(__cplusplus)
extern "C"
{
#endif

/* Initialise the key schedule from the user supplied key. The key
   length can be specified in bytes, with legal values of 16, 24
   and 32, or in bits, with legal values of 128, 192 and 256. These
   values correspond with Nk values of 4, 6 and 8 respectively.

   The following macros implement a single cycle in the key
   schedule generation process. The number of cycles needed
   for each cx->n_col and nk value is:

    nk =             4  5  6  7  8
    ------------------------------
    cx->n_col = 4   10  9  8  7  7
    cx->n_col = 5   14 11 10  9  9
    cx->n_col = 6   19 15 12 11 11
    cx->n_col = 7   21 19 16 13 14
    cx->n_col = 8   29 23 19 17 14
*/

#if (FUNCS_IN_C & ENC_KEYING_IN_C)

#if defined(AES_128) || defined(AES_VAR)

#define ke4(k,i) \
{   k[4*(i)+4] = ss[0] ^= ls_box(ss[3],3) ^ t_use(r,c)[i]; \
    k[4*(i)+5] = ss[1] ^= ss[0]; \
    k[4*(i)+6] = ss[2] ^= ss[1]; \
    k[4*(i)+7] = ss[3] ^= ss[2]; \
}

AES_RETURN aes_encrypt_key128(const unsigned char *key, aes_encrypt_ctx cx[1])
{   uint_32t    ss[4];

    cx->ks[0] = ss[0] = word_in(key, 0);
    cx->ks[1] = ss[1] = word_in(key, 1);
    cx->ks[2] = ss[2] = word_in(key, 2);
    cx->ks[3] = ss[3] = word_in(key, 3);

#if ENC_UNROLL == NONE
    {   uint_32t i;
        for(i = 0; i < 9; ++i)
            ke4(cx->ks, i);
    }
#else
    ke4(cx->ks, 0);  ke4(cx->ks, 1);
    ke4(cx->ks, 2);  ke4(cx->ks, 3);
    ke4(cx->ks, 4);  ke4(cx->ks, 5);
    ke4(cx->ks, 6);  ke4(cx->ks, 7);
    ke4(cx->ks, 8);
#endif
    ke4(cx->ks, 9);
    cx->inf.l = 0;
    cx->inf.b[0] = 10 * 16;

#ifdef USE_VIA_ACE_IF_PRESENT
    if(VIA_ACE_AVAILABLE)
        cx->inf.b[1] = 0xff;
#endif

#if defined( AES_ERR_CHK )
    return EXIT_SUCCESS;
#endif
}

#endif

#if defined(AES_192) || defined(AES_VAR)

#define kef6(k,i) \
{   k[6*(i)+ 6] = ss[0] ^= ls_box(ss[5],3) ^ t_use(r,c)[i]; \
    k[6*(i)+ 7] = ss[1] ^= ss[0]; \
    k[6*(i)+ 8] = ss[2] ^= ss[1]; \
    k[6*(i)+ 9] = ss[3] ^= ss[2]; \
}

#define ke6(k,i) \
{   kef6(k,i); \
    k[6*(i)+10] = ss[4] ^= ss[3]; \
    k[6*(i)+11] = ss[5] ^= ss[4]; \
}

AES_RETURN aes_encrypt_key192(const unsigned char *key, aes_encrypt_ctx cx[1])
{   uint_32t    ss[6];

    cx->ks[0] = ss[0] = word_in(key, 0);
    cx->ks[1] = ss[1] = word_in(key, 1);
    cx->ks[2] = ss[2] = word_in(key, 2);
    cx->ks[3] = ss[3] = word_in(key, 3);
    cx->ks[4] = ss[4] = word_in(key, 4);
    cx->ks[5] = ss[5] = word_in(key, 5);

#if ENC_UNROLL == NONE
    {   uint_32t i;
        for(i = 0; i < 7; ++i)
            ke6(cx->ks, i);
    }
#else
    ke6(cx->ks, 0);  ke6(cx->ks, 1);
    ke6(cx->ks, 2);  ke6(cx->ks, 3);
    ke6(cx->ks, 4);  ke6(cx->ks, 5);
    ke6(cx->ks, 6);
#endif
    kef6(cx->ks, 7);
    cx->inf.l = 0;
    cx->inf.b[0] = 12 * 16;

#ifdef USE_VIA_ACE_IF_PRESENT
    if(VIA_ACE_AVAILABLE)
        cx->inf.b[1] = 0xff;
#endif

#if defined( AES_ERR_CHK )
    return EXIT_SUCCESS;
#endif
}

#endif

#if defined(AES_256) || defined(AES_VAR)

#define kef8(k,i) \
{   k[8*(i)+ 8] = ss[0] ^= ls_box(ss[7],3) ^ t_use(r,c)[i]; \
    k[8*(i)+ 9] = ss[1] ^= ss[0]; \
    k[8*(i)+10] = ss[2] ^= ss[1]; \
    k[8*(i)+11] = ss[3] ^= ss[2]; \
}

#define ke8(k,i) \
{   kef8(k,i); \
    k[8*(i)+12] = ss[4] ^= ls_box(ss[3],0); \
    k[8*(i)+13] = ss[5] ^= ss[4]; \
    k[8*(i)+14] = ss[6] ^= ss[5]; \
    k[8*(i)+15] = ss[7] ^= ss[6]; \
}

AES_RETURN aes_encrypt_key256(const unsigned char *key, aes_encrypt_ctx cx[1])
{   uint_32t    ss[8];

    cx->ks[0] = ss[0] = word_in(key, 0);
    cx->ks[1] = ss[1] = word_in(key, 1);
    cx->ks[2] = ss[2] = word_in(key, 2);
    cx->ks[3] = ss[3] = word_in(key, 3);
    cx->ks[4] = ss[4] = word_in(key, 4);
    cx->ks[5] = ss[5] = word_in(key, 5);
    cx->ks[6] = ss[6] = word_in(key, 6);
    cx->ks[7] = ss[7] = word_in(key, 7);

#if ENC_UNROLL == NONE
    {   uint_32t i;
        for(i = 0; i < 6; ++i)
            ke8(cx->ks,  i);
    }
#else
    ke8(cx->ks, 0); ke8(cx->ks, 1);
    ke8(cx->ks, 2); ke8(cx->ks, 3);
    ke8(cx->ks, 4); ke8(cx->ks, 5);
#endif
    kef8(cx->ks, 6);
    cx->inf.l = 0;
    cx->inf.b[0] = 14 * 16;

#ifdef USE_VIA_ACE_IF_PRESENT
    if(VIA_ACE_AVAILABLE)
        cx->inf.b[1] = 0xff;
#endif

#if defined( AES_ERR_CHK )
    return EXIT_SUCCESS;
#endif
}

#endif

#if defined(AES_VAR)

AES_RETURN aes_encrypt_key(const unsigned char *key, int key_len, aes_encrypt_ctx cx[1])
{
    switch(key_len)
    {
#if defined( AES_ERR_CHK )
    case 16: case 128: return aes_encrypt_key128(key, cx);
    case 24: case 192: return aes_encrypt_key192(key, cx);
    case 32: case 256: return aes_encrypt_key256(key, cx);
    default: return EXIT_FAILURE;
#else
    case 16: case 128: aes_encrypt_key128(key, cx); return;
    case 24: case 192: aes_encrypt_key192(key, cx); return;
    case 32: case 256: aes_encrypt_key256(key, cx); return;
#endif
    }
}

#endif

#endif

#if (FUNCS_IN_C & DEC_KEYING_IN_C)

/* this is used to store the decryption round keys  */
/* in forward or reverse order                      */

#ifdef AES_REV_DKS
#define v(n,i)  ((n) - (i) + 2 * ((i) & 3))
#else
#define v(n,i)  (i)
#endif

#if DEC_ROUND == NO_TABLES
#define ff(x)   (x)
#else
#define ff(x)   inv_mcol(x)
#if defined( dec_imvars )
#define d_vars  dec_imvars
#endif
#endif

#if defined(AES_128) || defined(AES_VAR)

#define k4e(k,i) \
{   k[v(40,(4*(i))+4)] = ss[0] ^= ls_box(ss[3],3) ^ t_use(r,c)[i]; \
    k[v(40,(4*(i))+5)] = ss[1] ^= ss[0]; \
    k[v(40,(4*(i))+6)] = ss[2] ^= ss[1]; \
    k[v(40,(4*(i))+7)] = ss[3] ^= ss[2]; \
}

#if 1

#define kdf4(k,i) \
{   ss[0] = ss[0] ^ ss[2] ^ ss[1] ^ ss[3]; \
    ss[1] = ss[1] ^ ss[3]; \
    ss[2] = ss[2] ^ ss[3]; \
    ss[4] = ls_box(ss[(i+3) % 4], 3) ^ t_use(r,c)[i]; \
    ss[i % 4] ^= ss[4]; \
    ss[4] ^= k[v(40,(4*(i)))];   k[v(40,(4*(i))+4)] = ff(ss[4]); \
    ss[4] ^= k[v(40,(4*(i))+1)]; k[v(40,(4*(i))+5)] = ff(ss[4]); \
    ss[4] ^= k[v(40,(4*(i))+2)]; k[v(40,(4*(i))+6)] = ff(ss[4]); \
    ss[4] ^= k[v(40,(4*(i))+3)]; k[v(40,(4*(i))+7)] = ff(ss[4]); \
}

#define kd4(k,i) \
{   ss[4] = ls_box(ss[(i+3) % 4], 3) ^ t_use(r,c)[i]; \
    ss[i % 4] ^= ss[4]; ss[4] = ff(ss[4]); \
    k[v(40,(4*(i))+4)] = ss[4] ^= k[v(40,(4*(i)))]; \
    k[v(40,(4*(i))+5)] = ss[4] ^= k[v(40,(4*(i))+1)]; \
    k[v(40,(4*(i))+6)] = ss[4] ^= k[v(40,(4*(i))+2)]; \
    k[v(40,(4*(i))+7)] = ss[4] ^= k[v(40,(4*(i))+3)]; \
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲3atv精品一区二区三区| 久久久99免费| va亚洲va日韩不卡在线观看| 黄色日韩三级电影| 琪琪久久久久日韩精品| 青青草精品视频| 久久精品国内一区二区三区| 麻豆久久久久久久| 韩国欧美国产一区| 国产成人综合精品三级| 成人国产免费视频| 成人精品免费网站| 91蜜桃在线免费视频| 色综合婷婷久久| 欧美日韩一本到| 欧美视频一区二区三区四区| 欧美日韩免费高清一区色橹橹| 在线观看欧美精品| 91精品国产免费| 久久色在线视频| 亚洲日本在线观看| 五月激情综合婷婷| 激情六月婷婷综合| 99精品偷自拍| 欧美日韩一区二区三区不卡| 欧美刺激午夜性久久久久久久| 久久久精品天堂| 亚洲人午夜精品天堂一二香蕉| 亚洲成人久久影院| 激情欧美一区二区| 欧美综合久久久| xnxx国产精品| 亚洲视频一二三区| 三级久久三级久久久| 国产一区999| 在线视频综合导航| 精品国一区二区三区| 亚洲丝袜制服诱惑| 久久精品噜噜噜成人88aⅴ| bt欧美亚洲午夜电影天堂| 欧美喷潮久久久xxxxx| 国产欧美精品在线观看| 亚洲香肠在线观看| 国产精品66部| 日韩无一区二区| 亚洲宅男天堂在线观看无病毒| 天天综合色天天综合色h| 国产资源在线一区| 欧美日韩精品一区二区三区| 国产精品国产三级国产aⅴ原创 | 久久国产综合精品| 99re这里只有精品首页| 精品电影一区二区| 天天亚洲美女在线视频| 99精品国产视频| 久久久亚洲精品一区二区三区| 三级久久三级久久| 日本韩国一区二区三区视频| 国产亚洲欧美日韩俺去了| 天天色天天操综合| 在线观看日韩一区| 亚洲黄色小视频| av在线这里只有精品| 久久精品亚洲乱码伦伦中文| 美女在线视频一区| 91精品国产高清一区二区三区蜜臀| 国产精品久久福利| 粉嫩一区二区三区性色av| 久久综合999| 精品一区二区三区免费观看| 欧美一二三区精品| 麻豆精品在线播放| 日韩小视频在线观看专区| 偷拍与自拍一区| 91超碰这里只有精品国产| 亚洲一区视频在线观看视频| 色国产精品一区在线观看| 亚洲天天做日日做天天谢日日欢| av成人免费在线| 18欧美亚洲精品| 在线观看日韩高清av| 亚洲在线视频网站| 欧美美女直播网站| 欧美a级一区二区| 日韩精品专区在线影院观看| 国产在线精品一区二区夜色| 久久久久久久综合色一本| 国产精品自拍网站| 亚洲人成人一区二区在线观看| av高清久久久| 亚洲电影第三页| 欧美一级免费观看| 激情亚洲综合在线| 国产精品久久久久久久久果冻传媒 | 麻豆成人综合网| 337p粉嫩大胆噜噜噜噜噜91av| 国产盗摄精品一区二区三区在线| 国产欧美视频一区二区三区| 91亚洲国产成人精品一区二区三 | 午夜一区二区三区视频| 欧美日韩精品欧美日韩精品| 麻豆国产精品一区二区三区 | 在线视频一区二区三| 日韩精品1区2区3区| 久久女同性恋中文字幕| 色综合久久中文字幕| 水蜜桃久久夜色精品一区的特点| 精品久久久网站| 成人夜色视频网站在线观看| 一区二区三区不卡在线观看| 日韩一区二区三区免费看| 国产91精品露脸国语对白| 亚洲精品大片www| 日韩精品一区二区三区四区视频| 成人av网址在线| 青青国产91久久久久久 | 色国产综合视频| 蜜桃一区二区三区四区| 中文字幕一区二区视频| 日韩欧美亚洲另类制服综合在线| 97精品国产露脸对白| 捆绑调教美女网站视频一区| 亚洲欧美日韩国产另类专区| 欧美变态口味重另类| 欧美亚洲日本国产| 99国产精品国产精品久久| 卡一卡二国产精品| 日韩激情视频在线观看| ●精品国产综合乱码久久久久| 日韩女同互慰一区二区| 欧美三级在线视频| av资源网一区| 国产盗摄女厕一区二区三区| 日韩电影网1区2区| 依依成人综合视频| 亚洲欧洲另类国产综合| 久久这里都是精品| 精品国产一区二区三区久久久蜜月 | 欧美男女性生活在线直播观看 | 亚洲国产一区视频| 国产精品无遮挡| 久久久噜噜噜久久中文字幕色伊伊 | 91麻豆精东视频| 成人性生交大片免费看中文| 久久国产综合精品| 久久99精品久久久久久国产越南 | 欧美电影免费观看高清完整版在线观看 | 亚洲欧美一区二区不卡| 欧美高清一级片在线观看| 久久久久亚洲综合| 久久久欧美精品sm网站| 久久蜜桃av一区精品变态类天堂| 日韩欧美三级在线| 欧美成人bangbros| 欧美成人综合网站| 欧美tk丨vk视频| 精品国产免费久久| 久久综合九色综合97婷婷| 2020国产精品自拍| 欧美国产精品劲爆| 中文字幕一区二区三区四区| 国产精品传媒视频| 亚洲精品国产精品乱码不99| 一区二区三区四区五区视频在线观看 | 色一区在线观看| 欧美视频自拍偷拍| 日韩一二在线观看| 久久久久9999亚洲精品| 亚洲国产精品激情在线观看| 亚洲女性喷水在线观看一区| 亚洲成a人片综合在线| 免费观看一级欧美片| 韩国成人精品a∨在线观看| 国产成人精品亚洲日本在线桃色| 成人美女视频在线看| 91国偷自产一区二区使用方法| 在线不卡a资源高清| 久久综合精品国产一区二区三区 | 亚洲午夜久久久久久久久电影院| 亚洲成人自拍偷拍| 精品一区二区三区免费视频| av一区二区三区| 欧美妇女性影城| 欧美激情综合五月色丁香| 亚洲男人都懂的| 九九视频精品免费| 色88888久久久久久影院按摩| 日韩免费高清电影| 亚洲黄色尤物视频| 国模少妇一区二区三区| 色中色一区二区| 欧美成人vr18sexvr| 亚洲综合在线视频| 成人一区二区三区中文字幕| 91精品欧美一区二区三区综合在| 国产欧美综合在线观看第十页| 亚洲国产另类av| 国产高清不卡一区| 日韩一区二区三区观看| 亚洲免费av高清|