[openssl-commits] [openssl] master update

Kurt Roeckx kurt at openssl.org
Sat Jul 16 20:04:21 UTC 2016


The branch master has been updated
       via  e10aeee104383b711a6a58a13ed172fdb8642340 (commit)
       via  5e3553c2de9a365479324b8ba8b998f0cce3e527 (commit)
      from  85afea67f5e48dc4f02ac100454ec3caa41aa647 (commit)


- Log -----------------------------------------------------------------
commit e10aeee104383b711a6a58a13ed172fdb8642340
Author: Kurt Roeckx <kurt at roeckx.be>
Date:   Sat Jul 16 13:41:33 2016 +0200

    fuzzers: print and convert it back
    
    Reviewed-by: Rich Salz <rsalz at openssl.org>
    GH: #1323

commit 5e3553c2de9a365479324b8ba8b998f0cce3e527
Author: Kurt Roeckx <kurt at roeckx.be>
Date:   Sat Jul 16 16:56:54 2016 +0200

    Return error when trying to print invalid ASN1 integer
    
    Reviewed-by: Rich Salz <rsalz at openssl.org>
    GH: #1322

-----------------------------------------------------------------------

Summary of changes:
 crypto/asn1/tasn_prn.c |  2 ++
 fuzz/asn1.c            | 24 +++++++++++++++++++++++-
 fuzz/ct.c              | 12 +++++++++++-
 3 files changed, 36 insertions(+), 2 deletions(-)

diff --git a/crypto/asn1/tasn_prn.c b/crypto/asn1/tasn_prn.c
index 9f4c81e..930ef97 100644
--- a/crypto/asn1/tasn_prn.c
+++ b/crypto/asn1/tasn_prn.c
@@ -393,6 +393,8 @@ static int asn1_print_integer(BIO *out, ASN1_INTEGER *str)
     char *s;
     int ret = 1;
     s = i2s_ASN1_INTEGER(NULL, str);
+    if (s == NULL)
+        return 0;
     if (BIO_puts(out, s) <= 0)
         ret = 0;
     OPENSSL_free(s);
diff --git a/fuzz/asn1.c b/fuzz/asn1.c
index 5d871cd..4d5a726 100644
--- a/fuzz/asn1.c
+++ b/fuzz/asn1.c
@@ -69,11 +69,33 @@ int FuzzerInitialize(int *argc, char ***argv) {
 int FuzzerTestOneInput(const uint8_t *buf, size_t len) {
     int n;
 
+    ASN1_PCTX *pctx = ASN1_PCTX_new();
+
+    ASN1_PCTX_set_flags(pctx, ASN1_PCTX_FLAGS_SHOW_ABSENT |
+        ASN1_PCTX_FLAGS_SHOW_SEQUENCE | ASN1_PCTX_FLAGS_SHOW_SSOF |
+        ASN1_PCTX_FLAGS_SHOW_TYPE | ASN1_PCTX_FLAGS_SHOW_FIELD_STRUCT_NAME);
+    ASN1_PCTX_set_str_flags(pctx, ASN1_STRFLGS_UTF8_CONVERT |
+        ASN1_STRFLGS_SHOW_TYPE | ASN1_STRFLGS_DUMP_ALL);
+
     for (n = 0; item_type[n] != NULL; ++n) {
         const uint8_t *b = buf;
+        unsigned char *der = NULL;
         const ASN1_ITEM *i = ASN1_ITEM_ptr(item_type[n]);
         ASN1_VALUE *o = ASN1_item_d2i(NULL, &b, len, i);
-        ASN1_item_free(o, i);
+
+        if (o != NULL) {
+            BIO *bio = BIO_new(BIO_s_null());
+            ASN1_item_print(bio, o, 4, i, pctx);
+            BIO_free(bio);
+
+            ASN1_item_i2d(o, &der, i);
+            OPENSSL_free(der);
+
+            ASN1_item_free(o, i);
+        }
     }
+
+    ASN1_PCTX_free(pctx);
+
     return 0;
 }
diff --git a/fuzz/ct.c b/fuzz/ct.c
index 5dc47f1..0abcd8a 100644
--- a/fuzz/ct.c
+++ b/fuzz/ct.c
@@ -22,7 +22,17 @@ int FuzzerInitialize(int *argc, char ***argv) {
 
 int FuzzerTestOneInput(const uint8_t *buf, size_t len) {
     const uint8_t **pp = &buf;
+    unsigned char *der = NULL;
     STACK_OF(SCT) *scts = d2i_SCT_LIST(NULL, pp, len);
-    SCT_LIST_free(scts);
+    if (scts != NULL) {
+        BIO *bio = BIO_new(BIO_s_null());
+        SCT_LIST_print(scts, bio, 4, "\n", NULL);
+        BIO_free(bio);
+
+        i2d_SCT_LIST(scts, &der);
+        OPENSSL_free(der);
+
+        SCT_LIST_free(scts);
+    }
     return 0;
 }


More information about the openssl-commits mailing list