Line data Source code
1 : /********************************************************************\
2 : *
3 : * FILE: rmd160.c
4 : *
5 : * CONTENTS: A sample C-implementation of the RIPEMD-160
6 : * hash-function.
7 : * TARGET: any computer with an ANSI C compiler
8 : *
9 : * AUTHOR: Antoon Bosselaers, ESAT-COSIC
10 : * DATE: 1 March 1996
11 : * VERSION: 1.0
12 : *
13 : * Copyright (c) 1996 Katholieke Universiteit Leuven
14 : *
15 : * Permission is hereby granted, free of charge, to any person
16 : * obtaining a copy of this software and associated documentation
17 : * files (the "Software"), to deal in the Software without restriction,
18 : * including without limitation the rights to use, copy, modify, merge,
19 : * publish, distribute, sublicense, and/or sell copies of the Software,
20 : * and to permit persons to whom the Software is furnished to do so,
21 : * subject to the following conditions:
22 : *
23 : * The above copyright notice and this permission notice shall be
24 : * included in all copies or substantial portions of the Software.
25 : *
26 : * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
27 : * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
28 : * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
29 : * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
30 : * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
31 : * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
32 : * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
33 : *
34 : \********************************************************************/
35 :
36 : /* header files */
37 : #include "monetdb_config.h"
38 : #include "rmd160.h"
39 :
40 : /********************************************************************/
41 :
42 38280 : void MDinit(dword *MDbuf)
43 : {
44 38280 : MDbuf[0] = 0x67452301UL;
45 38280 : MDbuf[1] = 0xefcdab89UL;
46 38280 : MDbuf[2] = 0x98badcfeUL;
47 38280 : MDbuf[3] = 0x10325476UL;
48 38280 : MDbuf[4] = 0xc3d2e1f0UL;
49 :
50 38280 : return;
51 : }
52 :
53 : /********************************************************************/
54 :
55 114853 : void MDcompress(dword *MDbuf, dword *X)
56 : {
57 114853 : dword aa = MDbuf[0], bb = MDbuf[1], cc = MDbuf[2],
58 114853 : dd = MDbuf[3], ee = MDbuf[4];
59 114853 : dword aaa = MDbuf[0], bbb = MDbuf[1], ccc = MDbuf[2],
60 114853 : ddd = MDbuf[3], eee = MDbuf[4];
61 :
62 : /* round 1 */
63 114853 : FF(aa, bb, cc, dd, ee, X[ 0], 11);
64 114853 : FF(ee, aa, bb, cc, dd, X[ 1], 14);
65 114853 : FF(dd, ee, aa, bb, cc, X[ 2], 15);
66 114853 : FF(cc, dd, ee, aa, bb, X[ 3], 12);
67 114853 : FF(bb, cc, dd, ee, aa, X[ 4], 5);
68 114853 : FF(aa, bb, cc, dd, ee, X[ 5], 8);
69 114853 : FF(ee, aa, bb, cc, dd, X[ 6], 7);
70 114853 : FF(dd, ee, aa, bb, cc, X[ 7], 9);
71 114853 : FF(cc, dd, ee, aa, bb, X[ 8], 11);
72 114853 : FF(bb, cc, dd, ee, aa, X[ 9], 13);
73 114853 : FF(aa, bb, cc, dd, ee, X[10], 14);
74 114853 : FF(ee, aa, bb, cc, dd, X[11], 15);
75 114853 : FF(dd, ee, aa, bb, cc, X[12], 6);
76 114853 : FF(cc, dd, ee, aa, bb, X[13], 7);
77 114853 : FF(bb, cc, dd, ee, aa, X[14], 9);
78 114853 : FF(aa, bb, cc, dd, ee, X[15], 8);
79 :
80 : /* round 2 */
81 114853 : GG(ee, aa, bb, cc, dd, X[ 7], 7);
82 114853 : GG(dd, ee, aa, bb, cc, X[ 4], 6);
83 114853 : GG(cc, dd, ee, aa, bb, X[13], 8);
84 114853 : GG(bb, cc, dd, ee, aa, X[ 1], 13);
85 114853 : GG(aa, bb, cc, dd, ee, X[10], 11);
86 114853 : GG(ee, aa, bb, cc, dd, X[ 6], 9);
87 114853 : GG(dd, ee, aa, bb, cc, X[15], 7);
88 114853 : GG(cc, dd, ee, aa, bb, X[ 3], 15);
89 114853 : GG(bb, cc, dd, ee, aa, X[12], 7);
90 114853 : GG(aa, bb, cc, dd, ee, X[ 0], 12);
91 114853 : GG(ee, aa, bb, cc, dd, X[ 9], 15);
92 114853 : GG(dd, ee, aa, bb, cc, X[ 5], 9);
93 114853 : GG(cc, dd, ee, aa, bb, X[ 2], 11);
94 114853 : GG(bb, cc, dd, ee, aa, X[14], 7);
95 114853 : GG(aa, bb, cc, dd, ee, X[11], 13);
96 114853 : GG(ee, aa, bb, cc, dd, X[ 8], 12);
97 :
98 : /* round 3 */
99 114853 : HH(dd, ee, aa, bb, cc, X[ 3], 11);
100 114853 : HH(cc, dd, ee, aa, bb, X[10], 13);
101 114853 : HH(bb, cc, dd, ee, aa, X[14], 6);
102 114853 : HH(aa, bb, cc, dd, ee, X[ 4], 7);
103 114853 : HH(ee, aa, bb, cc, dd, X[ 9], 14);
104 114853 : HH(dd, ee, aa, bb, cc, X[15], 9);
105 114853 : HH(cc, dd, ee, aa, bb, X[ 8], 13);
106 114853 : HH(bb, cc, dd, ee, aa, X[ 1], 15);
107 114853 : HH(aa, bb, cc, dd, ee, X[ 2], 14);
108 114853 : HH(ee, aa, bb, cc, dd, X[ 7], 8);
109 114853 : HH(dd, ee, aa, bb, cc, X[ 0], 13);
110 114853 : HH(cc, dd, ee, aa, bb, X[ 6], 6);
111 114853 : HH(bb, cc, dd, ee, aa, X[13], 5);
112 114853 : HH(aa, bb, cc, dd, ee, X[11], 12);
113 114853 : HH(ee, aa, bb, cc, dd, X[ 5], 7);
114 114853 : HH(dd, ee, aa, bb, cc, X[12], 5);
115 :
116 : /* round 4 */
117 114853 : II(cc, dd, ee, aa, bb, X[ 1], 11);
118 114853 : II(bb, cc, dd, ee, aa, X[ 9], 12);
119 114853 : II(aa, bb, cc, dd, ee, X[11], 14);
120 114853 : II(ee, aa, bb, cc, dd, X[10], 15);
121 114853 : II(dd, ee, aa, bb, cc, X[ 0], 14);
122 114853 : II(cc, dd, ee, aa, bb, X[ 8], 15);
123 114853 : II(bb, cc, dd, ee, aa, X[12], 9);
124 114853 : II(aa, bb, cc, dd, ee, X[ 4], 8);
125 114853 : II(ee, aa, bb, cc, dd, X[13], 9);
126 114853 : II(dd, ee, aa, bb, cc, X[ 3], 14);
127 114853 : II(cc, dd, ee, aa, bb, X[ 7], 5);
128 114853 : II(bb, cc, dd, ee, aa, X[15], 6);
129 114853 : II(aa, bb, cc, dd, ee, X[14], 8);
130 114853 : II(ee, aa, bb, cc, dd, X[ 5], 6);
131 114853 : II(dd, ee, aa, bb, cc, X[ 6], 5);
132 114853 : II(cc, dd, ee, aa, bb, X[ 2], 12);
133 :
134 : /* round 5 */
135 114853 : JJ(bb, cc, dd, ee, aa, X[ 4], 9);
136 114853 : JJ(aa, bb, cc, dd, ee, X[ 0], 15);
137 114853 : JJ(ee, aa, bb, cc, dd, X[ 5], 5);
138 114853 : JJ(dd, ee, aa, bb, cc, X[ 9], 11);
139 114853 : JJ(cc, dd, ee, aa, bb, X[ 7], 6);
140 114853 : JJ(bb, cc, dd, ee, aa, X[12], 8);
141 114853 : JJ(aa, bb, cc, dd, ee, X[ 2], 13);
142 114853 : JJ(ee, aa, bb, cc, dd, X[10], 12);
143 114853 : JJ(dd, ee, aa, bb, cc, X[14], 5);
144 114853 : JJ(cc, dd, ee, aa, bb, X[ 1], 12);
145 114853 : JJ(bb, cc, dd, ee, aa, X[ 3], 13);
146 114853 : JJ(aa, bb, cc, dd, ee, X[ 8], 14);
147 114853 : JJ(ee, aa, bb, cc, dd, X[11], 11);
148 114853 : JJ(dd, ee, aa, bb, cc, X[ 6], 8);
149 114853 : JJ(cc, dd, ee, aa, bb, X[15], 5);
150 114853 : JJ(bb, cc, dd, ee, aa, X[13], 6);
151 :
152 : /* parallel round 1 */
153 114853 : JJJ(aaa, bbb, ccc, ddd, eee, X[ 5], 8);
154 114853 : JJJ(eee, aaa, bbb, ccc, ddd, X[14], 9);
155 114853 : JJJ(ddd, eee, aaa, bbb, ccc, X[ 7], 9);
156 114853 : JJJ(ccc, ddd, eee, aaa, bbb, X[ 0], 11);
157 114853 : JJJ(bbb, ccc, ddd, eee, aaa, X[ 9], 13);
158 114853 : JJJ(aaa, bbb, ccc, ddd, eee, X[ 2], 15);
159 114853 : JJJ(eee, aaa, bbb, ccc, ddd, X[11], 15);
160 114853 : JJJ(ddd, eee, aaa, bbb, ccc, X[ 4], 5);
161 114853 : JJJ(ccc, ddd, eee, aaa, bbb, X[13], 7);
162 114853 : JJJ(bbb, ccc, ddd, eee, aaa, X[ 6], 7);
163 114853 : JJJ(aaa, bbb, ccc, ddd, eee, X[15], 8);
164 114853 : JJJ(eee, aaa, bbb, ccc, ddd, X[ 8], 11);
165 114853 : JJJ(ddd, eee, aaa, bbb, ccc, X[ 1], 14);
166 114853 : JJJ(ccc, ddd, eee, aaa, bbb, X[10], 14);
167 114853 : JJJ(bbb, ccc, ddd, eee, aaa, X[ 3], 12);
168 114853 : JJJ(aaa, bbb, ccc, ddd, eee, X[12], 6);
169 :
170 : /* parallel round 2 */
171 114853 : III(eee, aaa, bbb, ccc, ddd, X[ 6], 9);
172 114853 : III(ddd, eee, aaa, bbb, ccc, X[11], 13);
173 114853 : III(ccc, ddd, eee, aaa, bbb, X[ 3], 15);
174 114853 : III(bbb, ccc, ddd, eee, aaa, X[ 7], 7);
175 114853 : III(aaa, bbb, ccc, ddd, eee, X[ 0], 12);
176 114853 : III(eee, aaa, bbb, ccc, ddd, X[13], 8);
177 114853 : III(ddd, eee, aaa, bbb, ccc, X[ 5], 9);
178 114853 : III(ccc, ddd, eee, aaa, bbb, X[10], 11);
179 114853 : III(bbb, ccc, ddd, eee, aaa, X[14], 7);
180 114853 : III(aaa, bbb, ccc, ddd, eee, X[15], 7);
181 114853 : III(eee, aaa, bbb, ccc, ddd, X[ 8], 12);
182 114853 : III(ddd, eee, aaa, bbb, ccc, X[12], 7);
183 114853 : III(ccc, ddd, eee, aaa, bbb, X[ 4], 6);
184 114853 : III(bbb, ccc, ddd, eee, aaa, X[ 9], 15);
185 114853 : III(aaa, bbb, ccc, ddd, eee, X[ 1], 13);
186 114853 : III(eee, aaa, bbb, ccc, ddd, X[ 2], 11);
187 :
188 : /* parallel round 3 */
189 114853 : HHH(ddd, eee, aaa, bbb, ccc, X[15], 9);
190 114853 : HHH(ccc, ddd, eee, aaa, bbb, X[ 5], 7);
191 114853 : HHH(bbb, ccc, ddd, eee, aaa, X[ 1], 15);
192 114853 : HHH(aaa, bbb, ccc, ddd, eee, X[ 3], 11);
193 114853 : HHH(eee, aaa, bbb, ccc, ddd, X[ 7], 8);
194 114853 : HHH(ddd, eee, aaa, bbb, ccc, X[14], 6);
195 114853 : HHH(ccc, ddd, eee, aaa, bbb, X[ 6], 6);
196 114853 : HHH(bbb, ccc, ddd, eee, aaa, X[ 9], 14);
197 114853 : HHH(aaa, bbb, ccc, ddd, eee, X[11], 12);
198 114853 : HHH(eee, aaa, bbb, ccc, ddd, X[ 8], 13);
199 114853 : HHH(ddd, eee, aaa, bbb, ccc, X[12], 5);
200 114853 : HHH(ccc, ddd, eee, aaa, bbb, X[ 2], 14);
201 114853 : HHH(bbb, ccc, ddd, eee, aaa, X[10], 13);
202 114853 : HHH(aaa, bbb, ccc, ddd, eee, X[ 0], 13);
203 114853 : HHH(eee, aaa, bbb, ccc, ddd, X[ 4], 7);
204 114853 : HHH(ddd, eee, aaa, bbb, ccc, X[13], 5);
205 :
206 : /* parallel round 4 */
207 114853 : GGG(ccc, ddd, eee, aaa, bbb, X[ 8], 15);
208 114853 : GGG(bbb, ccc, ddd, eee, aaa, X[ 6], 5);
209 114853 : GGG(aaa, bbb, ccc, ddd, eee, X[ 4], 8);
210 114853 : GGG(eee, aaa, bbb, ccc, ddd, X[ 1], 11);
211 114853 : GGG(ddd, eee, aaa, bbb, ccc, X[ 3], 14);
212 114853 : GGG(ccc, ddd, eee, aaa, bbb, X[11], 14);
213 114853 : GGG(bbb, ccc, ddd, eee, aaa, X[15], 6);
214 114853 : GGG(aaa, bbb, ccc, ddd, eee, X[ 0], 14);
215 114853 : GGG(eee, aaa, bbb, ccc, ddd, X[ 5], 6);
216 114853 : GGG(ddd, eee, aaa, bbb, ccc, X[12], 9);
217 114853 : GGG(ccc, ddd, eee, aaa, bbb, X[ 2], 12);
218 114853 : GGG(bbb, ccc, ddd, eee, aaa, X[13], 9);
219 114853 : GGG(aaa, bbb, ccc, ddd, eee, X[ 9], 12);
220 114853 : GGG(eee, aaa, bbb, ccc, ddd, X[ 7], 5);
221 114853 : GGG(ddd, eee, aaa, bbb, ccc, X[10], 15);
222 114853 : GGG(ccc, ddd, eee, aaa, bbb, X[14], 8);
223 :
224 : /* parallel round 5 */
225 114853 : FFF(bbb, ccc, ddd, eee, aaa, X[12] , 8);
226 114853 : FFF(aaa, bbb, ccc, ddd, eee, X[15] , 5);
227 114853 : FFF(eee, aaa, bbb, ccc, ddd, X[10] , 12);
228 114853 : FFF(ddd, eee, aaa, bbb, ccc, X[ 4] , 9);
229 114853 : FFF(ccc, ddd, eee, aaa, bbb, X[ 1] , 12);
230 114853 : FFF(bbb, ccc, ddd, eee, aaa, X[ 5] , 5);
231 114853 : FFF(aaa, bbb, ccc, ddd, eee, X[ 8] , 14);
232 114853 : FFF(eee, aaa, bbb, ccc, ddd, X[ 7] , 6);
233 114853 : FFF(ddd, eee, aaa, bbb, ccc, X[ 6] , 8);
234 114853 : FFF(ccc, ddd, eee, aaa, bbb, X[ 2] , 13);
235 114853 : FFF(bbb, ccc, ddd, eee, aaa, X[13] , 6);
236 114853 : FFF(aaa, bbb, ccc, ddd, eee, X[14] , 5);
237 114853 : FFF(eee, aaa, bbb, ccc, ddd, X[ 0] , 15);
238 114853 : FFF(ddd, eee, aaa, bbb, ccc, X[ 3] , 13);
239 114853 : FFF(ccc, ddd, eee, aaa, bbb, X[ 9] , 11);
240 114853 : FFF(bbb, ccc, ddd, eee, aaa, X[11] , 11);
241 :
242 : /* combine results */
243 114853 : ddd += cc + MDbuf[1]; /* final result for MDbuf[0] */
244 114853 : MDbuf[1] = MDbuf[2] + dd + eee;
245 114853 : MDbuf[2] = MDbuf[3] + ee + aaa;
246 114853 : MDbuf[3] = MDbuf[4] + aa + bbb;
247 114853 : MDbuf[4] = MDbuf[0] + bb + ccc;
248 114853 : MDbuf[0] = ddd;
249 :
250 114853 : return;
251 : }
252 :
253 : /********************************************************************/
254 :
255 38286 : void MDfinish(dword *MDbuf, byte *strptr, dword lswlen, dword mswlen)
256 : {
257 38286 : unsigned int i; /* counter */
258 38286 : dword X[16]; /* message words */
259 :
260 38286 : memset(X, 0, 16*sizeof(dword));
261 :
262 : /* put bytes from strptr into X */
263 402246 : for (i=0; i<(lswlen&63); i++) {
264 : /* byte i goes into word X[i div 4] at pos. 8*(i mod 4) */
265 363960 : X[i>>2] ^= (dword) *strptr++ << (8 * (i&3));
266 : }
267 :
268 : /* append the bit m_n == 1 */
269 38286 : X[(lswlen>>2)&15] ^= (dword)1 << (8*(lswlen&3) + 7);
270 :
271 38286 : if ((lswlen & 63) > 55) {
272 : /* length goes to next block */
273 0 : MDcompress(MDbuf, X);
274 0 : memset(X, 0, 16*sizeof(dword));
275 : }
276 :
277 : /* append length in bits*/
278 38286 : X[14] = lswlen << 3;
279 38286 : X[15] = (lswlen >> 29) | (mswlen << 3);
280 38286 : MDcompress(MDbuf, X);
281 :
282 38284 : return;
283 : }
284 :
285 : /************************ end of file rmd160.c **********************/
|