blob: 3362298b205e95273b9b2311ba8ded27d8da806a [file] [log] [blame]
Stefan Holmere5904162015-03-26 11:11:06 +01001/*
2 * Copyright (c) 2015 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
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef MODULES_PACING_PACKET_ROUTER_H_
12#define MODULES_PACING_PACKET_ROUTER_H_
Stefan Holmere5904162015-03-26 11:11:06 +010013
Yves Gerey988cc082018-10-23 12:03:01 +020014#include <stddef.h>
15#include <stdint.h>
Stefan Holmere5904162015-03-26 11:11:06 +010016#include <list>
nissefdbfdc92017-03-31 05:44:52 -070017#include <vector>
Stefan Holmere5904162015-03-26 11:11:06 +010018
Yves Gerey988cc082018-10-23 12:03:01 +020019#include "api/transport/network_types.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020020#include "modules/pacing/paced_sender.h"
21#include "modules/remote_bitrate_estimator/include/remote_bitrate_estimator.h"
22#include "modules/rtp_rtcp/include/rtp_rtcp_defines.h"
Steve Anton10542f22019-01-11 09:11:00 -080023#include "rtc_base/constructor_magic.h"
24#include "rtc_base/critical_section.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020025#include "rtc_base/thread_annotations.h"
Stefan Holmere5904162015-03-26 11:11:06 +010026
27namespace webrtc {
28
Stefan Holmere5904162015-03-26 11:11:06 +010029class RtpRtcp;
sprangebbf8a82015-09-21 15:11:14 -070030namespace rtcp {
31class TransportFeedback;
32} // namespace rtcp
Stefan Holmere5904162015-03-26 11:11:06 +010033
nissefdbfdc92017-03-31 05:44:52 -070034// PacketRouter keeps track of rtp send modules to support the pacer.
35// In addition, it handles feedback messages, which are sent on a send
36// module if possible (sender report), otherwise on receive module
37// (receiver report). For the latter case, we also keep track of the
38// receive modules.
perkjec81bcd2016-05-11 06:01:13 -070039class PacketRouter : public PacedSender::PacketSender,
nisse05843312017-04-18 23:38:35 -070040 public TransportSequenceNumberAllocator,
Danil Chapovalov599df852017-09-25 15:19:35 +020041 public RemoteBitrateObserver,
42 public TransportFeedbackSenderInterface {
Stefan Holmere5904162015-03-26 11:11:06 +010043 public:
44 PacketRouter();
nisse76e62b02017-05-31 02:24:52 -070045 ~PacketRouter() override;
Stefan Holmere5904162015-03-26 11:11:06 +010046
eladalon822ff2b2017-08-01 06:30:28 -070047 void AddSendRtpModule(RtpRtcp* rtp_module, bool remb_candidate);
48 void RemoveSendRtpModule(RtpRtcp* rtp_module);
eladalon822ff2b2017-08-01 06:30:28 -070049
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010050 void AddReceiveRtpModule(RtcpFeedbackSenderInterface* rtcp_sender,
51 bool remb_candidate);
52 void RemoveReceiveRtpModule(RtcpFeedbackSenderInterface* rtcp_sender);
Stefan Holmere5904162015-03-26 11:11:06 +010053
54 // Implements PacedSender::Callback.
55 bool TimeToSendPacket(uint32_t ssrc,
56 uint16_t sequence_number,
57 int64_t capture_timestamp,
philipel29dca2c2016-05-13 11:13:05 +020058 bool retransmission,
philipelc7bf32a2017-02-17 03:59:43 -080059 const PacedPacketInfo& packet_info) override;
Stefan Holmere5904162015-03-26 11:11:06 +010060
philipelc7bf32a2017-02-17 03:59:43 -080061 size_t TimeToSendPadding(size_t bytes,
62 const PacedPacketInfo& packet_info) override;
Stefan Holmere5904162015-03-26 11:11:06 +010063
sprang867fb522015-08-03 04:38:41 -070064 void SetTransportWideSequenceNumber(uint16_t sequence_number);
sprangebbf8a82015-09-21 15:11:14 -070065 uint16_t AllocateSequenceNumber() override;
Stefan Holmere5904162015-03-26 11:11:06 +010066
nisse05843312017-04-18 23:38:35 -070067 // Called every time there is a new bitrate estimate for a receive channel
68 // group. This call will trigger a new RTCP REMB packet if the bitrate
69 // estimate has decreased or if no RTCP REMB packet has been sent for
70 // a certain time interval.
71 // Implements RtpReceiveBitrateUpdate.
72 void OnReceiveBitrateChanged(const std::vector<uint32_t>& ssrcs,
73 uint32_t bitrate_bps) override;
74
danilchap47085372017-08-10 06:03:57 -070075 // Ensures remote party notified of the receive bitrate limit no larger than
76 // |bitrate_bps|.
Danil Chapovalov1de4b622017-12-13 13:35:10 +010077 void SetMaxDesiredReceiveBitrate(int64_t bitrate_bps);
danilchap47085372017-08-10 06:03:57 -070078
nisse05843312017-04-18 23:38:35 -070079 // Send REMB feedback.
Danil Chapovalov1de4b622017-12-13 13:35:10 +010080 bool SendRemb(int64_t bitrate_bps, const std::vector<uint32_t>& ssrcs);
nisse05843312017-04-18 23:38:35 -070081
sprang233bd872015-09-08 13:25:16 -070082 // Send transport feedback packet to send-side.
Danil Chapovalov599df852017-09-25 15:19:35 +020083 bool SendTransportFeedback(rtcp::TransportFeedback* packet) override;
sprang233bd872015-09-08 13:25:16 -070084
sprang867fb522015-08-03 04:38:41 -070085 private:
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010086 void AddRembModuleCandidate(RtcpFeedbackSenderInterface* candidate_module,
87 bool media_sender)
danilchap56359be2017-09-07 07:53:45 -070088 RTC_EXCLUSIVE_LOCKS_REQUIRED(modules_crit_);
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010089 void MaybeRemoveRembModuleCandidate(
90 RtcpFeedbackSenderInterface* candidate_module,
91 bool media_sender) RTC_EXCLUSIVE_LOCKS_REQUIRED(modules_crit_);
danilchap56359be2017-09-07 07:53:45 -070092 void UnsetActiveRembModule() RTC_EXCLUSIVE_LOCKS_REQUIRED(modules_crit_);
93 void DetermineActiveRembModule() RTC_EXCLUSIVE_LOCKS_REQUIRED(modules_crit_);
eladalon822ff2b2017-08-01 06:30:28 -070094
stefanbba9dec2016-02-01 04:39:55 -080095 rtc::CriticalSection modules_crit_;
Danil Chapovaloveb0edd82017-12-14 16:02:31 +010096 // Rtp and Rtcp modules of the rtp senders.
danilchap56359be2017-09-07 07:53:45 -070097 std::list<RtpRtcp*> rtp_send_modules_ RTC_GUARDED_BY(modules_crit_);
Erik Språng8b7ca4a2018-05-17 13:43:35 +020098 // The last module used to send media.
99 RtpRtcp* last_send_module_ RTC_GUARDED_BY(modules_crit_);
Danil Chapovaloveb0edd82017-12-14 16:02:31 +0100100 // Rtcp modules of the rtp receivers.
101 std::vector<RtcpFeedbackSenderInterface*> rtcp_feedback_senders_
102 RTC_GUARDED_BY(modules_crit_);
sprang867fb522015-08-03 04:38:41 -0700103
eladalon822ff2b2017-08-01 06:30:28 -0700104 // TODO(eladalon): remb_crit_ only ever held from one function, and it's not
105 // clear if that function can actually be called from more than one thread.
nisse05843312017-04-18 23:38:35 -0700106 rtc::CriticalSection remb_crit_;
107 // The last time a REMB was sent.
danilchap56359be2017-09-07 07:53:45 -0700108 int64_t last_remb_time_ms_ RTC_GUARDED_BY(remb_crit_);
Danil Chapovalov1de4b622017-12-13 13:35:10 +0100109 int64_t last_send_bitrate_bps_ RTC_GUARDED_BY(remb_crit_);
nisse05843312017-04-18 23:38:35 -0700110 // The last bitrate update.
Danil Chapovalov1de4b622017-12-13 13:35:10 +0100111 int64_t bitrate_bps_ RTC_GUARDED_BY(remb_crit_);
112 int64_t max_bitrate_bps_ RTC_GUARDED_BY(remb_crit_);
nisse05843312017-04-18 23:38:35 -0700113
eladalon822ff2b2017-08-01 06:30:28 -0700114 // Candidates for the REMB module can be RTP sender/receiver modules, with
115 // the sender modules taking precedence.
Danil Chapovaloveb0edd82017-12-14 16:02:31 +0100116 std::vector<RtcpFeedbackSenderInterface*> sender_remb_candidates_
117 RTC_GUARDED_BY(modules_crit_);
118 std::vector<RtcpFeedbackSenderInterface*> receiver_remb_candidates_
119 RTC_GUARDED_BY(modules_crit_);
120 RtcpFeedbackSenderInterface* active_remb_module_
121 RTC_GUARDED_BY(modules_crit_);
eladalon822ff2b2017-08-01 06:30:28 -0700122
pbos46ad5422015-12-07 14:29:14 -0800123 volatile int transport_seq_;
Stefan Holmere5904162015-03-26 11:11:06 +0100124
henrikg3c089d72015-09-16 05:37:44 -0700125 RTC_DISALLOW_COPY_AND_ASSIGN(PacketRouter);
Stefan Holmere5904162015-03-26 11:11:06 +0100126};
127} // namespace webrtc
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200128#endif // MODULES_PACING_PACKET_ROUTER_H_