Revert "Refactor FEC code to use COW buffers"
This reverts commit 7325bc3917e6dd4c92e7a18fd879ba91f0b2851f. Reason for revert: FecTest.UlpfecTest is consistently failing. Original change's description: > Refactor FEC code to use COW buffers > > This refactoring helps to reduce unnecessary memcpy calls on the receive > side. > > This CL is the first stage of refactoring: it only replaces > |uint8 data[IP_PACKET_SIZE]| with |rtc::CopyOnWriteBuffer data| and does > necessary changes. > > A follow-up CL will remove length field of the Packet class. > > > Bug: webrtc:10750 > Change-Id: Ie233da83ff33f6370f511955e4c65d59522389a7 > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/144881 > Reviewed-by: Artem Titov <titovartem@webrtc.org> > Reviewed-by: Stefan Holmer <stefan@webrtc.org> > Reviewed-by: Rasmus Brandt <brandtr@webrtc.org> > Commit-Queue: Ilya Nikolaevskiy <ilnik@webrtc.org> > Cr-Commit-Position: refs/heads/master@{#28539} TBR=brandtr@webrtc.org,ilnik@webrtc.org,asapersson@webrtc.org,stefan@webrtc.org,titovartem@webrtc.org Change-Id: I07c34256a76174f09a0d27eacbae6488e66f4b43 No-Presubmit: true No-Tree-Checks: true No-Try: true Bug: webrtc:10750 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/145340 Reviewed-by: Qingsi Wang <qingsi@webrtc.org> Commit-Queue: Ilya Nikolaevskiy <ilnik@webrtc.org> Cr-Commit-Position: refs/heads/master@{#28545}
This commit is contained in:
@ -157,7 +157,10 @@ void RtpPacket::SetSsrc(uint32_t ssrc) {
|
||||
ByteWriter<uint32_t>::WriteBigEndian(WriteAt(8), ssrc);
|
||||
}
|
||||
|
||||
void RtpPacket::ZeroMutableExtensions() {
|
||||
void RtpPacket::CopyAndZeroMutableExtensions(
|
||||
rtc::ArrayView<uint8_t> buffer) const {
|
||||
RTC_CHECK_GE(buffer.size(), buffer_.size());
|
||||
memcpy(buffer.data(), buffer_.cdata(), buffer_.size());
|
||||
for (const ExtensionInfo& extension : extension_entries_) {
|
||||
switch (extensions_.GetType(extension.id)) {
|
||||
case RTPExtensionType::kRtpExtensionNone: {
|
||||
@ -167,9 +170,9 @@ void RtpPacket::ZeroMutableExtensions() {
|
||||
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);
|
||||
memset(buffer.data() + extension.offset +
|
||||
VideoSendTiming::kPacerExitDeltaOffset,
|
||||
0, 6);
|
||||
break;
|
||||
}
|
||||
case RTPExtensionType::kRtpExtensionTransportSequenceNumber:
|
||||
@ -177,7 +180,7 @@ void RtpPacket::ZeroMutableExtensions() {
|
||||
case RTPExtensionType::kRtpExtensionTransmissionTimeOffset:
|
||||
case RTPExtensionType::kRtpExtensionAbsoluteSendTime: {
|
||||
// Nullify whole extension, as it's filled in the pacer.
|
||||
memset(WriteAt(extension.offset), 0, extension.length);
|
||||
memset(buffer.data() + extension.offset, 0, extension.length);
|
||||
break;
|
||||
}
|
||||
case RTPExtensionType::kRtpExtensionAudioLevel:
|
||||
|
||||
Reference in New Issue
Block a user