9 #include <botan/loadstor.h>
10 #include <botan/rotate.h>
21 A += (D ^ (B & (C ^ D))) + M;
30 A += ((B & C) | (D & (B | C))) + M + 0x5A827999;
39 A += (B ^ C ^ D) + M + 0x6ED9EBA1;
52 for(
size_t i = 0; i != blocks; ++i)
54 load_le(&M[0], input, M.size());
56 FF(A,B,C,D,M[ 0], 3); FF(D,A,B,C,M[ 1], 7);
57 FF(C,D,A,B,M[ 2],11); FF(B,C,D,A,M[ 3],19);
58 FF(A,B,C,D,M[ 4], 3); FF(D,A,B,C,M[ 5], 7);
59 FF(C,D,A,B,M[ 6],11); FF(B,C,D,A,M[ 7],19);
60 FF(A,B,C,D,M[ 8], 3); FF(D,A,B,C,M[ 9], 7);
61 FF(C,D,A,B,M[10],11); FF(B,C,D,A,M[11],19);
62 FF(A,B,C,D,M[12], 3); FF(D,A,B,C,M[13], 7);
63 FF(C,D,A,B,M[14],11); FF(B,C,D,A,M[15],19);
65 GG(A,B,C,D,M[ 0], 3); GG(D,A,B,C,M[ 4], 5);
66 GG(C,D,A,B,M[ 8], 9); GG(B,C,D,A,M[12],13);
67 GG(A,B,C,D,M[ 1], 3); GG(D,A,B,C,M[ 5], 5);
68 GG(C,D,A,B,M[ 9], 9); GG(B,C,D,A,M[13],13);
69 GG(A,B,C,D,M[ 2], 3); GG(D,A,B,C,M[ 6], 5);
70 GG(C,D,A,B,M[10], 9); GG(B,C,D,A,M[14],13);
71 GG(A,B,C,D,M[ 3], 3); GG(D,A,B,C,M[ 7], 5);
72 GG(C,D,A,B,M[11], 9); GG(B,C,D,A,M[15],13);
74 HH(A,B,C,D,M[ 0], 3); HH(D,A,B,C,M[ 8], 9);
75 HH(C,D,A,B,M[ 4],11); HH(B,C,D,A,M[12],15);
76 HH(A,B,C,D,M[ 2], 3); HH(D,A,B,C,M[10], 9);
77 HH(C,D,A,B,M[ 6],11); HH(B,C,D,A,M[14],15);
78 HH(A,B,C,D,M[ 1], 3); HH(D,A,B,C,M[ 9], 9);
79 HH(C,D,A,B,M[ 5],11); HH(B,C,D,A,M[13],15);
80 HH(A,B,C,D,M[ 3], 3); HH(D,A,B,C,M[11], 9);
81 HH(C,D,A,B,M[ 7],11); HH(B,C,D,A,M[15],15);
SecureVector< u32bit > digest
T load_le(const byte in[], size_t off)
size_t hash_block_size() const
void store_le(u16bit in, byte out[2])
T rotate_left(T input, size_t rot)
size_t output_length() const
void compress_n(const byte input[], size_t blocks)
void zeroise(MemoryRegion< T > &vec)