Fabcoin Core  0.16.2
P2P Digital Currency
ripemd160.cpp
Go to the documentation of this file.
1 // Copyright (c) 2014-2017 The Bitcoin Core developers
2 // Distributed under the MIT software license, see the accompanying
3 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
4 
5 #include <crypto/ripemd160.h>
6 
7 #include <crypto/common.h>
8 
9 #include <string.h>
10 
11 // Internal implementation code.
12 namespace
13 {
15 namespace ripemd160
16 {
17 uint32_t inline f1(uint32_t x, uint32_t y, uint32_t z) { return x ^ y ^ z; }
18 uint32_t inline f2(uint32_t x, uint32_t y, uint32_t z) { return (x & y) | (~x & z); }
19 uint32_t inline f3(uint32_t x, uint32_t y, uint32_t z) { return (x | ~y) ^ z; }
20 uint32_t inline f4(uint32_t x, uint32_t y, uint32_t z) { return (x & z) | (y & ~z); }
21 uint32_t inline f5(uint32_t x, uint32_t y, uint32_t z) { return x ^ (y | ~z); }
22 
24 void inline Initialize(uint32_t* s)
25 {
26  s[0] = 0x67452301ul;
27  s[1] = 0xEFCDAB89ul;
28  s[2] = 0x98BADCFEul;
29  s[3] = 0x10325476ul;
30  s[4] = 0xC3D2E1F0ul;
31 }
32 
33 uint32_t inline rol(uint32_t x, int i) { return (x << i) | (x >> (32 - i)); }
34 
35 void inline Round(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t f, uint32_t x, uint32_t k, int r)
36 {
37  a = rol(a + f + x + k, r) + e;
38  c = rol(c, 10);
39 }
40 
41 void inline R11(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f1(b, c, d), x, 0, r); }
42 void inline R21(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f2(b, c, d), x, 0x5A827999ul, r); }
43 void inline R31(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f3(b, c, d), x, 0x6ED9EBA1ul, r); }
44 void inline R41(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f4(b, c, d), x, 0x8F1BBCDCul, r); }
45 void inline R51(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f5(b, c, d), x, 0xA953FD4Eul, r); }
46 
47 void inline R12(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f5(b, c, d), x, 0x50A28BE6ul, r); }
48 void inline R22(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f4(b, c, d), x, 0x5C4DD124ul, r); }
49 void inline R32(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f3(b, c, d), x, 0x6D703EF3ul, r); }
50 void inline R42(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f2(b, c, d), x, 0x7A6D76E9ul, r); }
51 void inline R52(uint32_t& a, uint32_t b, uint32_t& c, uint32_t d, uint32_t e, uint32_t x, int r) { Round(a, b, c, d, e, f1(b, c, d), x, 0, r); }
52 
54 void Transform(uint32_t* s, const unsigned char* chunk)
55 {
56  uint32_t a1 = s[0], b1 = s[1], c1 = s[2], d1 = s[3], e1 = s[4];
57  uint32_t a2 = a1, b2 = b1, c2 = c1, d2 = d1, e2 = e1;
58  uint32_t w0 = ReadLE32(chunk + 0), w1 = ReadLE32(chunk + 4), w2 = ReadLE32(chunk + 8), w3 = ReadLE32(chunk + 12);
59  uint32_t w4 = ReadLE32(chunk + 16), w5 = ReadLE32(chunk + 20), w6 = ReadLE32(chunk + 24), w7 = ReadLE32(chunk + 28);
60  uint32_t w8 = ReadLE32(chunk + 32), w9 = ReadLE32(chunk + 36), w10 = ReadLE32(chunk + 40), w11 = ReadLE32(chunk + 44);
61  uint32_t w12 = ReadLE32(chunk + 48), w13 = ReadLE32(chunk + 52), w14 = ReadLE32(chunk + 56), w15 = ReadLE32(chunk + 60);
62 
63  R11(a1, b1, c1, d1, e1, w0, 11);
64  R12(a2, b2, c2, d2, e2, w5, 8);
65  R11(e1, a1, b1, c1, d1, w1, 14);
66  R12(e2, a2, b2, c2, d2, w14, 9);
67  R11(d1, e1, a1, b1, c1, w2, 15);
68  R12(d2, e2, a2, b2, c2, w7, 9);
69  R11(c1, d1, e1, a1, b1, w3, 12);
70  R12(c2, d2, e2, a2, b2, w0, 11);
71  R11(b1, c1, d1, e1, a1, w4, 5);
72  R12(b2, c2, d2, e2, a2, w9, 13);
73  R11(a1, b1, c1, d1, e1, w5, 8);
74  R12(a2, b2, c2, d2, e2, w2, 15);
75  R11(e1, a1, b1, c1, d1, w6, 7);
76  R12(e2, a2, b2, c2, d2, w11, 15);
77  R11(d1, e1, a1, b1, c1, w7, 9);
78  R12(d2, e2, a2, b2, c2, w4, 5);
79  R11(c1, d1, e1, a1, b1, w8, 11);
80  R12(c2, d2, e2, a2, b2, w13, 7);
81  R11(b1, c1, d1, e1, a1, w9, 13);
82  R12(b2, c2, d2, e2, a2, w6, 7);
83  R11(a1, b1, c1, d1, e1, w10, 14);
84  R12(a2, b2, c2, d2, e2, w15, 8);
85  R11(e1, a1, b1, c1, d1, w11, 15);
86  R12(e2, a2, b2, c2, d2, w8, 11);
87  R11(d1, e1, a1, b1, c1, w12, 6);
88  R12(d2, e2, a2, b2, c2, w1, 14);
89  R11(c1, d1, e1, a1, b1, w13, 7);
90  R12(c2, d2, e2, a2, b2, w10, 14);
91  R11(b1, c1, d1, e1, a1, w14, 9);
92  R12(b2, c2, d2, e2, a2, w3, 12);
93  R11(a1, b1, c1, d1, e1, w15, 8);
94  R12(a2, b2, c2, d2, e2, w12, 6);
95 
96  R21(e1, a1, b1, c1, d1, w7, 7);
97  R22(e2, a2, b2, c2, d2, w6, 9);
98  R21(d1, e1, a1, b1, c1, w4, 6);
99  R22(d2, e2, a2, b2, c2, w11, 13);
100  R21(c1, d1, e1, a1, b1, w13, 8);
101  R22(c2, d2, e2, a2, b2, w3, 15);
102  R21(b1, c1, d1, e1, a1, w1, 13);
103  R22(b2, c2, d2, e2, a2, w7, 7);
104  R21(a1, b1, c1, d1, e1, w10, 11);
105  R22(a2, b2, c2, d2, e2, w0, 12);
106  R21(e1, a1, b1, c1, d1, w6, 9);
107  R22(e2, a2, b2, c2, d2, w13, 8);
108  R21(d1, e1, a1, b1, c1, w15, 7);
109  R22(d2, e2, a2, b2, c2, w5, 9);
110  R21(c1, d1, e1, a1, b1, w3, 15);
111  R22(c2, d2, e2, a2, b2, w10, 11);
112  R21(b1, c1, d1, e1, a1, w12, 7);
113  R22(b2, c2, d2, e2, a2, w14, 7);
114  R21(a1, b1, c1, d1, e1, w0, 12);
115  R22(a2, b2, c2, d2, e2, w15, 7);
116  R21(e1, a1, b1, c1, d1, w9, 15);
117  R22(e2, a2, b2, c2, d2, w8, 12);
118  R21(d1, e1, a1, b1, c1, w5, 9);
119  R22(d2, e2, a2, b2, c2, w12, 7);
120  R21(c1, d1, e1, a1, b1, w2, 11);
121  R22(c2, d2, e2, a2, b2, w4, 6);
122  R21(b1, c1, d1, e1, a1, w14, 7);
123  R22(b2, c2, d2, e2, a2, w9, 15);
124  R21(a1, b1, c1, d1, e1, w11, 13);
125  R22(a2, b2, c2, d2, e2, w1, 13);
126  R21(e1, a1, b1, c1, d1, w8, 12);
127  R22(e2, a2, b2, c2, d2, w2, 11);
128 
129  R31(d1, e1, a1, b1, c1, w3, 11);
130  R32(d2, e2, a2, b2, c2, w15, 9);
131  R31(c1, d1, e1, a1, b1, w10, 13);
132  R32(c2, d2, e2, a2, b2, w5, 7);
133  R31(b1, c1, d1, e1, a1, w14, 6);
134  R32(b2, c2, d2, e2, a2, w1, 15);
135  R31(a1, b1, c1, d1, e1, w4, 7);
136  R32(a2, b2, c2, d2, e2, w3, 11);
137  R31(e1, a1, b1, c1, d1, w9, 14);
138  R32(e2, a2, b2, c2, d2, w7, 8);
139  R31(d1, e1, a1, b1, c1, w15, 9);
140  R32(d2, e2, a2, b2, c2, w14, 6);
141  R31(c1, d1, e1, a1, b1, w8, 13);
142  R32(c2, d2, e2, a2, b2, w6, 6);
143  R31(b1, c1, d1, e1, a1, w1, 15);
144  R32(b2, c2, d2, e2, a2, w9, 14);
145  R31(a1, b1, c1, d1, e1, w2, 14);
146  R32(a2, b2, c2, d2, e2, w11, 12);
147  R31(e1, a1, b1, c1, d1, w7, 8);
148  R32(e2, a2, b2, c2, d2, w8, 13);
149  R31(d1, e1, a1, b1, c1, w0, 13);
150  R32(d2, e2, a2, b2, c2, w12, 5);
151  R31(c1, d1, e1, a1, b1, w6, 6);
152  R32(c2, d2, e2, a2, b2, w2, 14);
153  R31(b1, c1, d1, e1, a1, w13, 5);
154  R32(b2, c2, d2, e2, a2, w10, 13);
155  R31(a1, b1, c1, d1, e1, w11, 12);
156  R32(a2, b2, c2, d2, e2, w0, 13);
157  R31(e1, a1, b1, c1, d1, w5, 7);
158  R32(e2, a2, b2, c2, d2, w4, 7);
159  R31(d1, e1, a1, b1, c1, w12, 5);
160  R32(d2, e2, a2, b2, c2, w13, 5);
161 
162  R41(c1, d1, e1, a1, b1, w1, 11);
163  R42(c2, d2, e2, a2, b2, w8, 15);
164  R41(b1, c1, d1, e1, a1, w9, 12);
165  R42(b2, c2, d2, e2, a2, w6, 5);
166  R41(a1, b1, c1, d1, e1, w11, 14);
167  R42(a2, b2, c2, d2, e2, w4, 8);
168  R41(e1, a1, b1, c1, d1, w10, 15);
169  R42(e2, a2, b2, c2, d2, w1, 11);
170  R41(d1, e1, a1, b1, c1, w0, 14);
171  R42(d2, e2, a2, b2, c2, w3, 14);
172  R41(c1, d1, e1, a1, b1, w8, 15);
173  R42(c2, d2, e2, a2, b2, w11, 14);
174  R41(b1, c1, d1, e1, a1, w12, 9);
175  R42(b2, c2, d2, e2, a2, w15, 6);
176  R41(a1, b1, c1, d1, e1, w4, 8);
177  R42(a2, b2, c2, d2, e2, w0, 14);
178  R41(e1, a1, b1, c1, d1, w13, 9);
179  R42(e2, a2, b2, c2, d2, w5, 6);
180  R41(d1, e1, a1, b1, c1, w3, 14);
181  R42(d2, e2, a2, b2, c2, w12, 9);
182  R41(c1, d1, e1, a1, b1, w7, 5);
183  R42(c2, d2, e2, a2, b2, w2, 12);
184  R41(b1, c1, d1, e1, a1, w15, 6);
185  R42(b2, c2, d2, e2, a2, w13, 9);
186  R41(a1, b1, c1, d1, e1, w14, 8);
187  R42(a2, b2, c2, d2, e2, w9, 12);
188  R41(e1, a1, b1, c1, d1, w5, 6);
189  R42(e2, a2, b2, c2, d2, w7, 5);
190  R41(d1, e1, a1, b1, c1, w6, 5);
191  R42(d2, e2, a2, b2, c2, w10, 15);
192  R41(c1, d1, e1, a1, b1, w2, 12);
193  R42(c2, d2, e2, a2, b2, w14, 8);
194 
195  R51(b1, c1, d1, e1, a1, w4, 9);
196  R52(b2, c2, d2, e2, a2, w12, 8);
197  R51(a1, b1, c1, d1, e1, w0, 15);
198  R52(a2, b2, c2, d2, e2, w15, 5);
199  R51(e1, a1, b1, c1, d1, w5, 5);
200  R52(e2, a2, b2, c2, d2, w10, 12);
201  R51(d1, e1, a1, b1, c1, w9, 11);
202  R52(d2, e2, a2, b2, c2, w4, 9);
203  R51(c1, d1, e1, a1, b1, w7, 6);
204  R52(c2, d2, e2, a2, b2, w1, 12);
205  R51(b1, c1, d1, e1, a1, w12, 8);
206  R52(b2, c2, d2, e2, a2, w5, 5);
207  R51(a1, b1, c1, d1, e1, w2, 13);
208  R52(a2, b2, c2, d2, e2, w8, 14);
209  R51(e1, a1, b1, c1, d1, w10, 12);
210  R52(e2, a2, b2, c2, d2, w7, 6);
211  R51(d1, e1, a1, b1, c1, w14, 5);
212  R52(d2, e2, a2, b2, c2, w6, 8);
213  R51(c1, d1, e1, a1, b1, w1, 12);
214  R52(c2, d2, e2, a2, b2, w2, 13);
215  R51(b1, c1, d1, e1, a1, w3, 13);
216  R52(b2, c2, d2, e2, a2, w13, 6);
217  R51(a1, b1, c1, d1, e1, w8, 14);
218  R52(a2, b2, c2, d2, e2, w14, 5);
219  R51(e1, a1, b1, c1, d1, w11, 11);
220  R52(e2, a2, b2, c2, d2, w0, 15);
221  R51(d1, e1, a1, b1, c1, w6, 8);
222  R52(d2, e2, a2, b2, c2, w3, 13);
223  R51(c1, d1, e1, a1, b1, w15, 5);
224  R52(c2, d2, e2, a2, b2, w9, 11);
225  R51(b1, c1, d1, e1, a1, w13, 6);
226  R52(b2, c2, d2, e2, a2, w11, 11);
227 
228  uint32_t t = s[0];
229  s[0] = s[1] + c1 + d2;
230  s[1] = s[2] + d1 + e2;
231  s[2] = s[3] + e1 + a2;
232  s[3] = s[4] + a1 + b2;
233  s[4] = t + b1 + c2;
234 }
235 
236 } // namespace ripemd160
237 
238 } // namespace
239 
241 
243 {
244  ripemd160::Initialize(s);
245 }
246 
247 CRIPEMD160& CRIPEMD160::Write(const unsigned char* data, size_t len)
248 {
249  const unsigned char* end = data + len;
250  size_t bufsize = bytes % 64;
251  if (bufsize && bufsize + len >= 64) {
252  // Fill the buffer, and process it.
253  memcpy(buf + bufsize, data, 64 - bufsize);
254  bytes += 64 - bufsize;
255  data += 64 - bufsize;
256  ripemd160::Transform(s, buf);
257  bufsize = 0;
258  }
259  while (end >= data + 64) {
260  // Process full chunks directly from the source.
261  ripemd160::Transform(s, data);
262  bytes += 64;
263  data += 64;
264  }
265  if (end > data) {
266  // Fill the buffer with what remains.
267  memcpy(buf + bufsize, data, end - data);
268  bytes += end - data;
269  }
270  return *this;
271 }
272 
273 void CRIPEMD160::Finalize(unsigned char hash[OUTPUT_SIZE])
274 {
275  static const unsigned char pad[64] = {0x80};
276  unsigned char sizedesc[8];
277  WriteLE64(sizedesc, bytes << 3);
278  Write(pad, 1 + ((119 - (bytes % 64)) % 64));
279  Write(sizedesc, 8);
280  WriteLE32(hash, s[0]);
281  WriteLE32(hash + 4, s[1]);
282  WriteLE32(hash + 8, s[2]);
283  WriteLE32(hash + 12, s[3]);
284  WriteLE32(hash + 16, s[4]);
285 }
286 
288 {
289  bytes = 0;
290  ripemd160::Initialize(s);
291  return *this;
292 }
#define f1(l, r, km, kr)
Definition: cast.cpp:17
#define Round(a, b, c, d, e, f, g, h, k, w)
Definition: hash_impl.h:23
uint64_t bytes
Definition: ripemd160.h:17
#define c(i)
unsigned char buf[64]
Definition: ripemd160.h:16
#define f2(l, r, km, kr)
Definition: cast.cpp:21
#define a(i)
#define x(i)
#define a1
static const size_t OUTPUT_SIZE
Definition: ripemd160.h:20
CRIPEMD160 & Reset()
Definition: ripemd160.cpp:287
std::vector< byte > bytes
Definition: Common.h:75
#define f3(l, r, km, kr)
Definition: cast.cpp:25
#define b(i, j)
uint32_t s[5]
Definition: ripemd160.h:15
CRIPEMD160 & Write(const unsigned char *data, size_t len)
Definition: ripemd160.cpp:247
#define f(x)
Definition: gost.cpp:57
#define f4(x)
Definition: rijndael.cpp:166
void * memcpy(void *a, const void *b, size_t c)
#define e(i)
Definition: sha.cpp:733
#define d(i)
Definition: sha.cpp:732
#define z(i)
#define a2
void Finalize(unsigned char hash[OUTPUT_SIZE])
Definition: ripemd160.cpp:273
#define rol(x, s)
Definition: Utils.cpp:62
uint8_t const * data
Definition: sha3.h:19
A hasher class for RIPEMD-160.
Definition: ripemd160.h:12
Internal RIPEMD-160 implementation.
Definition: ripemd160.cpp:15