1 /* $NetBSD: mdXhl.c,v 1.13 2014/09/24 13:18:52 christos Exp $ */
4 * ----------------------------------------------------------------------------
5 * "THE BEER-WARE LICENSE" (Revision 42):
6 * <phk@login.dkuug.dk> wrote this file. As long as you retain this notice you
7 * can do whatever you want with this stuff. If we meet some day, and you think
8 * this stuff is worth it, you can buy me a beer in return. Poul-Henning Kamp
9 * ----------------------------------------------------------------------------
11 * from FreeBSD Id: mdXhl.c,v 1.8 1996/10/25 06:48:12 bde Exp
15 * Modified April 29, 1997 by Jason R. Thorpe <thorpej@NetBSD.org>
18 #if HAVE_NBTOOL_CONFIG_H
19 #include "nbtool_config.h"
22 #define CONCAT(x,y) __CONCAT(x,y)
23 #define MDNAME(x) CONCAT(MDALGORITHM,x)
25 #if !defined(_KERNEL) && defined(__weak_alias) && !defined(HAVE_NBTOOL_CONFIG_H)
26 #define WA(a,b) __weak_alias(a,b)
27 WA(MDNAME(End
),CONCAT(_
,MDNAME(End
)))
28 WA(MDNAME(File
),CONCAT(_
,MDNAME(File
)))
29 WA(MDNAME(Data
),CONCAT(_
,MDNAME(Data
)))
33 #include "namespace.h"
35 #include <sys/types.h>
46 MDNAME(End
)(MDNAME(_CTX
) *ctx
, char *buf
)
49 unsigned char digest
[16];
50 static const char hex
[]="0123456789abcdef";
52 _DIAGASSERT(ctx
!= 0);
59 MDNAME(Final
)(digest
, ctx
);
61 for (i
= 0; i
< 16; i
++) {
62 buf
[i
+i
] = hex
[(u_int32_t
)digest
[i
] >> 4];
63 buf
[i
+i
+1] = hex
[digest
[i
] & 0x0f];
71 MDNAME(File
)(const char *filename
, char *buf
)
73 unsigned char buffer
[BUFSIZ
];
78 _DIAGASSERT(filename
!= 0);
82 f
= open(filename
, O_RDONLY
| O_CLOEXEC
, 0666);
86 while ((i
= read(f
, buffer
, sizeof(buffer
))) > 0)
87 MDNAME(Update
)(&ctx
, buffer
, (unsigned int)i
);
96 return (MDNAME(End
)(&ctx
, buf
));
100 MDNAME(Data
)(const unsigned char *data
, unsigned int len
, char *buf
)
104 _DIAGASSERT(data
!= 0);
107 MDNAME(Update
)(&ctx
, data
, len
);
108 return (MDNAME(End
)(&ctx
, buf
));