diff options
author | Taru Karttunen <taruti@taruti.net> | 2011-03-30 15:46:40 +0300 |
---|---|---|
committer | Taru Karttunen <taruti@taruti.net> | 2011-03-30 15:46:40 +0300 |
commit | e5888a1ffdae813d7575f5fb02275c6bb07e5199 (patch) | |
tree | d8d51eac403f07814b9e936eed0c9a79195e2450 /sys/src/libsec/port/hmac.c |
Import sources from 2011-03-30 iso image
Diffstat (limited to 'sys/src/libsec/port/hmac.c')
-rwxr-xr-x | sys/src/libsec/port/hmac.c | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/sys/src/libsec/port/hmac.c b/sys/src/libsec/port/hmac.c new file mode 100755 index 000000000..aa2fa03f6 --- /dev/null +++ b/sys/src/libsec/port/hmac.c @@ -0,0 +1,41 @@ +#include "os.h" +#include <libsec.h> + +/* rfc2104 */ +DigestState* +hmac_x(uchar *p, ulong len, uchar *key, ulong klen, uchar *digest, DigestState *s, + DigestState*(*x)(uchar*, ulong, uchar*, DigestState*), int xlen) +{ + int i; + uchar pad[Hmacblksz+1], innerdigest[256]; + + if(xlen > sizeof(innerdigest)) + return nil; + if(klen > Hmacblksz) + return nil; + + /* first time through */ + if(s == nil || s->seeded == 0){ + memset(pad, 0x36, Hmacblksz); + pad[Hmacblksz] = 0; + for(i = 0; i < klen; i++) + pad[i] ^= key[i]; + s = (*x)(pad, Hmacblksz, nil, s); + if(s == nil) + return nil; + } + + s = (*x)(p, len, nil, s); + if(digest == nil) + return s; + + /* last time through */ + memset(pad, 0x5c, Hmacblksz); + pad[Hmacblksz] = 0; + for(i = 0; i < klen; i++) + pad[i] ^= key[i]; + (*x)(nil, 0, innerdigest, s); + s = (*x)(pad, Hmacblksz, nil, nil); + (*x)(innerdigest, xlen, digest, s); + return nil; +} |