*/
#include <stdio.h>
+#include <assert.h>
#include <openssl/md5.h>
#include <openssl/sha.h>
#include <openssl/evp.h>
{
MD5_CTX m5;
SHA_CTX s1;
- unsigned char buf[8],smd[SHA_DIGEST_LENGTH];
+ unsigned char buf[16],smd[SHA_DIGEST_LENGTH];
unsigned char c='A';
int i,j,k;
for (i=0; i<num; i+=MD5_DIGEST_LENGTH)
{
k++;
+ /* If this assert is triggered, it means buf needs to be
+ resized. This should never be triggered in a release. */
+ assert(k <= sizeof(buf));
for (j=0; j<k; j++)
buf[j]=c;
c++;
EVP_DigestFinal( &md_ctx,md,&md_size);
for (i=7; i>=0; i--)
- if (++seq[i]) break;
+ {
+ ++seq[i];
+ if (seq[i] != 0) break;
+ }
return(md_size);
}