summaryrefslogtreecommitdiffstats
path: root/crypto/params.c
diff options
context:
space:
mode:
authorPauli <paul.dale@oracle.com>2020-04-06 11:53:10 +1000
committerPauli <paul.dale@oracle.com>2020-04-08 09:14:17 +1000
commit86f32187c31fcff88253fcead04196563c04be09 (patch)
tree7e0606ceb494a23dbbef7729afc6cf3e9eed26f6 /crypto/params.c
parentc61ced5ec50fc68707c7cea79f7df1d170f03f13 (diff)
params: avoid a core dump with a null pointer and a get string call
Previous a get string (UTF8 or octet) params call would memcpy(2) from a NULL pointer if the OSSL_PARAM didn't have its data field set. This change makes the operation fail rather than core dump and it returns to param size (if set). Reviewed-by: Tomas Mraz <tmraz@fedoraproject.org> (Merged from https://github.com/openssl/openssl/pull/11474)
Diffstat (limited to 'crypto/params.c')
-rw-r--r--crypto/params.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/crypto/params.c b/crypto/params.c
index 5d1fc6a6f2..64d53c50e3 100644
--- a/crypto/params.c
+++ b/crypto/params.c
@@ -778,6 +778,8 @@ static int get_string_internal(const OSSL_PARAM *p, void **val, size_t max_len,
if (sz == 0)
return 1;
+ if (p->data == NULL)
+ return 0;
if (*val == NULL) {
char *const q = OPENSSL_malloc(sz);