blob: 8b70c6d9877b511ca1e602aff22418f0d5d9503d [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.
70 // Includes REMB in following compound packets.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010071 void SetRemb(int64_t bitrate_bps, std::vector<uint32_t> ssrcs) override;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010072 // Stops sending REMB in following compound packets.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010073 void UnsetRemb() override;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010074
Danil Chapovalovd5cae4d2017-12-14 11:14:35 +010075 // TODO(bugs.webrtc.org/8239): Remove SendFeedbackPacket and SSRC functions
76 // and move generating of the TransportFeedback message inside
77 // RtcpTransceiverImpl when there is one RtcpTransceiver per rtp transport.
78
79 // Returns ssrc to put as sender ssrc into rtcp::TransportFeedback.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010080 uint32_t SSRC() const override;
81 bool SendFeedbackPacket(const rtcp::TransportFeedback& packet) override;
Sebastian Janssone1795f42019-07-24 11:38:03 +020082 bool SendNetworkStateEstimatePacket(
83 const rtcp::RemoteEstimate& packet) override;
Danil Chapovalovd5cae4d2017-12-14 11:14:35 +010084
Danil Chapovalov327c43c2017-11-27 17:23:04 +010085 // Reports missing packets, https://tools.ietf.org/html/rfc4585#section-6.2.1
86 void SendNack(uint32_t ssrc, std::vector<uint16_t> sequence_numbers);
87
88 // Requests new key frame.
Danil Chapovalov2ddf98d2017-11-22 14:00:41 +010089 // using PLI, https://tools.ietf.org/html/rfc4585#section-6.3.1.1
Danil Chapovalov8d19e032017-11-28 19:53:33 +010090 void SendPictureLossIndication(uint32_t ssrc);
Danil Chapovalov2ddf98d2017-11-22 14:00:41 +010091 // using FIR, https://tools.ietf.org/html/rfc5104#section-4.3.1.2
92 void SendFullIntraRequest(std::vector<uint32_t> ssrcs);
Danil Chapovalova7e418c2017-11-21 11:08:53 +010093
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010094 private:
95 rtc::TaskQueue* const task_queue_;
96 std::unique_ptr<RtcpTransceiverImpl> rtcp_transceiver_;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010097};
98
99} // namespace webrtc
100
101#endif // MODULES_RTP_RTCP_SOURCE_RTCP_TRANSCEIVER_H_