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

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

?? square.cpp

?? 此文件是實現加解密算法的函數庫
?? CPP
字號:
// square.cpp - written and placed in the public domain by Wei Dai
// Based on Paulo S.L.M. Barreto's public domain implementation

#include "pch.h"
#include "square.h"
#include "misc.h"
#include "gf256.h"

NAMESPACE_BEGIN(CryptoPP)

// apply theta to a roundkey
static void SquareTransform (word32 in[4], word32 out[4])
{
	static const byte G[4][4] = 
	{
		0x02U, 0x01U, 0x01U, 0x03U, 
		0x03U, 0x02U, 0x01U, 0x01U, 
		0x01U, 0x03U, 0x02U, 0x01U, 
		0x01U, 0x01U, 0x03U, 0x02U
	};

	GF256 gf256(0xf5);

	for (int i = 0; i < 4; i++)
	{
		word32 temp = 0;
		for (int j = 0; j < 4; j++)
			for (int k = 0; k < 4; k++)
				temp ^= (word32)gf256.Multiply(GETBYTE(in[i], 3-k), G[k][j]) << ((3-j)*8);
		out[i] = temp;
	}
}

void Square::Base::UncheckedSetKey(CipherDir dir, const byte *userKey, unsigned int length)
{
	AssertValidKeyLength(length);

	static const word32 offset[ROUNDS] = {
	0x01000000UL, 0x02000000UL, 0x04000000UL, 0x08000000UL,
	0x10000000UL, 0x20000000UL, 0x40000000UL, 0x80000000UL,
	};

	GetUserKey(BIG_ENDIAN_ORDER, roundkeys[0], KEYLENGTH/4, userKey, KEYLENGTH);

	/* apply the key evolution function */
	for (int i = 1; i < ROUNDS+1; i++)
	{
		roundkeys[i][0] = roundkeys[i-1][0] ^ rotlFixed(roundkeys[i-1][3], 8U) ^ offset[i-1];
		roundkeys[i][1] = roundkeys[i-1][1] ^ roundkeys[i][0];
		roundkeys[i][2] = roundkeys[i-1][2] ^ roundkeys[i][1];
		roundkeys[i][3] = roundkeys[i-1][3] ^ roundkeys[i][2];
	}  

	/* produce the round keys */
	if (dir == ENCRYPTION)
	{
		for (int i = 0; i < ROUNDS; i++)
			SquareTransform (roundkeys[i], roundkeys[i]);
	}
	else
	{
		for (int i = 0; i < ROUNDS/2; i++)
			for (int j = 0; j < 4; j++)
				std::swap(roundkeys[i][j], roundkeys[ROUNDS-i][j]);
		SquareTransform (roundkeys[ROUNDS], roundkeys[ROUNDS]);
	}
}

#define MSB(x) (((x) >> 24) & 0xffU)	/* most  significant byte */
#define SSB(x) (((x) >> 16) & 0xffU)	/* second in significance */
#define TSB(x) (((x) >>  8) & 0xffU)	/* third  in significance */
#define LSB(x) (((x)      ) & 0xffU)	/* least significant byte */

#define squareRound(text, temp, T0, T1, T2, T3, roundkey) \
{ \
	temp[0] = T0[MSB (text[0])] \
			^ T1[MSB (text[1])] \
			^ T2[MSB (text[2])] \
			^ T3[MSB (text[3])] \
			^ roundkey[0]; \
	temp[1] = T0[SSB (text[0])] \
			^ T1[SSB (text[1])] \
			^ T2[SSB (text[2])] \
			^ T3[SSB (text[3])] \
			^ roundkey[1]; \
	temp[2] = T0[TSB (text[0])] \
			^ T1[TSB (text[1])] \
			^ T2[TSB (text[2])] \
			^ T3[TSB (text[3])] \
			^ roundkey[2]; \
	temp[3] = T0[LSB (text[0])] \
			^ T1[LSB (text[1])] \
			^ T2[LSB (text[2])] \
			^ T3[LSB (text[3])] \
			^ roundkey[3]; \
} /* squareRound */

#define squareFinal(text, temp, S, roundkey) \
{ \
	text[0] = ((word32) (S[MSB (temp[0])]) << 24) \
			^ ((word32) (S[MSB (temp[1])]) << 16) \
			^ ((word32) (S[MSB (temp[2])]) <<  8) \
			^  (word32) (S[MSB (temp[3])]) \
			^ roundkey[0]; \
	text[1] = ((word32) (S[SSB (temp[0])]) << 24) \
			^ ((word32) (S[SSB (temp[1])]) << 16) \
			^ ((word32) (S[SSB (temp[2])]) <<  8) \
			^  (word32) (S[SSB (temp[3])]) \
			^ roundkey[1]; \
	text[2] = ((word32) (S[TSB (temp[0])]) << 24) \
			^ ((word32) (S[TSB (temp[1])]) << 16) \
			^ ((word32) (S[TSB (temp[2])]) <<  8) \
			^  (word32) (S[TSB (temp[3])]) \
			^ roundkey[2]; \
	text[3] = ((word32) (S[LSB (temp[0])]) << 24) \
			^ ((word32) (S[LSB (temp[1])]) << 16) \
			^ ((word32) (S[LSB (temp[2])]) <<  8) \
			^  (word32) (S[LSB (temp[3])]) \
			^ roundkey[3]; \
} /* squareFinal */

typedef BlockGetAndPut<word32, BigEndian> Block;

void Square::Enc::ProcessAndXorBlock(const byte *inBlock, const byte *xorBlock, byte *outBlock) const
{
	word32 text[4], temp[4];
	Block::Get(inBlock)(text[0])(text[1])(text[2])(text[3]);
   
	/* initial key addition */
	text[0] ^= roundkeys[0][0];
	text[1] ^= roundkeys[0][1];
	text[2] ^= roundkeys[0][2];
	text[3] ^= roundkeys[0][3];
 
	/* ROUNDS - 1 full rounds */
	for (int i=1; i+1<ROUNDS; i+=2)
	{
		squareRound (text, temp, Te[0], Te[1], Te[2], Te[3], roundkeys[i]);
		squareRound (temp, text, Te[0], Te[1], Te[2], Te[3], roundkeys[i+1]);
	}
	squareRound (text, temp, Te[0], Te[1], Te[2], Te[3], roundkeys[ROUNDS-1]);

	/* last round (diffusion becomes only transposition) */
	squareFinal (text, temp, Se, roundkeys[ROUNDS]);

	Block::Put(xorBlock, outBlock)(text[0])(text[1])(text[2])(text[3]);
}

void Square::Dec::ProcessAndXorBlock(const byte *inBlock, const byte *xorBlock, byte *outBlock) const
{
	word32 text[4], temp[4];
	Block::Get(inBlock)(text[0])(text[1])(text[2])(text[3]);
   
	/* initial key addition */
	text[0] ^= roundkeys[0][0];
	text[1] ^= roundkeys[0][1];
	text[2] ^= roundkeys[0][2];
	text[3] ^= roundkeys[0][3];
 
	/* ROUNDS - 1 full rounds */
	for (int i=1; i+1<ROUNDS; i+=2)
	{
		squareRound (text, temp, Td[0], Td[1], Td[2], Td[3], roundkeys[i]);
		squareRound (temp, text, Td[0], Td[1], Td[2], Td[3], roundkeys[i+1]);
	}
	squareRound (text, temp, Td[0], Td[1], Td[2], Td[3], roundkeys[ROUNDS-1]);

	/* last round (diffusion becomes only transposition) */
	squareFinal (text, temp, Sd, roundkeys[ROUNDS]);

	Block::Put(xorBlock, outBlock)(text[0])(text[1])(text[2])(text[3]);
}

NAMESPACE_END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区精美| 日韩一区二区三区免费看| 精品一区二区三区免费播放| 亚洲国产日韩综合久久精品| 一区二区三区日韩精品| 亚洲免费视频中文字幕| 亚洲精品高清视频在线观看| 亚洲六月丁香色婷婷综合久久 | 欧美日韩精品一区二区三区| 一本色道综合亚洲| 日韩美女在线视频| 欧美一级片在线观看| 欧美大胆人体bbbb| 久久久精品综合| 国产精品―色哟哟| 亚洲中国最大av网站| 亚洲成人777| 国产精品一线二线三线| 国产不卡高清在线观看视频| 99在线精品免费| 欧美久久久久久蜜桃| 精品国产一区二区三区久久影院| 久久综合网色—综合色88| 中文字幕第一区二区| 亚洲综合一区在线| 捆绑紧缚一区二区三区视频| 狠狠色综合色综合网络| 9i看片成人免费高清| 欧美日韩国产在线播放网站| 精品久久人人做人人爽| 亚洲欧美日韩综合aⅴ视频| 五月天网站亚洲| 国产成人av电影免费在线观看| 色综合久久综合网| 精品国产一区a| 一区二区三区加勒比av| 韩国成人福利片在线播放| 色哟哟欧美精品| 精品福利一区二区三区免费视频| 亚洲人精品一区| 九色综合狠狠综合久久| 色噜噜狠狠成人中文综合| 日韩精品专区在线| 亚洲永久精品国产| 国产精品888| 91精品国产综合久久久蜜臀图片 | 国产一区二区在线电影| 在线一区二区三区四区五区 | 99久免费精品视频在线观看| 欧美精品久久天天躁| 国产精品久久久久精k8| 精品无人码麻豆乱码1区2区| 欧洲视频一区二区| 国产精品毛片a∨一区二区三区| 日av在线不卡| 在线观看日韩国产| 亚洲素人一区二区| 国产成人精品一区二区三区四区 | 国产亚洲人成网站| 日韩av一区二区在线影视| 99久久免费精品| 国产亚洲福利社区一区| 久久国产精品无码网站| 欧美一区二区三区视频在线| 亚洲综合激情小说| 99久久精品久久久久久清纯| 国产欧美久久久精品影院| 精品一区二区免费在线观看| 欧美一级夜夜爽| 视频一区在线视频| 欧美乱熟臀69xxxxxx| 亚洲最大色网站| 在线国产亚洲欧美| 亚洲女人的天堂| 91麻豆高清视频| 亚洲乱码中文字幕| 欧美在线免费观看亚洲| 亚洲一区二区三区美女| 欧美色爱综合网| 香蕉影视欧美成人| 欧美肥妇bbw| 青青草伊人久久| 91麻豆精品国产91久久久久久 | 香蕉av福利精品导航| 欧美私模裸体表演在线观看| 亚洲曰韩产成在线| 欧美精品一卡二卡| 久久精品av麻豆的观看方式| 欧美成人综合网站| 福利一区二区在线观看| 中文字幕中文乱码欧美一区二区| av电影在线观看一区| 伊人性伊人情综合网| 欧美日韩免费电影| 精品一区二区三区日韩| 中文字幕不卡在线| 在线免费观看日本欧美| 日本亚洲电影天堂| 国产日韩欧美电影| 色婷婷久久一区二区三区麻豆| 亚洲成精国产精品女| 精品国产91乱码一区二区三区| 韩国女主播一区二区三区| 国产精品色一区二区三区| 在线观看日韩av先锋影音电影院| 日韩av一区二区三区四区| 国产亚洲一本大道中文在线| 91国在线观看| 国产在线不卡一区| 一级精品视频在线观看宜春院| 欧美一区二区视频网站| gogo大胆日本视频一区| 日韩国产欧美在线播放| 国产精品欧美精品| 欧美一区二区在线观看| 波波电影院一区二区三区| 日韩综合一区二区| 国产精品人成在线观看免费| 69久久99精品久久久久婷婷 | 日本不卡的三区四区五区| 国产欧美日韩不卡| 欧美一区二区三区在线看| 91丝袜美腿高跟国产极品老师 | 91亚洲精品乱码久久久久久蜜桃 | 亚洲人成网站在线| 久久综合久久综合亚洲| 欧美日韩国产三级| 99麻豆久久久国产精品免费| 久久99蜜桃精品| 午夜欧美大尺度福利影院在线看| 国产欧美一区二区精品性色超碰| 欧美老女人在线| 色综合天天天天做夜夜夜夜做| 国产老肥熟一区二区三区| 丝袜国产日韩另类美女| 亚洲激情网站免费观看| 国产精品女主播在线观看| 久久亚洲欧美国产精品乐播 | 成人久久久精品乱码一区二区三区| 午夜精品国产更新| 一区二区三区四区在线免费观看| 久久久九九九九| 久久综合国产精品| 欧美电影精品一区二区| 日韩一区二区在线看| 欧美久久久久久久久久| 欧美日韩亚州综合| 欧美日韩性生活| 欧美高清www午色夜在线视频| 欧美熟乱第一页| 欧美日韩另类一区| 欧美日韩精品久久久| 欧美久久婷婷综合色| 欧美日韩一区二区欧美激情| 欧美午夜电影一区| 欧美日韩国产综合久久| 5566中文字幕一区二区电影| 91精选在线观看| 日韩欧美国产不卡| 久久婷婷成人综合色| 国产午夜精品一区二区三区视频 | 91老师片黄在线观看| 一本大道久久a久久综合婷婷 | 亚洲在线视频免费观看| 亚洲国产一区在线观看| 日韩在线卡一卡二| 精品一区二区三区香蕉蜜桃| 国产成人午夜视频| 不卡一区二区三区四区| 91福利视频在线| 91精品国产综合久久久蜜臀图片| 日韩一级片在线观看| 国产视频一区不卡| 亚洲三级在线观看| 日韩一区欧美二区| 国产精品自在在线| 色婷婷激情久久| 日韩午夜在线影院| 亚洲国产成人一区二区三区| 亚洲女与黑人做爰| 免费成人在线影院| www.欧美亚洲| 欧美日韩www| 国产精品蜜臀在线观看| 五月婷婷激情综合网| 国产最新精品免费| 色婷婷激情久久| 久久这里都是精品| 亚洲国产精品影院| 国产98色在线|日韩| 欧美日本免费一区二区三区| 久久精品一区二区三区四区| 一级中文字幕一区二区| 国产乱人伦偷精品视频免下载| 日本乱人伦一区| 国产欧美日韩卡一| 美洲天堂一区二卡三卡四卡视频| 成人免费观看视频| 日韩欧美国产一区二区三区| 亚洲激情图片一区|