blob: fe5c9695c368cf2f304044db17c31f8d5b88bd65 [file] [log] [blame]
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +01001/*
2 * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#ifndef MODULES_RTP_RTCP_SOURCE_RTCP_TRANSCEIVER_H_
12#define MODULES_RTP_RTCP_SOURCE_RTCP_TRANSCEIVER_H_
13
Danil Chapovalov98f5f6c2018-10-22 14:22:31 +020014#include <functional>
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010015#include <memory>
16#include <string>
17#include <vector>
18
19#include "modules/rtp_rtcp/source/rtcp_transceiver_config.h"
20#include "modules/rtp_rtcp/source/rtcp_transceiver_impl.h"
Steve Anton10542f22019-01-11 09:11:00 -080021#include "rtc_base/copy_on_write_buffer.h"
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010022#include "rtc_base/task_queue.h"
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010023
24namespace webrtc {
25//
26// Manage incoming and outgoing rtcp messages for multiple BUNDLED streams.
27//
28// This class is thread-safe wrapper of RtcpTransceiverImpl
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010029class RtcpTransceiver : public RtcpFeedbackSenderInterface {
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010030 public:
31 explicit RtcpTransceiver(const RtcpTransceiverConfig& config);
Danil Chapovalov067818f2018-09-10 09:59:51 +020032 RtcpTransceiver(const RtcpTransceiver&) = delete;
33 RtcpTransceiver& operator=(const RtcpTransceiver&) = delete;
Danil Chapovalov792df6b2018-09-07 13:03:32 +020034 // Note that interfaces provided in constructor still might be used after the
35 // destructor. However they can only be used on the confic.task_queue.
36 // Use Stop function to get notified when they are no longer used or
37 // ensure those objects outlive the task queue.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010038 ~RtcpTransceiver() override;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010039
Danil Chapovalovf0076d32018-09-05 16:46:40 +020040 // Start asynchronious destruction of the RtcpTransceiver.
41 // It is safe to call destructor right after Stop exits.
42 // No other methods can be called.
Danil Chapovalov792df6b2018-09-07 13:03:32 +020043 // Note that interfaces provided in constructor or registered with AddObserver
44 // still might be used by the transceiver on the task queue
45 // until |on_destroyed| runs.
Danil Chapovalov98f5f6c2018-10-22 14:22:31 +020046 void Stop(std::function<void()> on_destroyed);
Danil Chapovalovf0076d32018-09-05 16:46:40 +020047
Danil Chapovalova32d7102017-12-14 17:28:27 +010048 // Registers observer to be notified about incoming rtcp packets.
49 // Calls to observer will be done on the |config.task_queue|.
50 void AddMediaReceiverRtcpObserver(uint32_t remote_ssrc,
51 MediaReceiverRtcpObserver* observer);
52 // Deregisters the observer. Might return before observer is deregistered.
Danil Chapovalov98f5f6c2018-10-22 14:22:31 +020053 // Runs |on_removed| when observer is deregistered.
Danil Chapovalov98f5f6c2018-10-22 14:22:31 +020054 void RemoveMediaReceiverRtcpObserver(uint32_t remote_ssrc,
55 MediaReceiverRtcpObserver* observer,
56 std::function<void()> on_removed);
Danil Chapovalova32d7102017-12-14 17:28:27 +010057
Danil Chapovalove3927c52018-03-06 14:33:20 +010058 // Enables/disables sending rtcp packets eventually.
59 // Packets may be sent after the SetReadyToSend(false) returns, but no new
60 // packets will be scheduled.
61 void SetReadyToSend(bool ready);
62
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010063 // Handles incoming rtcp packets.
64 void ReceivePacket(rtc::CopyOnWriteBuffer packet);
65
66 // Sends RTCP packets starting with a sender or receiver report.
67 void SendCompoundPacket();
68
69 // (REMB) Receiver Estimated Max Bitrate.
Per Kjellanderc93595b2020-02-27 13:20:55 +010070 // Includes REMB in following compound packets and sends a REMB message
71 // immediately if 'RtcpTransceiverConfig::send_remb_on_change' is set.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010072 void SetRemb(int64_t bitrate_bps, std::vector<uint32_t> ssrcs) override;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010073 // Stops sending REMB in following compound packets.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010074 void UnsetRemb() override;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010075
Per Kjellander16999812019-10-10 12:57:28 +020076 // TODO(bugs.webrtc.org/8239): Remove SendCombinedRtcpPacket
77 // and move generating of the TransportFeedback message inside
78 // RtcpTransceiverImpl when there is one RtcpTransceiver per rtp transport.
79 void SendCombinedRtcpPacket(
80 std::vector<std::unique_ptr<rtcp::RtcpPacket>> rtcp_packets) override;
81
Danil Chapovalov327c43c2017-11-27 17:23:04 +010082 // Reports missing packets, https://tools.ietf.org/html/rfc4585#section-6.2.1
83 void SendNack(uint32_t ssrc, std::vector<uint16_t> sequence_numbers);
84
85 // Requests new key frame.
Danil Chapovalov2ddf98d2017-11-22 14:00:41 +010086 // using PLI, https://tools.ietf.org/html/rfc4585#section-6.3.1.1
Danil Chapovalov8d19e032017-11-28 19:53:33 +010087 void SendPictureLossIndication(uint32_t ssrc);
Danil Chapovalov2ddf98d2017-11-22 14:00:41 +010088 // using FIR, https://tools.ietf.org/html/rfc5104#section-4.3.1.2
Evan Shrubsole577b88d2019-12-04 13:50:28 +010089 // Use the SendFullIntraRequest(ssrcs, true) instead.
Danil Chapovalov2ddf98d2017-11-22 14:00:41 +010090 void SendFullIntraRequest(std::vector<uint32_t> ssrcs);
Evan Shrubsole577b88d2019-12-04 13:50:28 +010091 // If new_request is true then requested sequence no. will increase for each
92 // requested ssrc.
93 void SendFullIntraRequest(std::vector<uint32_t> ssrcs, bool new_request);
Danil Chapovalova7e418c2017-11-21 11:08:53 +010094
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010095 private:
96 rtc::TaskQueue* const task_queue_;
97 std::unique_ptr<RtcpTransceiverImpl> rtcp_transceiver_;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010098};
99
100} // namespace webrtc
101
102#endif // MODULES_RTP_RTCP_SOURCE_RTCP_TRANSCEIVER_H_