blob: dbfcaf99766bc458769d8ca0bd44d9b898aaca1c [file] [log] [blame]
/*
* Copyright (c) 2022 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 <memory>
#include "modules/audio_coding/codecs/g711/audio_decoder_pcm.h"
#include "test/fuzzers/audio_decoder_fuzzer.h"
namespace webrtc {
void FuzzOneInput(const uint8_t* data, size_t size) {
if (size > 10000 || size < 2) {
return;
}
const size_t num_channels = data[0] % 16 + 1;
std::unique_ptr<AudioDecoder> dec;
if (data[1] % 2) {
dec = std::make_unique<AudioDecoderPcmU>(num_channels);
} else {
dec = std::make_unique<AudioDecoderPcmA>(num_channels);
}
// Two first bytes of the data are used. Move forward.
data += 2;
size -= 2;
// Allocate a maximum output size of 100 ms.
const size_t allocated_ouput_size_samples =
dec->SampleRateHz() * num_channels / 10;
std::unique_ptr<int16_t[]> output =
std::make_unique<int16_t[]>(allocated_ouput_size_samples);
FuzzAudioDecoder(DecoderFunctionType::kNormalDecode, data, size, dec.get(),
dec->SampleRateHz(),
allocated_ouput_size_samples * sizeof(int16_t),
output.get());
}
} // namespace webrtc