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

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

?? des.c

?? Keil uVision2
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*--------------------------------------------------------------------------------
DES.C: DES Algorithm Program from the Book Applied Cryptography, Bruce Schneier
--------------------------------------------------------------------------------*/

#define EN0   0      /* MODE == encrypt */
#define DE1   1      /* MODE == decrypt */

#include <stdio.h>
#include <reg51.h>

typedef struct {
  unsigned long ek[32];
 unsigned long dk[32];
} des_ctx;

extern void deskey(unsigned char *, short);
/*                  hexkey[8]     MODE
 * Sets the internal key register according to the hexadecimal
 * key contained in the 8 bytes of hexkey, according to the DES,
 * for encryption or decryption according to MODE.
 */

extern void usekey(unsigned long *);
/*                cookedkey[32]
 * Loads the internal key register with the data in cookedkey.
 */

extern void cpkey(unsigned long *);
/*               cookedkey[32]
 * Copies the contents of the internal key register into the storage
 * located at &cookedkey[0].
 */

extern void des(unsigned char *, unsigned char *);
/*                from[8]         to[8]
 * Encrypts/Decrypts (according to the key currently loaded in the
 * internal key register) one block of eight bytes at address 'from'
 * into the block at address 'to'.  They can be the same.
 */

static void scrunch(unsigned char *, unsigned long *);
static void unscrun(unsigned long *, unsigned char *);
static void desfunc(unsigned long *, unsigned long *);
static void cookey(unsigned long *);

static unsigned long KnL[32] = { 0L };
static unsigned long KnR[32] = { 0L };
static unsigned long Kn3[32] = { 0L };
static unsigned char Df_Key[24] = {
       0x01,0x23,0x45,0x67,0x89,0xab,0xcd,0xef,
       0xfe,0xdc,0xba,0x98,0x76,0x54,0x32,0x10,
       0x89,0xab,0xcd,0xef,0x01,0x23,0x45,0x67 };

static unsigned short bytebit[8]    = {
       0200, 0100, 040, 020, 010, 04, 02, 01 };

static unsigned long bigbyte[24] = {
       0x800000L,    0x400000L,     0x200000L,    0x100000L,
       0x80000L,     0x40000L,      0x20000L,     0x10000L,
       0x8000L,      0x4000L,       0x2000L,      0x1000L,
       0x800L,              0x400L,               0x200L,              0x100L,
       0x80L,               0x40L,                0x20L,               0x10L,
       0x8L,         0x4L,          0x2L,         0x1L   };

/* Use the key schedule specified in the Standard (ANSI X3.92-1981). */

static unsigned char pc1[56] = {
       56, 48, 40, 32, 24, 16,  8,   0, 57, 49, 41, 33, 25, 17,
        9,  1, 58, 50, 42, 34, 26,  18, 10,  2, 59, 51, 43, 35,
       62, 54, 46, 38, 30, 22, 14,   6, 61, 53, 45, 37, 29, 21,
       13,  5, 60, 52, 44, 36, 28,  20, 12,  4, 27, 19, 11,  3 };

static unsigned char totrot[16] = {
       1,2,4,6,8,10,12,14,15,17,19,21,23,25,27,28 };

static unsigned char pc2[48] = {
       13, 16, 10, 23,  0,  4,       2, 27, 14,  5, 20,  9,
       22, 18, 11,  3, 25,  7,      15,  6, 26, 19, 12,  1,
       40, 51, 30, 36, 46, 54,      29, 39, 50, 44, 32, 47,
       43, 48, 38, 55, 33, 52,      45, 41, 49, 35, 28, 31 };

void deskey(unsigned char *key, short edf)  {
  /* Thanks to James Gillogly & Phil Karn! */
  register int i, j, l, m, n;
  unsigned char pc1m[56], pcr[56];
  unsigned long kn[32];

  for ( j = 0; j < 56; j++ ) {
    l = pc1[j];
    m = l & 07;
    pc1m[j] = (key[l >> 3] & bytebit[m]) ? 1 : 0;
  }
  for( i = 0; i < 16; i++ ) {
    if( edf == DE1 ) m = (15 - i) << 1;
    else             m = i << 1;
    n = m + 1;
    kn[m] = kn[n] = 0L;
    for( j = 0; j < 28; j++ ) {
      l = j + totrot[i];
      if( l < 28 ) pcr[j] = pc1m[l];
      else pcr[j] = pc1m[l - 28];
    }
    for( j = 28; j < 56; j++ ) {
      l = j + totrot[i];
      if( l < 56 ) pcr[j] = pc1m[l];
      else         pcr[j] = pc1m[l - 28];
    }
    for( j = 0; j < 24; j++ ) {
      if( pcr[pc2[j]] )    kn[m] |= bigbyte[j];
      if( pcr[pc2[j+24]] ) kn[n] |= bigbyte[j];
    }
  }
  cookey(kn);
}

static void cookey(unsigned long *raw1)  {
  register unsigned long *cook, *raw0;
  unsigned long dough[32];
  register int i;

  cook = dough;
  for( i = 0; i < 16; i++, raw1++ ) {
    raw0 = raw1++;
    *cook   = (*raw0 & 0x00fc0000L) << 6;
    *cook  |= (*raw0 & 0x00000fc0L) << 10;
    *cook  |= (*raw1 & 0x00fc0000L) >> 10;
    *cook++|= (*raw1 & 0x00000fc0L) >> 6;
    *cook   = (*raw0 & 0x0003f000L) << 12;
    *cook  |= (*raw0 & 0x0000003fL) << 16;
    *cook  |= (*raw1 & 0x0003f000L) >> 4;
    *cook++       |= (*raw1 & 0x0000003fL);
  }
  usekey(dough);
}

void cpkey(unsigned long *into)  {
  register unsigned long *from, *endp;

  from = KnL, endp = &KnL[32];
  while( from < endp ) *into++ = *from++;
}

void usekey(unsigned long *from)  {
  register unsigned long *to, *endp;

  to = KnL, endp = &KnL[32];
  while( to < endp ) *to++ = *from++;
}

#if 0
void des(unsigned char *inblock, unsigned char *outblock)  {
  unsigned long work[2];

  scrunch(inblock, work);
  desfunc(work, KnL);
  unscrun(work, outblock);
}
#endif

static void scrunch(unsigned char *outof, unsigned long *into)  {
  *into   = (*outof++ & 0xffL) << 24;
  *into  |= (*outof++ & 0xffL) << 16;
  *into  |= (*outof++ & 0xffL) << 8;
  *into++ |= (*outof++ & 0xffL);
  *into   = (*outof++ & 0xffL) << 24;
  *into  |= (*outof++ & 0xffL) << 16;
  *into  |= (*outof++ & 0xffL) << 8;
  *into  |= (*outof   & 0xffL);
}

static void unscrun(unsigned long *outof, unsigned char *into)  {
  *into++ = (*outof >> 24) & 0xffL;
  *into++ = (*outof >> 16) & 0xffL;
  *into++ = (*outof >>  8) & 0xffL;
  *into++ =  *outof++      & 0xffL;
  *into++ = (*outof >> 24) & 0xffL;
  *into++ = (*outof >> 16) & 0xffL;
  *into++ = (*outof >>  8) & 0xffL;
  *into   =  *outof     & 0xffL;
}

static unsigned long SP1[64] = {
  0x01010400L, 0x00000000L, 0x00010000L, 0x01010404L,
  0x01010004L, 0x00010404L, 0x00000004L, 0x00010000L,
  0x00000400L, 0x01010400L, 0x01010404L, 0x00000400L,
  0x01000404L, 0x01010004L, 0x01000000L, 0x00000004L,
  0x00000404L, 0x01000400L, 0x01000400L, 0x00010400L,
  0x00010400L, 0x01010000L, 0x01010000L, 0x01000404L,
  0x00010004L, 0x01000004L, 0x01000004L, 0x00010004L,
  0x00000000L, 0x00000404L, 0x00010404L, 0x01000000L,
  0x00010000L, 0x01010404L, 0x00000004L, 0x01010000L,
  0x01010400L, 0x01000000L, 0x01000000L, 0x00000400L,
  0x01010004L, 0x00010000L, 0x00010400L, 0x01000004L,
  0x00000400L, 0x00000004L, 0x01000404L, 0x00010404L,
  0x01010404L, 0x00010004L, 0x01010000L, 0x01000404L,
  0x01000004L, 0x00000404L, 0x00010404L, 0x01010400L,
  0x00000404L, 0x01000400L, 0x01000400L, 0x00000000L,
  0x00010004L, 0x00010400L, 0x00000000L, 0x01010004L };

static unsigned long SP2[64] = {
  0x80108020L, 0x80008000L, 0x00008000L, 0x00108020L,
  0x00100000L, 0x00000020L, 0x80100020L, 0x80008020L,
  0x80000020L, 0x80108020L, 0x80108000L, 0x80000000L,
  0x80008000L, 0x00100000L, 0x00000020L, 0x80100020L,
  0x00108000L, 0x00100020L, 0x80008020L, 0x00000000L,
  0x80000000L, 0x00008000L, 0x00108020L, 0x80100000L,
  0x00100020L, 0x80000020L, 0x00000000L, 0x00108000L,
  0x00008020L, 0x80108000L, 0x80100000L, 0x00008020L,
  0x00000000L, 0x00108020L, 0x80100020L, 0x00100000L,
  0x80008020L, 0x80100000L, 0x80108000L, 0x00008000L,
  0x80100000L, 0x80008000L, 0x00000020L, 0x80108020L,
  0x00108020L, 0x00000020L, 0x00008000L, 0x80000000L,
  0x00008020L, 0x80108000L, 0x00100000L, 0x80000020L,
  0x00100020L, 0x80008020L, 0x80000020L, 0x00100020L,
  0x00108000L, 0x00000000L, 0x80008000L, 0x00008020L,
  0x80000000L, 0x80100020L, 0x80108020L, 0x00108000L };

static unsigned long SP3[64] = {
  0x00000208L, 0x08020200L, 0x00000000L, 0x08020008L,
  0x08000200L, 0x00000000L, 0x00020208L, 0x08000200L,
  0x00020008L, 0x08000008L, 0x08000008L, 0x00020000L,
  0x08020208L, 0x00020008L, 0x08020000L, 0x00000208L,
  0x08000000L, 0x00000008L, 0x08020200L, 0x00000200L,
  0x00020200L, 0x08020000L, 0x08020008L, 0x00020208L,
  0x08000208L, 0x00020200L, 0x00020000L, 0x08000208L,
  0x00000008L, 0x08020208L, 0x00000200L, 0x08000000L,
  0x08020200L, 0x08000000L, 0x00020008L, 0x00000208L,
  0x00020000L, 0x08020200L, 0x08000200L, 0x00000000L,
  0x00000200L, 0x00020008L, 0x08020208L, 0x08000200L,
  0x08000008L, 0x00000200L, 0x00000000L, 0x08020008L,
  0x08000208L, 0x00020000L, 0x08000000L, 0x08020208L,
  0x00000008L, 0x00020208L, 0x00020200L, 0x08000008L,
  0x08020000L, 0x08000208L, 0x00000208L, 0x08020000L,
  0x00020208L, 0x00000008L, 0x08020008L, 0x00020200L };

static unsigned long SP4[64] = {
  0x00802001L, 0x00002081L, 0x00002081L, 0x00000080L,
  0x00802080L, 0x00800081L, 0x00800001L, 0x00002001L,
  0x00000000L, 0x00802000L, 0x00802000L, 0x00802081L,
  0x00000081L, 0x00000000L, 0x00800080L, 0x00800001L,
  0x00000001L, 0x00002000L, 0x00800000L, 0x00802001L,
  0x00000080L, 0x00800000L, 0x00002001L, 0x00002080L,
  0x00800081L, 0x00000001L, 0x00002080L, 0x00800080L,
  0x00002000L, 0x00802080L, 0x00802081L, 0x00000081L,
  0x00800080L, 0x00800001L, 0x00802000L, 0x00802081L,
  0x00000081L, 0x00000000L, 0x00000000L, 0x00802000L,

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕欧美三区| 国产综合色视频| 免费高清视频精品| 成人av在线影院| 欧美日韩国产精品成人| 久久女同互慰一区二区三区| 亚洲在线中文字幕| 韩国v欧美v日本v亚洲v| 欧美日韩国产综合视频在线观看| 亚洲高清免费观看 | 天堂资源在线中文精品| 一区二区三区在线播放| 亚洲在线视频一区| 亚洲自拍另类综合| 日精品一区二区三区| 天天影视网天天综合色在线播放| 三级一区在线视频先锋 | 欧美电影免费观看高清完整版在线观看 | 91色综合久久久久婷婷| 一本久道久久综合中文字幕| 色菇凉天天综合网| 欧美精品第1页| 精品久久国产老人久久综合| 久久免费的精品国产v∧| 国产成人在线视频播放| 精品欧美久久久| 裸体一区二区三区| 欧美一区二区三区免费大片| 天堂一区二区在线| 在线观看一区日韩| 一区二区三区在线视频观看| 99久久婷婷国产综合精品电影| 国产亚洲制服色| 国产不卡免费视频| 久久一留热品黄| 国产一区二区影院| 久久一夜天堂av一区二区三区| 久久精品国内一区二区三区| 91精品国产一区二区人妖| 首页综合国产亚洲丝袜| 69精品人人人人| 亚洲v精品v日韩v欧美v专区 | 国产麻豆视频一区| 国产三级一区二区| 岛国精品在线播放| 欧美极品另类videosde| 99热99精品| 亚洲精品免费在线观看| 在线观看国产日韩| 日韩电影在线观看一区| 欧美成人三级在线| 高清成人在线观看| 亚洲欧美日韩精品久久久久| 欧美最新大片在线看| 五月天欧美精品| 欧美va亚洲va国产综合| 国产激情视频一区二区在线观看| 国产精品久久夜| 国产成人精品亚洲777人妖 | 日韩视频免费观看高清完整版在线观看 | 99久久精品99国产精品| 欧美撒尿777hd撒尿| 国产欧美一区二区精品仙草咪| 午夜欧美电影在线观看| 一区二区三区不卡视频| www.欧美日韩| 亚洲欧美日韩精品久久久久| 欧美精品在欧美一区二区少妇| 精品一区二区av| 欧美精品一区二区三区高清aⅴ| 国产亚洲一区二区三区在线观看| 成人精品在线视频观看| 最新日韩在线视频| 欧美三级三级三级| 精东粉嫩av免费一区二区三区| 日本一二三不卡| 欧美年轻男男videosbes| 国产一区999| 一区二区三区国产精品| 亚洲精品在线观看视频| 在线免费一区三区| 狠狠狠色丁香婷婷综合激情 | ...xxx性欧美| 日韩一级片网址| 91麻豆高清视频| 久草中文综合在线| 亚洲黄一区二区三区| 日韩一区二区免费在线电影| 成人精品国产免费网站| 精品一区二区日韩| 亚洲a一区二区| 亚洲欧美视频在线观看| 久久久久久免费网| 欧美一级片在线| 欧美无乱码久久久免费午夜一区| 免费在线看一区| 亚洲va欧美va国产va天堂影院| 亚洲欧美自拍偷拍色图| 精品对白一区国产伦| 欧美美女网站色| 91福利区一区二区三区| 成人精品gif动图一区| 欧美午夜电影一区| 亚洲天堂a在线| 717成人午夜免费福利电影| 国产精品原创巨作av| 亚洲日本在线看| 91精品国产综合久久精品图片| 国内精品免费在线观看| 中文字幕av一区 二区| 欧美日韩一区二区三区不卡| 久久er精品视频| 最好看的中文字幕久久| 国产精品99久久久久久久女警| 亚洲精品国产一区二区精华液| 亚洲欧美一区二区在线观看| 中文字幕成人网| 国产精品久久久一区麻豆最新章节| 日韩精品专区在线| 日韩欧美国产1| 欧美一区二区三区在线观看| 在线观看av一区| a级精品国产片在线观看| 99精品久久只有精品| 色综合久久久久综合99| 91在线高清观看| 92精品国产成人观看免费| 一本大道av伊人久久综合| 色综合视频在线观看| 日本高清不卡视频| 99热这里都是精品| 欧美中文字幕一区二区三区亚洲| 91久久线看在观草草青青| 欧美日韩成人一区二区| 日韩美女在线视频| 亚洲午夜私人影院| 精品久久久久久久一区二区蜜臀| 精品视频1区2区3区| 972aa.com艺术欧美| 成人午夜电影久久影院| 久久99日本精品| 首页国产欧美久久| 亚洲自拍偷拍欧美| 亚洲精品视频一区| 亚洲人妖av一区二区| 国产日韩欧美综合一区| 精品国产一区a| 精品国产一二三区| 2024国产精品| 久久蜜桃av一区二区天堂| 91精选在线观看| 欧美精品1区2区| 欧美女孩性生活视频| 欧美久久一区二区| 欧美日韩国产成人在线91| 在线精品观看国产| 欧美日韩一卡二卡| 欧美久久高跟鞋激| 日韩一区和二区| 日韩一级高清毛片| 日韩欧美中文字幕公布| 日韩三级在线免费观看| 欧美成人女星排名| 国产亚洲女人久久久久毛片| 欧美激情一区二区三区| 国产精品久久久久久久久图文区| 国产精品久久久久久亚洲伦| 亚洲免费资源在线播放| 亚洲不卡av一区二区三区| 男女性色大片免费观看一区二区 | 免费成人美女在线观看| 免费在线看一区| 国产成人aaa| 色菇凉天天综合网| 欧美剧情电影在线观看完整版免费励志电影 | 国产亚洲精品7777| 中文乱码免费一区二区| 一区二区三区四区在线播放 | 欧美色综合久久| 欧美一区二区在线免费播放| 日韩精品一区二区三区swag| 国产午夜精品理论片a级大结局| 日本一区二区不卡视频| 亚洲一二三四久久| 麻豆精品久久久| 成人小视频免费在线观看| 色88888久久久久久影院野外| 欧美日本高清视频在线观看| 26uuu国产电影一区二区| 综合av第一页| 日本在线不卡视频| 国产aⅴ综合色| 欧美美女直播网站| 国产精品美女久久久久久久久 | 欧美视频一区在线| 欧美精品一区二区精品网| 亚洲人精品午夜| 国内成人精品2018免费看| 91精品办公室少妇高潮对白| 欧美精品一区二区三区在线|