Add NULL checks from master

The big "don't check for NULL" cleanup requires backporting some
of the lowest-level functions to actually do nothing if NULL is
given.  This will make it easier to backport fixes to release
branches, where master assumes those lower-level functions are "safe"

This commit addresses those tickets: 3798 3799 3801.

Reviewed-by: Matt Caswell <matt@openssl.org>
(cherry picked from commit f34b095fab1569d093b639bfcc9a77d6020148ff)
This commit is contained in:
Rich Salz 2015-05-12 11:49:32 -04:00 committed by Rich Salz
parent 5e0ec9012b
commit 76b49a8ad7
3 changed files with 6 additions and 0 deletions

View File

@ -126,6 +126,8 @@ EVP_CIPHER_CTX *CMAC_CTX_get0_cipher_ctx(CMAC_CTX *ctx)
void CMAC_CTX_free(CMAC_CTX *ctx) void CMAC_CTX_free(CMAC_CTX *ctx)
{ {
if (!ctx)
return;
CMAC_CTX_cleanup(ctx); CMAC_CTX_cleanup(ctx);
OPENSSL_free(ctx); OPENSSL_free(ctx);
} }

View File

@ -216,6 +216,8 @@ X509_STORE *X509_STORE_new(void)
static void cleanup(X509_OBJECT *a) static void cleanup(X509_OBJECT *a)
{ {
if (!a)
return;
if (a->type == X509_LU_X509) { if (a->type == X509_LU_X509) {
X509_free(a->data.x509); X509_free(a->data.x509);
} else if (a->type == X509_LU_CRL) { } else if (a->type == X509_LU_CRL) {

View File

@ -1921,6 +1921,8 @@ X509_STORE_CTX *X509_STORE_CTX_new(void)
void X509_STORE_CTX_free(X509_STORE_CTX *ctx) void X509_STORE_CTX_free(X509_STORE_CTX *ctx)
{ {
if (!ctx)
return;
X509_STORE_CTX_cleanup(ctx); X509_STORE_CTX_cleanup(ctx);
OPENSSL_free(ctx); OPENSSL_free(ctx);
} }