OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
(...skipping 14 matching lines...) Expand all Loading... |
25 void OnReceiveBitrateChanged(const std::vector<uint32_t>& ssrcs, | 25 void OnReceiveBitrateChanged(const std::vector<uint32_t>& ssrcs, |
26 uint32_t bitrate) override {} | 26 uint32_t bitrate) override {} |
27 }; | 27 }; |
28 | 28 |
29 void FuzzOneInput(const uint8_t* data, size_t size) { | 29 void FuzzOneInput(const uint8_t* data, size_t size) { |
30 size_t i = 0; | 30 size_t i = 0; |
31 if (size < sizeof(int64_t) + sizeof(uint8_t) + sizeof(uint32_t)) | 31 if (size < sizeof(int64_t) + sizeof(uint8_t) + sizeof(uint32_t)) |
32 return; | 32 return; |
33 SimulatedClock clock(data[i++]); | 33 SimulatedClock clock(data[i++]); |
34 NullBitrateObserver observer; | 34 NullBitrateObserver observer; |
35 RtcEventLogNullImpl event_log; | 35 CongestionController cc(&clock, &observer, &observer, nullptr); |
36 CongestionController cc(&clock, &observer, &observer, &event_log); | |
37 RemoteBitrateEstimator* rbe = cc.GetRemoteBitrateEstimator(true); | 36 RemoteBitrateEstimator* rbe = cc.GetRemoteBitrateEstimator(true); |
38 RTPHeader header; | 37 RTPHeader header; |
39 header.ssrc = ByteReader<uint32_t>::ReadBigEndian(&data[i]); | 38 header.ssrc = ByteReader<uint32_t>::ReadBigEndian(&data[i]); |
40 i += sizeof(uint32_t); | 39 i += sizeof(uint32_t); |
41 header.extension.hasTransportSequenceNumber = true; | 40 header.extension.hasTransportSequenceNumber = true; |
42 int64_t arrival_time_ms = | 41 int64_t arrival_time_ms = |
43 std::max<int64_t>(ByteReader<int64_t>::ReadBigEndian(&data[i]), 0); | 42 std::max<int64_t>(ByteReader<int64_t>::ReadBigEndian(&data[i]), 0); |
44 i += sizeof(int64_t); | 43 i += sizeof(int64_t); |
45 const size_t kMinPacketSize = | 44 const size_t kMinPacketSize = |
46 sizeof(size_t) + sizeof(uint16_t) + sizeof(uint8_t); | 45 sizeof(size_t) + sizeof(uint16_t) + sizeof(uint8_t); |
47 while (i + kMinPacketSize < size) { | 46 while (i + kMinPacketSize < size) { |
48 size_t payload_size = ByteReader<size_t>::ReadBigEndian(&data[i]) % 1500; | 47 size_t payload_size = ByteReader<size_t>::ReadBigEndian(&data[i]) % 1500; |
49 i += sizeof(size_t); | 48 i += sizeof(size_t); |
50 header.extension.transportSequenceNumber = | 49 header.extension.transportSequenceNumber = |
51 ByteReader<uint16_t>::ReadBigEndian(&data[i]); | 50 ByteReader<uint16_t>::ReadBigEndian(&data[i]); |
52 i += sizeof(uint16_t); | 51 i += sizeof(uint16_t); |
53 rbe->IncomingPacket(arrival_time_ms, payload_size, header); | 52 rbe->IncomingPacket(arrival_time_ms, payload_size, header); |
54 clock.AdvanceTimeMilliseconds(5); | 53 clock.AdvanceTimeMilliseconds(5); |
55 arrival_time_ms += ByteReader<uint8_t>::ReadBigEndian(&data[i]); | 54 arrival_time_ms += ByteReader<uint8_t>::ReadBigEndian(&data[i]); |
56 arrival_time_ms += sizeof(uint8_t); | 55 arrival_time_ms += sizeof(uint8_t); |
57 } | 56 } |
58 rbe->Process(); | 57 rbe->Process(); |
59 } | 58 } |
60 } // namespace webrtc | 59 } // namespace webrtc |
OLD | NEW |