xref: /minix3/external/bsd/bind/dist/bin/tests/lfsr_test.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: lfsr_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) 1999-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: lfsr_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 #include <config.h>
24*00b67f09SDavid van Moolenbroek 
25*00b67f09SDavid van Moolenbroek #include <stdio.h>
26*00b67f09SDavid van Moolenbroek 
27*00b67f09SDavid van Moolenbroek #include <isc/lfsr.h>
28*00b67f09SDavid van Moolenbroek #include <isc/util.h>
29*00b67f09SDavid van Moolenbroek 
30*00b67f09SDavid van Moolenbroek isc_uint32_t state[1024 * 64];
31*00b67f09SDavid van Moolenbroek 
32*00b67f09SDavid van Moolenbroek int
main(int argc,char ** argv)33*00b67f09SDavid van Moolenbroek main(int argc, char **argv) {
34*00b67f09SDavid van Moolenbroek 	isc_lfsr_t lfsr1, lfsr2;
35*00b67f09SDavid van Moolenbroek 	int i;
36*00b67f09SDavid van Moolenbroek 	isc_uint32_t temp;
37*00b67f09SDavid van Moolenbroek 
38*00b67f09SDavid van Moolenbroek 	UNUSED(argc);
39*00b67f09SDavid van Moolenbroek 	UNUSED(argv);
40*00b67f09SDavid van Moolenbroek 
41*00b67f09SDavid van Moolenbroek 	/*
42*00b67f09SDavid van Moolenbroek 	 * Verify that returned values are reproducable.
43*00b67f09SDavid van Moolenbroek 	 */
44*00b67f09SDavid van Moolenbroek 	isc_lfsr_init(&lfsr1, 0, 32, 0x80000057U, 0, NULL, NULL);
45*00b67f09SDavid van Moolenbroek 	for (i = 0; i < 32; i++) {
46*00b67f09SDavid van Moolenbroek 		isc_lfsr_generate(&lfsr1, &state[i], 4);
47*00b67f09SDavid van Moolenbroek 		printf("lfsr1:  state[%2d] = %08x\n", i, state[i]);
48*00b67f09SDavid van Moolenbroek 	}
49*00b67f09SDavid van Moolenbroek 	isc_lfsr_init(&lfsr1, 0, 32, 0x80000057U, 0, NULL, NULL);
50*00b67f09SDavid van Moolenbroek 	for (i = 0; i < 32; i++) {
51*00b67f09SDavid van Moolenbroek 		isc_lfsr_generate(&lfsr1, &temp, 4);
52*00b67f09SDavid van Moolenbroek 		if (state[i] != temp)
53*00b67f09SDavid van Moolenbroek 			printf("lfsr1:  state[%2d] = %08x, "
54*00b67f09SDavid van Moolenbroek 			       "but new state is %08x\n",
55*00b67f09SDavid van Moolenbroek 			       i, state[i], temp);
56*00b67f09SDavid van Moolenbroek 	}
57*00b67f09SDavid van Moolenbroek 
58*00b67f09SDavid van Moolenbroek 	/*
59*00b67f09SDavid van Moolenbroek 	 * Now do the same with skipping.
60*00b67f09SDavid van Moolenbroek 	 */
61*00b67f09SDavid van Moolenbroek 	isc_lfsr_init(&lfsr1, 0, 32, 0x80000057U, 0, NULL, NULL);
62*00b67f09SDavid van Moolenbroek 	for (i = 0; i < 32; i++) {
63*00b67f09SDavid van Moolenbroek 		isc_lfsr_generate(&lfsr1, &state[i], 4);
64*00b67f09SDavid van Moolenbroek 		isc_lfsr_skip(&lfsr1, 32);
65*00b67f09SDavid van Moolenbroek 		printf("lfsr1:  state[%2d] = %08x\n", i, state[i]);
66*00b67f09SDavid van Moolenbroek 	}
67*00b67f09SDavid van Moolenbroek 	isc_lfsr_init(&lfsr1, 0, 32, 0x80000057U, 0, NULL, NULL);
68*00b67f09SDavid van Moolenbroek 	for (i = 0; i < 32; i++) {
69*00b67f09SDavid van Moolenbroek 		isc_lfsr_generate(&lfsr1, &temp, 4);
70*00b67f09SDavid van Moolenbroek 		isc_lfsr_skip(&lfsr1, 32);
71*00b67f09SDavid van Moolenbroek 		if (state[i] != temp)
72*00b67f09SDavid van Moolenbroek 			printf("lfsr1:  state[%2d] = %08x, "
73*00b67f09SDavid van Moolenbroek 			       "but new state is %08x\n",
74*00b67f09SDavid van Moolenbroek 			       i, state[i], temp);
75*00b67f09SDavid van Moolenbroek 	}
76*00b67f09SDavid van Moolenbroek 
77*00b67f09SDavid van Moolenbroek 	/*
78*00b67f09SDavid van Moolenbroek 	 * Try to find the period of the LFSR.
79*00b67f09SDavid van Moolenbroek 	 *
80*00b67f09SDavid van Moolenbroek 	 *	x^16 + x^5 + x^3 + x^2 + 1
81*00b67f09SDavid van Moolenbroek 	 */
82*00b67f09SDavid van Moolenbroek 	isc_lfsr_init(&lfsr2, 0, 16, 0x00008016U, 0, NULL, NULL);
83*00b67f09SDavid van Moolenbroek 	for (i = 0; i < 32; i++) {
84*00b67f09SDavid van Moolenbroek 		isc_lfsr_generate(&lfsr2, &state[i], 4);
85*00b67f09SDavid van Moolenbroek 		printf("lfsr2:  state[%2d] = %08x\n", i, state[i]);
86*00b67f09SDavid van Moolenbroek 	}
87*00b67f09SDavid van Moolenbroek 	isc_lfsr_init(&lfsr2, 0, 16, 0x00008016U, 0, NULL, NULL);
88*00b67f09SDavid van Moolenbroek 	for (i = 0; i < 32; i++) {
89*00b67f09SDavid van Moolenbroek 		isc_lfsr_generate(&lfsr2, &temp, 4);
90*00b67f09SDavid van Moolenbroek 		if (state[i] != temp)
91*00b67f09SDavid van Moolenbroek 			printf("lfsr2:  state[%2d] = %08x, "
92*00b67f09SDavid van Moolenbroek 			       "but new state is %08x\n",
93*00b67f09SDavid van Moolenbroek 			       i, state[i], temp);
94*00b67f09SDavid van Moolenbroek 	}
95*00b67f09SDavid van Moolenbroek 
96*00b67f09SDavid van Moolenbroek 	return (0);
97*00b67f09SDavid van Moolenbroek }
98