From 7f3687ce2661a9d869a2a4f7e60fcf1a46773d93 Mon Sep 17 00:00:00 2001 From: Benjamin Wright Date: Wed, 13 Mar 2019 10:59:12 -0700 Subject: [PATCH] Integrate parsing of SCTP messages into WebRTC Fuzzers. This change adds a basic fuzzer to exercise parsing of SCTP messages. Bug: webrtc:10395 Change-Id: I1fd7a8560add3463c1978ebcad30082ae31f2073 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/127042 Reviewed-by: Steve Anton Reviewed-by: Qingsi Wang Commit-Queue: Benjamin Wright Cr-Commit-Position: refs/heads/master@{#27113} --- test/fuzzers/BUILD.gn | 13 +++++++++++++ test/fuzzers/DEPS | 1 + test/fuzzers/sctp_utils_fuzzer.cc | 30 ++++++++++++++++++++++++++++++ 3 files changed, 44 insertions(+) create mode 100644 test/fuzzers/sctp_utils_fuzzer.cc diff --git a/test/fuzzers/BUILD.gn b/test/fuzzers/BUILD.gn index 797f270483..13a7a2017c 100644 --- a/test/fuzzers/BUILD.gn +++ b/test/fuzzers/BUILD.gn @@ -598,3 +598,16 @@ webrtc_fuzzer_test("rtp_rtcp_demuxer_helper_fuzzer") { ] seed_corpus = "corpora/rtcp-corpus" } + +webrtc_fuzzer_test("sctp_utils_fuzzer") { + sources = [ + "sctp_utils_fuzzer.cc", + ] + deps = [ + "../../api:libjingle_peerconnection_api", + "../../pc:libjingle_peerconnection", + "../../pc:peerconnection", + "../../rtc_base:rtc_base_approved", + ] +} + diff --git a/test/fuzzers/DEPS b/test/fuzzers/DEPS index 222cd0202e..82631c4a1b 100644 --- a/test/fuzzers/DEPS +++ b/test/fuzzers/DEPS @@ -1,3 +1,4 @@ include_rules = [ "+audio", + "+pc", ] diff --git a/test/fuzzers/sctp_utils_fuzzer.cc b/test/fuzzers/sctp_utils_fuzzer.cc new file mode 100644 index 0000000000..54bd40ace4 --- /dev/null +++ b/test/fuzzers/sctp_utils_fuzzer.cc @@ -0,0 +1,30 @@ +/* + * Copyright (c) 2019 The WebRTC project authors. All Rights Reserved. + * + * Use of this source code is governed by a BSD-style license + * that can be found in the LICENSE file in the root of the source + * tree. An additional intellectual property rights grant can be found + * in the file PATENTS. All contributing project authors may + * be found in the AUTHORS file in the root of the source tree. + */ + +#include +#include +#include + +#include "api/data_channel_interface.h" +#include "pc/sctp_utils.h" +#include "rtc_base/copy_on_write_buffer.h" + +namespace webrtc { + +void FuzzOneInput(const uint8_t* data, size_t size) { + rtc::CopyOnWriteBuffer payload(data, size); + std::string label; + DataChannelInit config; + IsOpenMessage(payload); + ParseDataChannelOpenMessage(payload, &label, &config); + ParseDataChannelOpenAckMessage(payload); +} + +} // namespace webrtc