blob: 9f823cccf353c6137e1b735ab0326e38a7f91953 [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
14#include <memory>
15#include <string>
16#include <vector>
17
18#include "modules/rtp_rtcp/source/rtcp_transceiver_config.h"
19#include "modules/rtp_rtcp/source/rtcp_transceiver_impl.h"
20#include "rtc_base/constructormagic.h"
21#include "rtc_base/copyonwritebuffer.h"
22#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 Chapovalov792df6b2018-09-07 13:03:32 +020032 // Note that interfaces provided in constructor still might be used after the
33 // destructor. However they can only be used on the confic.task_queue.
34 // Use Stop function to get notified when they are no longer used or
35 // ensure those objects outlive the task queue.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010036 ~RtcpTransceiver() override;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010037
Danil Chapovalovf0076d32018-09-05 16:46:40 +020038 // Start asynchronious destruction of the RtcpTransceiver.
39 // It is safe to call destructor right after Stop exits.
40 // No other methods can be called.
Danil Chapovalov792df6b2018-09-07 13:03:32 +020041 // Note that interfaces provided in constructor or registered with AddObserver
42 // still might be used by the transceiver on the task queue
43 // until |on_destroyed| runs.
Danil Chapovalovf0076d32018-09-05 16:46:40 +020044 void Stop(std::unique_ptr<rtc::QueuedTask> on_destroyed);
45
Danil Chapovalova32d7102017-12-14 17:28:27 +010046 // Registers observer to be notified about incoming rtcp packets.
47 // Calls to observer will be done on the |config.task_queue|.
48 void AddMediaReceiverRtcpObserver(uint32_t remote_ssrc,
49 MediaReceiverRtcpObserver* observer);
50 // Deregisters the observer. Might return before observer is deregistered.
51 // Posts |on_removed| task when observer is deregistered.
52 void RemoveMediaReceiverRtcpObserver(
53 uint32_t remote_ssrc,
54 MediaReceiverRtcpObserver* observer,
55 std::unique_ptr<rtc::QueuedTask> on_removed);
56
Danil Chapovalove3927c52018-03-06 14:33:20 +010057 // Enables/disables sending rtcp packets eventually.
58 // Packets may be sent after the SetReadyToSend(false) returns, but no new
59 // packets will be scheduled.
60 void SetReadyToSend(bool ready);
61
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010062 // Handles incoming rtcp packets.
63 void ReceivePacket(rtc::CopyOnWriteBuffer packet);
64
65 // Sends RTCP packets starting with a sender or receiver report.
66 void SendCompoundPacket();
67
68 // (REMB) Receiver Estimated Max Bitrate.
69 // Includes REMB in following compound packets.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010070 void SetRemb(int64_t bitrate_bps, std::vector<uint32_t> ssrcs) override;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010071 // Stops sending REMB in following compound packets.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010072 void UnsetRemb() override;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010073
Danil Chapovalovd5cae4d2017-12-14 11:14:35 +010074 // TODO(bugs.webrtc.org/8239): Remove SendFeedbackPacket and SSRC functions
75 // and move generating of the TransportFeedback message inside
76 // RtcpTransceiverImpl when there is one RtcpTransceiver per rtp transport.
77
78 // Returns ssrc to put as sender ssrc into rtcp::TransportFeedback.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010079 uint32_t SSRC() const override;
80 bool SendFeedbackPacket(const rtcp::TransportFeedback& packet) override;
Danil Chapovalovd5cae4d2017-12-14 11:14:35 +010081
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
89 void SendFullIntraRequest(std::vector<uint32_t> ssrcs);
Danil Chapovalova7e418c2017-11-21 11:08:53 +010090
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010091 private:
92 rtc::TaskQueue* const task_queue_;
93 std::unique_ptr<RtcpTransceiverImpl> rtcp_transceiver_;
Danil Chapovalovc0fd5f92017-11-16 14:35:32 +010094
95 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(RtcpTransceiver);
96};
97
98} // namespace webrtc
99
100#endif // MODULES_RTP_RTCP_SOURCE_RTCP_TRANSCEIVER_H_