Skip to content

Commit

Permalink
lib: add rand() function
Browse files Browse the repository at this point in the history
It's a PRNG using the simple and fast xorshift method.

Signed-off-by: Michael Walle <[email protected]>
Cc: Wolfgang Denk <[email protected]>
  • Loading branch information
mwalle authored and albert-aribaud-u-boot committed Jul 7, 2012
1 parent d131ad6 commit 9acf1ca
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 0 deletions.
8 changes: 8 additions & 0 deletions include/common.h
Original file line number Diff line number Diff line change
Expand Up @@ -760,6 +760,14 @@ char * strmhz(char *buf, unsigned long hz);
/* lib/crc32.c */
#include <u-boot/crc.h>

/* lib/rand.c */
#ifdef CONFIG_RANDOM_MACADDR
#define RAND_MAX -1U
void srand(unsigned int seed);
unsigned int rand(void);
unsigned int rand_r(unsigned int *seedp);
#endif

/* common/console.c */
int console_init_f(void); /* Before relocation; uses the serial stuff */
int console_init_r(void); /* After relocation; uses the console stuff */
Expand Down
1 change: 1 addition & 0 deletions lib/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,7 @@ COBJS-y += string.o
COBJS-y += time.o
COBJS-$(CONFIG_BOOTP_PXE) += uuid.o
COBJS-y += vsprintf.o
COBJS-$(CONFIG_RANDOM_MACADDR) += rand.o

COBJS := $(COBJS-y)
SRCS := $(COBJS:.o=.c)
Expand Down
48 changes: 48 additions & 0 deletions lib/rand.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
/*
* Simple xorshift PRNG
* see http://www.jstatsoft.org/v08/i14/paper
*
* Copyright (c) 2012 Michael Walle
* Michael Walle <[email protected]>
*
* See file CREDITS for list of people who contributed to this
* project.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of
* the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*/

#include <common.h>

static unsigned int y = 1U;

unsigned int rand_r(unsigned int *seedp)
{
*seedp ^= (*seedp << 13);
*seedp ^= (*seedp >> 17);
*seedp ^= (*seedp << 5);

return *seedp;
}

unsigned int rand(void)
{
return rand_r(&y);
}

void srand(unsigned int seed)
{
y = seed;
}

0 comments on commit 9acf1ca

Please sign in to comment.