blob: d811e87719778571ca65cb04e6736598e15ec8b4 [file] [log] [blame]
Niels Möller530ead42018-10-04 14:28:39 +02001/*
2 * Copyright (c) 2012 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 AUDIO_CHANNEL_RECEIVE_H_
12#define AUDIO_CHANNEL_RECEIVE_H_
13
14#include <map>
15#include <memory>
Fredrik Solenbergf693bfa2018-12-11 12:22:10 +010016#include <utility>
Niels Möller530ead42018-10-04 14:28:39 +020017#include <vector>
18
19#include "absl/types/optional.h"
20#include "api/audio/audio_mixer.h"
Niels Möller349ade32018-11-16 09:50:42 +010021#include "api/audio_codecs/audio_decoder_factory.h"
Niels Möller530ead42018-10-04 14:28:39 +020022#include "api/call/audio_sink.h"
23#include "api/call/transport.h"
Steve Anton10542f22019-01-11 09:11:00 -080024#include "api/crypto/crypto_options.h"
Marina Ciocea3e9af7f2020-04-01 07:46:16 +020025#include "api/frame_transformer_interface.h"
Ivo Creusenc3d1f9b2019-11-01 11:47:51 +010026#include "api/neteq/neteq_factory.h"
Niels Möllera8370302019-09-02 15:16:49 +020027#include "api/transport/rtp/rtp_source.h"
Niels Möller349ade32018-11-16 09:50:42 +010028#include "call/rtp_packet_sink_interface.h"
Niels Möller530ead42018-10-04 14:28:39 +020029#include "call/syncable.h"
Niels Möllered44f542019-07-30 15:15:59 +020030#include "modules/audio_coding/include/audio_coding_module_typedefs.h"
Ranveer Aggarwaldea374a2021-01-23 12:27:19 +053031#include "modules/rtp_rtcp/source/source_tracker.h"
Niels Möllered44f542019-07-30 15:15:59 +020032#include "system_wrappers/include/clock.h"
Niels Möller530ead42018-10-04 14:28:39 +020033
34// TODO(solenberg, nisse): This file contains a few NOLINT marks, to silence
Niels Möller349ade32018-11-16 09:50:42 +010035// warnings about use of unsigned short.
Niels Möller530ead42018-10-04 14:28:39 +020036// These need cleanup, in a separate cl.
37
38namespace rtc {
39class TimestampWrapAroundHandler;
40}
41
42namespace webrtc {
43
44class AudioDeviceModule;
Benjamin Wright84583f62018-10-04 14:22:34 -070045class FrameDecryptorInterface;
Niels Möller530ead42018-10-04 14:28:39 +020046class PacketRouter;
Niels Möller530ead42018-10-04 14:28:39 +020047class RateLimiter;
48class ReceiveStatistics;
49class RtcEventLog;
50class RtpPacketReceived;
51class RtpRtcp;
52
53struct CallReceiveStatistics {
Niels Möller530ead42018-10-04 14:28:39 +020054 unsigned int cumulativeLost;
Niels Möller530ead42018-10-04 14:28:39 +020055 unsigned int jitterSamples;
56 int64_t rttMs;
Niels Möllerac0a4cb2019-10-09 15:01:33 +020057 int64_t payload_bytes_rcvd = 0;
58 int64_t header_and_padding_bytes_rcvd = 0;
Niels Möller530ead42018-10-04 14:28:39 +020059 int packetsReceived;
Jakob Ivarssone54914a2021-07-01 11:16:05 +020060 uint32_t nacks_sent = 0;
Alessio Bazzicaf0adf382021-03-23 09:36:51 +010061 // The capture NTP time (in local timebase) of the first played out audio
Niels Möller530ead42018-10-04 14:28:39 +020062 // frame.
63 int64_t capture_start_ntp_time_ms_;
Henrik Boström01738c62019-04-15 17:32:00 +020064 // The timestamp at which the last packet was received, i.e. the time of the
65 // local clock when it was received - not the RTP timestamp of that packet.
66 // https://w3c.github.io/webrtc-stats/#dom-rtcinboundrtpstreamstats-lastpacketreceivedtimestamp
67 absl::optional<int64_t> last_packet_received_timestamp_ms;
Alessio Bazzicabc1c93d2021-03-12 17:45:26 +010068 // Remote outbound stats derived by the received RTCP sender reports.
Alessio Bazzicaf0adf382021-03-23 09:36:51 +010069 // Note that the timestamps below correspond to the time elapsed since the
70 // Unix epoch.
Alessio Bazzicabc1c93d2021-03-12 17:45:26 +010071 // https://w3c.github.io/webrtc-stats/#remoteoutboundrtpstats-dict*
72 absl::optional<int64_t> last_sender_report_timestamp_ms;
73 absl::optional<int64_t> last_sender_report_remote_timestamp_ms;
74 uint32_t sender_reports_packets_sent = 0;
75 uint64_t sender_reports_bytes_sent = 0;
76 uint64_t sender_reports_reports_count = 0;
Ivo Creusen2562cf02021-09-03 14:51:22 +000077 absl::optional<TimeDelta> round_trip_time;
78 TimeDelta total_round_trip_time = TimeDelta::Zero();
79 int round_trip_time_measurements;
Niels Möller530ead42018-10-04 14:28:39 +020080};
81
82namespace voe {
83
Niels Möllerdced9f62018-11-19 10:27:07 +010084class ChannelSendInterface;
Niels Möller530ead42018-10-04 14:28:39 +020085
Niels Möller349ade32018-11-16 09:50:42 +010086// Interface class needed for AudioReceiveStream tests that use a
87// MockChannelReceive.
88
89class ChannelReceiveInterface : public RtpPacketSinkInterface {
Niels Möller530ead42018-10-04 14:28:39 +020090 public:
Niels Möller349ade32018-11-16 09:50:42 +010091 virtual ~ChannelReceiveInterface() = default;
Niels Möller530ead42018-10-04 14:28:39 +020092
Niels Möller349ade32018-11-16 09:50:42 +010093 virtual void SetSink(AudioSinkInterface* sink) = 0;
Niels Möller530ead42018-10-04 14:28:39 +020094
Niels Möller349ade32018-11-16 09:50:42 +010095 virtual void SetReceiveCodecs(
96 const std::map<int, SdpAudioFormat>& codecs) = 0;
Niels Möller530ead42018-10-04 14:28:39 +020097
Niels Möller349ade32018-11-16 09:50:42 +010098 virtual void StartPlayout() = 0;
99 virtual void StopPlayout() = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200100
Fredrik Solenbergf693bfa2018-12-11 12:22:10 +0100101 // Payload type and format of last received RTP packet, if any.
Jonas Olssona4d87372019-07-05 19:08:33 +0200102 virtual absl::optional<std::pair<int, SdpAudioFormat>> GetReceiveCodec()
103 const = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200104
Niels Möller8fb1a6a2019-03-05 14:29:42 +0100105 virtual void ReceivedRTCPPacket(const uint8_t* data, size_t length) = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200106
Niels Möller349ade32018-11-16 09:50:42 +0100107 virtual void SetChannelOutputVolumeScaling(float scaling) = 0;
108 virtual int GetSpeechOutputLevelFullRange() const = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200109 // See description of "totalAudioEnergy" in the WebRTC stats spec:
110 // https://w3c.github.io/webrtc-stats/#dom-rtcmediastreamtrackstats-totalaudioenergy
Niels Möller349ade32018-11-16 09:50:42 +0100111 virtual double GetTotalOutputEnergy() const = 0;
112 virtual double GetTotalOutputDuration() const = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200113
114 // Stats.
Niels Möller6b4d9622020-09-14 10:47:50 +0200115 virtual NetworkStatistics GetNetworkStatistics(
116 bool get_and_clear_legacy_stats) const = 0;
Niels Möller349ade32018-11-16 09:50:42 +0100117 virtual AudioDecodingCallStats GetDecodingCallStatistics() const = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200118
119 // Audio+Video Sync.
Niels Möller349ade32018-11-16 09:50:42 +0100120 virtual uint32_t GetDelayEstimate() const = 0;
Ivo Creusenbef7b052020-09-08 16:30:25 +0200121 virtual bool SetMinimumPlayoutDelay(int delay_ms) = 0;
Åsa Perssonfcf79cc2019-10-22 15:23:44 +0200122 virtual bool GetPlayoutRtpTimestamp(uint32_t* rtp_timestamp,
123 int64_t* time_ms) const = 0;
124 virtual void SetEstimatedPlayoutNtpTimestampMs(int64_t ntp_timestamp_ms,
125 int64_t time_ms) = 0;
126 virtual absl::optional<int64_t> GetCurrentEstimatedPlayoutNtpTimestampMs(
127 int64_t now_ms) const = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200128
Ruslan Burakov3b50f9f2019-02-06 09:45:56 +0100129 // Audio quality.
130 // Base minimum delay sets lower bound on minimum delay value which
131 // determines minimum delay until audio playout.
132 virtual bool SetBaseMinimumPlayoutDelayMs(int delay_ms) = 0;
133 virtual int GetBaseMinimumPlayoutDelayMs() const = 0;
134
Niels Möller530ead42018-10-04 14:28:39 +0200135 // Produces the transport-related timestamps; current_delay_ms is left unset.
Niels Möller349ade32018-11-16 09:50:42 +0100136 virtual absl::optional<Syncable::Info> GetSyncInfo() const = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200137
Niels Möller349ade32018-11-16 09:50:42 +0100138 virtual void RegisterReceiverCongestionControlObjects(
139 PacketRouter* packet_router) = 0;
140 virtual void ResetReceiverCongestionControlObjects() = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200141
Niels Möller349ade32018-11-16 09:50:42 +0100142 virtual CallReceiveStatistics GetRTCPStatistics() const = 0;
143 virtual void SetNACKStatus(bool enable, int max_packets) = 0;
Ivo Creusen2562cf02021-09-03 14:51:22 +0000144 virtual void SetNonSenderRttMeasurement(bool enabled) = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200145
Niels Möller349ade32018-11-16 09:50:42 +0100146 virtual AudioMixer::Source::AudioFrameInfo GetAudioFrameWithInfo(
Niels Möller530ead42018-10-04 14:28:39 +0200147 int sample_rate_hz,
Niels Möller349ade32018-11-16 09:50:42 +0100148 AudioFrame* audio_frame) = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200149
Niels Möller349ade32018-11-16 09:50:42 +0100150 virtual int PreferredSampleRate() const = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200151
Ranveer Aggarwaldea374a2021-01-23 12:27:19 +0530152 // Sets the source tracker to notify about "delivered" packets when output is
153 // muted.
154 virtual void SetSourceTracker(SourceTracker* source_tracker) = 0;
155
Niels Möller530ead42018-10-04 14:28:39 +0200156 // Associate to a send channel.
157 // Used for obtaining RTT for a receive-only channel.
Niels Möllerdced9f62018-11-19 10:27:07 +0100158 virtual void SetAssociatedSendChannel(
159 const ChannelSendInterface* channel) = 0;
Marina Ciocea3e9af7f2020-04-01 07:46:16 +0200160
161 // Sets a frame transformer between the depacketizer and the decoder, to
162 // transform the received frames before decoding them.
163 virtual void SetDepacketizerToDecoderFrameTransformer(
164 rtc::scoped_refptr<webrtc::FrameTransformerInterface>
165 frame_transformer) = 0;
Tommie0972822021-06-14 08:11:10 +0200166
167 virtual void SetFrameDecryptor(
168 rtc::scoped_refptr<webrtc::FrameDecryptorInterface> frame_decryptor) = 0;
Tommi08be9ba2021-06-15 23:01:57 +0200169
170 virtual void OnLocalSsrcChange(uint32_t local_ssrc) = 0;
171 virtual uint32_t GetLocalSsrc() const = 0;
Niels Möller530ead42018-10-04 14:28:39 +0200172};
173
Niels Möller349ade32018-11-16 09:50:42 +0100174std::unique_ptr<ChannelReceiveInterface> CreateChannelReceive(
Sebastian Jansson977b3352019-03-04 17:43:34 +0100175 Clock* clock,
Ivo Creusenc3d1f9b2019-11-01 11:47:51 +0100176 NetEqFactory* neteq_factory,
Niels Möller349ade32018-11-16 09:50:42 +0100177 AudioDeviceModule* audio_device_module,
Niels Möller349ade32018-11-16 09:50:42 +0100178 Transport* rtcp_send_transport,
179 RtcEventLog* rtc_event_log,
Erik Språng70efdde2019-08-21 13:36:20 +0200180 uint32_t local_ssrc,
Niels Möller349ade32018-11-16 09:50:42 +0100181 uint32_t remote_ssrc,
182 size_t jitter_buffer_max_packets,
183 bool jitter_buffer_fast_playout,
Jakob Ivarsson10403ae2018-11-27 15:45:20 +0100184 int jitter_buffer_min_delay_ms,
Jakob Ivarsson53eae872019-01-10 15:58:36 +0100185 bool jitter_buffer_enable_rtx_handling,
Ivo Creusen2562cf02021-09-03 14:51:22 +0000186 bool enable_non_sender_rtt,
Niels Möller349ade32018-11-16 09:50:42 +0100187 rtc::scoped_refptr<AudioDecoderFactory> decoder_factory,
188 absl::optional<AudioCodecPairId> codec_pair_id,
189 rtc::scoped_refptr<FrameDecryptorInterface> frame_decryptor,
Marina Ciocea3e9af7f2020-04-01 07:46:16 +0200190 const webrtc::CryptoOptions& crypto_options,
191 rtc::scoped_refptr<FrameTransformerInterface> frame_transformer);
Niels Möller349ade32018-11-16 09:50:42 +0100192
Niels Möller530ead42018-10-04 14:28:39 +0200193} // namespace voe
194} // namespace webrtc
195
196#endif // AUDIO_CHANNEL_RECEIVE_H_