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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? misc.h

?? 研讀AxCrypt對加解密的處理方法
?? H
?? 第 1 頁 / 共 2 頁
字號:
	// PPC: load reverse indexed instruction
	return (word32)__lwbrx(&value,0);
#elif defined(FAST_ROTATE)
	// 5 instructions with rotate instruction, 9 without
	return (rotrFixed(value, 8U) & 0xff00ff00) | (rotlFixed(value, 8U) & 0x00ff00ff);
#else
	// 6 instructions with rotate instruction, 8 without
	value = ((value & 0xFF00FF00) >> 8) | ((value & 0x00FF00FF) << 8);
	return rotlFixed(value, 16U);
#endif
}

#ifdef WORD64_AVAILABLE
inline word64 ByteReverse(word64 value)
{
#ifdef CRYPTOPP_SLOW_WORD64
	return (word64(ByteReverse(word32(value))) << 32) | ByteReverse(word32(value>>32));
#else
	value = ((value & W64LIT(0xFF00FF00FF00FF00)) >> 8) | ((value & W64LIT(0x00FF00FF00FF00FF)) << 8);
	value = ((value & W64LIT(0xFFFF0000FFFF0000)) >> 16) | ((value & W64LIT(0x0000FFFF0000FFFF)) << 16);
	return rotlFixed(value, 32U);
#endif
}
#endif

inline byte BitReverse(byte value)
{
	value = ((value & 0xAA) >> 1) | ((value & 0x55) << 1);
	value = ((value & 0xCC) >> 2) | ((value & 0x33) << 2);
	return rotlFixed(value, 4);
}

inline word16 BitReverse(word16 value)
{
	value = ((value & 0xAAAA) >> 1) | ((value & 0x5555) << 1);
	value = ((value & 0xCCCC) >> 2) | ((value & 0x3333) << 2);
	value = ((value & 0xF0F0) >> 4) | ((value & 0x0F0F) << 4);
	return ByteReverse(value);
}

inline word32 BitReverse(word32 value)
{
	value = ((value & 0xAAAAAAAA) >> 1) | ((value & 0x55555555) << 1);
	value = ((value & 0xCCCCCCCC) >> 2) | ((value & 0x33333333) << 2);
	value = ((value & 0xF0F0F0F0) >> 4) | ((value & 0x0F0F0F0F) << 4);
	return ByteReverse(value);
}

#ifdef WORD64_AVAILABLE
inline word64 BitReverse(word64 value)
{
#ifdef CRYPTOPP_SLOW_WORD64
	return (word64(BitReverse(word32(value))) << 32) | BitReverse(word32(value>>32));
#else
	value = ((value & W64LIT(0xAAAAAAAAAAAAAAAA)) >> 1) | ((value & W64LIT(0x5555555555555555)) << 1);
	value = ((value & W64LIT(0xCCCCCCCCCCCCCCCC)) >> 2) | ((value & W64LIT(0x3333333333333333)) << 2);
	value = ((value & W64LIT(0xF0F0F0F0F0F0F0F0)) >> 4) | ((value & W64LIT(0x0F0F0F0F0F0F0F0F)) << 4);
	return ByteReverse(value);
#endif
}
#endif

template <class T>
inline T BitReverse(T value)
{
	if (sizeof(T) == 1)
		return (T)BitReverse((byte)value);
	else if (sizeof(T) == 2)
		return (T)BitReverse((word16)value);
	else if (sizeof(T) == 4)
		return (T)BitReverse((word32)value);
	else
	{
#ifdef WORD64_AVAILABLE
		assert(sizeof(T) == 8);
		return (T)BitReverse((word64)value);
#else
		assert(false);
		return 0;
#endif
	}
}

template <class T>
inline T ConditionalByteReverse(ByteOrder order, T value)
{
	return NativeByteOrderIs(order) ? value : ByteReverse(value);
}

template <class T>
void ByteReverse(T *out, const T *in, unsigned int byteCount)
{
	assert(byteCount % sizeof(T) == 0);
	unsigned int count = byteCount/sizeof(T);
	for (unsigned int i=0; i<count; i++)
		out[i] = ByteReverse(in[i]);
}

template <class T>
inline void ConditionalByteReverse(ByteOrder order, T *out, const T *in, unsigned int byteCount)
{
	if (!NativeByteOrderIs(order))
		ByteReverse(out, in, byteCount);
	else if (in != out)
		memcpy(out, in, byteCount);
}

template <class T>
inline void GetUserKey(ByteOrder order, T *out, unsigned int outlen, const byte *in, unsigned int inlen)
{
	const unsigned int U = sizeof(T);
	assert(inlen <= outlen*U);
	memcpy(out, in, inlen);
	memset((byte *)out+inlen, 0, outlen*U-inlen);
	ConditionalByteReverse(order, out, out, RoundUpToMultipleOf(inlen, U));
}

inline byte UnalignedGetWordNonTemplate(ByteOrder order, const byte *block, byte*)
{
	return block[0];
}

inline word16 UnalignedGetWordNonTemplate(ByteOrder order, const byte *block, word16*)
{
	return (order == BIG_ENDIAN_ORDER)
		? block[1] | (block[0] << 8)
		: block[0] | (block[1] << 8);
}

inline word32 UnalignedGetWordNonTemplate(ByteOrder order, const byte *block, word32*)
{
	return (order == BIG_ENDIAN_ORDER)
		? word32(block[3]) | (word32(block[2]) << 8) | (word32(block[1]) << 16) | (word32(block[0]) << 24)
		: word32(block[0]) | (word32(block[1]) << 8) | (word32(block[2]) << 16) | (word32(block[3]) << 24);
}

#ifdef WORD64_AVAILABLE
inline word64 UnalignedGetWordNonTemplate(ByteOrder order, const byte *block, word64*)
{
	return (order == BIG_ENDIAN_ORDER)
		?
		(word64(block[7]) |
		(word64(block[6]) <<  8) |
		(word64(block[5]) << 16) |
		(word64(block[4]) << 24) |
		(word64(block[3]) << 32) |
		(word64(block[2]) << 40) |
		(word64(block[1]) << 48) |
		(word64(block[0]) << 56))
		:
		(word64(block[0]) |
		(word64(block[1]) <<  8) |
		(word64(block[2]) << 16) |
		(word64(block[3]) << 24) |
		(word64(block[4]) << 32) |
		(word64(block[5]) << 40) |
		(word64(block[6]) << 48) |
		(word64(block[7]) << 56));
}
#endif

template <class T>
inline T UnalignedGetWord(ByteOrder order, const byte *block, T*dummy=NULL)
{
	return UnalignedGetWordNonTemplate(order, block, dummy);
}

inline void UnalignedPutWord(ByteOrder order, byte *block, byte value, const byte *xorBlock = NULL)
{
	block[0] = xorBlock ? (value ^ xorBlock[0]) : value;
}

inline void UnalignedPutWord(ByteOrder order, byte *block, word16 value, const byte *xorBlock = NULL)
{
	if (order == BIG_ENDIAN_ORDER)
	{
		block[0] = GETBYTE(value, 1);
		block[1] = GETBYTE(value, 0);
	}
	else
	{
		block[0] = GETBYTE(value, 0);
		block[1] = GETBYTE(value, 1);
	}

	if (xorBlock)
	{
		block[0] ^= xorBlock[0];
		block[1] ^= xorBlock[1];
	}
}

inline void UnalignedPutWord(ByteOrder order, byte *block, word32 value, const byte *xorBlock = NULL)
{
	if (order == BIG_ENDIAN_ORDER)
	{
		block[0] = GETBYTE(value, 3);
		block[1] = GETBYTE(value, 2);
		block[2] = GETBYTE(value, 1);
		block[3] = GETBYTE(value, 0);
	}
	else
	{
		block[0] = GETBYTE(value, 0);
		block[1] = GETBYTE(value, 1);
		block[2] = GETBYTE(value, 2);
		block[3] = GETBYTE(value, 3);
	}

	if (xorBlock)
	{
		block[0] ^= xorBlock[0];
		block[1] ^= xorBlock[1];
		block[2] ^= xorBlock[2];
		block[3] ^= xorBlock[3];
	}
}

#ifdef WORD64_AVAILABLE
inline void UnalignedPutWord(ByteOrder order, byte *block, word64 value, const byte *xorBlock = NULL)
{
	if (order == BIG_ENDIAN_ORDER)
	{
		block[0] = GETBYTE(value, 7);
		block[1] = GETBYTE(value, 6);
		block[2] = GETBYTE(value, 5);
		block[3] = GETBYTE(value, 4);
		block[4] = GETBYTE(value, 3);
		block[5] = GETBYTE(value, 2);
		block[6] = GETBYTE(value, 1);
		block[7] = GETBYTE(value, 0);
	}
	else
	{
		block[0] = GETBYTE(value, 0);
		block[1] = GETBYTE(value, 1);
		block[2] = GETBYTE(value, 2);
		block[3] = GETBYTE(value, 3);
		block[4] = GETBYTE(value, 4);
		block[5] = GETBYTE(value, 5);
		block[6] = GETBYTE(value, 6);
		block[7] = GETBYTE(value, 7);
	}

	if (xorBlock)
	{
		block[0] ^= xorBlock[0];
		block[1] ^= xorBlock[1];
		block[2] ^= xorBlock[2];
		block[3] ^= xorBlock[3];
		block[4] ^= xorBlock[4];
		block[5] ^= xorBlock[5];
		block[6] ^= xorBlock[6];
		block[7] ^= xorBlock[7];
	}
}
#endif

template <class T>
inline T GetWord(bool assumeAligned, ByteOrder order, const byte *block)
{
	if (assumeAligned)
	{
		assert(IsAligned<T>(block));
		return ConditionalByteReverse(order, *reinterpret_cast<const T *>(block));
	}
	else
		return UnalignedGetWord<T>(order, block);
}

template <class T>
inline void GetWord(bool assumeAligned, ByteOrder order, T &result, const byte *block)
{
	result = GetWord<T>(assumeAligned, order, block);
}

template <class T>
inline void PutWord(bool assumeAligned, ByteOrder order, byte *block, T value, const byte *xorBlock = NULL)
{
	if (assumeAligned)
	{
		assert(IsAligned<T>(block));
		if (xorBlock)
			*reinterpret_cast<T *>(block) = ConditionalByteReverse(order, value) ^ *reinterpret_cast<const T *>(xorBlock);
		else
			*reinterpret_cast<T *>(block) = ConditionalByteReverse(order, value);
	}
	else
		UnalignedPutWord(order, block, value, xorBlock);
}

template <class T, class B, bool A=true>
class GetBlock
{
public:
	GetBlock(const void *block)
		: m_block((const byte *)block) {}

	template <class U>
	inline GetBlock<T, B, A> & operator()(U &x)
	{
		CRYPTOPP_COMPILE_ASSERT(sizeof(U) >= sizeof(T));
		x = GetWord<T>(A, B::ToEnum(), m_block);
		m_block += sizeof(T);
		return *this;
	}

private:
	const byte *m_block;
};

template <class T, class B, bool A=true>
class PutBlock
{
public:
	PutBlock(const void *xorBlock, void *block)
		: m_xorBlock((const byte *)xorBlock), m_block((byte *)block) {}

	template <class U>
	inline PutBlock<T, B, A> & operator()(U x)
	{
		PutWord(A, B::ToEnum(), m_block, (T)x, m_xorBlock);
		m_block += sizeof(T);
		if (m_xorBlock)
			m_xorBlock += sizeof(T);
		return *this;
	}

private:
	const byte *m_xorBlock;
	byte *m_block;
};

template <class T, class B, bool A=true>
struct BlockGetAndPut
{
	// function needed because of C++ grammatical ambiguity between expression-statements and declarations
	static inline GetBlock<T, B, A> Get(const void *block) {return GetBlock<T, B, A>(block);}
	typedef PutBlock<T, B, A> Put;
};

template <class T>
std::string WordToString(T value, ByteOrder order = BIG_ENDIAN_ORDER)
{
	if (!NativeByteOrderIs(order))
		value = ByteReverse(value);

	return std::string((char *)&value, sizeof(value));
}

template <class T>
T StringToWord(const std::string &str, ByteOrder order = BIG_ENDIAN_ORDER)
{
	T value = 0;
	memcpy(&value, str.data(), STDMIN(sizeof(value), str.size()));
	return NativeByteOrderIs(order) ? value : ByteReverse(value);
}

// ************** help remove warning on g++ ***************

template <bool overflow> struct SafeShifter;

template<> struct SafeShifter<true>
{
	template <class T>
	static inline T RightShift(T value, unsigned int bits)
	{
		return 0;
	}

	template <class T>
	static inline T LeftShift(T value, unsigned int bits)
	{
		return 0;
	}
};

template<> struct SafeShifter<false>
{
	template <class T>
	static inline T RightShift(T value, unsigned int bits)
	{
		return value >> bits;
	}

	template <class T>
	static inline T LeftShift(T value, unsigned int bits)
	{
		return value << bits;
	}
};

template <unsigned int bits, class T>
inline T SafeRightShift(T value)
{
	return SafeShifter<(bits>=(8*sizeof(T)))>::RightShift(value, bits);
}

template <unsigned int bits, class T>
inline T SafeLeftShift(T value)
{
	return SafeShifter<(bits>=(8*sizeof(T)))>::LeftShift(value, bits);
}

NAMESPACE_END

#endif // MISC_H

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩国产在线观看一区| 国模无码大尺度一区二区三区| 成人免费高清视频| 亚洲激情六月丁香| 国产精品久久久久久久久久久免费看| 成人黄色免费短视频| 一区二区三区中文在线| 欧美一二三区在线| 国产揄拍国内精品对白| 欧美激情一区三区| 制服丝袜国产精品| gogo大胆日本视频一区| 免费高清在线一区| 亚洲乱码国产乱码精品精可以看| 日韩欧美三级在线| 在线视频欧美区| 国产精品66部| 日韩高清在线不卡| 亚洲男人都懂的| 欧美精品一区二区精品网| 在线观看av一区二区| 国产精品一区一区| 青青草原综合久久大伊人精品优势| 国产精品人人做人人爽人人添| 91精品久久久久久蜜臀| 99久久精品免费| 国产伦精品一区二区三区免费迷 | 国产精品99久久久久久久女警| 亚洲精品成人在线| 国产精品入口麻豆原神| 精品国产免费久久| 欧美二区在线观看| 久久久精品中文字幕麻豆发布| 亚洲免费av在线| 久久久久综合网| 色婷婷av一区二区三区之一色屋| 精品综合久久久久久8888| 久久久国际精品| 欧美一区2区视频在线观看| 成人理论电影网| 狠狠色狠狠色综合| 久久精品国产一区二区| 日韩精彩视频在线观看| 亚洲国产综合色| 国产精品成人一区二区三区夜夜夜| 欧美xxxxx裸体时装秀| 在线观看91av| 欧美精品aⅴ在线视频| 欧美在线免费观看亚洲| 色综合久久久久久久久| 99久久久精品| 91丨九色丨蝌蚪富婆spa| 99精品一区二区| 成人的网站免费观看| 国产·精品毛片| 日韩视频永久免费| 色噜噜夜夜夜综合网| 国产激情视频一区二区在线观看| 狠狠色丁香婷婷综合久久片| 韩国av一区二区三区| 一本在线高清不卡dvd| 成人avav影音| 99精品国产视频| 一本到三区不卡视频| 97超碰欧美中文字幕| 97aⅴ精品视频一二三区| 972aa.com艺术欧美| 91精品福利视频| 欧美性色综合网| 欧美三级电影网| 在线不卡欧美精品一区二区三区| 在线亚洲人成电影网站色www| 91免费国产视频网站| 91国偷自产一区二区开放时间 | 欧美在线免费观看亚洲| 欧美性感一区二区三区| 91精品国产91综合久久蜜臀| 91精品国产欧美日韩| 精品欧美乱码久久久久久1区2区| 久久一区二区三区四区| 中文在线一区二区| 一区二区在线免费| 午夜精品久久久久影视| 人人精品人人爱| 黄色成人免费在线| 国产伦精品一区二区三区免费| 国产精品18久久久| 成人久久18免费网站麻豆| 成人午夜电影久久影院| 在线视频综合导航| 免费人成黄页网站在线一区二区| 亚洲欧美日韩系列| 丝袜美腿亚洲一区| 国产在线播精品第三| 99精品视频在线播放观看| 欧美丰满少妇xxxxx高潮对白 | 久久精品久久99精品久久| 国产精品影音先锋| 在线观看不卡视频| 欧美一区二区播放| 久久久久久久久蜜桃| 亚洲免费观看在线观看| 日韩精彩视频在线观看| 成人免费毛片aaaaa**| 欧美三级蜜桃2在线观看| 久久久久久久精| 一区二区三区久久久| 香蕉加勒比综合久久| 风间由美中文字幕在线看视频国产欧美| 色综合久久久网| 久久无码av三级| 亚洲一二三四久久| 99国产精品国产精品毛片| 国产三级一区二区三区| www.欧美日韩国产在线| 盗摄精品av一区二区三区| 欧美日韩一区二区三区不卡| 欧美另类高清zo欧美| 国产精品狼人久久影院观看方式| 日本女优在线视频一区二区| 91玉足脚交白嫩脚丫在线播放| 欧美白人最猛性xxxxx69交| 精品一区二区三区影院在线午夜| 日本高清不卡视频| 国产精品久久久久久久第一福利| 美女一区二区在线观看| 欧美在线观看视频在线| 国产精品嫩草99a| 久久99国产乱子伦精品免费| 亚洲乱码国产乱码精品精可以看| 男男成人高潮片免费网站| proumb性欧美在线观看| 国产午夜久久久久| 毛片一区二区三区| 欧美精品久久久久久久多人混战| 中文字幕亚洲不卡| 国产成人综合自拍| 2020国产精品自拍| 蜜桃视频在线观看一区二区| 欧美色视频在线| 亚洲欧美日韩成人高清在线一区| 国产一区美女在线| 日韩三级av在线播放| 午夜精彩视频在线观看不卡| 色婷婷av一区二区三区软件| 国产精品妹子av| 国产成人小视频| 国产婷婷一区二区| 国产又黄又大久久| 欧美精品一区在线观看| 国精产品一区一区三区mba桃花| 欧美日韩免费观看一区二区三区 | 国产麻豆精品一区二区| 色狠狠桃花综合| 亚洲欧洲av在线| 99久久99精品久久久久久 | 国产欧美一区二区三区在线老狼| 精品综合久久久久久8888| 亚洲精品在线观| 国产一区三区三区| 26uuu色噜噜精品一区二区| 国产一区欧美二区| 国产欧美一区二区三区鸳鸯浴| 国产精品一区二区久激情瑜伽| 久久精品人人做人人综合 | 久久精品综合网| 成人av电影在线播放| 亚洲色图视频免费播放| 色欧美日韩亚洲| 日韩中文欧美在线| 欧美xxx久久| 成人免费电影视频| 一区二区三区中文在线观看| 69p69国产精品| 国产一区二区三区四区五区入口| 亚洲永久精品大片| 欧美性大战久久久久久久 | 欧美日韩国产片| 视频一区中文字幕国产| 欧美一级生活片| 国产成人精品影视| 亚洲精品亚洲人成人网在线播放| 欧美日韩精品免费观看视频| 亚洲一区二区三区四区在线免费观看| 欧美又粗又大又爽| 亚洲国产成人porn| 日韩女优av电影在线观看| 国产精品自产自拍| 亚洲午夜久久久久久久久久久| 欧美一级高清片在线观看| 不卡区在线中文字幕| 蜜桃久久久久久久| 亚洲激情图片qvod| 国产欧美日韩麻豆91| 91精品欧美综合在线观看最新| 99riav久久精品riav| 狠狠色丁香婷婷综合| 丝袜亚洲另类欧美| 亚洲欧美日韩国产中文在线| 国产视频亚洲色图|