code: 9ferno

ref: ed77f1550337e186ee740e42a1506fc61a5385c5
dir: /libsec/port/pbkdf2.c/

View raw version
#include "os.h"
#include "libsec.h"

/* rfc2898 */
void
pbkdf2_x(p, plen, s, slen, rounds, d, dlen, x, xlen)
	uchar *p, *s, *d;
	u32 plen, slen, dlen, rounds;
	DigestState* (*x)(uchar*, u32, uchar*, u32, uchar*, DigestState*);
	int xlen;
{
	uchar block[256], tmp[256];
	u32 i, j, k, n;
	DigestState *ds;

	assert(xlen <= sizeof(tmp));

	for(i = 1; dlen > 0; i++, d += n, dlen -= n){
		tmp[3] = i;
		tmp[2] = i >> 8;
		tmp[1] = i >> 16;
		tmp[0] = i >> 24;
		ds = (*x)(s, slen, p, plen, nil, nil);
		(*x)(tmp, 4, p, plen, block, ds);
		memmove(tmp, block, xlen);
		for(j = 1; j < rounds; j++){
			(*x)(tmp, xlen, p, plen, tmp, nil);
			for(k=0; k<xlen; k++)
				block[k] ^= tmp[k];
		}
		n = dlen > xlen ? xlen : dlen;
		memmove(d, block, n); 
	}
}