| * 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 "modules/audio_coding/codecs/g711/audio_decoder_pcm.h" |
| #include "test/fuzzers/audio_decoder_fuzzer.h" |
| void FuzzOneInput(const uint8_t* data, size_t size) { |
| if (size > 10000 || size < 2) { |
| const size_t num_channels = data[0] % 16 + 1; |
| std::unique_ptr<AudioDecoder> dec; |
| dec = std::make_unique<AudioDecoderPcmU>(num_channels); |
| dec = std::make_unique<AudioDecoderPcmA>(num_channels); |
| // Two first bytes of the data are used. Move forward. |
| // 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(), |
| allocated_ouput_size_samples * sizeof(int16_t), |