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)
void store_le(u16bit in, byte out[2])
T rotate_left(T input, size_t rot)
void compress_n(const byte input[], size_t blocks)
size_t output_length() const
size_t hash_block_size() const
void zeroise(MemoryRegion< T > &vec)