Skip to content

Commit

Permalink
Add safety checks in RtpPacket::ZeroMutableExtensions and fuzz it
Browse files Browse the repository at this point in the history
Bug: chromium:1042535
Change-Id: I0f7ef1086631b5beb2e0c89d57534d2551289117
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/166441
Reviewed-by: Niels Moller <nisse@webrtc.org>
Reviewed-by: Danil Chapovalov <danilchap@webrtc.org>
Commit-Queue: Ilya Nikolaevskiy <ilnik@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#30303}
  • Loading branch information
Ilya Nikolaevskiy authored and Commit Bot committed Jan 17, 2020
1 parent 5d9b964 commit db6ca7f
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 5 deletions.
12 changes: 7 additions & 5 deletions modules/rtp_rtcp/source/rtp_packet.cc
Original file line number Diff line number Diff line change
Expand Up @@ -165,11 +165,13 @@ void RtpPacket::ZeroMutableExtensions() {
break;
}
case RTPExtensionType::kRtpExtensionVideoTiming: {
// Nullify 3 last entries: packetization delay and 2 network timestamps.
// Each of them is 2 bytes.
memset(
WriteAt(extension.offset + VideoSendTiming::kPacerExitDeltaOffset),
0, 6);
// Nullify last entries, starting at pacer delay.
// These are set by pacer and SFUs
if (VideoSendTiming::kPacerExitDeltaOffset < extension.length) {
memset(WriteAt(extension.offset +
VideoSendTiming::kPacerExitDeltaOffset),
0, extension.length - VideoSendTiming::kPacerExitDeltaOffset);
}
break;
}
case RTPExtensionType::kRtpExtensionTransportSequenceNumber:
Expand Down
3 changes: 3 additions & 0 deletions test/fuzzers/rtp_packet_fuzzer.cc
Original file line number Diff line number Diff line change
Expand Up @@ -156,5 +156,8 @@ void FuzzOneInput(const uint8_t* data, size_t size) {
break;
}
}

// Check that zero-ing mutable extensions wouldn't cause any problems.
packet.ZeroMutableExtensions();
}
} // namespace webrtc

0 comments on commit db6ca7f

Please sign in to comment.