Make EVP_Digest*() routines return a value.
TODO: update docs, and make soe other routines which use EVP_Digest*() check return codes.
This commit is contained in:
		
							
								
								
									
										5
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								CHANGES
									
									
									
									
									
								
							@@ -3,6 +3,11 @@
 | 
			
		||||
 | 
			
		||||
 Changes between 0.9.6 and 0.9.7  [xx XXX 2000]
 | 
			
		||||
 | 
			
		||||
  *) Modify EVP_Digest*() routines so they now return values. Although the
 | 
			
		||||
     internal software routines can never fail additional hardware versions
 | 
			
		||||
     might.
 | 
			
		||||
     [Steve Henson]
 | 
			
		||||
 | 
			
		||||
  *) Clean up crypto/err/err.h and change some error codes to avoid conflicts:
 | 
			
		||||
 | 
			
		||||
     Previously ERR_R_FATAL was too small and coincided with ERR_LIB_PKCS7
 | 
			
		||||
 
 | 
			
		||||
@@ -61,24 +61,26 @@
 | 
			
		||||
#include <openssl/objects.h>
 | 
			
		||||
#include <openssl/evp.h>
 | 
			
		||||
 | 
			
		||||
void EVP_DigestInit(EVP_MD_CTX *ctx, const EVP_MD *type)
 | 
			
		||||
int EVP_DigestInit(EVP_MD_CTX *ctx, const EVP_MD *type)
 | 
			
		||||
	{
 | 
			
		||||
	ctx->digest=type;
 | 
			
		||||
	type->init(&(ctx->md));
 | 
			
		||||
	return type->init(&(ctx->md));
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
void EVP_DigestUpdate(EVP_MD_CTX *ctx, const void *data,
 | 
			
		||||
int EVP_DigestUpdate(EVP_MD_CTX *ctx, const void *data,
 | 
			
		||||
	     unsigned int count)
 | 
			
		||||
	{
 | 
			
		||||
	ctx->digest->update(&(ctx->md.base[0]),data,(unsigned long)count);
 | 
			
		||||
	return ctx->digest->update(&(ctx->md.base[0]),data,(unsigned long)count);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
void EVP_DigestFinal(EVP_MD_CTX *ctx, unsigned char *md, unsigned int *size)
 | 
			
		||||
int EVP_DigestFinal(EVP_MD_CTX *ctx, unsigned char *md, unsigned int *size)
 | 
			
		||||
	{
 | 
			
		||||
	ctx->digest->final(md,&(ctx->md.base[0]));
 | 
			
		||||
	int ret;
 | 
			
		||||
	ret = ctx->digest->final(md,&(ctx->md.base[0]));
 | 
			
		||||
	if (size != NULL)
 | 
			
		||||
		*size=ctx->digest->md_size;
 | 
			
		||||
	memset(&(ctx->md),0,sizeof(ctx->md));
 | 
			
		||||
	return ret;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
int EVP_MD_CTX_copy(EVP_MD_CTX *out, EVP_MD_CTX *in)
 | 
			
		||||
@@ -95,8 +97,9 @@ int EVP_Digest(void *data, unsigned int count,
 | 
			
		||||
		unsigned char *md, unsigned int *size, const EVP_MD *type)
 | 
			
		||||
{
 | 
			
		||||
	EVP_MD_CTX ctx;
 | 
			
		||||
	EVP_DigestInit(&ctx, type);
 | 
			
		||||
	EVP_DigestUpdate(&ctx, data, count);
 | 
			
		||||
	EVP_DigestFinal(&ctx, md, size);
 | 
			
		||||
	return 1;
 | 
			
		||||
	if (!EVP_DigestInit(&ctx, type))
 | 
			
		||||
		return 0;
 | 
			
		||||
	if (!EVP_DigestUpdate(&ctx, data, count))
 | 
			
		||||
		return 0;
 | 
			
		||||
	return EVP_DigestFinal(&ctx, md, size);
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -268,9 +268,9 @@ typedef struct env_md_st
 | 
			
		||||
	int type;
 | 
			
		||||
	int pkey_type;
 | 
			
		||||
	int md_size;
 | 
			
		||||
	void (*init)();
 | 
			
		||||
	void (*update)();
 | 
			
		||||
	void (*final)();
 | 
			
		||||
	int (*init)();
 | 
			
		||||
	int (*update)();
 | 
			
		||||
	int (*final)();
 | 
			
		||||
 | 
			
		||||
	int (*sign)();
 | 
			
		||||
	int (*verify)();
 | 
			
		||||
@@ -558,10 +558,10 @@ void BIO_set_md(BIO *,const EVP_MD *md);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
int     EVP_MD_CTX_copy(EVP_MD_CTX *out,EVP_MD_CTX *in);  
 | 
			
		||||
void	EVP_DigestInit(EVP_MD_CTX *ctx, const EVP_MD *type);
 | 
			
		||||
void	EVP_DigestUpdate(EVP_MD_CTX *ctx,const void *d,
 | 
			
		||||
int	EVP_DigestInit(EVP_MD_CTX *ctx, const EVP_MD *type);
 | 
			
		||||
int	EVP_DigestUpdate(EVP_MD_CTX *ctx,const void *d,
 | 
			
		||||
			 unsigned int cnt);
 | 
			
		||||
void	EVP_DigestFinal(EVP_MD_CTX *ctx,unsigned char *md,unsigned int *s);
 | 
			
		||||
int	EVP_DigestFinal(EVP_MD_CTX *ctx,unsigned char *md,unsigned int *s);
 | 
			
		||||
int	EVP_Digest(void *data, unsigned int count,
 | 
			
		||||
		unsigned char *md, unsigned int *size, const EVP_MD *type);
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -62,8 +62,9 @@
 | 
			
		||||
#include <openssl/objects.h>
 | 
			
		||||
#include <openssl/x509.h>
 | 
			
		||||
 | 
			
		||||
static void function(void)
 | 
			
		||||
static int function(void)
 | 
			
		||||
	{
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
static EVP_MD null_md=
 | 
			
		||||
 
 | 
			
		||||
@@ -80,9 +80,9 @@ typedef struct MD2state_st
 | 
			
		||||
	} MD2_CTX;
 | 
			
		||||
 | 
			
		||||
const char *MD2_options(void);
 | 
			
		||||
void MD2_Init(MD2_CTX *c);
 | 
			
		||||
void MD2_Update(MD2_CTX *c, const unsigned char *data, unsigned long len);
 | 
			
		||||
void MD2_Final(unsigned char *md, MD2_CTX *c);
 | 
			
		||||
int MD2_Init(MD2_CTX *c);
 | 
			
		||||
int MD2_Update(MD2_CTX *c, const unsigned char *data, unsigned long len);
 | 
			
		||||
int MD2_Final(unsigned char *md, MD2_CTX *c);
 | 
			
		||||
unsigned char *MD2(const unsigned char *d, unsigned long n,unsigned char *md);
 | 
			
		||||
#ifdef  __cplusplus
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -115,19 +115,20 @@ const char *MD2_options(void)
 | 
			
		||||
		return("md2(int)");
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
void MD2_Init(MD2_CTX *c)
 | 
			
		||||
int MD2_Init(MD2_CTX *c)
 | 
			
		||||
	{
 | 
			
		||||
	c->num=0;
 | 
			
		||||
	memset(c->state,0,MD2_BLOCK*sizeof(MD2_INT));
 | 
			
		||||
	memset(c->cksm,0,MD2_BLOCK*sizeof(MD2_INT));
 | 
			
		||||
	memset(c->data,0,MD2_BLOCK);
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
void MD2_Update(MD2_CTX *c, const unsigned char *data, unsigned long len)
 | 
			
		||||
int MD2_Update(MD2_CTX *c, const unsigned char *data, unsigned long len)
 | 
			
		||||
	{
 | 
			
		||||
	register UCHAR *p;
 | 
			
		||||
 | 
			
		||||
	if (len == 0) return;
 | 
			
		||||
	if (len == 0) return 1;
 | 
			
		||||
 | 
			
		||||
	p=c->data;
 | 
			
		||||
	if (c->num != 0)
 | 
			
		||||
@@ -146,7 +147,7 @@ void MD2_Update(MD2_CTX *c, const unsigned char *data, unsigned long len)
 | 
			
		||||
			memcpy(&(p[c->num]),data,(int)len);
 | 
			
		||||
			/* data+=len; */
 | 
			
		||||
			c->num+=(int)len;
 | 
			
		||||
			return;
 | 
			
		||||
			return 1;
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
	/* we now can process the input data in blocks of MD2_BLOCK
 | 
			
		||||
@@ -159,6 +160,7 @@ void MD2_Update(MD2_CTX *c, const unsigned char *data, unsigned long len)
 | 
			
		||||
		}
 | 
			
		||||
	memcpy(p,data,(int)len);
 | 
			
		||||
	c->num=(int)len;
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
static void md2_block(MD2_CTX *c, const unsigned char *d)
 | 
			
		||||
@@ -197,7 +199,7 @@ static void md2_block(MD2_CTX *c, const unsigned char *d)
 | 
			
		||||
	memset(state,0,48*sizeof(MD2_INT));
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
void MD2_Final(unsigned char *md, MD2_CTX *c)
 | 
			
		||||
int MD2_Final(unsigned char *md, MD2_CTX *c)
 | 
			
		||||
	{
 | 
			
		||||
	int i,v;
 | 
			
		||||
	register UCHAR *cp;
 | 
			
		||||
@@ -219,5 +221,6 @@ void MD2_Final(unsigned char *md, MD2_CTX *c)
 | 
			
		||||
	for (i=0; i<16; i++)
 | 
			
		||||
		md[i]=(UCHAR)(p1[i]&0xff);
 | 
			
		||||
	memset((char *)&c,0,sizeof(c));
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -410,14 +410,14 @@
 | 
			
		||||
 * Time for some action:-)
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
void HASH_UPDATE (HASH_CTX *c, const void *data_, unsigned long len)
 | 
			
		||||
int HASH_UPDATE (HASH_CTX *c, const void *data_, unsigned long len)
 | 
			
		||||
	{
 | 
			
		||||
	const unsigned char *data=data_;
 | 
			
		||||
	register HASH_LONG * p;
 | 
			
		||||
	register unsigned long l;
 | 
			
		||||
	int sw,sc,ew,ec;
 | 
			
		||||
 | 
			
		||||
	if (len==0) return;
 | 
			
		||||
	if (len==0) return 1;
 | 
			
		||||
 | 
			
		||||
	l=(c->Nl+(len<<3))&0xffffffffL;
 | 
			
		||||
	/* 95-05-24 eay Fixed a bug with the overflow handling, thanks to
 | 
			
		||||
@@ -466,7 +466,7 @@ void HASH_UPDATE (HASH_CTX *c, const void *data_, unsigned long len)
 | 
			
		||||
					HOST_c2l_p(data,l,ec); p[sw]=l;
 | 
			
		||||
					}
 | 
			
		||||
				}
 | 
			
		||||
			return;
 | 
			
		||||
			return 1;
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
@@ -520,6 +520,7 @@ void HASH_UPDATE (HASH_CTX *c, const void *data_, unsigned long len)
 | 
			
		||||
		HOST_c2l_p(data,l,ec);
 | 
			
		||||
		*p=l;
 | 
			
		||||
		}
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@@ -543,7 +544,7 @@ void HASH_TRANSFORM (HASH_CTX *c, const unsigned char *data)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void HASH_FINAL (unsigned char *md, HASH_CTX *c)
 | 
			
		||||
int HASH_FINAL (unsigned char *md, HASH_CTX *c)
 | 
			
		||||
	{
 | 
			
		||||
	register HASH_LONG *p;
 | 
			
		||||
	register unsigned long l;
 | 
			
		||||
@@ -604,4 +605,5 @@ void HASH_FINAL (unsigned char *md, HASH_CTX *c)
 | 
			
		||||
	 * but I'm not worried :-)
 | 
			
		||||
	memset((void *)c,0,sizeof(HASH_CTX));
 | 
			
		||||
	 */
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
@@ -104,9 +104,9 @@ typedef struct MD4state_st
 | 
			
		||||
	int num;
 | 
			
		||||
	} MD4_CTX;
 | 
			
		||||
 | 
			
		||||
void MD4_Init(MD4_CTX *c);
 | 
			
		||||
void MD4_Update(MD4_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
void MD4_Final(unsigned char *md, MD4_CTX *c);
 | 
			
		||||
int MD4_Init(MD4_CTX *c);
 | 
			
		||||
int MD4_Update(MD4_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
int MD4_Final(unsigned char *md, MD4_CTX *c);
 | 
			
		||||
unsigned char *MD4(const unsigned char *d, unsigned long n, unsigned char *md);
 | 
			
		||||
void MD4_Transform(MD4_CTX *c, const unsigned char *b);
 | 
			
		||||
#ifdef  __cplusplus
 | 
			
		||||
 
 | 
			
		||||
@@ -70,7 +70,7 @@ const char *MD4_version="MD4" OPENSSL_VERSION_PTEXT;
 | 
			
		||||
#define INIT_DATA_C (unsigned long)0x98badcfeL
 | 
			
		||||
#define INIT_DATA_D (unsigned long)0x10325476L
 | 
			
		||||
 | 
			
		||||
void MD4_Init(MD4_CTX *c)
 | 
			
		||||
int MD4_Init(MD4_CTX *c)
 | 
			
		||||
	{
 | 
			
		||||
	c->A=INIT_DATA_A;
 | 
			
		||||
	c->B=INIT_DATA_B;
 | 
			
		||||
@@ -79,6 +79,7 @@ void MD4_Init(MD4_CTX *c)
 | 
			
		||||
	c->Nl=0;
 | 
			
		||||
	c->Nh=0;
 | 
			
		||||
	c->num=0;
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
#ifndef md4_block_host_order
 | 
			
		||||
 
 | 
			
		||||
@@ -102,9 +102,9 @@ typedef struct MD5state_st
 | 
			
		||||
	int num;
 | 
			
		||||
	} MD5_CTX;
 | 
			
		||||
 | 
			
		||||
void MD5_Init(MD5_CTX *c);
 | 
			
		||||
void MD5_Update(MD5_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
void MD5_Final(unsigned char *md, MD5_CTX *c);
 | 
			
		||||
int MD5_Init(MD5_CTX *c);
 | 
			
		||||
int MD5_Update(MD5_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
int MD5_Final(unsigned char *md, MD5_CTX *c);
 | 
			
		||||
unsigned char *MD5(const unsigned char *d, unsigned long n, unsigned char *md);
 | 
			
		||||
void MD5_Transform(MD5_CTX *c, const unsigned char *b);
 | 
			
		||||
#ifdef  __cplusplus
 | 
			
		||||
 
 | 
			
		||||
@@ -70,7 +70,7 @@ const char *MD5_version="MD5" OPENSSL_VERSION_PTEXT;
 | 
			
		||||
#define INIT_DATA_C (unsigned long)0x98badcfeL
 | 
			
		||||
#define INIT_DATA_D (unsigned long)0x10325476L
 | 
			
		||||
 | 
			
		||||
void MD5_Init(MD5_CTX *c)
 | 
			
		||||
int MD5_Init(MD5_CTX *c)
 | 
			
		||||
	{
 | 
			
		||||
	c->A=INIT_DATA_A;
 | 
			
		||||
	c->B=INIT_DATA_B;
 | 
			
		||||
@@ -79,6 +79,7 @@ void MD5_Init(MD5_CTX *c)
 | 
			
		||||
	c->Nl=0;
 | 
			
		||||
	c->Nh=0;
 | 
			
		||||
	c->num=0;
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
#ifndef md5_block_host_order
 | 
			
		||||
 
 | 
			
		||||
@@ -81,9 +81,9 @@ typedef struct mdc2_ctx_st
 | 
			
		||||
	} MDC2_CTX;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void MDC2_Init(MDC2_CTX *c);
 | 
			
		||||
void MDC2_Update(MDC2_CTX *c, const unsigned char *data, unsigned long len);
 | 
			
		||||
void MDC2_Final(unsigned char *md, MDC2_CTX *c);
 | 
			
		||||
int MDC2_Init(MDC2_CTX *c);
 | 
			
		||||
int MDC2_Update(MDC2_CTX *c, const unsigned char *data, unsigned long len);
 | 
			
		||||
int MDC2_Final(unsigned char *md, MDC2_CTX *c);
 | 
			
		||||
unsigned char *MDC2(const unsigned char *d, unsigned long n,
 | 
			
		||||
	unsigned char *md);
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -75,15 +75,16 @@
 | 
			
		||||
			*((c)++)=(unsigned char)(((l)>>24L)&0xff))
 | 
			
		||||
 | 
			
		||||
static void mdc2_body(MDC2_CTX *c, const unsigned char *in, unsigned int len);
 | 
			
		||||
void MDC2_Init(MDC2_CTX *c)
 | 
			
		||||
int MDC2_Init(MDC2_CTX *c)
 | 
			
		||||
	{
 | 
			
		||||
	c->num=0;
 | 
			
		||||
	c->pad_type=1;
 | 
			
		||||
	memset(&(c->h[0]),0x52,MDC2_BLOCK);
 | 
			
		||||
	memset(&(c->hh[0]),0x25,MDC2_BLOCK);
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
void MDC2_Update(MDC2_CTX *c, const unsigned char *in, unsigned long len)
 | 
			
		||||
int MDC2_Update(MDC2_CTX *c, const unsigned char *in, unsigned long len)
 | 
			
		||||
	{
 | 
			
		||||
	int i,j;
 | 
			
		||||
 | 
			
		||||
@@ -95,7 +96,7 @@ void MDC2_Update(MDC2_CTX *c, const unsigned char *in, unsigned long len)
 | 
			
		||||
			/* partial block */
 | 
			
		||||
			memcpy(&(c->data[i]),in,(int)len);
 | 
			
		||||
			c->num+=(int)len;
 | 
			
		||||
			return;
 | 
			
		||||
			return 1;
 | 
			
		||||
			}
 | 
			
		||||
		else
 | 
			
		||||
			{
 | 
			
		||||
@@ -116,6 +117,7 @@ void MDC2_Update(MDC2_CTX *c, const unsigned char *in, unsigned long len)
 | 
			
		||||
		memcpy(&(c->data[0]),&(in[i]),j);
 | 
			
		||||
		c->num=j;
 | 
			
		||||
		}
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
static void mdc2_body(MDC2_CTX *c, const unsigned char *in, unsigned int len)
 | 
			
		||||
@@ -156,7 +158,7 @@ static void mdc2_body(MDC2_CTX *c, const unsigned char *in, unsigned int len)
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
void MDC2_Final(unsigned char *md, MDC2_CTX *c)
 | 
			
		||||
int MDC2_Final(unsigned char *md, MDC2_CTX *c)
 | 
			
		||||
	{
 | 
			
		||||
	int i,j;
 | 
			
		||||
 | 
			
		||||
@@ -171,6 +173,7 @@ void MDC2_Final(unsigned char *md, MDC2_CTX *c)
 | 
			
		||||
		}
 | 
			
		||||
	memcpy(md,(char *)c->h,MDC2_BLOCK);
 | 
			
		||||
	memcpy(&(md[MDC2_BLOCK]),(char *)c->hh,MDC2_BLOCK);
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
#undef TEST
 | 
			
		||||
 
 | 
			
		||||
@@ -90,9 +90,9 @@ typedef struct RIPEMD160state_st
 | 
			
		||||
	int num;
 | 
			
		||||
	} RIPEMD160_CTX;
 | 
			
		||||
 | 
			
		||||
void RIPEMD160_Init(RIPEMD160_CTX *c);
 | 
			
		||||
void RIPEMD160_Update(RIPEMD160_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
void RIPEMD160_Final(unsigned char *md, RIPEMD160_CTX *c);
 | 
			
		||||
int RIPEMD160_Init(RIPEMD160_CTX *c);
 | 
			
		||||
int RIPEMD160_Update(RIPEMD160_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
int RIPEMD160_Final(unsigned char *md, RIPEMD160_CTX *c);
 | 
			
		||||
unsigned char *RIPEMD160(const unsigned char *d, unsigned long n,
 | 
			
		||||
	unsigned char *md);
 | 
			
		||||
void RIPEMD160_Transform(RIPEMD160_CTX *c, const unsigned char *b);
 | 
			
		||||
 
 | 
			
		||||
@@ -69,7 +69,7 @@ const char *RMD160_version="RIPE-MD160" OPENSSL_VERSION_PTEXT;
 | 
			
		||||
     void ripemd160_block(RIPEMD160_CTX *c, unsigned long *p,int num);
 | 
			
		||||
#  endif
 | 
			
		||||
 | 
			
		||||
void RIPEMD160_Init(RIPEMD160_CTX *c)
 | 
			
		||||
int RIPEMD160_Init(RIPEMD160_CTX *c)
 | 
			
		||||
	{
 | 
			
		||||
	c->A=RIPEMD160_A;
 | 
			
		||||
	c->B=RIPEMD160_B;
 | 
			
		||||
@@ -79,6 +79,7 @@ void RIPEMD160_Init(RIPEMD160_CTX *c)
 | 
			
		||||
	c->Nl=0;
 | 
			
		||||
	c->Nh=0;
 | 
			
		||||
	c->num=0;
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
#ifndef ripemd160_block_host_order
 | 
			
		||||
 
 | 
			
		||||
@@ -101,16 +101,16 @@ typedef struct SHAstate_st
 | 
			
		||||
	} SHA_CTX;
 | 
			
		||||
 | 
			
		||||
#ifndef OPENSSL_NO_SHA0
 | 
			
		||||
void SHA_Init(SHA_CTX *c);
 | 
			
		||||
void SHA_Update(SHA_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
void SHA_Final(unsigned char *md, SHA_CTX *c);
 | 
			
		||||
int SHA_Init(SHA_CTX *c);
 | 
			
		||||
int SHA_Update(SHA_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
int SHA_Final(unsigned char *md, SHA_CTX *c);
 | 
			
		||||
unsigned char *SHA(const unsigned char *d, unsigned long n,unsigned char *md);
 | 
			
		||||
void SHA_Transform(SHA_CTX *c, const unsigned char *data);
 | 
			
		||||
#endif
 | 
			
		||||
#ifndef OPENSSL_NO_SHA1
 | 
			
		||||
void SHA1_Init(SHA_CTX *c);
 | 
			
		||||
void SHA1_Update(SHA_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
void SHA1_Final(unsigned char *md, SHA_CTX *c);
 | 
			
		||||
int SHA1_Init(SHA_CTX *c);
 | 
			
		||||
int SHA1_Update(SHA_CTX *c, const void *data, unsigned long len);
 | 
			
		||||
int SHA1_Final(unsigned char *md, SHA_CTX *c);
 | 
			
		||||
unsigned char *SHA1(const unsigned char *d, unsigned long n,unsigned char *md);
 | 
			
		||||
void SHA1_Transform(SHA_CTX *c, const unsigned char *data);
 | 
			
		||||
#endif
 | 
			
		||||
 
 | 
			
		||||
@@ -138,7 +138,7 @@
 | 
			
		||||
#define INIT_DATA_h3 0x10325476UL
 | 
			
		||||
#define INIT_DATA_h4 0xc3d2e1f0UL
 | 
			
		||||
 | 
			
		||||
void HASH_INIT (SHA_CTX *c)
 | 
			
		||||
int HASH_INIT (SHA_CTX *c)
 | 
			
		||||
	{
 | 
			
		||||
	c->h0=INIT_DATA_h0;
 | 
			
		||||
	c->h1=INIT_DATA_h1;
 | 
			
		||||
@@ -148,6 +148,7 @@ void HASH_INIT (SHA_CTX *c)
 | 
			
		||||
	c->Nl=0;
 | 
			
		||||
	c->Nh=0;
 | 
			
		||||
	c->num=0;
 | 
			
		||||
	return 1;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
#define K_00_19	0x5a827999UL
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user