/*- * Copyright (c) 2002 Millions Consulting Limited * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $Id: monobit.c,v 1.1.1.1 2002/09/11 03:36:00 stacy Exp $ */ #include /* * FIPS 140-1 monobit test for a random number generator * * Refrence: * http://csrc.nist.gov/publications/fips/fips140-1/fips1401.htm */ /* s should point to a stream of 20,000 bits of muck */ int fips_monobit_test(u_char *s) { int i; int ones; ones = 0; for(i = 0; i < 2500; i++, s++) { if(*s & 0x01) ones++; if(*s & 0x02) ones++; if(*s & 0x04) ones++; if(*s & 0x08) ones++; if(*s & 0x10) ones++; if(*s & 0x20) ones++; if(*s & 0x40) ones++; if(*s & 0x80) ones++; } if(ones > 9654 && ones < 10346) return 1; return 0; }