107#define FF(b, c, d) (d ^ (b & (c ^ d)))
108#define FG(b, c, d) FF(d, b, c)
109#define FH(b, c, d) (b ^ c ^ d)
110#define FI(b, c, d) (c ^ (b | ~d))
114#define CYCLIC(w, s) (w = (w << s) | (w >> (32 - s)))
126 while (words < endp) {
139#define OP(a, b, c, d, s, T) \
140 a += FF(b, c, d) + (*cwp++ = SWAP(*words)) + T; \
151 OP(A,
B, C, D, 7, 0xd76aa478);
152 OP(D, A,
B, C, 12, 0xe8c7b756);
153 OP(C, D, A,
B, 17, 0x242070db);
154 OP(
B, C, D, A, 22, 0xc1bdceee);
155 OP(A,
B, C, D, 7, 0xf57c0faf);
156 OP(D, A,
B, C, 12, 0x4787c62a);
157 OP(C, D, A,
B, 17, 0xa8304613);
158 OP(
B, C, D, A, 22, 0xfd469501);
159 OP(A,
B, C, D, 7, 0x698098d8);
160 OP(D, A,
B, C, 12, 0x8b44f7af);
161 OP(C, D, A,
B, 17, 0xffff5bb1);
162 OP(
B, C, D, A, 22, 0x895cd7be);
163 OP(A,
B, C, D, 7, 0x6b901122);
164 OP(D, A,
B, C, 12, 0xfd987193);
165 OP(C, D, A,
B, 17, 0xa679438e);
166 OP(
B, C, D, A, 22, 0x49b40821);
173#define OP(f, a, b, c, d, k, s, T) \
174 a += f(b, c, d) + correct_words[k] + T; \
180 OP(
FG, A,
B, C, D, 1, 5, 0xf61e2562);
181 OP(
FG, D, A,
B, C, 6, 9, 0xc040b340);
182 OP(
FG, C, D, A,
B, 11, 14, 0x265e5a51);
183 OP(
FG,
B, C, D, A, 0, 20, 0xe9b6c7aa);
184 OP(
FG, A,
B, C, D, 5, 5, 0xd62f105d);
185 OP(
FG, D, A,
B, C, 10, 9, 0x02441453);
186 OP(
FG, C, D, A,
B, 15, 14, 0xd8a1e681);
187 OP(
FG,
B, C, D, A, 4, 20, 0xe7d3fbc8);
188 OP(
FG, A,
B, C, D, 9, 5, 0x21e1cde6);
189 OP(
FG, D, A,
B, C, 14, 9, 0xc33707d6);
190 OP(
FG, C, D, A,
B, 3, 14, 0xf4d50d87);
191 OP(
FG,
B, C, D, A, 8, 20, 0x455a14ed);
192 OP(
FG, A,
B, C, D, 13, 5, 0xa9e3e905);
193 OP(
FG, D, A,
B, C, 2, 9, 0xfcefa3f8);
194 OP(
FG, C, D, A,
B, 7, 14, 0x676f02d9);
195 OP(
FG,
B, C, D, A, 12, 20, 0x8d2a4c8a);
198 OP(
FH, A,
B, C, D, 5, 4, 0xfffa3942);
199 OP(
FH, D, A,
B, C, 8, 11, 0x8771f681);
200 OP(
FH, C, D, A,
B, 11, 16, 0x6d9d6122);
201 OP(
FH,
B, C, D, A, 14, 23, 0xfde5380c);
202 OP(
FH, A,
B, C, D, 1, 4, 0xa4beea44);
203 OP(
FH, D, A,
B, C, 4, 11, 0x4bdecfa9);
204 OP(
FH, C, D, A,
B, 7, 16, 0xf6bb4b60);
205 OP(
FH,
B, C, D, A, 10, 23, 0xbebfbc70);
206 OP(
FH, A,
B, C, D, 13, 4, 0x289b7ec6);
207 OP(
FH, D, A,
B, C, 0, 11, 0xeaa127fa);
208 OP(
FH, C, D, A,
B, 3, 16, 0xd4ef3085);
209 OP(
FH,
B, C, D, A, 6, 23, 0x04881d05);
210 OP(
FH, A,
B, C, D, 9, 4, 0xd9d4d039);
211 OP(
FH, D, A,
B, C, 12, 11, 0xe6db99e5);
212 OP(
FH, C, D, A,
B, 15, 16, 0x1fa27cf8);
213 OP(
FH,
B, C, D, A, 2, 23, 0xc4ac5665);
216 OP(
FI, A,
B, C, D, 0, 6, 0xf4292244);
217 OP(
FI, D, A,
B, C, 7, 10, 0x432aff97);
218 OP(
FI, C, D, A,
B, 14, 15, 0xab9423a7);
219 OP(
FI,
B, C, D, A, 5, 21, 0xfc93a039);
220 OP(
FI, A,
B, C, D, 12, 6, 0x655b59c3);
221 OP(
FI, D, A,
B, C, 3, 10, 0x8f0ccc92);
222 OP(
FI, C, D, A,
B, 10, 15, 0xffeff47d);
223 OP(
FI,
B, C, D, A, 1, 21, 0x85845dd1);
224 OP(
FI, A,
B, C, D, 8, 6, 0x6fa87e4f);
225 OP(
FI, D, A,
B, C, 15, 10, 0xfe2ce6e0);
226 OP(
FI, C, D, A,
B, 6, 15, 0xa3014314);
227 OP(
FI,
B, C, D, A, 13, 21, 0x4e0811a1);
228 OP(
FI, A,
B, C, D, 4, 6, 0xf7537e82);
229 OP(
FI, D, A,
B, C, 11, 10, 0xbd3af235);
230 OP(
FI, C, D, A,
B, 2, 15, 0x2ad7d2bb);
231 OP(
FI,
B, C, D, A, 9, 21, 0xeb86d391);
static T sum(const btAlignedObjectArray< T > &items)