update to qemu v2.9.0! rand_check.c, init_forward.sh

This commit is contained in:
Ciro Santilli
2017-10-07 04:11:08 +01:00
parent 88cd83cd02
commit 62976c688b
6 changed files with 51 additions and 5 deletions

View File

@@ -18,6 +18,7 @@ These programs can also be compiled and used on host.
1. [poweroff](poweroff.c)
1. [init_dev_kmsg](init_dev_kmsg.c)
1. [uio_read](uio_read.c)
1. [rand_check](rand_check.c)
1. Module tests
1. [anonymous_inode](anonymous_inode.c)
1. [poll](poll.c)

View File

@@ -0,0 +1,41 @@
/* Check if we were able to remove certain sources of randomness
* across boots using different techniques:
*
* - QEMU icount record replay
* - norandmaps boot parameter
*
* You might want to run this as the init process to further remove undeterminism. */
#include <inttypes.h>
#include <signal.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int bss = 0;
int data = 1;
int main(__attribute__((unused)) int argc, char **argv) {
int i, *ip;
uint64_t uint64;
FILE *fp;
printf("time(NULL) = %ju\n", (uintmax_t)time(NULL));
printf("&i = %p\n", (void *)&i);
printf("&argv[0] = %p\n", (void *)&argv[0]);
printf("&main = %p\n", (void *)(intptr_t)main);
printf("&bss = %p\n", (void *)&bss);
printf("&data = %p\n", (void *)&data);
/* malloc */
ip = malloc(sizeof(*ip));
printf("&malloc = %p\n", (void *)ip);
free(ip);
/* /dev/urandom */
fp = fopen("/dev/urandom", "rb");
fread(&uint64, sizeof(uint64), 1, fp);
printf("/dev/urandom = %" PRIx64 "\n", uint64);
fclose(fp);
}