diff options
author | svoj@mysql.com/june.mysql.com <> | 2008-01-15 16:23:14 +0400 |
---|---|---|
committer | svoj@mysql.com/june.mysql.com <> | 2008-01-15 16:23:14 +0400 |
commit | f249ea7e4f538ae1d84c9105d58c6398eae9a619 (patch) | |
tree | d3fe4867a53f2592716b27097fbfa933359259b1 /mysys | |
parent | 6836db1cee363a47a0fd2423307e60fe7ecfedd4 (diff) | |
download | mariadb-git-f249ea7e4f538ae1d84c9105d58c6398eae9a619.tar.gz |
BUG#28884 - maybe a problem with malloc into base64.c
Fixed that return value of malloc was not checked.
Fixed wrong argument count (compilation failure) to base64_decode()
function.
Note:
- there is no test case for this fix as this code is never compiled
into mysql clients/server;
- as this code is used for internal testing purposes only, no changelog
entry needed.
Diffstat (limited to 'mysys')
-rw-r--r-- | mysys/base64.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/mysys/base64.c b/mysys/base64.c index dbe8927290d..6157dcaa5af 100644 --- a/mysys/base64.c +++ b/mysys/base64.c @@ -256,6 +256,7 @@ main(void) char * str; char * dst; + require(src); for (j= 0; j<src_len; j++) { char c= rand(); @@ -265,6 +266,7 @@ main(void) /* Encode */ needed_length= base64_needed_encoded_length(src_len); str= (char *) malloc(needed_length); + require(str); for (k= 0; k < needed_length; k++) str[k]= 0xff; /* Fill memory to check correct NUL termination */ require(base64_encode(src, src_len, str) == 0); @@ -272,7 +274,8 @@ main(void) /* Decode */ dst= (char *) malloc(base64_needed_decoded_length(strlen(str))); - dst_len= base64_decode(str, strlen(str), dst); + require(dst); + dst_len= base64_decode(str, strlen(str), dst, NULL); require(dst_len == src_len); if (memcmp(src, dst, src_len) != 0) |