aboutsummaryrefslogtreecommitdiffstats
path: root/src/cipher/blowfish/blowfish.cpp
diff options
context:
space:
mode:
authorlloyd <[email protected]>2008-11-08 19:46:52 +0000
committerlloyd <[email protected]>2008-11-08 19:46:52 +0000
commitf1c459725da56fd8ed5766e7779300182fa26bcf (patch)
tree32295cec92df1155563ae8a535dc695d6800d7f6 /src/cipher/blowfish/blowfish.cpp
parent8dba7b5264403e781bbb86ff61850e4377dca7b9 (diff)
Split ciphers into block and stream ciphers. Move base class headers
Diffstat (limited to 'src/cipher/blowfish/blowfish.cpp')
-rw-r--r--src/cipher/blowfish/blowfish.cpp123
1 files changed, 0 insertions, 123 deletions
diff --git a/src/cipher/blowfish/blowfish.cpp b/src/cipher/blowfish/blowfish.cpp
deleted file mode 100644
index ffca9241f..000000000
--- a/src/cipher/blowfish/blowfish.cpp
+++ /dev/null
@@ -1,123 +0,0 @@
-/*************************************************
-* Blowfish Source File *
-* (C) 1999-2007 Jack Lloyd *
-*************************************************/
-
-#include <botan/blowfish.h>
-#include <botan/loadstor.h>
-
-namespace Botan {
-
-/*************************************************
-* Blowfish Encryption *
-*************************************************/
-void Blowfish::enc(const byte in[], byte out[]) const
- {
- const u32bit* S1 = S + 0;
- const u32bit* S2 = S + 256;
- const u32bit* S3 = S + 512;
- const u32bit* S4 = S + 768;
-
- u32bit L = load_be<u32bit>(in, 0);
- u32bit R = load_be<u32bit>(in, 1);
-
- for(u32bit j = 0; j != 16; j += 2)
- {
- L ^= P[j];
- R ^= ((S1[get_byte(0, L)] + S2[get_byte(1, L)]) ^
- S3[get_byte(2, L)]) + S4[get_byte(3, L)];
-
- R ^= P[j+1];
- L ^= ((S1[get_byte(0, R)] + S2[get_byte(1, R)]) ^
- S3[get_byte(2, R)]) + S4[get_byte(3, R)];
- }
-
- L ^= P[16]; R ^= P[17];
-
- store_be(out, R, L);
- }
-
-/*************************************************
-* Blowfish Decryption *
-*************************************************/
-void Blowfish::dec(const byte in[], byte out[]) const
- {
- const u32bit* S1 = S + 0;
- const u32bit* S2 = S + 256;
- const u32bit* S3 = S + 512;
- const u32bit* S4 = S + 768;
-
- u32bit L = load_be<u32bit>(in, 0);
- u32bit R = load_be<u32bit>(in, 1);
-
- for(u32bit j = 17; j != 1; j -= 2)
- {
- L ^= P[j];
- R ^= ((S1[get_byte(0, L)] + S2[get_byte(1, L)]) ^
- S3[get_byte(2, L)]) + S4[get_byte(3, L)];
-
- R ^= P[j-1];
- L ^= ((S1[get_byte(0, R)] + S2[get_byte(1, R)]) ^
- S3[get_byte(2, R)]) + S4[get_byte(3, R)];
- }
-
- L ^= P[1]; R ^= P[0];
-
- store_be(out, R, L);
- }
-
-/*************************************************
-* Blowfish Key Schedule *
-*************************************************/
-void Blowfish::key(const byte key[], u32bit length)
- {
- clear();
-
- for(u32bit j = 0, k = 0; j != 18; ++j, k += 4)
- P[j] ^= make_u32bit(key[(k ) % length], key[(k+1) % length],
- key[(k+2) % length], key[(k+3) % length]);
-
- u32bit L = 0, R = 0;
- generate_sbox(P, 18, L, R);
- generate_sbox(S, 1024, L, R);
- }
-
-/*************************************************
-* Generate one of the Sboxes *
-*************************************************/
-void Blowfish::generate_sbox(u32bit Box[], u32bit size,
- u32bit& L, u32bit& R) const
- {
- const u32bit* S1 = S + 0;
- const u32bit* S2 = S + 256;
- const u32bit* S3 = S + 512;
- const u32bit* S4 = S + 768;
-
- for(u32bit j = 0; j != size; j += 2)
- {
- for(u32bit k = 0; k != 16; k += 2)
- {
- L ^= P[k];
- R ^= ((S1[get_byte(0, L)] + S2[get_byte(1, L)]) ^
- S3[get_byte(2, L)]) + S4[get_byte(3, L)];
-
- R ^= P[k+1];
- L ^= ((S1[get_byte(0, R)] + S2[get_byte(1, R)]) ^
- S3[get_byte(2, R)]) + S4[get_byte(3, R)];
- }
-
- u32bit T = R; R = L ^ P[16]; L = T ^ P[17];
- Box[j] = L; Box[j+1] = R;
- }
- }
-
-/*************************************************
-* Clear memory of sensitive data *
-*************************************************/
-void Blowfish::clear() throw()
- {
- P.copy(P_INIT, 18);
- S.copy(S_INIT, 1024);
- }
-
-}