62 #if !defined(OPENSSL_SYS_MSDOS) && (!defined(OPENSSL_SYS_VMS) || defined(__DECC)) && !defined(OPENSSL_SYS_MACOSX)
69 #include OPENSSL_UNISTD_IO
72 #ifndef OPENSSL_SYS_NETWARE
80 #include <sys/types.h>
81 #include <sys/times.h>
88 #if defined(OPENSSL_SYS_VMS_DECC) && !defined(__TMS)
93 #include <sys/timeb.h>
96 #if defined(sun) || defined(__ultrix)
99 #include <sys/param.h>
104 #define BF_DEFAULT_OPTIONS
107 #define BF_encrypt BF_encrypt_normal
108 #undef HEADER_BF_LOCL_H
115 #define BF_encrypt BF_encrypt_ptr
116 #undef HEADER_BF_LOCL_H
123 #define BF_encrypt BF_encrypt_ptr2
124 #undef HEADER_BF_LOCL_H
130 # ifndef _BSD_CLK_TCK_
133 # define HZ ((double)_BSD_CLK_TCK_)
136 # define HZ ((double)CLK_TCK)
140 #define BUFSIZE ((long)1024)
145 #if defined(__STDC__) || defined(sgi)
146 #define SIGRETTYPE void
148 #define SIGRETTYPE int
151 SIGRETTYPE sig_done(
int sig);
152 SIGRETTYPE sig_done(
int sig)
154 signal(SIGALRM,sig_done);
169 static struct tms tstart,tend;
179 ret=((double)(tend.tms_utime-tstart.tms_utime))/
HZ;
180 return((ret == 0.0)?1
e-6:ret);
183 static struct timeb tstart,tend;
194 i=(long)tend.millitm-(
long)tstart.millitm;
195 ret=((double)(tend.time-tstart.time))+((
double)i)/1000.0;
196 return((ret == 0.0)?1
e-6:ret);
202 #define print_name(name) fprintf(stderr,"Doing %s's for 10 seconds\n",name); alarm(10);
204 #define print_name(name) fprintf(stderr,"Doing %s %ld times\n",name,cb);
207 #define time_it(func,name,index) \
210 for (count=0,run=1; COND(cb); count+=4) \
212 unsigned long d[2]; \
218 tm[index]=Time_F(STOP); \
219 fprintf(stderr,"%ld %s's in %.2f second\n",count,name,tm[index]); \
220 tm[index]=((double)COUNT(cb))/tm[index];
222 #define print_it(name,index) \
223 fprintf(stderr,"%s bytes per sec = %12.2f (%5.1fuS)\n",name, \
224 tm[index]*8,1.0e6/tm[index]);
226 int main(
int argc,
char **argv)
229 static unsigned char buf[
BUFSIZE];
230 static char key[16]={ 0x12,0x34,0x56,0x78,0x9a,0xbc,0xde,0xf0,
231 0x12,0x34,0x56,0x78,0x9a,0xbc,0xde,0xf0};
233 double d,tm[16],
max=0;
236 int max_idx=0,i,
num=0,j;
248 fprintf(stderr,
"To get the most accurate results, try to run this\n");
249 fprintf(stderr,
"program when this computer is idle.\n");
255 fprintf(stderr,
"First we calculate the approximate speed ...\n");
259 unsigned long data[2];
263 for (i=count; i; i--)
273 #define COND(d) (count != (d))
276 #define COND(c) (run)
277 #define COUNT(d) (count)
278 signal(SIGALRM,sig_done);
282 time_it(BF_encrypt_normal,
"BF_encrypt_normal ", 0);
283 time_it(BF_encrypt_ptr,
"BF_encrypt_ptr ", 1);
284 time_it(BF_encrypt_ptr2,
"BF_encrypt_ptr2 ", 2);
293 if (max < tm[1]) { max=tm[1]; max_idx=1; }
296 if (max < tm[2]) { max=tm[2]; max_idx=2; }
298 printf(
"options BF ecb/s\n");
299 printf(
"%s %12.2f 100.0%%\n",str[max_idx],tm[max_idx]);
307 if (max < tm[i]) { max=tm[i]; j=i; }
309 if (max < 0.0)
break;
310 printf(
"%s %12.2f %4.1f%%\n",str[j],tm[j],tm[j]/d*100.0);
318 printf(
"-DBF_DEFAULT_OPTIONS\n");
321 printf(
"-DBF_PTR\n");
324 printf(
"-DBF_PTR2\n");
328 #if defined(LINT) || defined(OPENSSL_SYS_MSDOS)