Actually input packets into the PacketBuffer.
Also prepared it for comming changes to RTPVideoHeader. Bug: none Change-Id: I60e57f779aee4ee98b6eec3d6631e43ac682c37f Reviewed-on: https://webrtc-review.googlesource.com/87825 Reviewed-by: Alex Loiko <aleloi@webrtc.org> Commit-Queue: Philip Eliasson <philipel@webrtc.org> Cr-Commit-Position: refs/heads/master@{#23911}
This commit is contained in:
@ -27,8 +27,26 @@ void FuzzOneInput(const uint8_t* data, size_t size) {
|
|||||||
video_coding::PacketBuffer::Create(&clock, 8, 1024, &callback));
|
video_coding::PacketBuffer::Create(&clock, 8, 1024, &callback));
|
||||||
test::FuzzDataHelper helper(rtc::ArrayView<const uint8_t>(data, size));
|
test::FuzzDataHelper helper(rtc::ArrayView<const uint8_t>(data, size));
|
||||||
|
|
||||||
while (helper.BytesLeft())
|
while (helper.BytesLeft()) {
|
||||||
|
// The RTPVideoHeader is a complex type, so overwriting it with random data
|
||||||
|
// will put it in an invalid state. Therefore we save/restore it.
|
||||||
|
uint8_t video_header_backup[sizeof(packet.video_header)];
|
||||||
|
memcpy(&video_header_backup, &packet.video_header,
|
||||||
|
sizeof(packet.video_header));
|
||||||
|
|
||||||
helper.CopyTo(&packet);
|
helper.CopyTo(&packet);
|
||||||
|
|
||||||
|
memcpy(&packet.video_header, &video_header_backup,
|
||||||
|
sizeof(packet.video_header));
|
||||||
|
|
||||||
|
// The packet buffer owns the payload of the packet.
|
||||||
|
uint8_t payload_size;
|
||||||
|
helper.CopyTo(&payload_size);
|
||||||
|
packet.sizeBytes = payload_size;
|
||||||
|
packet.dataPtr = new uint8_t[payload_size];
|
||||||
|
|
||||||
|
packet_buffer->InsertPacket(&packet);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace webrtc
|
} // namespace webrtc
|
||||||
|
Reference in New Issue
Block a user