mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-12 21:30:45 +01:00

The feauture was added in https://webrtc-review.googlesource.com/c/src/+/291119 in order to ensure RTX packet is part of BWE even before the RTP stream is known. However, it cause an issue if media is signaled with an SSRC that has this RTX SSRC. Since BWE is now notified about received packets before demuxing to the correct receive stream, it is not necessary to demux RTX packets before the media SSRC is known. Note that WebRTC require at least one negotiated SSRC/MID before RTCP feedback can be sent. Ie, for BWE to work, at least one media SSRC must be known after this cl. It can either be unsignaled or signaled. BWE tested with BweRampupWithInitialProbeTest. Bug: webrtc:14795, webrtc:14817, b/320258158 Change-Id: Icf2c67bedc352720bf846b9ee38d509346af36f2 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/340141 Reviewed-by: Harald Alvestrand <hta@webrtc.org> Commit-Queue: Per Kjellander <perkj@webrtc.org> Cr-Commit-Position: refs/heads/main@{#41785}
45 lines
1.5 KiB
C++
45 lines
1.5 KiB
C++
/*
|
|
* Copyright (c) 2018 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 CALL_PACKET_RECEIVER_H_
|
|
#define CALL_PACKET_RECEIVER_H_
|
|
|
|
#include "absl/functional/any_invocable.h"
|
|
#include "api/media_types.h"
|
|
#include "modules/rtp_rtcp/source/rtp_packet_received.h"
|
|
#include "rtc_base/checks.h"
|
|
#include "rtc_base/copy_on_write_buffer.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class PacketReceiver {
|
|
public:
|
|
// Demux RTCP packets. Must be called on the worker thread.
|
|
virtual void DeliverRtcpPacket(rtc::CopyOnWriteBuffer packet) = 0;
|
|
|
|
// Invoked once when a packet is received that can not be demuxed.
|
|
// If the method returns true, a new attempt is made to demux the packet.
|
|
using OnUndemuxablePacketHandler =
|
|
absl::AnyInvocable<bool(const RtpPacketReceived& parsed_packet)>;
|
|
|
|
// Must be called on the worker thread.
|
|
// If `media_type` is not Audio or Video, packets may be used for BWE
|
|
// calculations but are not demuxed.
|
|
virtual void DeliverRtpPacket(
|
|
MediaType media_type,
|
|
RtpPacketReceived packet,
|
|
OnUndemuxablePacketHandler undemuxable_packet_handler) = 0;
|
|
|
|
protected:
|
|
virtual ~PacketReceiver() {}
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // CALL_PACKET_RECEIVER_H_
|