亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
在线亚洲免费视频| 波波电影院一区二区三区| 欧美性感一区二区三区| 日韩和欧美一区二区三区| 26uuu国产电影一区二区| 成人理论电影网| 亚洲成a人v欧美综合天堂| 欧美刺激脚交jootjob| 成人午夜在线视频| 亚洲1区2区3区视频| 久久久不卡网国产精品二区| 91浏览器在线视频| 国内成+人亚洲+欧美+综合在线| 国产日韩欧美一区二区三区乱码 | 白白色亚洲国产精品| 亚洲va韩国va欧美va精品| 亚洲精品一区二区三区精华液| 91在线一区二区| 精品亚洲成a人| 一卡二卡欧美日韩| 久久久久久久久97黄色工厂| 欧美视频在线观看一区| 激情欧美一区二区三区在线观看| 亚洲精品乱码久久久久| 日本一区二区久久| 日韩一区二区三区视频在线观看| 色婷婷久久综合| 国产乱码精品一品二品| 七七婷婷婷婷精品国产| 亚洲精品高清在线| 国产精品乱人伦| 欧美精品一区男女天堂| 欧美一区二区视频在线观看| 91美女在线视频| 久久99精品国产91久久来源| 亚洲色图欧美偷拍| 国产日本欧洲亚洲| 欧美精品一区二区三区久久久| 成人高清视频免费观看| 国产乱人伦偷精品视频不卡| 日韩在线一二三区| 婷婷国产v国产偷v亚洲高清| 一级做a爱片久久| 亚洲精品日产精品乱码不卡| 中文字幕第一区二区| 精品国产乱码久久久久久1区2区| 91精品国产综合久久久久| 欧洲一区二区三区在线| 在线一区二区三区四区| 91免费在线播放| av毛片久久久久**hd| 国产中文一区二区三区| 婷婷综合久久一区二区三区| 亚洲主播在线播放| 亚洲一区在线观看视频| 一区二区三区四区视频精品免费 | www.66久久| 国产jizzjizz一区二区| 国产一区二区三区不卡在线观看| 麻豆精品国产91久久久久久| 日本va欧美va瓶| 秋霞午夜鲁丝一区二区老狼| 日本最新不卡在线| 喷白浆一区二区| 久久99精品一区二区三区三区| 捆绑调教美女网站视频一区| 日韩成人免费在线| 久久99精品视频| 国产精品亚洲专一区二区三区 | 欧美激情一区三区| 欧美刺激午夜性久久久久久久| 欧美三片在线视频观看| 欧美天天综合网| 日韩一级成人av| 久久女同互慰一区二区三区| 久久久久久久久久久久久女国产乱| 精品国产一区二区三区久久久蜜月| 久久综合狠狠综合久久激情| 欧美激情艳妇裸体舞| 中文字幕一区二区三区四区 | 国产精品久久久久四虎| 伊人色综合久久天天| 五月天激情小说综合| 久久草av在线| 丁香激情综合国产| 欧美视频一区二区三区四区| 欧美精品一二三区| 久久伊人中文字幕| 亚洲免费av网站| 日韩精品一卡二卡三卡四卡无卡| 狠狠久久亚洲欧美| 91麻豆国产香蕉久久精品| 91.成人天堂一区| 久久久久综合网| 亚洲人成网站精品片在线观看| 午夜视黄欧洲亚洲| 成人自拍视频在线观看| 不卡av在线网| 欧美日韩你懂得| www国产精品av| 欧美激情一区三区| 天堂精品中文字幕在线| 国产69精品久久777的优势| 欧美视频一区二区| 亚洲国产精品v| 日本成人中文字幕在线视频 | 国产精品一二三区在线| 在线看一区二区| 国产视频一区二区三区在线观看| 一区二区三区鲁丝不卡| 久久99最新地址| 色综合久久天天| 日韩欧美你懂的| 一区二区三区视频在线观看 | 成人免费观看男女羞羞视频| 精品视频在线免费看| 国产欧美日韩卡一| 欧美bbbbb| 欧美系列在线观看| 中文字幕欧美激情| 久久精品国产**网站演员| 91久久人澡人人添人人爽欧美| 欧美一级理论片| 日韩久久一区二区| 激情六月婷婷久久| 欧美巨大另类极品videosbest| 国产精品国产成人国产三级 | 国产精品88888| 欧美精品在欧美一区二区少妇| 国产精品久久夜| 国产一区二区精品在线观看| 欧美日韩亚洲另类| 亚洲精品美腿丝袜| 成人高清在线视频| 中文字幕免费观看一区| 激情伊人五月天久久综合| 欧美一级在线视频| 亚洲线精品一区二区三区 | 青青草伊人久久| 99riav久久精品riav| 中文一区二区完整视频在线观看| 激情综合网av| 精品理论电影在线观看| 日韩电影免费在线| 欧美日韩成人在线一区| 午夜一区二区三区在线观看| 91成人国产精品| 中文字幕精品综合| 麻豆精品新av中文字幕| 欧美成人a∨高清免费观看| 老司机午夜精品| 欧美tk丨vk视频| 久久99精品国产.久久久久久| 91精品国产手机| 久久爱另类一区二区小说| 91精品欧美福利在线观看| 精品中文字幕一区二区| 久久久三级国产网站| 91亚洲精品一区二区乱码| 亚洲国产一区二区三区青草影视| 欧美日韩午夜在线| 国内成人自拍视频| 亚洲人成影院在线观看| 欧美一区永久视频免费观看| 国产精品一二三四五| 亚洲美女精品一区| 欧美一级电影网站| www.亚洲色图.com| 图片区小说区国产精品视频| 亚洲精品在线免费播放| 99精品欧美一区二区三区综合在线| 亚洲激情图片一区| 精品1区2区在线观看| 色综合一个色综合亚洲| 美女网站在线免费欧美精品| 国产精品婷婷午夜在线观看| 欧美精品久久99| 成人精品在线视频观看| 日韩高清不卡在线| 国产精品久久久久久久久免费丝袜| 欧美性猛交xxxxxx富婆| 国产成人一区二区精品非洲| 一区二区三区四区在线免费观看 | 亚洲电影一区二区三区| 2022国产精品视频| 欧美系列日韩一区| 国产成人自拍网| 青青青伊人色综合久久| 国产精品夫妻自拍| 精品毛片乱码1区2区3区| 欧美午夜精品久久久| 丁香天五香天堂综合| 免费成人性网站| 亚洲卡通动漫在线| 精品国产成人在线影院| 欧美午夜影院一区| av在线播放一区二区三区| 久久99精品一区二区三区| 亚洲一二三区在线观看| 国产精品美女久久久久久久久久久|