xref: /minix3/lib/libc/md/mdXhl.c (revision 0a6a1f1d05b60e214de2f05a7310ddd1f0e590e7)
1*0a6a1f1dSLionel Sambuc /*	$NetBSD: mdXhl.c,v 1.13 2014/09/24 13:18:52 christos Exp $	*/
22fe8fb19SBen Gras 
32fe8fb19SBen Gras /*
42fe8fb19SBen Gras  * ----------------------------------------------------------------------------
52fe8fb19SBen Gras  * "THE BEER-WARE LICENSE" (Revision 42):
62fe8fb19SBen Gras  * <phk@login.dkuug.dk> wrote this file.  As long as you retain this notice you
72fe8fb19SBen Gras  * can do whatever you want with this stuff. If we meet some day, and you think
82fe8fb19SBen Gras  * this stuff is worth it, you can buy me a beer in return.   Poul-Henning Kamp
92fe8fb19SBen Gras  * ----------------------------------------------------------------------------
102fe8fb19SBen Gras  *
112fe8fb19SBen Gras  * from FreeBSD Id: mdXhl.c,v 1.8 1996/10/25 06:48:12 bde Exp
122fe8fb19SBen Gras  */
132fe8fb19SBen Gras 
142fe8fb19SBen Gras /*
152fe8fb19SBen Gras  * Modified April 29, 1997 by Jason R. Thorpe <thorpej@NetBSD.org>
162fe8fb19SBen Gras  */
172fe8fb19SBen Gras 
182fe8fb19SBen Gras #if HAVE_NBTOOL_CONFIG_H
192fe8fb19SBen Gras #include "nbtool_config.h"
202fe8fb19SBen Gras #endif
212fe8fb19SBen Gras 
222fe8fb19SBen Gras #define	CONCAT(x,y)	__CONCAT(x,y)
232fe8fb19SBen Gras #define	MDNAME(x)	CONCAT(MDALGORITHM,x)
242fe8fb19SBen Gras 
252fe8fb19SBen Gras #if !defined(_KERNEL) && defined(__weak_alias) && !defined(HAVE_NBTOOL_CONFIG_H)
262fe8fb19SBen Gras #define	WA(a,b)	__weak_alias(a,b)
WA(MDNAME (End),CONCAT (_,MDNAME (End)))272fe8fb19SBen Gras WA(MDNAME(End),CONCAT(_,MDNAME(End)))
282fe8fb19SBen Gras WA(MDNAME(File),CONCAT(_,MDNAME(File)))
292fe8fb19SBen Gras WA(MDNAME(Data),CONCAT(_,MDNAME(Data)))
302fe8fb19SBen Gras #undef WA
312fe8fb19SBen Gras #endif
322fe8fb19SBen Gras 
332fe8fb19SBen Gras #include "namespace.h"
342fe8fb19SBen Gras 
352fe8fb19SBen Gras #include <sys/types.h>
362fe8fb19SBen Gras 
372fe8fb19SBen Gras #include MDINCLUDE
382fe8fb19SBen Gras #include <assert.h>
392fe8fb19SBen Gras #include <fcntl.h>
402fe8fb19SBen Gras #include <errno.h>
412fe8fb19SBen Gras #include <stdio.h>
422fe8fb19SBen Gras #include <stdlib.h>
432fe8fb19SBen Gras #include <unistd.h>
442fe8fb19SBen Gras 
452fe8fb19SBen Gras char *
46f14fb602SLionel Sambuc MDNAME(End)(MDNAME(_CTX) *ctx, char *buf)
472fe8fb19SBen Gras {
482fe8fb19SBen Gras 	int i;
492fe8fb19SBen Gras 	unsigned char digest[16];
502fe8fb19SBen Gras 	static const char hex[]="0123456789abcdef";
512fe8fb19SBen Gras 
522fe8fb19SBen Gras 	_DIAGASSERT(ctx != 0);
532fe8fb19SBen Gras 
542fe8fb19SBen Gras 	if (buf == NULL)
552fe8fb19SBen Gras 		buf = malloc(33);
562fe8fb19SBen Gras 	if (buf == NULL)
572fe8fb19SBen Gras 		return (NULL);
582fe8fb19SBen Gras 
592fe8fb19SBen Gras 	MDNAME(Final)(digest, ctx);
602fe8fb19SBen Gras 
612fe8fb19SBen Gras 	for (i = 0; i < 16; i++) {
622fe8fb19SBen Gras 		buf[i+i] = hex[(u_int32_t)digest[i] >> 4];
632fe8fb19SBen Gras 		buf[i+i+1] = hex[digest[i] & 0x0f];
642fe8fb19SBen Gras 	}
652fe8fb19SBen Gras 
662fe8fb19SBen Gras 	buf[i+i] = '\0';
672fe8fb19SBen Gras 	return (buf);
682fe8fb19SBen Gras }
692fe8fb19SBen Gras 
702fe8fb19SBen Gras char *
MDNAME(File)71f14fb602SLionel Sambuc MDNAME(File)(const char *filename, char *buf)
722fe8fb19SBen Gras {
732fe8fb19SBen Gras 	unsigned char buffer[BUFSIZ];
742fe8fb19SBen Gras 	MDNAME(_CTX) ctx;
75f14fb602SLionel Sambuc 	int f, j;
76f14fb602SLionel Sambuc 	ssize_t i;
772fe8fb19SBen Gras 
782fe8fb19SBen Gras 	_DIAGASSERT(filename != 0);
792fe8fb19SBen Gras 	/* buf may be NULL */
802fe8fb19SBen Gras 
812fe8fb19SBen Gras 	MDNAME(Init)(&ctx);
82*0a6a1f1dSLionel Sambuc 	f = open(filename, O_RDONLY | O_CLOEXEC, 0666);
832fe8fb19SBen Gras 	if (f < 0)
842fe8fb19SBen Gras 		return NULL;
852fe8fb19SBen Gras 
862fe8fb19SBen Gras 	while ((i = read(f, buffer, sizeof(buffer))) > 0)
872fe8fb19SBen Gras 		MDNAME(Update)(&ctx, buffer, (unsigned int)i);
882fe8fb19SBen Gras 
892fe8fb19SBen Gras 	j = errno;
902fe8fb19SBen Gras 	close(f);
912fe8fb19SBen Gras 	errno = j;
922fe8fb19SBen Gras 
932fe8fb19SBen Gras 	if (i < 0)
942fe8fb19SBen Gras 		return NULL;
952fe8fb19SBen Gras 
962fe8fb19SBen Gras 	return (MDNAME(End)(&ctx, buf));
972fe8fb19SBen Gras }
982fe8fb19SBen Gras 
992fe8fb19SBen Gras char *
MDNAME(Data)100f14fb602SLionel Sambuc MDNAME(Data)(const unsigned char *data, unsigned int len, char *buf)
1012fe8fb19SBen Gras {
1022fe8fb19SBen Gras 	MDNAME(_CTX) ctx;
1032fe8fb19SBen Gras 
1042fe8fb19SBen Gras 	_DIAGASSERT(data != 0);
1052fe8fb19SBen Gras 
1062fe8fb19SBen Gras 	MDNAME(Init)(&ctx);
1072fe8fb19SBen Gras 	MDNAME(Update)(&ctx, data, len);
1082fe8fb19SBen Gras 	return (MDNAME(End)(&ctx, buf));
1092fe8fb19SBen Gras }
110