#include #include #include #include #include #include #include #ifndef FIPS int main(int argc, char *argv[]) { printf("No FIPS SHA1 support\n"); return(0); } #else #include #define MAX_TEST_BITS 103432 static void dump(const unsigned char *b,int n) { while(n-- > 0) printf("%02X",*b++); } static void bitfill(unsigned char *buf,int bit,int b,int n) { for( ; n > 0 ; --n,++bit) { assert(bit < MAX_TEST_BITS); buf[bit/8]|=b << (7-bit%8); } } void montecarlo(unsigned char *seed,int n) { int i,j; unsigned char m[10240]; memcpy(m,seed,n); for(j=0 ; j < 100 ; ++j) { for(i=1 ; i <= 50000 ; ++i) { memset(m+n,'\0',j/4+3); n+=j/4+3; m[n++]=i >> 24; m[n++]=i >> 16; m[n++]=i >> 8; m[n++]=i; /* putchar(' '); */ /* dump(m,bit/8); */ /* putchar('\n'); */ SHA1(m,n,m); n=20; } dump(m,20); puts(" ^"); } } int main(int argc,char **argv) { FILE *fp; int phase; if(argc != 2) { fprintf(stderr,"%s \n",argv[0]); exit(1); } if(!FIPS_mode_set(1,argv[0])) { ERR_load_crypto_strings(); ERR_print_errors(BIO_new_fp(stderr,BIO_NOCLOSE)); exit(1); } fp=fopen(argv[1],"r"); if(!fp) { perror(argv[1]); exit(2); } for(phase=0 ; ; ) { unsigned char buf[MAX_TEST_BITS/8]; unsigned char md[20]; char line[10240]; int n,t,b,bit; char *p; fgets(line,1024,fp); if(feof(fp)) break; n=strlen(line); line[n-1]='\0'; if(!strcmp(line,"D>")) ++phase; if(!isdigit(line[0])) { puts(line); continue; } for( ; ; ) { assert(n > 1); if(line[n-2] == '^') break; fgets(line+n-1,sizeof(line)-n+1,fp); n=strlen(line); /* printf("line=%s\n",line); */ assert(!feof(fp)); } p=strtok(line," "); t=atoi(p); p=strtok(NULL," "); b=atoi(p); memset(buf,'\0',sizeof buf); for(bit=0,p=strtok(NULL," ") ; p && *p != '^' ; p=strtok(NULL," ")) { assert(t-- > 0); bitfill(buf,bit,b,atoi(p)); bit+=atoi(p); b=1-b; } assert(t == 0); assert((bit%8) == 0); /* dump(buf,bit/8); */ /* putchar('\n'); */ if(phase < 3) { SHA1(buf,bit/8,md); dump(md,20); puts(" ^"); } else montecarlo(buf,bit/8); } return 0; } #endif