2013-09-12 18:30:26 +00:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2013 The WebRTC project authors. All Rights Reserved.
|
|
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
|
*/
|
|
|
|
|
|
2017-09-15 06:47:31 +02:00
|
|
|
#ifndef MODULES_AUDIO_CODING_ACM2_ACM_RECEIVER_H_
|
|
|
|
|
#define MODULES_AUDIO_CODING_ACM2_ACM_RECEIVER_H_
|
2013-09-12 18:30:26 +00:00
|
|
|
|
2018-10-23 12:03:01 +02:00
|
|
|
#include <stdint.h>
|
2019-07-05 19:08:33 +02:00
|
|
|
|
2015-03-23 11:19:35 +00:00
|
|
|
#include <map>
|
2016-02-15 02:27:22 -08:00
|
|
|
#include <memory>
|
2015-12-09 06:20:58 -08:00
|
|
|
#include <string>
|
Remove CodecInst pt.2
The following APIs on AudioCodingModule are deprecated with this CL:
static int NumberOfCodecs();
static int Codec(int, CodecInst*);
static int Codec(const char*, CodecInst*, int, size_t);
static int Codec(const char*, int, size_t);
absl::optional<CodecInst> SendCodec() const;
bool RegisterReceiveCodec(int, const SdpAudioFormat&);
int RegisterExternalReceiveCodec(int, AudioDecoder*, int, int, const std::string&);
int UnregisterReceiveCodec(uint8_t);
int32_t ReceiveCodec(CodecInst*);
absl::optional<SdpAudioFormat> ReceiveFormat();
As well as this method on RtpRtcp module:
int32_t RegisterSendPayload(const CodecInst&);
Bug: webrtc:7626
Change-Id: I1230732136f1fe9048cf74afdeab767ca57ac9ce
Reviewed-on: https://webrtc-review.googlesource.com/c/113816
Commit-Queue: Fredrik Solenberg <solenberg@webrtc.org>
Reviewed-by: Karl Wiberg <kwiberg@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#26025}
2018-12-11 12:22:10 +01:00
|
|
|
#include <utility>
|
2013-09-12 18:30:26 +00:00
|
|
|
#include <vector>
|
|
|
|
|
|
2018-06-19 13:26:36 +02:00
|
|
|
#include "absl/types/optional.h"
|
2017-09-15 06:47:31 +02:00
|
|
|
#include "api/array_view.h"
|
2018-10-23 12:03:01 +02:00
|
|
|
#include "api/audio_codecs/audio_decoder.h"
|
|
|
|
|
#include "api/audio_codecs/audio_format.h"
|
2017-09-15 06:47:31 +02:00
|
|
|
#include "modules/audio_coding/acm2/acm_resampler.h"
|
|
|
|
|
#include "modules/audio_coding/acm2/call_statistics.h"
|
|
|
|
|
#include "modules/audio_coding/include/audio_coding_module.h"
|
2019-01-11 09:11:00 -08:00
|
|
|
#include "rtc_base/critical_section.h"
|
2017-09-15 06:47:31 +02:00
|
|
|
#include "rtc_base/thread_annotations.h"
|
2013-09-12 18:30:26 +00:00
|
|
|
|
|
|
|
|
namespace webrtc {
|
|
|
|
|
|
2018-10-23 12:03:01 +02:00
|
|
|
class Clock;
|
2013-09-12 18:30:26 +00:00
|
|
|
class NetEq;
|
2018-10-23 12:03:01 +02:00
|
|
|
struct RTPHeader;
|
2013-10-06 04:47:28 +00:00
|
|
|
|
|
|
|
|
namespace acm2 {
|
|
|
|
|
|
2013-09-12 18:30:26 +00:00
|
|
|
class AcmReceiver {
|
|
|
|
|
public:
|
|
|
|
|
// Constructor of the class
|
2014-04-29 08:09:31 +00:00
|
|
|
explicit AcmReceiver(const AudioCodingModule::Config& config);
|
2013-09-12 18:30:26 +00:00
|
|
|
|
|
|
|
|
// Destructor of the class.
|
|
|
|
|
~AcmReceiver();
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Inserts a payload with its associated RTP-header into NetEq.
|
|
|
|
|
//
|
|
|
|
|
// Input:
|
|
|
|
|
// - rtp_header : RTP header for the incoming payload containing
|
|
|
|
|
// information about payload type, sequence number,
|
|
|
|
|
// timestamp, SSRC and marker bit.
|
|
|
|
|
// - incoming_payload : Incoming audio payload.
|
|
|
|
|
// - length_payload : Length of incoming audio payload in bytes.
|
|
|
|
|
//
|
|
|
|
|
// Return value : 0 if OK.
|
|
|
|
|
// <0 if NetEq returned an error.
|
|
|
|
|
//
|
2019-02-15 15:21:47 +01:00
|
|
|
int InsertPacket(const RTPHeader& rtp_header,
|
2015-11-11 10:34:00 -08:00
|
|
|
rtc::ArrayView<const uint8_t> incoming_payload);
|
2013-09-12 18:30:26 +00:00
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Asks NetEq for 10 milliseconds of decoded audio.
|
|
|
|
|
//
|
|
|
|
|
// Input:
|
|
|
|
|
// -desired_freq_hz : specifies the sampling rate [Hz] of the output
|
|
|
|
|
// audio. If set -1 indicates to resampling is
|
|
|
|
|
// is required and the audio returned at the
|
|
|
|
|
// sampling rate of the decoder.
|
|
|
|
|
//
|
|
|
|
|
// Output:
|
|
|
|
|
// -audio_frame : an audio frame were output data and
|
|
|
|
|
// associated parameters are written to.
|
2016-05-13 03:45:24 -07:00
|
|
|
// -muted : if true, the sample data in audio_frame is not
|
|
|
|
|
// populated, and must be interpreted as all zero.
|
2013-09-12 18:30:26 +00:00
|
|
|
//
|
|
|
|
|
// Return value : 0 if OK.
|
|
|
|
|
// -1 if NetEq returned an error.
|
|
|
|
|
//
|
2016-05-13 03:45:24 -07:00
|
|
|
int GetAudio(int desired_freq_hz, AudioFrame* audio_frame, bool* muted);
|
2013-09-12 18:30:26 +00:00
|
|
|
|
2017-03-27 07:15:49 -07:00
|
|
|
// Replace the current set of decoders with the specified set.
|
|
|
|
|
void SetCodecs(const std::map<int, SdpAudioFormat>& codecs);
|
|
|
|
|
|
2013-09-12 18:30:26 +00:00
|
|
|
//
|
|
|
|
|
// Sets a minimum delay for packet buffer. The given delay is maintained,
|
|
|
|
|
// unless channel condition dictates a higher delay.
|
|
|
|
|
//
|
|
|
|
|
// Input:
|
|
|
|
|
// - delay_ms : minimum delay in milliseconds.
|
|
|
|
|
//
|
|
|
|
|
// Return value : 0 if OK.
|
|
|
|
|
// <0 if NetEq returned an error.
|
|
|
|
|
//
|
|
|
|
|
int SetMinimumDelay(int delay_ms);
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Sets a maximum delay [ms] for the packet buffer. The target delay does not
|
|
|
|
|
// exceed the given value, even if channel condition requires so.
|
|
|
|
|
//
|
|
|
|
|
// Input:
|
|
|
|
|
// - delay_ms : maximum delay in milliseconds.
|
|
|
|
|
//
|
|
|
|
|
// Return value : 0 if OK.
|
|
|
|
|
// <0 if NetEq returned an error.
|
|
|
|
|
//
|
|
|
|
|
int SetMaximumDelay(int delay_ms);
|
|
|
|
|
|
2019-02-05 13:49:26 +01:00
|
|
|
// Sets a base minimum delay in milliseconds for the packet buffer.
|
|
|
|
|
// Base minimum delay sets lower bound minimum delay value which
|
|
|
|
|
// is set via SetMinimumDelay.
|
|
|
|
|
//
|
|
|
|
|
// Returns true if value was successfully set, false overwise.
|
|
|
|
|
bool SetBaseMinimumDelayMs(int delay_ms);
|
|
|
|
|
|
|
|
|
|
// Returns current value of base minimum delay in milliseconds.
|
|
|
|
|
int GetBaseMinimumDelayMs() const;
|
|
|
|
|
|
2013-09-12 18:30:26 +00:00
|
|
|
//
|
|
|
|
|
// Resets the initial delay to zero.
|
|
|
|
|
//
|
|
|
|
|
void ResetInitialDelay();
|
|
|
|
|
|
2015-11-23 08:19:52 -08:00
|
|
|
// Returns the sample rate of the decoder associated with the last incoming
|
|
|
|
|
// packet. If no packet of a registered non-CNG codec has been received, the
|
|
|
|
|
// return value is empty. Also, if the decoder was unregistered since the last
|
|
|
|
|
// packet was inserted, the return value is empty.
|
2018-06-19 13:26:36 +02:00
|
|
|
absl::optional<int> last_packet_sample_rate_hz() const;
|
2015-11-23 08:19:52 -08:00
|
|
|
|
2015-11-23 06:49:25 -08:00
|
|
|
// Returns last_output_sample_rate_hz from the NetEq instance.
|
|
|
|
|
int last_output_sample_rate_hz() const;
|
2013-09-12 18:30:26 +00:00
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Get the current network statistics from NetEq.
|
|
|
|
|
//
|
|
|
|
|
// Output:
|
|
|
|
|
// - statistics : The current network statistics.
|
|
|
|
|
//
|
2019-07-30 15:15:59 +02:00
|
|
|
void GetNetworkStatistics(NetworkStatistics* statistics) const;
|
2013-09-12 18:30:26 +00:00
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Flushes the NetEq packet and speech buffers.
|
|
|
|
|
//
|
|
|
|
|
void FlushBuffers();
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Remove all registered codecs.
|
|
|
|
|
//
|
2016-09-20 04:02:25 -07:00
|
|
|
void RemoveAllCodecs();
|
2013-09-12 18:30:26 +00:00
|
|
|
|
2016-04-06 01:39:22 -07:00
|
|
|
// Returns the RTP timestamp for the last sample delivered by GetAudio().
|
|
|
|
|
// The return value will be empty if no valid timestamp is available.
|
2018-06-19 13:26:36 +02:00
|
|
|
absl::optional<uint32_t> GetPlayoutTimestamp();
|
2013-09-12 18:30:26 +00:00
|
|
|
|
2016-08-22 15:39:53 -07:00
|
|
|
// Returns the current total delay from NetEq (packet buffer and sync buffer)
|
|
|
|
|
// in ms, with smoothing applied to even out short-time fluctuations due to
|
|
|
|
|
// jitter. The packet buffer part of the delay is not updated during DTX/CNG
|
|
|
|
|
// periods.
|
|
|
|
|
//
|
|
|
|
|
int FilteredCurrentDelayMs() const;
|
2017-11-29 09:14:04 +01:00
|
|
|
|
|
|
|
|
// Returns the current target delay for NetEq in ms.
|
|
|
|
|
//
|
|
|
|
|
int TargetDelayMs() const;
|
2016-08-22 15:39:53 -07:00
|
|
|
|
2013-09-12 18:30:26 +00:00
|
|
|
//
|
Remove CodecInst pt.2
The following APIs on AudioCodingModule are deprecated with this CL:
static int NumberOfCodecs();
static int Codec(int, CodecInst*);
static int Codec(const char*, CodecInst*, int, size_t);
static int Codec(const char*, int, size_t);
absl::optional<CodecInst> SendCodec() const;
bool RegisterReceiveCodec(int, const SdpAudioFormat&);
int RegisterExternalReceiveCodec(int, AudioDecoder*, int, int, const std::string&);
int UnregisterReceiveCodec(uint8_t);
int32_t ReceiveCodec(CodecInst*);
absl::optional<SdpAudioFormat> ReceiveFormat();
As well as this method on RtpRtcp module:
int32_t RegisterSendPayload(const CodecInst&);
Bug: webrtc:7626
Change-Id: I1230732136f1fe9048cf74afdeab767ca57ac9ce
Reviewed-on: https://webrtc-review.googlesource.com/c/113816
Commit-Queue: Fredrik Solenberg <solenberg@webrtc.org>
Reviewed-by: Karl Wiberg <kwiberg@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#26025}
2018-12-11 12:22:10 +01:00
|
|
|
// Get payload type and format of the last non-CNG/non-DTMF received payload.
|
|
|
|
|
// If no non-CNG/non-DTMF packet is received absl::nullopt is returned.
|
2013-09-12 18:30:26 +00:00
|
|
|
//
|
Remove CodecInst pt.2
The following APIs on AudioCodingModule are deprecated with this CL:
static int NumberOfCodecs();
static int Codec(int, CodecInst*);
static int Codec(const char*, CodecInst*, int, size_t);
static int Codec(const char*, int, size_t);
absl::optional<CodecInst> SendCodec() const;
bool RegisterReceiveCodec(int, const SdpAudioFormat&);
int RegisterExternalReceiveCodec(int, AudioDecoder*, int, int, const std::string&);
int UnregisterReceiveCodec(uint8_t);
int32_t ReceiveCodec(CodecInst*);
absl::optional<SdpAudioFormat> ReceiveFormat();
As well as this method on RtpRtcp module:
int32_t RegisterSendPayload(const CodecInst&);
Bug: webrtc:7626
Change-Id: I1230732136f1fe9048cf74afdeab767ca57ac9ce
Reviewed-on: https://webrtc-review.googlesource.com/c/113816
Commit-Queue: Fredrik Solenberg <solenberg@webrtc.org>
Reviewed-by: Karl Wiberg <kwiberg@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#26025}
2018-12-11 12:22:10 +01:00
|
|
|
absl::optional<std::pair<int, SdpAudioFormat>> LastDecoder() const;
|
2013-09-12 18:30:26 +00:00
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Enable NACK and set the maximum size of the NACK list. If NACK is already
|
|
|
|
|
// enabled then the maximum NACK list size is modified accordingly.
|
|
|
|
|
//
|
2019-08-09 09:29:48 +02:00
|
|
|
// If the sequence number of last received packet is N, the sequence numbers
|
|
|
|
|
// of NACK list are in the range of [N - |max_nack_list_size|, N).
|
|
|
|
|
//
|
|
|
|
|
// |max_nack_list_size| should be positive (none zero) and less than or
|
|
|
|
|
// equal to |Nack::kNackListSizeLimit|. Otherwise, No change is applied and -1
|
|
|
|
|
// is returned. 0 is returned at success.
|
2013-09-12 18:30:26 +00:00
|
|
|
//
|
|
|
|
|
int EnableNack(size_t max_nack_list_size);
|
|
|
|
|
|
|
|
|
|
// Disable NACK.
|
|
|
|
|
void DisableNack();
|
|
|
|
|
|
|
|
|
|
//
|
2019-08-09 09:29:48 +02:00
|
|
|
// Get a list of packets to be retransmitted. |round_trip_time_ms| is an
|
|
|
|
|
// estimate of the round-trip-time (in milliseconds). Missing packets which
|
|
|
|
|
// will be playout in a shorter time than the round-trip-time (with respect
|
|
|
|
|
// to the time this API is called) will not be included in the list.
|
2013-09-12 18:30:26 +00:00
|
|
|
//
|
2019-08-09 09:29:48 +02:00
|
|
|
// Negative |round_trip_time_ms| results is an error message and empty list
|
|
|
|
|
// is returned.
|
2013-09-12 18:30:26 +00:00
|
|
|
//
|
2015-01-12 21:51:21 +00:00
|
|
|
std::vector<uint16_t> GetNackList(int64_t round_trip_time_ms) const;
|
2013-09-12 18:30:26 +00:00
|
|
|
|
2013-12-13 19:17:43 +00:00
|
|
|
//
|
|
|
|
|
// Get statistics of calls to GetAudio().
|
|
|
|
|
void GetDecodingCallStatistics(AudioDecodingCallStats* stats) const;
|
|
|
|
|
|
2013-09-12 18:30:26 +00:00
|
|
|
private:
|
2019-10-11 09:37:42 +02:00
|
|
|
struct DecoderInfo {
|
|
|
|
|
int payload_type;
|
|
|
|
|
int sample_rate_hz;
|
|
|
|
|
int num_channels;
|
|
|
|
|
SdpAudioFormat sdp_format;
|
|
|
|
|
};
|
|
|
|
|
|
2013-09-12 18:30:26 +00:00
|
|
|
uint32_t NowInTimestamp(int decoder_sampling_rate) const;
|
|
|
|
|
|
2016-01-25 03:52:44 -08:00
|
|
|
rtc::CriticalSection crit_sect_;
|
2019-10-11 09:37:42 +02:00
|
|
|
absl::optional<DecoderInfo> last_decoder_ RTC_GUARDED_BY(crit_sect_);
|
2017-09-07 07:53:45 -07:00
|
|
|
ACMResampler resampler_ RTC_GUARDED_BY(crit_sect_);
|
|
|
|
|
std::unique_ptr<int16_t[]> last_audio_buffer_ RTC_GUARDED_BY(crit_sect_);
|
|
|
|
|
CallStatistics call_stats_ RTC_GUARDED_BY(crit_sect_);
|
2017-06-14 14:13:02 +02:00
|
|
|
const std::unique_ptr<NetEq> neteq_; // NetEq is thread-safe; no lock needed.
|
2019-01-30 11:28:59 +01:00
|
|
|
Clock* const clock_;
|
2017-09-07 07:53:45 -07:00
|
|
|
bool resampled_last_output_frame_ RTC_GUARDED_BY(crit_sect_);
|
2013-09-12 18:30:26 +00:00
|
|
|
};
|
|
|
|
|
|
2013-10-06 04:47:28 +00:00
|
|
|
} // namespace acm2
|
|
|
|
|
|
2013-09-12 18:30:26 +00:00
|
|
|
} // namespace webrtc
|
|
|
|
|
|
2017-09-15 06:47:31 +02:00
|
|
|
#endif // MODULES_AUDIO_CODING_ACM2_ACM_RECEIVER_H_
|