xref: /minix3/external/bsd/bind/dist/bin/tests/entropy2_test.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: entropy2_test.c,v 1.6 2014/12/10 04:37:53 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek  * Copyright (C) 2004, 2005, 2007  Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek  * Copyright (C) 2000, 2001  Internet Software Consortium.
6*00b67f09SDavid van Moolenbroek  *
7*00b67f09SDavid van Moolenbroek  * Permission to use, copy, modify, and/or distribute this software for any
8*00b67f09SDavid van Moolenbroek  * purpose with or without fee is hereby granted, provided that the above
9*00b67f09SDavid van Moolenbroek  * copyright notice and this permission notice appear in all copies.
10*00b67f09SDavid van Moolenbroek  *
11*00b67f09SDavid van Moolenbroek  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
12*00b67f09SDavid van Moolenbroek  * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
13*00b67f09SDavid van Moolenbroek  * AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
14*00b67f09SDavid van Moolenbroek  * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
15*00b67f09SDavid van Moolenbroek  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
16*00b67f09SDavid van Moolenbroek  * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*00b67f09SDavid van Moolenbroek  * PERFORMANCE OF THIS SOFTWARE.
18*00b67f09SDavid van Moolenbroek  */
19*00b67f09SDavid van Moolenbroek 
20*00b67f09SDavid van Moolenbroek /* Id: entropy2_test.c,v 1.16 2007/06/19 23:46:59 tbox Exp  */
21*00b67f09SDavid van Moolenbroek 
22*00b67f09SDavid van Moolenbroek /*! \file */
23*00b67f09SDavid van Moolenbroek 
24*00b67f09SDavid van Moolenbroek #include <config.h>
25*00b67f09SDavid van Moolenbroek 
26*00b67f09SDavid van Moolenbroek #include <stdio.h>
27*00b67f09SDavid van Moolenbroek #include <stdlib.h>
28*00b67f09SDavid van Moolenbroek 
29*00b67f09SDavid van Moolenbroek #include <isc/entropy.h>
30*00b67f09SDavid van Moolenbroek #include <isc/keyboard.h>
31*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
32*00b67f09SDavid van Moolenbroek #include <isc/string.h>
33*00b67f09SDavid van Moolenbroek #include <isc/time.h>
34*00b67f09SDavid van Moolenbroek #include <isc/util.h>
35*00b67f09SDavid van Moolenbroek 
36*00b67f09SDavid van Moolenbroek static void
hex_dump(const char * msg,void * data,unsigned int length)37*00b67f09SDavid van Moolenbroek hex_dump(const char *msg, void *data, unsigned int length) {
38*00b67f09SDavid van Moolenbroek         unsigned int len;
39*00b67f09SDavid van Moolenbroek 	unsigned char *base;
40*00b67f09SDavid van Moolenbroek 	isc_boolean_t first = ISC_TRUE;
41*00b67f09SDavid van Moolenbroek 
42*00b67f09SDavid van Moolenbroek 	base = data;
43*00b67f09SDavid van Moolenbroek 
44*00b67f09SDavid van Moolenbroek         printf("DUMP of %d bytes:  %s\n\t", length, msg);
45*00b67f09SDavid van Moolenbroek         for (len = 0; len < length; len++) {
46*00b67f09SDavid van Moolenbroek                 if (len % 16 == 0 && !first)
47*00b67f09SDavid van Moolenbroek 			printf("\n\t");
48*00b67f09SDavid van Moolenbroek                 printf("%02x ", base[len]);
49*00b67f09SDavid van Moolenbroek 		first = ISC_FALSE;
50*00b67f09SDavid van Moolenbroek         }
51*00b67f09SDavid van Moolenbroek         printf("\n");
52*00b67f09SDavid van Moolenbroek }
53*00b67f09SDavid van Moolenbroek 
54*00b67f09SDavid van Moolenbroek static void
CHECK(const char * msg,isc_result_t result)55*00b67f09SDavid van Moolenbroek CHECK(const char *msg, isc_result_t result) {
56*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS) {
57*00b67f09SDavid van Moolenbroek 		printf("FAILURE:  %s:  %s\n", msg, isc_result_totext(result));
58*00b67f09SDavid van Moolenbroek 		exit(1);
59*00b67f09SDavid van Moolenbroek 	}
60*00b67f09SDavid van Moolenbroek }
61*00b67f09SDavid van Moolenbroek 
62*00b67f09SDavid van Moolenbroek static isc_result_t
start(isc_entropysource_t * source,void * arg,isc_boolean_t blocking)63*00b67f09SDavid van Moolenbroek start(isc_entropysource_t *source, void *arg, isc_boolean_t blocking) {
64*00b67f09SDavid van Moolenbroek 	isc_keyboard_t *kbd = (isc_keyboard_t *)arg;
65*00b67f09SDavid van Moolenbroek 
66*00b67f09SDavid van Moolenbroek 	UNUSED(source);
67*00b67f09SDavid van Moolenbroek 
68*00b67f09SDavid van Moolenbroek 	if (blocking)
69*00b67f09SDavid van Moolenbroek 		printf("start called, blocking mode.\n");
70*00b67f09SDavid van Moolenbroek 	else
71*00b67f09SDavid van Moolenbroek 		printf("start called, non-blocking mode.\n");
72*00b67f09SDavid van Moolenbroek 
73*00b67f09SDavid van Moolenbroek 	return (isc_keyboard_open(kbd));
74*00b67f09SDavid van Moolenbroek }
75*00b67f09SDavid van Moolenbroek 
76*00b67f09SDavid van Moolenbroek static void
stop(isc_entropysource_t * source,void * arg)77*00b67f09SDavid van Moolenbroek stop(isc_entropysource_t *source, void *arg) {
78*00b67f09SDavid van Moolenbroek 	isc_keyboard_t *kbd = (isc_keyboard_t *)arg;
79*00b67f09SDavid van Moolenbroek 
80*00b67f09SDavid van Moolenbroek 	UNUSED(source);
81*00b67f09SDavid van Moolenbroek 
82*00b67f09SDavid van Moolenbroek 	printf("ENOUGH!  Stop typing, please.\r\n");
83*00b67f09SDavid van Moolenbroek 
84*00b67f09SDavid van Moolenbroek 	(void)isc_keyboard_close(kbd, 3);
85*00b67f09SDavid van Moolenbroek 	printf("stop called\n");
86*00b67f09SDavid van Moolenbroek }
87*00b67f09SDavid van Moolenbroek 
88*00b67f09SDavid van Moolenbroek static isc_result_t
get(isc_entropysource_t * source,void * arg,isc_boolean_t blocking)89*00b67f09SDavid van Moolenbroek get(isc_entropysource_t *source, void *arg, isc_boolean_t blocking) {
90*00b67f09SDavid van Moolenbroek 	isc_keyboard_t *kbd = (isc_keyboard_t *)arg;
91*00b67f09SDavid van Moolenbroek 	isc_result_t result;
92*00b67f09SDavid van Moolenbroek 	isc_time_t t;
93*00b67f09SDavid van Moolenbroek 	isc_uint32_t sample;
94*00b67f09SDavid van Moolenbroek 	isc_uint32_t extra;
95*00b67f09SDavid van Moolenbroek 	unsigned char c;
96*00b67f09SDavid van Moolenbroek 
97*00b67f09SDavid van Moolenbroek 	if (!blocking)
98*00b67f09SDavid van Moolenbroek 		return (ISC_R_NOENTROPY);
99*00b67f09SDavid van Moolenbroek 
100*00b67f09SDavid van Moolenbroek 	result = isc_keyboard_getchar(kbd, &c);
101*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS)
102*00b67f09SDavid van Moolenbroek 		return (result);
103*00b67f09SDavid van Moolenbroek 
104*00b67f09SDavid van Moolenbroek 	TIME_NOW(&t);
105*00b67f09SDavid van Moolenbroek 
106*00b67f09SDavid van Moolenbroek 	sample = isc_time_nanoseconds(&t);
107*00b67f09SDavid van Moolenbroek 	extra = c;
108*00b67f09SDavid van Moolenbroek 
109*00b67f09SDavid van Moolenbroek 	result = isc_entropy_addcallbacksample(source, sample, extra);
110*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS) {
111*00b67f09SDavid van Moolenbroek 		printf("\r\n");
112*00b67f09SDavid van Moolenbroek 		return (result);
113*00b67f09SDavid van Moolenbroek 	}
114*00b67f09SDavid van Moolenbroek 
115*00b67f09SDavid van Moolenbroek 	printf(".");
116*00b67f09SDavid van Moolenbroek 	fflush(stdout);
117*00b67f09SDavid van Moolenbroek 
118*00b67f09SDavid van Moolenbroek 	return (result);
119*00b67f09SDavid van Moolenbroek }
120*00b67f09SDavid van Moolenbroek 
121*00b67f09SDavid van Moolenbroek int
main(int argc,char ** argv)122*00b67f09SDavid van Moolenbroek main(int argc, char **argv) {
123*00b67f09SDavid van Moolenbroek 	isc_mem_t *mctx;
124*00b67f09SDavid van Moolenbroek 	unsigned char buffer[512];
125*00b67f09SDavid van Moolenbroek 	isc_entropy_t *ent;
126*00b67f09SDavid van Moolenbroek 	isc_entropysource_t *source;
127*00b67f09SDavid van Moolenbroek 	unsigned int returned;
128*00b67f09SDavid van Moolenbroek 	unsigned int flags;
129*00b67f09SDavid van Moolenbroek 	isc_result_t result;
130*00b67f09SDavid van Moolenbroek 	isc_keyboard_t kbd;
131*00b67f09SDavid van Moolenbroek 
132*00b67f09SDavid van Moolenbroek 	UNUSED(argc);
133*00b67f09SDavid van Moolenbroek 	UNUSED(argv);
134*00b67f09SDavid van Moolenbroek 
135*00b67f09SDavid van Moolenbroek 	mctx = NULL;
136*00b67f09SDavid van Moolenbroek 	CHECK("isc_mem_create()",
137*00b67f09SDavid van Moolenbroek 	      isc_mem_create(0, 0, &mctx));
138*00b67f09SDavid van Moolenbroek 
139*00b67f09SDavid van Moolenbroek 	ent = NULL;
140*00b67f09SDavid van Moolenbroek 	CHECK("isc_entropy_create()",
141*00b67f09SDavid van Moolenbroek 	      isc_entropy_create(mctx, &ent));
142*00b67f09SDavid van Moolenbroek 
143*00b67f09SDavid van Moolenbroek 	isc_entropy_stats(ent, stderr);
144*00b67f09SDavid van Moolenbroek 
145*00b67f09SDavid van Moolenbroek 	source = NULL;
146*00b67f09SDavid van Moolenbroek 	result = isc_entropy_createcallbacksource(ent, start, get, stop, &kbd,
147*00b67f09SDavid van Moolenbroek 						  &source);
148*00b67f09SDavid van Moolenbroek 	CHECK("isc_entropy_createcallbacksource()", result);
149*00b67f09SDavid van Moolenbroek 
150*00b67f09SDavid van Moolenbroek 	fprintf(stderr,
151*00b67f09SDavid van Moolenbroek 		"Reading 32 bytes of GOOD random data only, partial OK\n");
152*00b67f09SDavid van Moolenbroek 
153*00b67f09SDavid van Moolenbroek 	flags = 0;
154*00b67f09SDavid van Moolenbroek 	flags |= ISC_ENTROPY_GOODONLY;
155*00b67f09SDavid van Moolenbroek 	flags |= ISC_ENTROPY_PARTIAL;
156*00b67f09SDavid van Moolenbroek 	flags |= ISC_ENTROPY_BLOCKING;
157*00b67f09SDavid van Moolenbroek 	returned = 0;
158*00b67f09SDavid van Moolenbroek 	result = isc_entropy_getdata(ent, buffer, 32, &returned, flags);
159*00b67f09SDavid van Moolenbroek 	if (result == ISC_R_NOENTROPY) {
160*00b67f09SDavid van Moolenbroek 		fprintf(stderr, "No entropy.\r\n");
161*00b67f09SDavid van Moolenbroek 	}
162*00b67f09SDavid van Moolenbroek 
163*00b67f09SDavid van Moolenbroek 	isc_entropy_stopcallbacksources(ent);
164*00b67f09SDavid van Moolenbroek 
165*00b67f09SDavid van Moolenbroek 	hex_dump("good data only:", buffer, returned);
166*00b67f09SDavid van Moolenbroek 
167*00b67f09SDavid van Moolenbroek 	isc_entropy_stats(ent, stderr);
168*00b67f09SDavid van Moolenbroek 
169*00b67f09SDavid van Moolenbroek 	isc_entropy_destroysource(&source);
170*00b67f09SDavid van Moolenbroek 	isc_entropy_detach(&ent);
171*00b67f09SDavid van Moolenbroek 
172*00b67f09SDavid van Moolenbroek 	isc_mem_stats(mctx, stderr);
173*00b67f09SDavid van Moolenbroek 	isc_mem_destroy(&mctx);
174*00b67f09SDavid van Moolenbroek 
175*00b67f09SDavid van Moolenbroek 	return (0);
176*00b67f09SDavid van Moolenbroek }
177*00b67f09SDavid van Moolenbroek 
178