Reason for revert: Intend to fix perf failures and reland. Original issue's description: > Revert of Use RtxReceiveStream. (patchset #5 id:80001 of https://codereview.webrtc.org/3008773002/ ) > > Reason for revert: > A few perf tests broken, including > > RampUpTest.UpDownUpAbsSendTimeSimulcastRedRtx > RampUpTest.UpDownUpTransportSequenceNumberRtx > RampUpTest.UpDownUpTransportSequenceNumberPacketLoss > > > Original issue's description: > > Use RtxReceiveStream. > > > > This also has the beneficial side-effect that when a media stream > > which is protected by FlexFEC receives an RTX retransmission, the > > retransmitted media packet is passed into the FlexFEC machinery, > > which should improve its ability to recover packets via FEC. > > > > BUG=webrtc:7135 > > > > Review-Url: https://codereview.webrtc.org/3008773002 > > Cr-Commit-Position: refs/heads/master@{#19649} > > Committed:5c0f6c62ea> > TBR=brandtr@webrtc.org,danilchap@webrtc.org,stefan@webrtc.org,magjed@webrtc.org > # Skipping CQ checks because original CL landed less than 1 days ago. > NOPRESUBMIT=true > NOTREECHECKS=true > NOTRY=true > BUG=webrtc:7135 > > Review-Url: https://codereview.webrtc.org/3010983002 > Cr-Commit-Position: refs/heads/master@{#19653} > Committed:3c39c0137aTBR=brandtr@webrtc.org,danilchap@webrtc.org,stefan@webrtc.org,magjed@webrtc.org # Skipping CQ checks because original CL landed less than 1 days ago. NOPRESUBMIT=true NOTREECHECKS=true BUG=webrtc:7135 Review-Url: https://codereview.webrtc.org/3006063002 Cr-Commit-Position: refs/heads/master@{#19715}
51 lines
1.8 KiB
C++
51 lines
1.8 KiB
C++
/*
|
|
* Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#ifndef WEBRTC_CALL_RTX_RECEIVE_STREAM_H_
|
|
#define WEBRTC_CALL_RTX_RECEIVE_STREAM_H_
|
|
|
|
#include <map>
|
|
|
|
#include "webrtc/call/rtp_packet_sink_interface.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class ReceiveStatistics;
|
|
|
|
// This class is responsible for RTX decapsulation. The resulting media packets
|
|
// are passed on to a sink representing the associated media stream.
|
|
class RtxReceiveStream : public RtpPacketSinkInterface {
|
|
public:
|
|
RtxReceiveStream(RtpPacketSinkInterface* media_sink,
|
|
std::map<int, int> associated_payload_types,
|
|
uint32_t media_ssrc,
|
|
// TODO(nisse): Delete this argument, and
|
|
// corresponding member variable, by moving the
|
|
// responsibility for rtcp feedback to
|
|
// RtpStreamReceiverController.
|
|
ReceiveStatistics* rtp_receive_statistics = nullptr);
|
|
~RtxReceiveStream() override;
|
|
// RtpPacketSinkInterface.
|
|
void OnRtpPacket(const RtpPacketReceived& packet) override;
|
|
|
|
private:
|
|
RtpPacketSinkInterface* const media_sink_;
|
|
// Map from rtx payload type -> media payload type.
|
|
const std::map<int, int> associated_payload_types_;
|
|
// TODO(nisse): Ultimately, the media receive stream shouldn't care about the
|
|
// ssrc, and we should delete this.
|
|
const uint32_t media_ssrc_;
|
|
ReceiveStatistics* const rtp_receive_statistics_;
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // WEBRTC_CALL_RTX_RECEIVE_STREAM_H_
|