-
Notifications
You must be signed in to change notification settings - Fork 8
/
ripemd160.h
146 lines (144 loc) · 8.61 KB
/
ripemd160.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
#define ROL(x, n) (x << n | x >> (32 - n))
#define F(x, y, z) (x ^ y ^ z)
#define G(x, y, z) (x & y | ~x & z)
#define H(x, y, z) ((x | ~y) ^ z)
#define IQ(x, y, z) (x & z | y & ~z)
#define J(x, y, z) (x ^ (y | ~z))
#define FF(a, b, c, d, e, x, s) \
a += F(b, c, d) + x; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define GG(a, b, c, d, e, x, s) \
a += G(b, c, d) + x + 0x5A827999; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define HH(a, b, c, d, e, x, s) \
a += H(b, c, d) + x + 0x6ED9EBA1; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define II(a, b, c, d, e, x, s) \
a += IQ(b, c, d) + x + 0x8F1BBCDC; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define JJ(a, b, c, d, e, x, s) \
a += J(b, c, d) + x + 0xA953FD4E; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define FFF(a, b, c, d, e, x, s) \
a += F(b, c, d) + x; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define GGG(a, b, c, d, e, x, s) \
a += G(b, c, d) + x + 0x7A6D76E9; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define HHH(a, b, c, d, e, x, s) \
a += H(b, c, d) + x + 0x6D703EF3; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define III(a, b, c, d, e, x, s) \
a += IQ(b, c, d) + x + 0x5C4DD124; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define JJJ(a, b, c, d, e, x, s) \
a += J(b, c, d) + x + 0x50A28BE6; \
a = ROL(a, s) + e; \
c = ROL(c, 10);
#define REVERSE(input, output) *((unsigned char*)output + 3) = input; *((unsigned char*)output + 2) = input >> 8; *((unsigned char*)output + 1) = input >> 16; *(unsigned char*)output = input >> 24;
#define RIPEMD160 \
output[0] = 0x67452301; \
output[1] = 0xEFCDAB89; \
output[2] = 0x98BADCFE; \
output[3] = 0x10325476; \
output[4] = 0xC3D2E1F0; \
unsigned chunk[16]; \
REVERSE(input[0], &chunk[0]) REVERSE(input[1], &chunk[1]) \
REVERSE(input[2], &chunk[2]) REVERSE(input[3], &chunk[3]) \
REVERSE(input[4], &chunk[4]) REVERSE(input[5], &chunk[5]) \
REVERSE(input[6], &chunk[6]) REVERSE(input[7], &chunk[7]) \
chunk[8] = 128; chunk[9] = 0; chunk[10] = 0; chunk[11] = 0; \
chunk[12] = 0; chunk[13] = 0; chunk[14] = 256; chunk[15] = 0; \
unsigned aa = output[0], bb = output[1], cc = output[2], dd = output[3], ee = output[4]; \
unsigned aaa = output[0], bbb = output[1], ccc = output[2], ddd = output[3], eee = output[4]; \
FF(aa, bb, cc, dd, ee, chunk[0], 11) FF(ee, aa, bb, cc, dd, chunk[1], 14) \
FF(dd, ee, aa, bb, cc, chunk[2], 15) FF(cc, dd, ee, aa, bb, chunk[3], 12) \
FF(bb, cc, dd, ee, aa, chunk[4], 5) FF(aa, bb, cc, dd, ee, chunk[5], 8) \
FF(ee, aa, bb, cc, dd, chunk[6], 7) FF(dd, ee, aa, bb, cc, chunk[7], 9) \
FF(cc, dd, ee, aa, bb, chunk[8], 11) FF(bb, cc, dd, ee, aa, chunk[9], 13) \
FF(aa, bb, cc, dd, ee, chunk[10], 14) FF(ee, aa, bb, cc, dd, chunk[11], 15) \
FF(dd, ee, aa, bb, cc, chunk[12], 6) FF(cc, dd, ee, aa, bb, chunk[13], 7) \
FF(bb, cc, dd, ee, aa, chunk[14], 9) FF(aa, bb, cc, dd, ee, chunk[15], 8) \
GG(ee, aa, bb, cc, dd, chunk[7], 7) GG(dd, ee, aa, bb, cc, chunk[4], 6) \
GG(cc, dd, ee, aa, bb, chunk[13], 8) GG(bb, cc, dd, ee, aa, chunk[1], 13) \
GG(aa, bb, cc, dd, ee, chunk[10], 11) GG(ee, aa, bb, cc, dd, chunk[6], 9) \
GG(dd, ee, aa, bb, cc, chunk[15], 7) GG(cc, dd, ee, aa, bb, chunk[3], 15) \
GG(bb, cc, dd, ee, aa, chunk[12], 7) GG(aa, bb, cc, dd, ee, chunk[0], 12) \
GG(ee, aa, bb, cc, dd, chunk[9], 15) GG(dd, ee, aa, bb, cc, chunk[5], 9) \
GG(cc, dd, ee, aa, bb, chunk[2], 11) GG(bb, cc, dd, ee, aa, chunk[14], 7) \
GG(aa, bb, cc, dd, ee, chunk[11], 13) GG(ee, aa, bb, cc, dd, chunk[8], 12) \
HH(dd, ee, aa, bb, cc, chunk[3], 11) HH(cc, dd, ee, aa, bb, chunk[10], 13) \
HH(bb, cc, dd, ee, aa, chunk[14], 6) HH(aa, bb, cc, dd, ee, chunk[4], 7) \
HH(ee, aa, bb, cc, dd, chunk[9], 14) HH(dd, ee, aa, bb, cc, chunk[15], 9) \
HH(cc, dd, ee, aa, bb, chunk[8], 13) HH(bb, cc, dd, ee, aa, chunk[1], 15) \
HH(aa, bb, cc, dd, ee, chunk[2], 14) HH(ee, aa, bb, cc, dd, chunk[7], 8) \
HH(dd, ee, aa, bb, cc, chunk[0], 13) HH(cc, dd, ee, aa, bb, chunk[6], 6) \
HH(bb, cc, dd, ee, aa, chunk[13], 5) HH(aa, bb, cc, dd, ee, chunk[11], 12) \
HH(ee, aa, bb, cc, dd, chunk[5], 7) HH(dd, ee, aa, bb, cc, chunk[12], 5) \
II(cc, dd, ee, aa, bb, chunk[1], 11) II(bb, cc, dd, ee, aa, chunk[9], 12) \
II(aa, bb, cc, dd, ee, chunk[11], 14) II(ee, aa, bb, cc, dd, chunk[10], 15) \
II(dd, ee, aa, bb, cc, chunk[0], 14) II(cc, dd, ee, aa, bb, chunk[8], 15) \
II(bb, cc, dd, ee, aa, chunk[12], 9) II(aa, bb, cc, dd, ee, chunk[4], 8) \
II(ee, aa, bb, cc, dd, chunk[13], 9) II(dd, ee, aa, bb, cc, chunk[3], 14) \
II(cc, dd, ee, aa, bb, chunk[7], 5) II(bb, cc, dd, ee, aa, chunk[15], 6) \
II(aa, bb, cc, dd, ee, chunk[14], 8) II(ee, aa, bb, cc, dd, chunk[5], 6) \
II(dd, ee, aa, bb, cc, chunk[6], 5) II(cc, dd, ee, aa, bb, chunk[2], 12) \
JJ(bb, cc, dd, ee, aa, chunk[4], 9) JJ(aa, bb, cc, dd, ee, chunk[0], 15) \
JJ(ee, aa, bb, cc, dd, chunk[5], 5) JJ(dd, ee, aa, bb, cc, chunk[9], 11) \
JJ(cc, dd, ee, aa, bb, chunk[7], 6) JJ(bb, cc, dd, ee, aa, chunk[12], 8) \
JJ(aa, bb, cc, dd, ee, chunk[2], 13) JJ(ee, aa, bb, cc, dd, chunk[10], 12) \
JJ(dd, ee, aa, bb, cc, chunk[14], 5) JJ(cc, dd, ee, aa, bb, chunk[1], 12) \
JJ(bb, cc, dd, ee, aa, chunk[3], 13) JJ(aa, bb, cc, dd, ee, chunk[8], 14) \
JJ(ee, aa, bb, cc, dd, chunk[11], 11) JJ(dd, ee, aa, bb, cc, chunk[6], 8) \
JJ(cc, dd, ee, aa, bb, chunk[15], 5) JJ(bb, cc, dd, ee, aa, chunk[13], 6) \
JJJ(aaa, bbb, ccc, ddd, eee, chunk[5], 8) JJJ(eee, aaa, bbb, ccc, ddd, chunk[14], 9) \
JJJ(ddd, eee, aaa, bbb, ccc, chunk[7], 9) JJJ(ccc, ddd, eee, aaa, bbb, chunk[0], 11) \
JJJ(bbb, ccc, ddd, eee, aaa, chunk[9], 13) JJJ(aaa, bbb, ccc, ddd, eee, chunk[2], 15) \
JJJ(eee, aaa, bbb, ccc, ddd, chunk[11], 15) JJJ(ddd, eee, aaa, bbb, ccc, chunk[4], 5) \
JJJ(ccc, ddd, eee, aaa, bbb, chunk[13], 7) JJJ(bbb, ccc, ddd, eee, aaa, chunk[6], 7) \
JJJ(aaa, bbb, ccc, ddd, eee, chunk[15], 8) JJJ(eee, aaa, bbb, ccc, ddd, chunk[8], 11) \
JJJ(ddd, eee, aaa, bbb, ccc, chunk[1], 14) JJJ(ccc, ddd, eee, aaa, bbb, chunk[10], 14) \
JJJ(bbb, ccc, ddd, eee, aaa, chunk[3], 12) JJJ(aaa, bbb, ccc, ddd, eee, chunk[12], 6) \
III(eee, aaa, bbb, ccc, ddd, chunk[6], 9) III(ddd, eee, aaa, bbb, ccc, chunk[11], 13) \
III(ccc, ddd, eee, aaa, bbb, chunk[3], 15) III(bbb, ccc, ddd, eee, aaa, chunk[7], 7) \
III(aaa, bbb, ccc, ddd, eee, chunk[0], 12) III(eee, aaa, bbb, ccc, ddd, chunk[13], 8) \
III(ddd, eee, aaa, bbb, ccc, chunk[5], 9) III(ccc, ddd, eee, aaa, bbb, chunk[10], 11) \
III(bbb, ccc, ddd, eee, aaa, chunk[14], 7) III(aaa, bbb, ccc, ddd, eee, chunk[15], 7) \
III(eee, aaa, bbb, ccc, ddd, chunk[8], 12) III(ddd, eee, aaa, bbb, ccc, chunk[12], 7) \
III(ccc, ddd, eee, aaa, bbb, chunk[4], 6) III(bbb, ccc, ddd, eee, aaa, chunk[9], 15) \
III(aaa, bbb, ccc, ddd, eee, chunk[1], 13) III(eee, aaa, bbb, ccc, ddd, chunk[2], 11) \
HHH(ddd, eee, aaa, bbb, ccc, chunk[15], 9) HHH(ccc, ddd, eee, aaa, bbb, chunk[5], 7) \
HHH(bbb, ccc, ddd, eee, aaa, chunk[1], 15) HHH(aaa, bbb, ccc, ddd, eee, chunk[3], 11) \
HHH(eee, aaa, bbb, ccc, ddd, chunk[7], 8) HHH(ddd, eee, aaa, bbb, ccc, chunk[14], 6) \
HHH(ccc, ddd, eee, aaa, bbb, chunk[6], 6) HHH(bbb, ccc, ddd, eee, aaa, chunk[9], 14) \
HHH(aaa, bbb, ccc, ddd, eee, chunk[11], 12) HHH(eee, aaa, bbb, ccc, ddd, chunk[8], 13) \
HHH(ddd, eee, aaa, bbb, ccc, chunk[12], 5) HHH(ccc, ddd, eee, aaa, bbb, chunk[2], 14) \
HHH(bbb, ccc, ddd, eee, aaa, chunk[10], 13) HHH(aaa, bbb, ccc, ddd, eee, chunk[0], 13) \
HHH(eee, aaa, bbb, ccc, ddd, chunk[4], 7) HHH(ddd, eee, aaa, bbb, ccc, chunk[13], 5) \
GGG(ccc, ddd, eee, aaa, bbb, chunk[8], 15) GGG(bbb, ccc, ddd, eee, aaa, chunk[6], 5) \
GGG(aaa, bbb, ccc, ddd, eee, chunk[4], 8) GGG(eee, aaa, bbb, ccc, ddd, chunk[1], 11) \
GGG(ddd, eee, aaa, bbb, ccc, chunk[3], 14) GGG(ccc, ddd, eee, aaa, bbb, chunk[11], 14) \
GGG(bbb, ccc, ddd, eee, aaa, chunk[15], 6) GGG(aaa, bbb, ccc, ddd, eee, chunk[0], 14) \
GGG(eee, aaa, bbb, ccc, ddd, chunk[5], 6) GGG(ddd, eee, aaa, bbb, ccc, chunk[12], 9) \
GGG(ccc, ddd, eee, aaa, bbb, chunk[2], 12) GGG(bbb, ccc, ddd, eee, aaa, chunk[13], 9) \
GGG(aaa, bbb, ccc, ddd, eee, chunk[9], 12) GGG(eee, aaa, bbb, ccc, ddd, chunk[7], 5) \
GGG(ddd, eee, aaa, bbb, ccc, chunk[10], 15) GGG(ccc, ddd, eee, aaa, bbb, chunk[14], 8) \
FFF(bbb, ccc, ddd, eee, aaa, chunk[12], 8) FFF(aaa, bbb, ccc, ddd, eee, chunk[15], 5) \
FFF(eee, aaa, bbb, ccc, ddd, chunk[10], 12) FFF(ddd, eee, aaa, bbb, ccc, chunk[4], 9) \
FFF(ccc, ddd, eee, aaa, bbb, chunk[1], 12) FFF(bbb, ccc, ddd, eee, aaa, chunk[5], 5) \
FFF(aaa, bbb, ccc, ddd, eee, chunk[8], 14) FFF(eee, aaa, bbb, ccc, ddd, chunk[7], 6) \
FFF(ddd, eee, aaa, bbb, ccc, chunk[6], 8) FFF(ccc, ddd, eee, aaa, bbb, chunk[2], 13) \
FFF(bbb, ccc, ddd, eee, aaa, chunk[13], 6) FFF(aaa, bbb, ccc, ddd, eee, chunk[14], 5) \
FFF(eee, aaa, bbb, ccc, ddd, chunk[0], 15) FFF(ddd, eee, aaa, bbb, ccc, chunk[3], 13) \
FFF(ccc, ddd, eee, aaa, bbb, chunk[9], 11) FFF(bbb, ccc, ddd, eee, aaa, chunk[11], 11)
unsigned ripemd160(unsigned* input);
void ripemd160(unsigned* input, unsigned* output);