提交 42748c08 编写于 作者: R Richard Levitte

Resize a local buffer to accomodate the size requirements of AES.

Protect against future mistakes with an assert().
上级 77dd9c18
...@@ -57,6 +57,7 @@ ...@@ -57,6 +57,7 @@
*/ */
#include <stdio.h> #include <stdio.h>
#include <assert.h>
#include <openssl/md5.h> #include <openssl/md5.h>
#include <openssl/sha.h> #include <openssl/sha.h>
#include <openssl/evp.h> #include <openssl/evp.h>
...@@ -85,7 +86,7 @@ static void ssl3_generate_key_block(SSL *s, unsigned char *km, int num) ...@@ -85,7 +86,7 @@ static void ssl3_generate_key_block(SSL *s, unsigned char *km, int num)
{ {
MD5_CTX m5; MD5_CTX m5;
SHA_CTX s1; SHA_CTX s1;
unsigned char buf[8],smd[SHA_DIGEST_LENGTH]; unsigned char buf[16],smd[SHA_DIGEST_LENGTH];
unsigned char c='A'; unsigned char c='A';
int i,j,k; int i,j,k;
...@@ -96,6 +97,9 @@ static void ssl3_generate_key_block(SSL *s, unsigned char *km, int num) ...@@ -96,6 +97,9 @@ static void ssl3_generate_key_block(SSL *s, unsigned char *km, int num)
for (i=0; i<num; i+=MD5_DIGEST_LENGTH) for (i=0; i<num; i+=MD5_DIGEST_LENGTH)
{ {
k++; 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++) for (j=0; j<k; j++)
buf[j]=c; buf[j]=c;
c++; c++;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册