|
- /**
- * WARNING
- *
- * This file generates a PREDICTABLE and NOT AT ALL RANDOM sequence of bytes.
- *
- * Its purpose is to support our testing suite and it MUST NOT be used in any
- * scenario where you are expecting actual cryptography to happen.
- */
-
- #include "randombytes.h"
- #include <stdint.h>
-
- static uint32_t seed[32] = { 3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5, 8, 9, 7, 9, 3,
- 2, 3, 8, 4, 6, 2, 6, 4, 3, 3, 8, 3, 2, 7, 9, 5
- };
- static uint32_t in[12];
- static uint32_t out[8];
- static int32_t outleft = 0;
-
- #define ROTATE(x, b) (((x) << (b)) | ((x) >> (32 - (b))))
- #define MUSH(i, b) x = t[i] += (((x ^ seed[i]) + sum) ^ ROTATE(x, b));
-
- static void surf(void) {
- uint32_t t[12];
- uint32_t x;
- uint32_t sum = 0;
- int32_t r;
- int32_t i;
- int32_t loop;
-
- for (i = 0; i < 12; ++i) {
- t[i] = in[i] ^ seed[12 + i];
- }
- for (i = 0; i < 8; ++i) {
- out[i] = seed[24 + i];
- }
- x = t[11];
- for (loop = 0; loop < 2; ++loop) {
- for (r = 0; r < 16; ++r) {
- sum += 0x9e3779b9;
- MUSH(0, 5)
- MUSH(1, 7)
- MUSH(2, 9)
- MUSH(3, 13)
- MUSH(4, 5)
- MUSH(5, 7)
- MUSH(6, 9)
- MUSH(7, 13)
- MUSH(8, 5)
- MUSH(9, 7)
- MUSH(10, 9)
- MUSH(11, 13)
- }
- for (i = 0; i < 8; ++i) {
- out[i] ^= t[i + 4];
- }
- }
- }
-
- int randombytes(uint8_t *buf, size_t xlen) {
- while (xlen > 0) {
- if (!outleft) {
- if (!++in[0]) {
- if (!++in[1]) {
- if (!++in[2]) {
- ++in[3];
- }
- }
- }
- surf();
- outleft = 8;
- }
- *buf = (uint8_t) out[--outleft];
- ++buf;
- --xlen;
- }
- return 0;
- }
|