⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 x86_prof.c

📁 Dropbear is an SSH 2 server, designed to be usable in small memory environments. It supports:
💻 C
📖 第 1 页 / 共 2 页
字号:
#include <tomcrypt_test.h>prng_state yarrow_prng;struct list results[100];int no_results;int sorter(const void *a, const void *b){   const struct list *A, *B;   A = a;   B = b;   if (A->avg < B->avg) return -1;   if (A->avg > B->avg) return 1;   return 0;}void tally_results(int type){   int x;   // qsort the results   qsort(results, no_results, sizeof(struct list), &sorter);   fprintf(stderr, "\n");   if (type == 0) {      for (x = 0; x < no_results; x++) {         fprintf(stderr, "%-20s: Schedule at %6lu\n", cipher_descriptor[results[x].id].name, (unsigned long)results[x].spd1);      }    } else if (type == 1) {      for (x = 0; x < no_results; x++) {        printf          ("%-20s[%3d]: Encrypt at %5lu, Decrypt at %5lu\n", cipher_descriptor[results[x].id].name, cipher_descriptor[results[x].id].ID, results[x].spd1, results[x].spd2);      }   } else {      for (x = 0; x < no_results; x++) {        printf          ("%-20s: Process at %5lu\n", hash_descriptor[results[x].id].name, results[x].spd1 / 1000);      }   }}/* RDTSC from Scott Duplichan */ulong64 rdtsc (void)   {   #if defined __GNUC__ && !defined(LTC_NO_ASM)      #ifdef INTEL_CC			ulong64 a;			asm ( " rdtsc ":"=A"(a));         return a;      #elif defined(__i386__) || defined(__x86_64__)         ulong64 a;         asm __volatile__ ("rdtsc\nmovl %%eax,(%0)\nmovl %%edx,4(%0)\n"::"r"(&a):"%eax","%edx");         return a;      #elif defined(__ia64__)  /* gcc-IA64 version */         unsigned long result;         __asm__ __volatile__("mov %0=ar.itc" : "=r"(result) :: "memory");         while (__builtin_expect ((int) result == -1, 0))         __asm__ __volatile__("mov %0=ar.itc" : "=r"(result) :: "memory");         return result;      #else          return XCLOCK();      #endif   // Microsoft and Intel Windows compilers   #elif defined _M_IX86 && !defined(LTC_NO_ASM)     __asm rdtsc   #elif defined _M_AMD64 && !defined(LTC_NO_ASM)     return __rdtsc ();   #elif defined _M_IA64 && !defined(LTC_NO_ASM)     #if defined __INTEL_COMPILER       #include <ia64intrin.h>     #endif      return __getReg (3116);   #else     return XCLOCK();   #endif   }static ulong64 timer, skew = 0;void t_start(void){   timer = rdtsc();}ulong64 t_read(void){   return rdtsc() - timer;}void init_timer(void){   ulong64 c1, c2, t1, t2, t3;   unsigned long y1;   c1 = c2 = (ulong64)-1;   for (y1 = 0; y1 < TIMES*100; y1++) {      t_start();      t1 = t_read();      t3 = t_read();      t2 = (t_read() - t1)>>1;      c1 = (t1 > c1) ? t1 : c1;      c2 = (t2 > c2) ? t2 : c2;   }   skew = c2 - c1;   fprintf(stderr, "Clock Skew: %lu\n", (unsigned long)skew);}void reg_algs(void){  int err;#ifdef RIJNDAEL  register_cipher (&aes_desc);#endif#ifdef BLOWFISH  register_cipher (&blowfish_desc);#endif#ifdef XTEA  register_cipher (&xtea_desc);#endif#ifdef RC5  register_cipher (&rc5_desc);#endif#ifdef RC6  register_cipher (&rc6_desc);#endif#ifdef SAFERP  register_cipher (&saferp_desc);#endif#ifdef TWOFISH  register_cipher (&twofish_desc);#endif#ifdef SAFER  register_cipher (&safer_k64_desc);  register_cipher (&safer_sk64_desc);  register_cipher (&safer_k128_desc);  register_cipher (&safer_sk128_desc);#endif#ifdef RC2  register_cipher (&rc2_desc);#endif#ifdef DES  register_cipher (&des_desc);  register_cipher (&des3_desc);#endif#ifdef CAST5  register_cipher (&cast5_desc);#endif#ifdef NOEKEON  register_cipher (&noekeon_desc);#endif#ifdef SKIPJACK  register_cipher (&skipjack_desc);#endif#ifdef KHAZAD  register_cipher (&khazad_desc);#endif#ifdef ANUBIS  register_cipher (&anubis_desc);#endif#ifdef TIGER  register_hash (&tiger_desc);#endif#ifdef MD2  register_hash (&md2_desc);#endif#ifdef MD4  register_hash (&md4_desc);#endif#ifdef MD5  register_hash (&md5_desc);#endif#ifdef SHA1  register_hash (&sha1_desc);#endif#ifdef SHA224  register_hash (&sha224_desc);#endif#ifdef SHA256  register_hash (&sha256_desc);#endif#ifdef SHA384  register_hash (&sha384_desc);#endif#ifdef SHA512  register_hash (&sha512_desc);#endif#ifdef RIPEMD128  register_hash (&rmd128_desc);#endif#ifdef RIPEMD160  register_hash (&rmd160_desc);#endif#ifdef WHIRLPOOL  register_hash (&whirlpool_desc);#endif#ifdef CHC_HASH  register_hash(&chc_desc);  if ((err = chc_register(register_cipher(&aes_desc))) != CRYPT_OK) {     fprintf(stderr, "chc_register error: %s\n", error_to_string(err));     exit(EXIT_FAILURE);  }#endif#ifndef YARROW    #error This demo requires Yarrow.#endifregister_prng(&yarrow_desc);#ifdef FORTUNAregister_prng(&fortuna_desc);#endif#ifdef RC4register_prng(&rc4_desc);#endif#ifdef SOBER128register_prng(&sober128_desc);#endifrng_make_prng(128, find_prng("yarrow"), &yarrow_prng, NULL);}int time_keysched(void){  unsigned long x, y1;  ulong64 t1, c1;  symmetric_key skey;  int kl;  int    (*func) (const unsigned char *, int , int , symmetric_key *);  unsigned char key[MAXBLOCKSIZE];  fprintf(stderr, "\n\nKey Schedule Time Trials for the Symmetric Ciphers:\n(Times are cycles per key)\n");  no_results = 0;  for (x = 0; cipher_descriptor[x].name != NULL; x++) {#define DO1(k)   func(k, kl, 0, &skey);    func = cipher_descriptor[x].setup;    kl   = cipher_descriptor[x].min_key_length;    c1 = (ulong64)-1;    for (y1 = 0; y1 < KTIMES; y1++) {       yarrow_read(key, kl, &yarrow_prng);       t_start();       DO1(key);       t1 = t_read();       c1 = (t1 > c1) ? c1 : t1;    }    t1 = c1 - skew;    results[no_results].spd1 = results[no_results].avg = t1;    results[no_results++].id = x;    fprintf(stderr, "."); fflush(stdout);#undef DO1   }   tally_results(0);   return 0;}int time_cipher(void){  unsigned long x, y1;  ulong64  t1, t2, c1, c2, a1, a2;  symmetric_ECB ecb;  unsigned char key[MAXBLOCKSIZE], pt[4096];  int err;  fprintf(stderr, "\n\nECB Time Trials for the Symmetric Ciphers:\n");  no_results = 0;  for (x = 0; cipher_descriptor[x].name != NULL; x++) {    ecb_start(x, key, cipher_descriptor[x].min_key_length, 0, &ecb);    /* sanity check on cipher */    if ((err = cipher_descriptor[x].test()) != CRYPT_OK) {       fprintf(stderr, "\n\nERROR: Cipher %s failed self-test %s\n", cipher_descriptor[x].name, error_to_string(err));       exit(EXIT_FAILURE);    }#define DO1   ecb_encrypt(pt, pt, sizeof(pt), &ecb);#define DO2   DO1 DO1    c1 = c2 = (ulong64)-1;    for (y1 = 0; y1 < 100; y1++) {        t_start();        DO1;        t1 = t_read();        DO2;        t2 = t_read();        t2 -= t1;        c1 = (t1 > c1 ? c1 : t1);        c2 = (t2 > c2 ? c2 : t2);    }    a1 = c2 - c1 - skew;#undef DO1#undef DO2#define DO1   ecb_decrypt(pt, pt, sizeof(pt), &ecb);#define DO2   DO1 DO1    c1 = c2 = (ulong64)-1;    for (y1 = 0; y1 < 100; y1++) {        t_start();        DO1;        t1 = t_read();        DO2;        t2 = t_read();        t2 -= t1;        c1 = (t1 > c1 ? c1 : t1);        c2 = (t2 > c2 ? c2 : t2);    }    a2 = c2 - c1 - skew;        results[no_results].id = x;    results[no_results].spd1 = a1/(sizeof(pt)/cipher_descriptor[x].block_length);    results[no_results].spd2 = a2/(sizeof(pt)/cipher_descriptor[x].block_length);    results[no_results].avg = (results[no_results].spd1 + results[no_results].spd2+1)/2;    ++no_results;    fprintf(stderr, "."); fflush(stdout);    #undef DO2#undef DO1   }   tally_results(1);   return 0;}#ifdef CBC int time_cipher2(void){  unsigned long x, y1;  ulong64  t1, t2, c1, c2, a1, a2;  symmetric_CBC cbc;  unsigned char key[MAXBLOCKSIZE], pt[4096];  int err;  fprintf(stderr, "\n\nCBC Time Trials for the Symmetric Ciphers:\n");  no_results = 0;  for (x = 0; cipher_descriptor[x].name != NULL; x++) {    cbc_start(x, pt, key, cipher_descriptor[x].min_key_length, 0, &cbc);    /* sanity check on cipher */    if ((err = cipher_descriptor[x].test()) != CRYPT_OK) {       fprintf(stderr, "\n\nERROR: Cipher %s failed self-test %s\n", cipher_descriptor[x].name, error_to_string(err));       exit(EXIT_FAILURE);    }#define DO1   cbc_encrypt(pt, pt, sizeof(pt), &cbc);#define DO2   DO1 DO1    c1 = c2 = (ulong64)-1;    for (y1 = 0; y1 < 100; y1++) {        t_start();        DO1;        t1 = t_read();        DO2;        t2 = t_read();        t2 -= t1;        c1 = (t1 > c1 ? c1 : t1);        c2 = (t2 > c2 ? c2 : t2);    }    a1 = c2 - c1 - skew;#undef DO1#undef DO2#define DO1   cbc_decrypt(pt, pt, sizeof(pt), &cbc);#define DO2   DO1 DO1    c1 = c2 = (ulong64)-1;    for (y1 = 0; y1 < 100; y1++) {        t_start();        DO1;        t1 = t_read();        DO2;        t2 = t_read();        t2 -= t1;        c1 = (t1 > c1 ? c1 : t1);        c2 = (t2 > c2 ? c2 : t2);    }    a2 = c2 - c1 - skew;        results[no_results].id = x;    results[no_results].spd1 = a1/(sizeof(pt)/cipher_descriptor[x].block_length);    results[no_results].spd2 = a2/(sizeof(pt)/cipher_descriptor[x].block_length);    results[no_results].avg = (results[no_results].spd1 + results[no_results].spd2+1)/2;    ++no_results;    fprintf(stderr, "."); fflush(stdout);    #undef DO2#undef DO1   }   tally_results(1);   return 0;}#elseint time_cipher2(void) { fprintf(stderr, "NO CBC\n"); return 0; }#endif#ifdef CTRint time_cipher3(void){  unsigned long x, y1;  ulong64  t1, t2, c1, c2, a1, a2;  symmetric_CTR ctr;  unsigned char key[MAXBLOCKSIZE], pt[4096];  int err;  fprintf(stderr, "\n\nCTR Time Trials for the Symmetric Ciphers:\n");  no_results = 0;  for (x = 0; cipher_descriptor[x].name != NULL; x++) {    ctr_start(x, pt, key, cipher_descriptor[x].min_key_length, 0, CTR_COUNTER_LITTLE_ENDIAN, &ctr);    /* sanity check on cipher */    if ((err = cipher_descriptor[x].test()) != CRYPT_OK) {       fprintf(stderr, "\n\nERROR: Cipher %s failed self-test %s\n", cipher_descriptor[x].name, error_to_string(err));       exit(EXIT_FAILURE);    }#define DO1   ctr_encrypt(pt, pt, sizeof(pt), &ctr);#define DO2   DO1 DO1    c1 = c2 = (ulong64)-1;    for (y1 = 0; y1 < 100; y1++) {        t_start();        DO1;        t1 = t_read();        DO2;        t2 = t_read();        t2 -= t1;        c1 = (t1 > c1 ? c1 : t1);        c2 = (t2 > c2 ? c2 : t2);    }    a1 = c2 - c1 - skew;#undef DO1#undef DO2#define DO1   ctr_decrypt(pt, pt, sizeof(pt), &ctr);#define DO2   DO1 DO1    c1 = c2 = (ulong64)-1;    for (y1 = 0; y1 < 100; y1++) {        t_start();        DO1;        t1 = t_read();        DO2;        t2 = t_read();        t2 -= t1;        c1 = (t1 > c1 ? c1 : t1);        c2 = (t2 > c2 ? c2 : t2);    }    a2 = c2 - c1 - skew;        results[no_results].id = x;    results[no_results].spd1 = a1/(sizeof(pt)/cipher_descriptor[x].block_length);    results[no_results].spd2 = a2/(sizeof(pt)/cipher_descriptor[x].block_length);    results[no_results].avg = (results[no_results].spd1 + results[no_results].spd2+1)/2;    ++no_results;    fprintf(stderr, "."); fflush(stdout);    #undef DO2#undef DO1   }   tally_results(1);   return 0;}#elseint time_cipher3(void) { fprintf(stderr, "NO CTR\n"); return 0; }#endifint time_hash(void){  unsigned long x, y1, len;  ulong64 t1, t2, c1, c2;  hash_state md;  int    (*func)(hash_state *, const unsigned char *, unsigned long), err;  unsigned char pt[MAXBLOCKSIZE];  fprintf(stderr, "\n\nHASH Time Trials for:\n");  no_results = 0;  for (x = 0; hash_descriptor[x].name != NULL; x++) {    /* sanity check on hash */    if ((err = hash_descriptor[x].test()) != CRYPT_OK) {       fprintf(stderr, "\n\nERROR: Hash %s failed self-test %s\n", hash_descriptor[x].name, error_to_string(err));       exit(EXIT_FAILURE);    }    hash_descriptor[x].init(&md);#define DO1   func(&md,pt,len);#define DO2   DO1 DO1    func = hash_descriptor[x].process;    len  = hash_descriptor[x].blocksize;    c1 = c2 = (ulong64)-1;    for (y1 = 0; y1 < TIMES; y1++) {       t_start();       DO1;       t1 = t_read();       DO2;       t2 = t_read() - t1;       c1 = (t1 > c1) ? c1 : t1;       c2 = (t2 > c2) ? c2 : t2;    }    t1 = c2 - c1 - skew;    t1 = ((t1 * CONST64(1000))) / ((ulong64)hash_descriptor[x].blocksize);    results[no_results].id = x;    results[no_results].spd1 = results[no_results].avg = t1;    ++no_results;    fprintf(stderr, "."); fflush(stdout);#undef DO2#undef DO1   }   tally_results(2);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -