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

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

?? des.c

?? 用來調試C51程序的軟件
?? 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 <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,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美日韩亚州综合| 欧美精品视频www在线观看| 久久婷婷国产综合国色天香| 精彩视频一区二区| 2023国产精品自拍| av电影一区二区| 亚洲制服丝袜一区| 在线观看91精品国产麻豆| 久久99精品国产麻豆婷婷| 国产视频911| 欧美影院精品一区| 美女视频第一区二区三区免费观看网站| 88在线观看91蜜桃国自产| 国内国产精品久久| 国产精品久久久久久久久久久免费看 | 欧美精品一区二区精品网| 国产精品主播直播| 樱花影视一区二区| 日韩一区二区三区免费看 | 日本麻豆一区二区三区视频| 欧美成人官网二区| 成人18视频在线播放| 亚洲精品伦理在线| 精品国产自在久精品国产| 成人黄色av电影| 日韩电影在线一区二区三区| 久久精品视频免费观看| 欧美日韩综合不卡| 国产成人免费视频网站| 亚洲一区二区在线播放相泽| 欧美精品一区二区在线播放| av高清久久久| 精品一区在线看| 亚洲综合男人的天堂| 久久久久久久av麻豆果冻| 在线观看免费一区| 国产99久久久国产精品免费看| 亚洲电影在线播放| 国产精品免费av| 日韩视频一区在线观看| 91久久奴性调教| 国产精品影视天天线| 午夜久久久久久电影| 国产精品久久久久桃色tv| 欧美电影免费观看高清完整版在| 91在线观看地址| 国产黄色精品网站| 毛片不卡一区二区| 亚洲成人777| 1000部国产精品成人观看| 欧美大白屁股肥臀xxxxxx| 精品视频全国免费看| av中文字幕不卡| 国产精品911| 国产永久精品大片wwwapp| 亚洲成人免费在线观看| 亚洲男人天堂av网| 中文字幕亚洲一区二区av在线| 久久久久久黄色| 欧美精品一区二区三区高清aⅴ| 欧美日韩国产美| 欧美性色综合网| 色婷婷狠狠综合| 色综合中文字幕国产| 国产精品18久久久久久久久| 看电视剧不卡顿的网站| 亚洲成人动漫av| 亚洲国产成人av| 亚洲最色的网站| 夜夜揉揉日日人人青青一国产精品| 中文字幕一区二区三区色视频| 国产欧美一区二区精品秋霞影院| 久久久久久一二三区| 精品国产伦一区二区三区观看体验| 欧美疯狂性受xxxxx喷水图片| 欧美艳星brazzers| 欧美裸体一区二区三区| 欧美裸体bbwbbwbbw| 欧美一区二区免费视频| 日韩欧美一二三区| 久久免费看少妇高潮| 国产丝袜美腿一区二区三区| 久久亚洲免费视频| 国产亚洲欧美激情| 国产精品麻豆99久久久久久| 国产精品成人免费在线| 亚洲欧美视频在线观看视频| 亚洲资源中文字幕| 日韩高清在线不卡| 国内精品免费在线观看| 大胆欧美人体老妇| 色天天综合色天天久久| 欧美三级视频在线| 日韩一级高清毛片| 久久精品一区二区三区四区| 久久婷婷成人综合色| 国产精品久久久久天堂| 一区二区国产盗摄色噜噜| 天天操天天色综合| 久草在线在线精品观看| 成人精品电影在线观看| 一本一道综合狠狠老| 91麻豆精品国产91久久久更新时间| 欧美一区二区三区视频免费 | 欧美xxxxx牲另类人与| 久久这里只有精品6| 中文字幕一区二区三区视频| 亚洲午夜一区二区| 狠狠色综合日日| 91色.com| 精品美女一区二区| 亚洲最色的网站| 国产一区二区三区久久久 | 欧美肥胖老妇做爰| 久久久精品天堂| 亚洲成人av在线电影| 国产综合色产在线精品| 在线亚洲精品福利网址导航| 精品久久久影院| 亚洲综合在线视频| 性做久久久久久免费观看| 高潮精品一区videoshd| 欧美高清视频一二三区 | 欧美韩日一区二区三区四区| 一二三四社区欧美黄| 国产伦精品一区二区三区在线观看| 在线免费观看视频一区| 国产日产亚洲精品系列| 天天色天天操综合| 在线一区二区观看| 日本一区二区三区高清不卡| 午夜婷婷国产麻豆精品| 99re热这里只有精品视频| 欧美tickling挠脚心丨vk| 亚洲一区二区综合| 国产精品亚洲第一| 欧美一区二区日韩| 亚洲一区二区三区精品在线| 成人av集中营| 久久综合色婷婷| 日韩综合小视频| 91成人国产精品| 亚洲精品免费视频| 高清shemale亚洲人妖| 欧美xxxx老人做受| 美女网站视频久久| 7777精品伊人久久久大香线蕉完整版| 中文字幕日韩一区| 国产精品99久久久久久久女警 | 国产视频一区在线观看 | 日韩中文字幕麻豆| 欧美日韩aaaaa| 亚洲综合激情网| 日本乱人伦aⅴ精品| 最新不卡av在线| 99re这里只有精品6| 国产精品剧情在线亚洲| 国产精品一级片在线观看| 26uuu另类欧美亚洲曰本| 日韩av电影天堂| 日韩欧美电影一二三| 免费在线视频一区| 日韩免费性生活视频播放| 麻豆国产一区二区| 日韩欧美第一区| 国内成人免费视频| 久久久精品蜜桃| 成人做爰69片免费看网站| 国产清纯在线一区二区www| 国产精品伊人色| 国产精品久久一级| 99re这里只有精品首页| 亚洲精品国产无套在线观| 在线欧美一区二区| 亚洲综合图片区| 欧美色视频一区| 日韩电影免费在线看| 精品区一区二区| 狠狠v欧美v日韩v亚洲ⅴ| 久久一夜天堂av一区二区三区| 国产一区二区三区高清播放| 国产亚洲1区2区3区| 成人av网站在线| 亚洲香肠在线观看| 日韩女优av电影| 成人免费看片app下载| 亚洲精品视频一区| 欧美三级电影在线观看| 麻豆成人久久精品二区三区小说| 2023国产一二三区日本精品2022| 成人午夜av在线| 亚洲国产精品嫩草影院| 日韩一级片网址| 99国产麻豆精品| 奇米综合一区二区三区精品视频| 久久久一区二区三区| 91丨porny丨首页| 日本sm残虐另类| 国产精品久久久久四虎| 这里只有精品免费|