// blowfish.cpp - originally written and placed in the public domain by Wei Dai #include "pch.h" #include "blowfish.h" #include "misc.h" NAMESPACE_BEGIN(CryptoPP) template void Blowfish_Base::UncheckedSetKey(const byte *key_string, unsigned int keylength, const NameValuePairs &) { this->AssertValidKeyLength(keylength); unsigned i, j=0, k; word32 data, dspace[2] = {0, 0}; memcpy(pbox, p_init, sizeof(p_init)); memcpy(sbox, s_init, sizeof(s_init)); // Xor key string into encryption key vector for (i=0 ; iIsForwardTransformation()) for (i=0; i<(Info::ROUNDS+2)/2; i++) std::swap(pbox[i], pbox[Info::ROUNDS+1-i]); } // this version is only used to make pbox and sbox template void Blowfish_Base::crypt_block(const word32 in[2], word32 out[2]) const { word32 left = in[0]; word32 right = in[1]; const word32 *const s=sbox; const word32 *p=pbox; left ^= p[0]; for (unsigned i=0; i void Blowfish_Base::ProcessAndXorBlock(const byte *inBlock, const byte *xorBlock, byte *outBlock) const { typedef BlockGetAndPut Block; word32 left, right; Block::Get(inBlock)(left)(right); const word32 *const s=sbox; const word32 *p=pbox; left ^= p[0]; for (unsigned i=0; i; template class Blowfish_Base; NAMESPACE_END