hammer.urandom (d82e286489da73321a47e329d98a98817b0438b6) | hammer.urandom (1130b656e5fe4c2d1ba299e024d1b40eaeebd380) |
---|---|
1#!/usr/bin/perl 2 3# 4# Test program for /dev/urandom 5# Read and display random numbers. 6# This also reads /dev/zero to make sure there is no brokenness there. 7# | 1#!/usr/bin/perl 2 3# 4# Test program for /dev/urandom 5# Read and display random numbers. 6# This also reads /dev/zero to make sure there is no brokenness there. 7# |
8# $Id$ | 8# $FreeBSD$ |
9# 10 11open(ZERO, "/dev/zero") || die "Cannot open /dev/zero - $!\n"; 12 13for (;;) { 14 open(BIN, "/dev/urandom"); 15 $len = sysread(BIN, $a, 20); 16 sysread(ZERO, $b, 20); 17 close(BIN); 18 if ($len > 0) { 19 for ($j = 0; $j < $len; $j += 2) { 20 $k = unpack("S", substr($a, $j, 2)); 21 $z = unpack("S", substr($b, $j, 2)); 22 $z == 0 || die "/dev/zero is returning non-zero!\n"; 23 printf("%.4X ", $k); 24 } 25 printf "\n"; 26 } 27} | 9# 10 11open(ZERO, "/dev/zero") || die "Cannot open /dev/zero - $!\n"; 12 13for (;;) { 14 open(BIN, "/dev/urandom"); 15 $len = sysread(BIN, $a, 20); 16 sysread(ZERO, $b, 20); 17 close(BIN); 18 if ($len > 0) { 19 for ($j = 0; $j < $len; $j += 2) { 20 $k = unpack("S", substr($a, $j, 2)); 21 $z = unpack("S", substr($b, $j, 2)); 22 $z == 0 || die "/dev/zero is returning non-zero!\n"; 23 printf("%.4X ", $k); 24 } 25 printf "\n"; 26 } 27} |