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:
@ -90,9 +90,8 @@ TEST_F(UlpfecGeneratorTest, NoEmptyFecWithSeqNumGaps) {
|
||||
packet[1] &= ~0x80;
|
||||
}
|
||||
ByteWriter<uint16_t>::WriteBigEndian(&packet[2], p.seq_num);
|
||||
ulpfec_generator_.AddRtpPacketAndGenerateFec(
|
||||
rtc::CopyOnWriteBuffer(packet, p.payload_size + p.header_size),
|
||||
p.header_size);
|
||||
ulpfec_generator_.AddRtpPacketAndGenerateFec(packet, p.payload_size,
|
||||
p.header_size);
|
||||
size_t num_fec_packets = ulpfec_generator_.NumAvailableFecPackets();
|
||||
if (num_fec_packets > 0) {
|
||||
std::vector<std::unique_ptr<RedPacket>> fec_packets =
|
||||
@ -118,8 +117,8 @@ TEST_F(UlpfecGeneratorTest, OneFrameFec) {
|
||||
for (size_t i = 0; i < kNumPackets; ++i) {
|
||||
std::unique_ptr<AugmentedPacket> packet =
|
||||
packet_generator_.NextPacket(i, 10);
|
||||
EXPECT_EQ(0, ulpfec_generator_.AddRtpPacketAndGenerateFec(packet->data,
|
||||
kRtpHeaderSize));
|
||||
EXPECT_EQ(0, ulpfec_generator_.AddRtpPacketAndGenerateFec(
|
||||
packet->data, packet->length, kRtpHeaderSize));
|
||||
last_timestamp = packet->header.timestamp;
|
||||
}
|
||||
EXPECT_TRUE(ulpfec_generator_.FecAvailable());
|
||||
@ -153,7 +152,7 @@ TEST_F(UlpfecGeneratorTest, TwoFrameFec) {
|
||||
std::unique_ptr<AugmentedPacket> packet =
|
||||
packet_generator_.NextPacket(i * kNumPackets + j, 10);
|
||||
EXPECT_EQ(0, ulpfec_generator_.AddRtpPacketAndGenerateFec(
|
||||
packet->data, kRtpHeaderSize));
|
||||
packet->data, packet->length, kRtpHeaderSize));
|
||||
last_timestamp = packet->header.timestamp;
|
||||
}
|
||||
}
|
||||
@ -182,7 +181,7 @@ TEST_F(UlpfecGeneratorTest, MixedMediaRtpHeaderLengths) {
|
||||
std::unique_ptr<AugmentedPacket> packet =
|
||||
packet_generator_.NextPacket(i, 10);
|
||||
EXPECT_EQ(0, ulpfec_generator_.AddRtpPacketAndGenerateFec(
|
||||
packet->data, kShortRtpHeaderLength));
|
||||
packet->data, packet->length, kShortRtpHeaderLength));
|
||||
EXPECT_FALSE(ulpfec_generator_.FecAvailable());
|
||||
}
|
||||
|
||||
@ -191,7 +190,7 @@ TEST_F(UlpfecGeneratorTest, MixedMediaRtpHeaderLengths) {
|
||||
std::unique_ptr<AugmentedPacket> packet =
|
||||
packet_generator_.NextPacket(kUlpfecMaxMediaPackets, 10);
|
||||
EXPECT_EQ(0, ulpfec_generator_.AddRtpPacketAndGenerateFec(
|
||||
packet->data, kLongRtpHeaderLength));
|
||||
packet->data, packet->length, kLongRtpHeaderLength));
|
||||
EXPECT_TRUE(ulpfec_generator_.FecAvailable());
|
||||
|
||||
// Ensure that the RED header is placed correctly, i.e. the correct
|
||||
|
||||
Reference in New Issue
Block a user