24 #if defined(_KERNEL) || defined(_STANDALONE) 25 #include <sys/param.h> 26 #include <sys/systm.h> 27 #define _DIAGASSERT(x) (void)0 35 #define _DIAGASSERT(cond) assert(cond) 42 #if defined(_KERNEL) || defined(_STANDALONE) 43 #define memcpy(s, d, l) bcopy((d), (s), (l)) 46 #define rol(value, bits) (((value) << (bits)) | ((value) >> (32 - (bits)))) 52 #ifndef WORDS_BIGENDIAN 53 # define blk0(i) (block->l[i] = (rol(block->l[i],24)&0xFF00FF00) \ 54 |(rol(block->l[i],8)&0x00FF00FF)) 56 # define blk0(i) block->l[i] 58 #define blk(i) (block->l[i&15] = rol(block->l[(i+13)&15]^block->l[(i+8)&15] \ 59 ^block->l[(i+2)&15]^block->l[i&15],1)) 64 #define R0(v,w,x,y,z,i) z+=((w&(x^y))^y)+blk0(i)+0x5A827999+rol(v,5);w=rol(w,30); 65 #define R1(v,w,x,y,z,i) z+=((w&(x^y))^y)+blk(i)+0x5A827999+rol(v,5);w=rol(w,30); 66 #define R2(v,w,x,y,z,i) z+=(w^x^y)+blk(i)+0x6ED9EBA1+rol(v,5);w=rol(w,30); 67 #define R3(v,w,x,y,z,i) z+=(((w|x)&y)|(w&x))+blk(i)+0x8F1BBCDC+rol(v,5);w=rol(w,30); 68 #define R4(v,w,x,y,z,i) z+=(w^x^y)+blk(i)+0xCA62C1D6+rol(v,5);w=rol(w,30); 82 #define nR0(v,w,x,y,z,i) R0(*v,*w,*x,*y,*z,i) 83 #define nR1(v,w,x,y,z,i) R1(*v,*w,*x,*y,*z,i) 84 #define nR2(v,w,x,y,z,i) R2(*v,*w,*x,*y,*z,i) 85 #define nR3(v,w,x,y,z,i) R3(*v,*w,*x,*y,*z,i) 86 #define nR4(v,w,x,y,z,i) R4(*v,*w,*x,*y,*z,i) 91 nR0(a,b,c,d,e, 0); nR0(e,a,b,c,d, 1); nR0(d,e,a,b,c, 2); nR0(c,d,e,a,b, 3);
92 nR0(b,c,d,e,a, 4); nR0(a,b,c,d,e, 5); nR0(e,a,b,c,d, 6); nR0(d,e,a,b,c, 7);
93 nR0(c,d,e,a,b, 8); nR0(b,c,d,e,a, 9); nR0(a,b,c,d,e,10); nR0(e,a,b,c,d,11);
94 nR0(d,e,a,b,c,12); nR0(c,d,e,a,b,13); nR0(b,c,d,e,a,14); nR0(a,b,c,d,e,15);
95 nR1(e,a,b,c,d,16); nR1(d,e,a,b,c,17); nR1(c,d,e,a,b,18); nR1(b,c,d,e,a,19);
101 nR2(a,b,c,d,e,20); nR2(e,a,b,c,d,21); nR2(d,e,a,b,c,22); nR2(c,d,e,a,b,23);
102 nR2(b,c,d,e,a,24); nR2(a,b,c,d,e,25); nR2(e,a,b,c,d,26); nR2(d,e,a,b,c,27);
103 nR2(c,d,e,a,b,28); nR2(b,c,d,e,a,29); nR2(a,b,c,d,e,30); nR2(e,a,b,c,d,31);
104 nR2(d,e,a,b,c,32); nR2(c,d,e,a,b,33); nR2(b,c,d,e,a,34); nR2(a,b,c,d,e,35);
105 nR2(e,a,b,c,d,36); nR2(d,e,a,b,c,37); nR2(c,d,e,a,b,38); nR2(b,c,d,e,a,39);
111 nR3(a,b,c,d,e,40); nR3(e,a,b,c,d,41); nR3(d,e,a,b,c,42); nR3(c,d,e,a,b,43);
112 nR3(b,c,d,e,a,44); nR3(a,b,c,d,e,45); nR3(e,a,b,c,d,46); nR3(d,e,a,b,c,47);
113 nR3(c,d,e,a,b,48); nR3(b,c,d,e,a,49); nR3(a,b,c,d,e,50); nR3(e,a,b,c,d,51);
114 nR3(d,e,a,b,c,52); nR3(c,d,e,a,b,53); nR3(b,c,d,e,a,54); nR3(a,b,c,d,e,55);
115 nR3(e,a,b,c,d,56); nR3(d,e,a,b,c,57); nR3(c,d,e,a,b,58); nR3(b,c,d,e,a,59);
121 nR4(a,b,c,d,e,60); nR4(e,a,b,c,d,61); nR4(d,e,a,b,c,62); nR4(c,d,e,a,b,63);
122 nR4(b,c,d,e,a,64); nR4(a,b,c,d,e,65); nR4(e,a,b,c,d,66); nR4(d,e,a,b,c,67);
123 nR4(c,d,e,a,b,68); nR4(b,c,d,e,a,69); nR4(a,b,c,d,e,70); nR4(e,a,b,c,d,71);
124 nR4(d,e,a,b,c,72); nR4(c,d,e,a,b,73); nR4(b,c,d,e,a,74); nR4(a,b,c,d,e,75);
125 nR4(e,a,b,c,d,76); nR4(d,e,a,b,c,77); nR4(c,d,e,a,b,78); nR4(b,c,d,e,a,79);
146 (void)memcpy(block, buffer, 64);
159 do_R01(&a, &b, &c, &d, &e, block);
160 do_R2(&a, &b, &c, &d, &e, block);
161 do_R3(&a, &b, &c, &d, &e, block);
162 do_R4(&a, &b, &c, &d, &e, block);
165 R0(a,b,c,d,e, 0);
R0(e,a,b,c,d, 1);
R0(d,e,a,b,c, 2);
R0(c,d,e,a,b, 3);
166 R0(b,c,d,e,a, 4);
R0(a,b,c,d,e, 5);
R0(e,a,b,c,d, 6);
R0(d,e,a,b,c, 7);
167 R0(c,d,e,a,b, 8);
R0(b,c,d,e,a, 9);
R0(a,b,c,d,e,10);
R0(e,a,b,c,d,11);
168 R0(d,e,a,b,c,12);
R0(c,d,e,a,b,13);
R0(b,c,d,e,a,14);
R0(a,b,c,d,e,15);
169 R1(e,a,b,c,d,16);
R1(d,e,a,b,c,17);
R1(c,d,e,a,b,18);
R1(b,c,d,e,a,19);
170 R2(a,b,c,d,e,20);
R2(e,a,b,c,d,21);
R2(d,e,a,b,c,22);
R2(c,d,e,a,b,23);
171 R2(b,c,d,e,a,24);
R2(a,b,c,d,e,25);
R2(e,a,b,c,d,26);
R2(d,e,a,b,c,27);
172 R2(c,d,e,a,b,28);
R2(b,c,d,e,a,29);
R2(a,b,c,d,e,30);
R2(e,a,b,c,d,31);
173 R2(d,e,a,b,c,32);
R2(c,d,e,a,b,33);
R2(b,c,d,e,a,34);
R2(a,b,c,d,e,35);
174 R2(e,a,b,c,d,36);
R2(d,e,a,b,c,37);
R2(c,d,e,a,b,38);
R2(b,c,d,e,a,39);
175 R3(a,b,c,d,e,40);
R3(e,a,b,c,d,41);
R3(d,e,a,b,c,42);
R3(c,d,e,a,b,43);
176 R3(b,c,d,e,a,44);
R3(a,b,c,d,e,45);
R3(e,a,b,c,d,46);
R3(d,e,a,b,c,47);
177 R3(c,d,e,a,b,48);
R3(b,c,d,e,a,49);
R3(a,b,c,d,e,50);
R3(e,a,b,c,d,51);
178 R3(d,e,a,b,c,52);
R3(c,d,e,a,b,53);
R3(b,c,d,e,a,54);
R3(a,b,c,d,e,55);
179 R3(e,a,b,c,d,56);
R3(d,e,a,b,c,57);
R3(c,d,e,a,b,58);
R3(b,c,d,e,a,59);
180 R4(a,b,c,d,e,60);
R4(e,a,b,c,d,61);
R4(d,e,a,b,c,62);
R4(c,d,e,a,b,63);
181 R4(b,c,d,e,a,64);
R4(a,b,c,d,e,65);
R4(e,a,b,c,d,66);
R4(d,e,a,b,c,67);
182 R4(c,d,e,a,b,68);
R4(b,c,d,e,a,69);
R4(a,b,c,d,e,70);
R4(e,a,b,c,d,71);
183 R4(d,e,a,b,c,72);
R4(c,d,e,a,b,73);
R4(b,c,d,e,a,74);
R4(a,b,c,d,e,75);
184 R4(e,a,b,c,d,76);
R4(d,e,a,b,c,77);
R4(c,d,e,a,b,78);
R4(b,c,d,e,a,79);
195 a = b = c = d = e = 0;
208 context->
state[0] = 0x67452301;
209 context->
state[1] = 0xEFCDAB89;
210 context->
state[2] = 0x98BADCFE;
211 context->
state[3] = 0x10325476;
212 context->
state[4] = 0xC3D2E1F0;
228 j = context->
count[0];
229 if ((context->
count[0] += len << 3) < j)
230 context->
count[1] += (len>>29)+1;
232 if ((j + len) > 63) {
233 (void)memcpy(&context->
buffer[j], data, (i = 64-j));
235 for ( ; i + 63 <
len; i += 64)
241 (void)memcpy(&context->
buffer[j], &data[i], len - i);
256 for (i = 0; i < 8; i++) {
257 finalcount[i] = (
uint8_t)((context->
count[(i >= 4 ? 0 : 1)]
258 >> ((3-(i & 3)) * 8) ) & 255);
261 while ((context->
count[0] & 504) != 448)
266 for (i = 0; i < 20; i++)
268 ((context->
state[i>>2] >> ((3-(i & 3)) * 8) ) & 255);
int SHA1_Init(SHA1_CTX *context)
int SHA1_Finish(SHA1_CTX *context, uint8_t digest[20])
#define _DIAGASSERT(cond)
#define R1(v, w, x, y, z, i)
#define R2(v, w, x, y, z, i)
register unsigned int len
void SHA1_Update(SHA1_CTX *context, const uint8_t *data, size_t len)
void SHA1_Transform(uint32_t state[5], const uint8_t buffer[64])
#define R3(v, w, x, y, z, i)
#define R0(v, w, x, y, z, i)
#define R4(v, w, x, y, z, i)