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

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

?? shark.cpp

?? 橢圓曲線密碼系統教程和相關源代碼,是非常難得的學術資料
?? CPP
字號:
// shark.cpp - written and placed in the public domain by Wei Dai

#include "pch.h"
#include "shark.h"

#ifdef WORD64_AVAILABLE

#include "modes.h"
#include "gf256.h"

NAMESPACE_BEGIN(CryptoPP)

static word64 SHARKTransform(word64 a)
{
	static const byte iG[8][8] = {
		0xe7, 0x30, 0x90, 0x85, 0xd0, 0x4b, 0x91, 0x41, 
		0x53, 0x95, 0x9b, 0xa5, 0x96, 0xbc, 0xa1, 0x68, 
		0x02, 0x45, 0xf7, 0x65, 0x5c, 0x1f, 0xb6, 0x52, 
		0xa2, 0xca, 0x22, 0x94, 0x44, 0x63, 0x2a, 0xa2, 
		0xfc, 0x67, 0x8e, 0x10, 0x29, 0x75, 0x85, 0x71, 
		0x24, 0x45, 0xa2, 0xcf, 0x2f, 0x22, 0xc1, 0x0e, 
		0xa1, 0xf1, 0x71, 0x40, 0x91, 0x27, 0x18, 0xa5, 
		0x56, 0xf4, 0xaf, 0x32, 0xd2, 0xa4, 0xdc, 0x71, 
	};

	word64 result=0;
	GF256 gf256(0xf5);
	for (unsigned int i=0; i<8; i++)
		for(unsigned int j=0; j<8; j++) 
			result ^= word64(gf256.Multiply(iG[i][j], a>>(56-8*j))) << (56-8*i);
	return result;
}

void SHARKBase::InitEncryptionRoundKeys(const byte *key, unsigned int keyLen, unsigned int rounds, word64 *roundkeys)
{
	// concatenate key enought times to fill a
	for (unsigned int i=0; i<(rounds+1)*8; i++)
		((byte *)roundkeys)[i] = key[i%keyLen];

	SHARKEncryption e;
	byte IV[8] = {0,0,0,0,0,0,0,0};
	CFBEncryption cfb(e, IV);

	cfb.ProcessString((byte *)roundkeys, (rounds+1)*8);

#ifdef IS_LITTLE_ENDIAN
	byteReverse(roundkeys, roundkeys, (rounds+1)*8);
#endif

	roundkeys[rounds] = SHARKTransform(roundkeys[rounds]);
}

// construct an SHARKEncryption object with fixed round keys, to be used to initialize actual round keys
SHARKEncryption::SHARKEncryption()
	: SHARKBase(ROUNDS)
{
	for (unsigned int i=0; i<ROUNDS; i++)
		roundkeys[i] = cbox[0][i];

	roundkeys[ROUNDS] = SHARKTransform(cbox[0][ROUNDS]);

#ifdef IS_LITTLE_ENDIAN
	roundkeys[0] = byteReverse(roundkeys[0]);
	roundkeys[ROUNDS] = byteReverse(roundkeys[ROUNDS]);
#endif
}

SHARKEncryption::SHARKEncryption(const byte *key, unsigned int keyLen, unsigned int rounds)
	: SHARKBase(rounds)
{
	InitEncryptionRoundKeys(key, keyLen, rounds, roundkeys);

#ifdef IS_LITTLE_ENDIAN
	roundkeys[0] = byteReverse(roundkeys[0]);
	roundkeys[rounds] = byteReverse(roundkeys[rounds]);
#endif
}

void SHARKEncryption::ProcessBlock(const byte *in, byte *out) const
{
	word64 tmp = *(word64 *)in ^ roundkeys[0];

#ifdef IS_LITTLE_ENDIAN
	tmp = cbox[0][GETBYTE(tmp, 0)] ^ cbox[1][GETBYTE(tmp, 1)] 
		^ cbox[2][GETBYTE(tmp, 2)] ^ cbox[3][GETBYTE(tmp, 3)] 
		^ cbox[4][GETBYTE(tmp, 4)] ^ cbox[5][GETBYTE(tmp, 5)] 
		^ cbox[6][GETBYTE(tmp, 6)] ^ cbox[7][GETBYTE(tmp, 7)]
		^ roundkeys[1];
#else
	tmp = cbox[0][GETBYTE(tmp, 7)] ^ cbox[1][GETBYTE(tmp, 6)] 
		^ cbox[2][GETBYTE(tmp, 5)] ^ cbox[3][GETBYTE(tmp, 4)] 
		^ cbox[4][GETBYTE(tmp, 3)] ^ cbox[5][GETBYTE(tmp, 2)] 
		^ cbox[6][GETBYTE(tmp, 1)] ^ cbox[7][GETBYTE(tmp, 0)]
		^ roundkeys[1];
#endif

	for(unsigned int i=2; i<rounds; i++) 
	{
		tmp = cbox[0][GETBYTE(tmp, 7)] ^ cbox[1][GETBYTE(tmp, 6)] 
			^ cbox[2][GETBYTE(tmp, 5)] ^ cbox[3][GETBYTE(tmp, 4)] 
			^ cbox[4][GETBYTE(tmp, 3)] ^ cbox[5][GETBYTE(tmp, 2)] 
			^ cbox[6][GETBYTE(tmp, 1)] ^ cbox[7][GETBYTE(tmp, 0)]
			^ roundkeys[i];
	}

	out[0] = sbox[GETBYTE(tmp, 7)];
	out[1] = sbox[GETBYTE(tmp, 6)];
	out[2] = sbox[GETBYTE(tmp, 5)];
	out[3] = sbox[GETBYTE(tmp, 4)];
	out[4] = sbox[GETBYTE(tmp, 3)];
	out[5] = sbox[GETBYTE(tmp, 2)];
	out[6] = sbox[GETBYTE(tmp, 1)];
	out[7] = sbox[GETBYTE(tmp, 0)];

	*(word64 *)out ^= roundkeys[rounds];
}

SHARKDecryption::SHARKDecryption(const byte *key, unsigned int keyLen, unsigned int rounds)
	: SHARKBase(rounds)
{
	InitEncryptionRoundKeys(key, keyLen, rounds, roundkeys);

	unsigned int i;

	// transform encryption round keys into decryption round keys
	for (i=0; i<rounds/2; i++)
		std::swap(roundkeys[i], roundkeys[rounds-i]);

	for (i=1; i<rounds; i++)
		roundkeys[i] = SHARKTransform(roundkeys[i]);

#ifdef IS_LITTLE_ENDIAN
	roundkeys[0] = byteReverse(roundkeys[0]);
	roundkeys[rounds] = byteReverse(roundkeys[rounds]);
#endif
}

void SHARKDecryption::ProcessBlock(const byte *in, byte *out) const
{
	word64 tmp = *(word64 *)in ^ roundkeys[0];

#ifdef IS_LITTLE_ENDIAN
	tmp = cbox[0][GETBYTE(tmp, 0)] ^ cbox[1][GETBYTE(tmp, 1)] 
		^ cbox[2][GETBYTE(tmp, 2)] ^ cbox[3][GETBYTE(tmp, 3)] 
		^ cbox[4][GETBYTE(tmp, 4)] ^ cbox[5][GETBYTE(tmp, 5)] 
		^ cbox[6][GETBYTE(tmp, 6)] ^ cbox[7][GETBYTE(tmp, 7)]
		^ roundkeys[1];
#else
	tmp = cbox[0][GETBYTE(tmp, 7)] ^ cbox[1][GETBYTE(tmp, 6)] 
		^ cbox[2][GETBYTE(tmp, 5)] ^ cbox[3][GETBYTE(tmp, 4)] 
		^ cbox[4][GETBYTE(tmp, 3)] ^ cbox[5][GETBYTE(tmp, 2)] 
		^ cbox[6][GETBYTE(tmp, 1)] ^ cbox[7][GETBYTE(tmp, 0)]
		^ roundkeys[1];
#endif

	for(unsigned int i=2; i<rounds; i++) 
	{
		tmp = cbox[0][GETBYTE(tmp, 7)] ^ cbox[1][GETBYTE(tmp, 6)] 
			^ cbox[2][GETBYTE(tmp, 5)] ^ cbox[3][GETBYTE(tmp, 4)] 
			^ cbox[4][GETBYTE(tmp, 3)] ^ cbox[5][GETBYTE(tmp, 2)] 
			^ cbox[6][GETBYTE(tmp, 1)] ^ cbox[7][GETBYTE(tmp, 0)]
			^ roundkeys[i];
	}

	out[0] = sbox[GETBYTE(tmp, 7)];
	out[1] = sbox[GETBYTE(tmp, 6)];
	out[2] = sbox[GETBYTE(tmp, 5)];
	out[3] = sbox[GETBYTE(tmp, 4)];
	out[4] = sbox[GETBYTE(tmp, 3)];
	out[5] = sbox[GETBYTE(tmp, 2)];
	out[6] = sbox[GETBYTE(tmp, 1)];
	out[7] = sbox[GETBYTE(tmp, 0)];

	*(word64 *)out ^= roundkeys[rounds];
}

NAMESPACE_END

#endif // WORD64_AVAILABLE

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区视频在线| 国产一本一道久久香蕉| 国产清纯白嫩初高生在线观看91 | 日韩精品电影一区亚洲| 亚洲色图欧美偷拍| 日韩黄色免费电影| 欧美裸体bbwbbwbbw| 国产精品久久国产精麻豆99网站| 亚洲成人免费影院| 国产乱人伦精品一区二区在线观看| 在线观看不卡视频| 国产欧美一区二区精品久导航| 国产一区二区网址| 久久久综合精品| 免费观看久久久4p| 色视频欧美一区二区三区| 精品福利视频一区二区三区| 一区二区三区日韩在线观看| 在线观看亚洲a| 另类小说视频一区二区| 精品视频在线视频| 九九视频精品免费| 欧美亚洲高清一区二区三区不卡| 国产拍揄自揄精品视频麻豆| 国产91丝袜在线播放九色| 日韩欧美久久久| 亚洲国产一区在线观看| 日本韩国一区二区三区视频| 国产精品成人免费精品自在线观看| 99精品视频一区| 国产精品久久久久久久久免费相片 | 99久久er热在这里只有精品66| 亚洲三级理论片| 日韩一区二区精品| 奇米精品一区二区三区四区 | 日韩高清一区二区| 欧美日韩成人高清| 午夜精品一区二区三区电影天堂 | 一区二区在线观看不卡| 9191精品国产综合久久久久久| 中文子幕无线码一区tr| 成人毛片在线观看| 国产精品久久久久久久久果冻传媒| 欧美特级限制片免费在线观看| 韩国女主播一区二区三区| 久久日一线二线三线suv| 国产精品亚洲成人| 日韩高清欧美激情| 亚洲色图一区二区| 国产女主播一区| 日韩免费观看高清完整版| 91精品福利在线| 成人免费va视频| 精品影视av免费| 日韩一区二区三区观看| 99天天综合性| 国产午夜一区二区三区| 夜夜爽夜夜爽精品视频| 精品久久久久久无| 无码av免费一区二区三区试看| 久久美女高清视频| 美脚の诱脚舐め脚责91| 久久久91精品国产一区二区三区| 成人激情电影免费在线观看| 亚洲私人影院在线观看| 日韩限制级电影在线观看| 91网站在线播放| 亚洲国产成人av| 亚洲国产精品精华液2区45| 欧美一区二区三区免费大片| 色老综合老女人久久久| 国产成人av影院| 精品久久五月天| 欧美日韩亚洲综合在线 | 亚洲日本在线天堂| 在线一区二区三区四区五区 | 91.麻豆视频| 色婷婷综合久久久久中文| 精品成人一区二区三区四区| 日本黄色一区二区| 91在线精品一区二区三区| 国产激情偷乱视频一区二区三区| 日本欧美一区二区三区乱码| 蜜臀久久99精品久久久久宅男 | 欧美色综合网站| 91小视频免费看| 麻豆精品久久久| 精品一区二区在线看| 偷偷要91色婷婷| 亚洲国产精品久久不卡毛片| 亚洲乱码精品一二三四区日韩在线| 久久精品亚洲国产奇米99| 精品国产凹凸成av人导航| 3atv在线一区二区三区| 91精品国产综合久久久久久久久久| 欧美日韩一区二区在线观看 | 国产精品福利一区二区| 中文字幕高清不卡| 欧美激情综合在线| 国产欧美精品区一区二区三区 | 制服丝袜在线91| 欧美精品免费视频| 欧美一区二区三区免费在线看 | 国产精品一卡二| 国产乱码精品1区2区3区| 国内不卡的二区三区中文字幕| 久久99精品久久久久| 国产自产v一区二区三区c| 国产精品伊人色| 成人av午夜电影| 91一区一区三区| 欧美探花视频资源| 日韩三级在线免费观看| 国产视频一区不卡| 中文字幕视频一区二区三区久| 国产三级久久久| 亚洲欧美日韩人成在线播放| 日韩一区二区三区电影| 精品国产乱码久久久久久图片 | 五月天激情综合| 久久爱另类一区二区小说| 粉嫩av一区二区三区粉嫩| 91老司机福利 在线| 欧美日韩精品免费观看视频| 精品久久久久av影院| 亚洲精品一区二区三区香蕉 | av一区二区三区在线| 在线亚洲欧美专区二区| 欧美一区二区视频在线观看 | 亚洲男人的天堂网| 日本vs亚洲vs韩国一区三区二区| 国产精品一二三四区| 99视频在线观看一区三区| 欧美剧情电影在线观看完整版免费励志电影 | 国产麻豆一精品一av一免费| 91在线国产福利| 3atv一区二区三区| 成人欧美一区二区三区| 日韩av网站免费在线| 国产99久久精品| 91麻豆精品国产91久久久久久久久| 久久综合国产精品| 亚洲制服丝袜av| 国产激情一区二区三区四区| 欧美日韩成人在线一区| 欧美日韩一二区| 色婷婷激情一区二区三区| 精品免费99久久| 成人欧美一区二区三区在线播放| 亚洲va欧美va国产va天堂影院| 国产精品66部| 91精品欧美久久久久久动漫| 久久影院视频免费| 亚洲大片精品永久免费| 国产丶欧美丶日本不卡视频| 欧美日韩1234| 亚洲欧洲韩国日本视频| 国产美女av一区二区三区| 6080日韩午夜伦伦午夜伦| 亚洲午夜久久久久久久久久久| 老司机精品视频在线| 欧美日韩一区 二区 三区 久久精品| 国产亚洲欧美激情| 免费成人在线播放| 在线影院国内精品| 国产v日产∨综合v精品视频| 日韩精品一区二区三区在线播放| 欧美成人在线直播| 中文字幕一区二区三| 一区二区三区日韩精品视频| 国产一区二区三区在线观看免费视频| 678五月天丁香亚洲综合网| 亚洲黄色小视频| 97久久精品人人做人人爽50路| 精品国产一区二区三区不卡| 肉色丝袜一区二区| 欧美日本国产视频| 亚洲福利国产精品| 色88888久久久久久影院按摩| 国产精品短视频| 91亚洲男人天堂| 国产精品黄色在线观看| 成人污视频在线观看| 中文天堂在线一区| 成人国产精品免费网站| 国产精品素人视频| 国产裸体歌舞团一区二区| 精品久久人人做人人爱| 精品一区二区久久久| 欧美一区二区三区免费在线看| 一区二区三区四区视频精品免费| 成人av在线看| 国产精品网站一区| 国产一区在线观看视频| 日韩精品电影一区亚洲| 精品视频在线免费观看| 亚洲国产精品久久人人爱| 欧美久久久久中文字幕| 日韩成人免费电影| 欧美成人精品3d动漫h|