summaryrefslogtreecommitdiff
path: root/regress/misc
diff options
context:
space:
mode:
authorDamien Miller <djm@mindrot.org>2019-10-09 13:49:35 +1100
committerDamien Miller <djm@mindrot.org>2019-10-09 13:49:35 +1100
commit1ba130ac8fb2884307f658126f04578f8aef409e (patch)
treecc2fb5617da82942610d785629b4882263b8f65e /regress/misc
parentcdf1d0a9f5d18535e0a18ff34860e81a6d83aa5c (diff)
add a fuzzer for private key parsing
Diffstat (limited to 'regress/misc')
-rw-r--r--regress/misc/fuzz-harness/Makefile6
-rw-r--r--regress/misc/fuzz-harness/privkey_fuzz.cc21
2 files changed, 26 insertions, 1 deletions
diff --git a/regress/misc/fuzz-harness/Makefile b/regress/misc/fuzz-harness/Makefile
index 85179ac4e..e164e8869 100644
--- a/regress/misc/fuzz-harness/Makefile
+++ b/regress/misc/fuzz-harness/Makefile
@@ -7,7 +7,8 @@ CXXFLAGS=-O2 -g -Wall -Wextra -I ../../.. $(FUZZ_FLAGS)
7LDFLAGS=-L ../../.. -L ../../../openbsd-compat -g $(FUZZ_FLAGS) 7LDFLAGS=-L ../../.. -L ../../../openbsd-compat -g $(FUZZ_FLAGS)
8LIBS=-lssh -lopenbsd-compat -lcrypto $(FUZZ_LIBS) 8LIBS=-lssh -lopenbsd-compat -lcrypto $(FUZZ_LIBS)
9 9
10TARGETS=pubkey_fuzz sig_fuzz authopt_fuzz sshsig_fuzz sshsigopt_fuzz 10TARGETS=pubkey_fuzz sig_fuzz authopt_fuzz sshsig_fuzz \
11 sshsigopt_fuzz privkey_fuzz
11 12
12all: $(TARGETS) 13all: $(TARGETS)
13 14
@@ -29,5 +30,8 @@ sshsig_fuzz: sshsig_fuzz.o
29sshsigopt_fuzz: sshsigopt_fuzz.o 30sshsigopt_fuzz: sshsigopt_fuzz.o
30 $(CXX) -o $@ sshsigopt_fuzz.o ../../../sshsig.o $(LDFLAGS) $(LIBS) 31 $(CXX) -o $@ sshsigopt_fuzz.o ../../../sshsig.o $(LDFLAGS) $(LIBS)
31 32
33privkey_fuzz: privkey_fuzz.o
34 $(CXX) -o $@ privkey_fuzz.o $(LDFLAGS) $(LIBS)
35
32clean: 36clean:
33 -rm -f *.o $(TARGETS) 37 -rm -f *.o $(TARGETS)
diff --git a/regress/misc/fuzz-harness/privkey_fuzz.cc b/regress/misc/fuzz-harness/privkey_fuzz.cc
new file mode 100644
index 000000000..ff0b0f776
--- /dev/null
+++ b/regress/misc/fuzz-harness/privkey_fuzz.cc
@@ -0,0 +1,21 @@
1#include <stddef.h>
2#include <stdio.h>
3#include <stdint.h>
4
5extern "C" {
6
7#include "sshkey.h"
8#include "sshbuf.h"
9
10int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
11{
12 struct sshkey *k = NULL;
13 struct sshbuf *b = sshbuf_from(data, size);
14 int r = sshkey_private_deserialize(b, &k);
15 if (r == 0) sshkey_free(k);
16 sshbuf_free(b);
17 return 0;
18}
19
20} // extern
21