1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Add smemclrs of all hash states we destroy.

This commit is contained in:
Simon Tatham 2015-04-26 23:55:33 +01:00
parent 9d5a164021
commit 16c46ecdaf
4 changed files with 12 additions and 0 deletions

View File

@ -210,6 +210,7 @@ void MD5Simple(void const *p, unsigned len, unsigned char output[16])
MD5Init(&s);
MD5Update(&s, (unsigned char const *)p, len);
MD5Final(output, &s);
smemclr(&s, sizeof(s));
}
/* ----------------------------------------------------------------------
@ -227,6 +228,7 @@ void *hmacmd5_make_context(void)
void hmacmd5_free_context(void *handle)
{
smemclr(handle, 3*sizeof(struct MD5Context));
sfree(handle);
}

View File

@ -184,6 +184,7 @@ void SHA256_Simple(const void *p, int len, unsigned char *output) {
SHA256_Init(&s);
SHA256_Bytes(&s, p, len);
SHA256_Final(&s, output);
smemclr(&s, sizeof(s));
}
/*
@ -211,6 +212,7 @@ static void sha256_final(void *handle, unsigned char *output)
SHA256_State *s = handle;
SHA256_Final(s, output);
smemclr(s, sizeof(*s));
sfree(s);
}
@ -230,6 +232,7 @@ static void *sha256_make_context(void)
static void sha256_free_context(void *handle)
{
smemclr(handle, 3 * sizeof(SHA256_State));
sfree(handle);
}

View File

@ -306,6 +306,7 @@ void SHA512_Simple(const void *p, int len, unsigned char *output) {
SHA512_Init(&s);
SHA512_Bytes(&s, p, len);
SHA512_Final(&s, output);
smemclr(&s, sizeof(s));
}
void SHA384_Simple(const void *p, int len, unsigned char *output) {
@ -314,6 +315,7 @@ void SHA384_Simple(const void *p, int len, unsigned char *output) {
SHA384_Init(&s);
SHA512_Bytes(&s, p, len);
SHA384_Final(&s, output);
smemclr(&s, sizeof(s));
}
/*
@ -341,6 +343,7 @@ static void sha512_final(void *handle, unsigned char *output)
SHA512_State *s = handle;
SHA512_Final(s, output);
smemclr(s, sizeof(*s));
sfree(s);
}
@ -362,6 +365,7 @@ static void sha384_final(void *handle, unsigned char *output)
SHA512_State *s = handle;
SHA384_Final(s, output);
smemclr(s, sizeof(*s));
sfree(s);
}

View File

@ -214,6 +214,7 @@ void SHA_Simple(const void *p, int len, unsigned char *output)
SHA_Init(&s);
SHA_Bytes(&s, p, len);
SHA_Final(&s, output);
smemclr(&s, sizeof(s));
}
/*
@ -241,6 +242,7 @@ static void sha1_final(void *handle, unsigned char *output)
SHA_State *s = handle;
SHA_Final(s, output);
smemclr(s, sizeof(*s));
sfree(s);
}
@ -260,6 +262,7 @@ static void *sha1_make_context(void)
static void sha1_free_context(void *handle)
{
smemclr(handle, 3 * sizeof(SHA_State));
sfree(handle);
}