Note that this needs to be done with a work directory that supports fuzzer builds, otherwise IWYU will bail out with complaints about find-bad-constructs and raw-ptr-plugin Some manual work was required to resolve the TaskQueueFactory which is forward-declared by environment which required a manual include of the header file. The DcSctp packet fuzzer was also updated use the disable_checksum_verification option which was moved to the DcSctpOptions struct. vp9_encoder_references_fuzzer was trying to include libvpx includes which had to be reverted. BUG=webrtc:42226242 Change-Id: I9fdcf979e73fdee77106c4583faff21ca7abf19f Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/375840 Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org> Reviewed-by: Danil Chapovalov <danilchap@webrtc.org> Commit-Queue: Philipp Hancke <phancke@meta.com> Cr-Commit-Position: refs/heads/main@{#43873}
32 lines
1.1 KiB
C++
32 lines
1.1 KiB
C++
/*
|
|
* Copyright (c) 2016 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 <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
#include <memory>
|
|
|
|
#include "api/array_view.h"
|
|
#include "api/transport/stun.h"
|
|
#include "rtc_base/byte_buffer.h"
|
|
|
|
namespace webrtc {
|
|
void FuzzOneInput(const uint8_t* data, size_t size) {
|
|
// Normally we'd check the integrity first, but those checks are
|
|
// fuzzed separately in stun_validator_fuzzer.cc. We still want to
|
|
// fuzz this target since the integrity checks could be forged by a
|
|
// malicious adversary who receives a call.
|
|
std::unique_ptr<cricket::IceMessage> stun_msg(new cricket::IceMessage());
|
|
rtc::ByteBufferReader buf(rtc::MakeArrayView(data, size));
|
|
stun_msg->Read(&buf);
|
|
stun_msg->ValidateMessageIntegrity("");
|
|
}
|
|
} // namespace webrtc
|