xref: /minix3/external/bsd/bind/dist/lib/isc/iterated_hash.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: iterated_hash.c,v 1.4 2014/12/10 04:37:59 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek  * Copyright (C) 2006, 2008, 2009  Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek  *
6*00b67f09SDavid van Moolenbroek  * Permission to use, copy, modify, and/or distribute this software for any
7*00b67f09SDavid van Moolenbroek  * purpose with or without fee is hereby granted, provided that the above
8*00b67f09SDavid van Moolenbroek  * copyright notice and this permission notice appear in all copies.
9*00b67f09SDavid van Moolenbroek  *
10*00b67f09SDavid van Moolenbroek  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
11*00b67f09SDavid van Moolenbroek  * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
12*00b67f09SDavid van Moolenbroek  * AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
13*00b67f09SDavid van Moolenbroek  * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
14*00b67f09SDavid van Moolenbroek  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
15*00b67f09SDavid van Moolenbroek  * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
16*00b67f09SDavid van Moolenbroek  * PERFORMANCE OF THIS SOFTWARE.
17*00b67f09SDavid van Moolenbroek  */
18*00b67f09SDavid van Moolenbroek 
19*00b67f09SDavid van Moolenbroek /* Id: iterated_hash.c,v 1.6 2009/02/18 23:47:48 tbox Exp  */
20*00b67f09SDavid van Moolenbroek 
21*00b67f09SDavid van Moolenbroek #include "config.h"
22*00b67f09SDavid van Moolenbroek 
23*00b67f09SDavid van Moolenbroek #include <stdio.h>
24*00b67f09SDavid van Moolenbroek 
25*00b67f09SDavid van Moolenbroek #include <isc/sha1.h>
26*00b67f09SDavid van Moolenbroek #include <isc/iterated_hash.h>
27*00b67f09SDavid van Moolenbroek 
28*00b67f09SDavid van Moolenbroek int
isc_iterated_hash(unsigned char out[ISC_SHA1_DIGESTLENGTH],unsigned int hashalg,int iterations,const unsigned char * salt,int saltlength,const unsigned char * in,int inlength)29*00b67f09SDavid van Moolenbroek isc_iterated_hash(unsigned char out[ISC_SHA1_DIGESTLENGTH],
30*00b67f09SDavid van Moolenbroek 		  unsigned int hashalg, int iterations,
31*00b67f09SDavid van Moolenbroek 		  const unsigned char *salt, int saltlength,
32*00b67f09SDavid van Moolenbroek 		  const unsigned char *in, int inlength)
33*00b67f09SDavid van Moolenbroek {
34*00b67f09SDavid van Moolenbroek 	isc_sha1_t ctx;
35*00b67f09SDavid van Moolenbroek 	int n = 0;
36*00b67f09SDavid van Moolenbroek 
37*00b67f09SDavid van Moolenbroek 	if (hashalg != 1)
38*00b67f09SDavid van Moolenbroek 		return (0);
39*00b67f09SDavid van Moolenbroek 
40*00b67f09SDavid van Moolenbroek 	do {
41*00b67f09SDavid van Moolenbroek 		isc_sha1_init(&ctx);
42*00b67f09SDavid van Moolenbroek 		isc_sha1_update(&ctx, in, inlength);
43*00b67f09SDavid van Moolenbroek 		isc_sha1_update(&ctx, salt, saltlength);
44*00b67f09SDavid van Moolenbroek 		isc_sha1_final(&ctx, out);
45*00b67f09SDavid van Moolenbroek 		in = out;
46*00b67f09SDavid van Moolenbroek 		inlength = ISC_SHA1_DIGESTLENGTH;
47*00b67f09SDavid van Moolenbroek 	} while (n++ < iterations);
48*00b67f09SDavid van Moolenbroek 
49*00b67f09SDavid van Moolenbroek 	return (ISC_SHA1_DIGESTLENGTH);
50*00b67f09SDavid van Moolenbroek }
51