Add ct fuzzer.
authorBen Laurie <ben@links.org>
Fri, 3 Jun 2016 10:07:42 +0000 (11:07 +0100)
committerBen Laurie <ben@links.org>
Fri, 3 Jun 2016 10:24:51 +0000 (11:24 +0100)
Reviewed-by: Rich Salz <rsalz@openssl.org>
.gitignore
fuzz/ct.c [new file with mode: 0644]

index 2f999520352765ae82c41649571753a48d2d7b2a..508fe0b30c3ba62f9ceff34b7b8ea29b77728fe3 100644 (file)
@@ -63,6 +63,7 @@ Makefile
 /fuzz/bndiv
 /fuzz/conf
 /fuzz/cms
+/fuzz/ct
 /fuzz/server
 /fuzz/x509
 /test/sha256t
@@ -85,6 +86,7 @@ Makefile
 *.dylib*
 *.dll*
 *.exe
+*.pyc
 # Exceptions
 !/test/bctest
 !/crypto/des/times/486-50.sol
diff --git a/fuzz/ct.c b/fuzz/ct.c
new file mode 100644 (file)
index 0000000..7050461
--- /dev/null
+++ b/fuzz/ct.c
@@ -0,0 +1,24 @@
+/*
+ * Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+ *
+ * Licensed under the OpenSSL licenses, (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * https://www.openssl.org/source/license.html
+ * or in the file LICENSE in the source distribution.
+ */
+
+/*
+ * Fuzz the SCT parser.
+ */
+
+#include <stdio.h>
+#include <openssl/ct.h>
+#include "fuzzer.h"
+
+int LLVMFuzzerTestOneInput(const uint8_t *buf, size_t len) {
+    const uint8_t **pp = &buf;
+    STACK_OF(SCT) *scts = d2i_SCT_LIST(NULL, pp, len);
+    SCT_LIST_free(scts);
+    return 0;
+}