mdXhl.c revision 1.11
11.11Schristos/*	$NetBSD: mdXhl.c,v 1.11 2014/09/18 13:58:20 christos Exp $	*/
21.1Sthorpej
31.2Sthorpej/*
41.1Sthorpej * ----------------------------------------------------------------------------
51.1Sthorpej * "THE BEER-WARE LICENSE" (Revision 42):
61.1Sthorpej * <phk@login.dkuug.dk> wrote this file.  As long as you retain this notice you
71.1Sthorpej * can do whatever you want with this stuff. If we meet some day, and you think
81.1Sthorpej * this stuff is worth it, you can buy me a beer in return.   Poul-Henning Kamp
91.1Sthorpej * ----------------------------------------------------------------------------
101.1Sthorpej *
111.1Sthorpej * from FreeBSD Id: mdXhl.c,v 1.8 1996/10/25 06:48:12 bde Exp
121.2Sthorpej */
131.2Sthorpej
141.2Sthorpej/*
151.7Schristos * Modified April 29, 1997 by Jason R. Thorpe <thorpej@NetBSD.org>
161.1Sthorpej */
171.1Sthorpej
181.8Sapb#if HAVE_NBTOOL_CONFIG_H
191.8Sapb#include "nbtool_config.h"
201.8Sapb#endif
211.8Sapb
221.7Schristos#define	CONCAT(x,y)	__CONCAT(x,y)
231.7Schristos#define	MDNAME(x)	CONCAT(MDALGORITHM,x)
241.7Schristos
251.8Sapb#if !defined(_KERNEL) && defined(__weak_alias) && !defined(HAVE_NBTOOL_CONFIG_H)
261.7Schristos#define	WA(a,b)	__weak_alias(a,b)
271.7SchristosWA(MDNAME(End),CONCAT(_,MDNAME(End)))
281.7SchristosWA(MDNAME(File),CONCAT(_,MDNAME(File)))
291.7SchristosWA(MDNAME(Data),CONCAT(_,MDNAME(Data)))
301.7Schristos#undef WA
311.7Schristos#endif
321.7Schristos
331.7Schristos#include "namespace.h"
341.7Schristos
351.1Sthorpej#include <sys/types.h>
361.4Slukem
371.7Schristos#include MDINCLUDE
381.4Slukem#include <assert.h>
391.1Sthorpej#include <fcntl.h>
401.1Sthorpej#include <errno.h>
411.1Sthorpej#include <stdio.h>
421.1Sthorpej#include <stdlib.h>
431.4Slukem#include <unistd.h>
441.1Sthorpej
451.7Schristos
461.1Sthorpej
471.1Sthorpejchar *
481.10SabsMDNAME(End)(MDNAME(_CTX) *ctx, char *buf)
491.1Sthorpej{
501.2Sthorpej	int i;
511.2Sthorpej	unsigned char digest[16];
521.2Sthorpej	static const char hex[]="0123456789abcdef";
531.2Sthorpej
541.4Slukem	_DIAGASSERT(ctx != 0);
551.4Slukem
561.2Sthorpej	if (buf == NULL)
571.2Sthorpej		buf = malloc(33);
581.2Sthorpej	if (buf == NULL)
591.2Sthorpej		return (NULL);
601.2Sthorpej
611.2Sthorpej	MDNAME(Final)(digest, ctx);
621.2Sthorpej
631.2Sthorpej	for (i = 0; i < 16; i++) {
641.3Schristos		buf[i+i] = hex[(u_int32_t)digest[i] >> 4];
651.2Sthorpej		buf[i+i+1] = hex[digest[i] & 0x0f];
661.2Sthorpej	}
671.2Sthorpej
681.2Sthorpej	buf[i+i] = '\0';
691.2Sthorpej	return (buf);
701.1Sthorpej}
711.1Sthorpej
721.1Sthorpejchar *
731.10SabsMDNAME(File)(const char *filename, char *buf)
741.1Sthorpej{
751.2Sthorpej	unsigned char buffer[BUFSIZ];
761.2Sthorpej	MDNAME(_CTX) ctx;
771.9Schristos	int f, j;
781.9Schristos	ssize_t i;
791.2Sthorpej
801.4Slukem	_DIAGASSERT(filename != 0);
811.4Slukem	/* buf may be NULL */
821.4Slukem
831.2Sthorpej	MDNAME(Init)(&ctx);
841.11Schristos	f = open(filename, O_RDONLY | O_CLOEXEC, 0666);
851.2Sthorpej	if (f < 0)
861.2Sthorpej		return NULL;
871.2Sthorpej
881.2Sthorpej	while ((i = read(f, buffer, sizeof(buffer))) > 0)
891.3Schristos		MDNAME(Update)(&ctx, buffer, (unsigned int)i);
901.2Sthorpej
911.2Sthorpej	j = errno;
921.2Sthorpej	close(f);
931.2Sthorpej	errno = j;
941.2Sthorpej
951.2Sthorpej	if (i < 0)
961.2Sthorpej		return NULL;
971.2Sthorpej
981.2Sthorpej	return (MDNAME(End)(&ctx, buf));
991.1Sthorpej}
1001.1Sthorpej
1011.1Sthorpejchar *
1021.10SabsMDNAME(Data)(const unsigned char *data, unsigned int len, char *buf)
1031.1Sthorpej{
1041.2Sthorpej	MDNAME(_CTX) ctx;
1051.4Slukem
1061.4Slukem	_DIAGASSERT(data != 0);
1071.1Sthorpej
1081.2Sthorpej	MDNAME(Init)(&ctx);
1091.2Sthorpej	MDNAME(Update)(&ctx, data, len);
1101.2Sthorpej	return (MDNAME(End)(&ctx, buf));
1111.1Sthorpej}
112