jehanne/sys/src/lib/sec/port/hkdf.c

39 lines
858 B
C

#include "os.h"
#include <libsec.h>
/* rfc5869 */
void
hkdf_x(salt, nsalt, info, ninfo, key, nkey, d, dlen, x, xlen)
uint8_t *salt, *info, *key, *d;
uint32_t nsalt, ninfo, nkey, dlen;
DigestState* (*x)(uint8_t*, uint32_t, uint8_t*, uint32_t, uint8_t*, DigestState*);
int xlen;
{
uint8_t prk[256], tmp[256], cnt;
DigestState *ds;
assert(xlen <= sizeof(tmp));
jehanne_memset(tmp, 0, xlen);
if(nsalt == 0){
salt = tmp;
nsalt = xlen;
}
/* note that salt and key are swapped in this case */
(*x)(key, nkey, salt, nsalt, prk, nil);
ds = nil;
for(cnt=1;; cnt++) {
if(ninfo > 0)
ds = (*x)(info, ninfo, prk, xlen, nil, ds);
(*x)(&cnt, 1, prk, xlen, tmp, ds);
if(dlen <= xlen){
jehanne_memmove(d, tmp, dlen);
break;
}
jehanne_memmove(d, tmp, xlen);
dlen -= xlen;
d += xlen;
ds = (*x)(tmp, xlen, prk, xlen, nil, nil);
}
}