| // |
| // gettsc.inl |
| // |
| // gives access to the Pentium's (secret) cycle counter |
| // |
| // This software was written by Leonard Janke (janke@unixg.ubc.ca) |
| // in 1996-7 and is entered, by him, into the public domain. |
| |
| #if defined(__WATCOMC__) |
| void GetTSC(unsigned long&); |
| #pragma aux GetTSC = 0x0f 0x31 "mov [edi], eax" parm [edi] modify [edx eax]; |
| #elif defined(__GNUC__) |
| inline |
| void GetTSC(unsigned long& tsc) |
| { |
| asm volatile(".byte 15, 49\n\t" |
| : "=eax" (tsc) |
| : |
| : "%edx", "%eax"); |
| } |
| #elif defined(_MSC_VER) |
| inline |
| void GetTSC(unsigned long& tsc) |
| { |
| unsigned long a; |
| __asm _emit 0fh |
| __asm _emit 31h |
| __asm mov a, eax; |
| tsc=a; |
| } |
| #endif |
| |
| #include <stdio.h> |
| #include <stdlib.h> |
| #include <openssl/rc4.h> |
| |
| void main(int argc,char *argv[]) |
| { |
| unsigned char buffer[1024]; |
| RC4_KEY ctx; |
| unsigned long s1,s2,e1,e2; |
| unsigned char k[16]; |
| unsigned long data[2]; |
| unsigned char iv[8]; |
| int i,num=64,numm; |
| int j=0; |
| |
| if (argc >= 2) |
| num=atoi(argv[1]); |
| |
| if (num == 0) num=256; |
| if (num > 1024-16) num=1024-16; |
| numm=num+8; |
| |
| for (j=0; j<6; j++) |
| { |
| for (i=0; i<10; i++) /**/ |
| { |
| RC4(&ctx,numm,buffer,buffer); |
| GetTSC(s1); |
| RC4(&ctx,numm,buffer,buffer); |
| GetTSC(e1); |
| GetTSC(s2); |
| RC4(&ctx,num,buffer,buffer); |
| GetTSC(e2); |
| RC4(&ctx,num,buffer,buffer); |
| } |
| |
| printf("RC4 (%d bytes) %d %d (%d) - 8 bytes\n",num, |
| e1-s1,e2-s2,(e1-s1)-(e2-s2)); |
| } |
| } |
| |