1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
|
//
// srecord - manipulate eprom load files
// Copyright (C) 2004, 2006, 2007 Peter Miller
//
// 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 3 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, see
// <http://www.gnu.org/licenses/>.
//
#include <cstdlib>
#include <time.h>
#include <unistd.h>
#include <lib/r250.h>
static unsigned long buf[250];
static unsigned long *pos;
static inline int
rand8(void)
{
return ((rand() >> 7) & 255);
}
static inline long
rand32(void)
{
return
(
((unsigned long)rand8() << 24)
|
((unsigned long)rand8() << 16)
|
((unsigned long)rand8() << 8)
|
(unsigned long)rand8()
);
}
#define SIZEOF(a) (sizeof(a) / sizeof(a[0]))
#define ENDOF(a) ((a) + SIZEOF(a))
static bool ready;
static void
r250_init(void)
{
ready = true;
/*
* initialize crummy linear congruential
*/
time_t now;
time(&now);
srand(now + getpid());
/*
* position to start of array
*/
pos = buf;
/*
* initialise contents of array
*/
unsigned long *bp;
for (bp = buf; bp < ENDOF(buf); ++bp)
*bp = rand32();
/*
* make sure the bits are linearly independent
*/
unsigned long bit;
for (bit = 1, bp = buf + 3; bit; bp += 11, bit <<= 1)
{
if (bp >= ENDOF(buf))
bp -= SIZEOF(buf);
*bp = (*bp & ~(bit - 1)) | bit;
}
}
unsigned long
r250(void)
{
if (!ready)
r250_init();
unsigned long *other = pos + 103;
if (other >= ENDOF(buf))
other -= SIZEOF(buf);
*pos ^= *other;
unsigned long result = *pos++;
if (pos >= ENDOF(buf))
pos = buf;
return result;
}
|