Fix segfault with empty fields as last in the config.
authorKurt Roeckx <kurt@roeckx.be>
Sat, 24 Jan 2015 13:46:50 +0000 (14:46 +0100)
committerKurt Roeckx <kurt@roeckx.be>
Sat, 24 Jan 2015 13:46:50 +0000 (14:46 +0100)
Reviewed-by: Tim Hudson <tjh@openssl.org>
crypto/asn1/asn1_gen.c
crypto/engine/eng_fat.c
ssl/ssl_conf.c
ssl/t1_lib.c

index 9ef89f6121f3c0f13deb860970b19b62927ed994..87066e83746a1e5eff2fcf29f72794ba3ef6ba7c 100644 (file)
@@ -279,6 +279,9 @@ static int asn1_cb(const char *elem, int len, void *bitstr)
 
     int tmp_tag, tmp_class;
 
+    if (elem == NULL)
+        return 0;
+
     for (i = 0, p = elem; i < len; p++, i++) {
         /* Look for the ':' in name value pairs */
         if (*p == ':') {
@@ -805,6 +808,8 @@ static int mask_cb(const char *elem, int len, void *arg)
 {
     unsigned long *pmask = arg, tmpmask;
     int tag;
+    if (elem == NULL)
+        return 0;
     if (len == 3 && !strncmp(elem, "DIR", 3)) {
         *pmask |= B_ASN1_DIRECTORYSTRING;
         return 1;
index bcb4c446b2a91f50402344e9049e694d28e5e42e..4279dd94b135b73f340abd5fce1ee1ece9b990f6 100644 (file)
@@ -103,6 +103,8 @@ int ENGINE_set_default(ENGINE *e, unsigned int flags)
 static int int_def_cb(const char *alg, int len, void *arg)
 {
     unsigned int *pflags = arg;
+    if (alg == NULL)
+        return 0;
     if (!strncmp(alg, "ALL", len))
         *pflags |= ENGINE_METHOD_ALL;
     else if (!strncmp(alg, "RSA", len))
index af88a475b8c2025d17bfa2f952015d23a2b9bec6..354f218cee9ee8d803e99a3880066c6eb70639aa 100644 (file)
@@ -167,6 +167,8 @@ static int ssl_set_option_list(const char *elem, int len, void *usr)
      * len == -1 indicates not being called in list context, just for single
      * command line switches, so don't allow +, -.
      */
+    if (elem == NULL)
+        return 0;
     if (len != -1) {
         if (*elem == '+') {
             elem++;
index 8fb26a4c8d2eac0326e14e61eb9a6b19034e37df..115aab5596246a818e37e6d673a471fcc65bb231 100644 (file)
@@ -596,6 +596,8 @@ static int nid_cb(const char *elem, int len, void *arg)
     size_t i;
     int nid;
     char etmp[20];
+    if (elem == NULL)
+        return 0;
     if (narg->nidcnt == MAX_CURVELIST)
         return 0;
     if (len > (int)(sizeof(etmp) - 1))
@@ -4001,6 +4003,8 @@ static int sig_cb(const char *elem, int len, void *arg)
     size_t i;
     char etmp[20], *p;
     int sig_alg, hash_alg;
+    if (elem == NULL)
+        return 0;
     if (sarg->sigalgcnt == MAX_SIGALGLEN)
         return 0;
     if (len > (int)(sizeof(etmp) - 1))