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
|
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include "nist.h"
#define _32MB (32 * 1024 * 1024)
#define _08MB (8 * 1024 * 1024)
#define _04MB (4 * 1024 * 1024)
#define _02MB (2 * 1024 * 1024)
static int random_pool1 [_32MB];
char basedirname[FILENAME_MAX+1];
char *GetBaseDir(void)
{
return basedirname;
}
int main(int argc, char **argv)
{
char *filename = "";
FILE *fp = stdin;
long result=0;
if (argc<2 || argc>3) {
printf("Usage sts <file> [<template directory>]\n");
return 1;
}
/**
* get optional directory name
*/
basedirname[0] = 0;
if (argc>2) {
strcat(basedirname, argv[2]);
strcat(basedirname, "/");
}
filename = argv[1];
if ((fp = fopen(filename, "rb")) == NULL) {
printf("Cannot open file %s\n", filename);
return 2;
}
result = fread(random_pool1,sizeof(int),_04MB,fp);
fclose(fp);
if (result!=_04MB) {
printf("16MB sample required %ld != %d\n",result, _04MB);
return 3;
}
if (PackTestF (random_pool1, _04MB, "nist.out") < 8) {
if (PackTestL (random_pool1, _04MB, "nist.out") < 8)
return 0;
return 5;
}
return 4;
}
|