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

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

?? des.c

?? C51下的DES加密函數包
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*--------------------------------------------------------------------------------
DES.C: DES Algorithm Program from the Book Appliced Cryptography, Bruce Schneier
--------------------------------------------------------------------------------*/

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

#include <stdio.h>
#include "common.h"

extern ICParamFlash	IC;					//存入flash中的可修改數據
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,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一本大道久久a久久精二百| 韩国成人福利片在线播放| 国产精品午夜在线| 欧美大片国产精品| 欧美精品久久久久久久多人混战| 99热这里都是精品| eeuss鲁一区二区三区| 国产精品一区二区久激情瑜伽| 亚洲v中文字幕| 亚洲一区二区综合| 亚洲伊人色欲综合网| 亚洲国产综合色| 亚洲一区在线电影| 青青草精品视频| 国产一区二区免费看| 免费高清视频精品| 国产毛片精品国产一区二区三区| 经典三级视频一区| 成人午夜大片免费观看| 欧美午夜一区二区三区| 精品久久久久久久久久久久久久久| 日韩欧美在线1卡| 精品久久人人做人人爰| 91香蕉国产在线观看软件| 成人妖精视频yjsp地址| 欧美高清hd18日本| 国产校园另类小说区| 亚洲欧美二区三区| 国产一区二区三区国产| 91丨九色丨黑人外教| 精品国产免费一区二区三区四区| 国产精品卡一卡二卡三| 午夜精品视频一区| 99v久久综合狠狠综合久久| 欧美一区二区在线视频| 一级女性全黄久久生活片免费| 久久国产精品色| 欧美日韩中字一区| 亚洲特级片在线| 国产精品综合在线视频| 制服丝袜av成人在线看| 亚洲欧美欧美一区二区三区| 日韩精品免费视频人成| 欧美日本一区二区| 亚洲最色的网站| 欧美在线免费播放| 欧美国产精品v| 日韩精品一卡二卡三卡四卡无卡| 欧美视频第二页| 亚洲午夜久久久久久久久电影网| 色婷婷香蕉在线一区二区| 中文字幕av一区 二区| 成人一级片网址| 综合久久国产九一剧情麻豆| 91免费看`日韩一区二区| 综合在线观看色| 91久久线看在观草草青青| 亚洲成人免费视| 日韩欧美久久久| 国产91精品在线观看| 1024成人网| 欧美日韩国产精品成人| 国产一区二区三区四区五区入口| 亚洲国产高清aⅴ视频| 一本色道久久综合亚洲91| 亚洲综合久久久| 精品国免费一区二区三区| av在线播放一区二区三区| 亚洲3atv精品一区二区三区| 91精品国产综合久久精品| 国内精品免费在线观看| 亚洲成人你懂的| 中文字幕乱码一区二区免费| 欧美一级视频精品观看| 99re8在线精品视频免费播放| 日本成人在线电影网| 中文字幕一区二区在线播放 | 日本三级亚洲精品| 国产精品福利av| 亚洲精品在线电影| 欧美一区二区不卡视频| 91在线看国产| 韩国三级在线一区| 久久精品国产99| 丝袜美腿高跟呻吟高潮一区| 亚洲综合在线视频| ㊣最新国产の精品bt伙计久久| 久久精品一区蜜桃臀影院| 成人综合在线网站| 午夜精品爽啪视频| 亚洲成人福利片| 亚洲最新在线观看| 亚洲美女偷拍久久| 亚洲欧美怡红院| 亚洲伦理在线精品| 自拍偷拍国产精品| 亚洲一区在线观看视频| 天堂在线亚洲视频| 日本不卡一区二区三区高清视频| 日韩国产精品久久久久久亚洲| 亚洲小少妇裸体bbw| 日产精品久久久久久久性色| 日韩高清国产一区在线| 精品午夜久久福利影院| 国产成人在线视频网址| voyeur盗摄精品| 欧美午夜理伦三级在线观看| 日韩一区二区麻豆国产| 国产片一区二区三区| 亚洲成在人线免费| 一区av在线播放| 日本不卡免费在线视频| 欧美日韩国产精品自在自线| 51精品国自产在线| 久久影院视频免费| 综合久久久久久| 婷婷亚洲久悠悠色悠在线播放| 麻豆91在线播放| 91福利精品视频| 久久久久久**毛片大全| 天堂午夜影视日韩欧美一区二区| 国产一区二区免费在线| 9191国产精品| 伊人婷婷欧美激情| 国产成人一级电影| 欧美成人一区二区| 亚洲aaa精品| 欧美性猛交xxxx乱大交退制版| 欧美国产综合色视频| 久久se这里有精品| 欧美一区二区免费视频| 亚洲国产综合人成综合网站| 91丨porny丨国产| 国产精品久久久久久久岛一牛影视 | 日韩精品一区二区三区在线| 亚洲一区在线视频| 欧美色成人综合| 亚洲一区二区三区视频在线播放| 激情综合网av| 久久亚洲精华国产精华液| 蜜臀精品久久久久久蜜臀| 欧美日韩成人在线| 蜜臀a∨国产成人精品| 欧美日韩国产三级| 国内精品久久久久影院薰衣草| 在线播放欧美女士性生活| 日韩二区三区四区| 日韩欧美电影一区| 国产成人在线视频播放| 国产精品白丝在线| 欧美色视频在线观看| 热久久久久久久| 亚洲国产岛国毛片在线| 欧美视频精品在线观看| 免费黄网站欧美| 亚洲婷婷综合色高清在线| 欧美另类videos死尸| 中文字幕制服丝袜成人av| 国产一区二区网址| 亚洲欧美日韩在线| 日韩欧美一级片| 91蝌蚪国产九色| 国产一区 二区 三区一级| 亚洲欧美综合色| 欧美日韩亚洲不卡| 国产精品羞羞答答xxdd| 午夜不卡在线视频| 国产精品卡一卡二卡三| 欧美成人一区二区三区在线观看| 91在线播放网址| 国产成人精品影视| 精品无人码麻豆乱码1区2区| 首页欧美精品中文字幕| 一区二区三区在线观看欧美| 国产欧美综合在线观看第十页| 91精品福利在线一区二区三区| 99久久777色| 91色视频在线| 不卡免费追剧大全电视剧网站| 久久99久久久久久久久久久| 亚洲制服丝袜av| 亚洲激情图片qvod| 亚洲乱码国产乱码精品精的特点 | 久久久www免费人成精品| 91精品国产综合久久精品性色| 欧美日本在线一区| 欧美一区二区精品在线| www亚洲一区| 久久久综合精品| 亚洲视频精选在线| 亚洲裸体xxx| 日韩精品亚洲专区| 麻豆精品蜜桃视频网站| 国产九色精品成人porny| 国产盗摄一区二区| 在线观看视频一区二区 | 国产精品丝袜久久久久久app| 中文字幕 久热精品 视频在线| 尤物视频一区二区| 日本成人在线看|