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

📄 sha1s.cpp

📁 SHA-1Hash函数源码
💻 CPP
字号:
//// 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__)inlinevoid GetTSC(unsigned long& tsc){  asm volatile(".byte 15, 49\n\t"	       : "=eax" (tsc)	       :	       : "%edx", "%eax");}#elif defined(_MSC_VER)inlinevoid 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/sha.h>#define sha1_block_x86 sha1_block_asm_data_orderextern "C" {void sha1_block_x86(SHA_CTX *ctx, unsigned char *buffer,int num);}void main(int argc,char *argv[])	{	unsigned char buffer[64*256];	SHA_CTX ctx;	unsigned long s1,s2,e1,e2;	unsigned char k[16];	unsigned long data[2];	unsigned char iv[8];	int i,num=0,numm;	int j=0;	if (argc >= 2)		num=atoi(argv[1]);	if (num == 0) num=16;	if (num > 250) num=16;	numm=num+2;#if 0	num*=64;	numm*=64;#endif	for (j=0; j<6; j++)		{		for (i=0; i<10; i++) /**/			{			sha1_block_x86(&ctx,buffer,numm);			GetTSC(s1);			sha1_block_x86(&ctx,buffer,numm);			GetTSC(e1);			GetTSC(s2);			sha1_block_x86(&ctx,buffer,num);			GetTSC(e2);			sha1_block_x86(&ctx,buffer,num);			}		printf("sha1 (%d bytes) %d %d (%.2f)\n",num*64,			e1-s1,e2-s2,(double)((e1-s1)-(e2-s2))/2);		}	}

⌨️ 快捷键说明

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