Bug: webrtc:13931 Change-Id: I7d139c9914c5a4ac71b8d15fd4d73229d3331be2 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/294840 Reviewed-by: Florent Castelli <orphis@webrtc.org> Commit-Queue: Harald Alvestrand <hta@webrtc.org> Cr-Commit-Position: refs/heads/main@{#39387}
284 lines
11 KiB
C++
284 lines
11 KiB
C++
/*
|
|
* Copyright (c) 2004 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.
|
|
*/
|
|
|
|
#ifndef MEDIA_BASE_MEDIA_ENGINE_H_
|
|
#define MEDIA_BASE_MEDIA_ENGINE_H_
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include "api/audio_codecs/audio_decoder_factory.h"
|
|
#include "api/audio_codecs/audio_encoder_factory.h"
|
|
#include "api/crypto/crypto_options.h"
|
|
#include "api/field_trials_view.h"
|
|
#include "api/rtp_parameters.h"
|
|
#include "api/video/video_bitrate_allocator_factory.h"
|
|
#include "call/audio_state.h"
|
|
#include "media/base/codec.h"
|
|
#include "media/base/media_channel.h"
|
|
#include "media/base/media_channel_impl.h"
|
|
#include "media/base/media_config.h"
|
|
#include "media/base/video_common.h"
|
|
#include "rtc_base/system/file_wrapper.h"
|
|
|
|
namespace webrtc {
|
|
class AudioDeviceModule;
|
|
class AudioMixer;
|
|
class AudioProcessing;
|
|
class Call;
|
|
} // namespace webrtc
|
|
|
|
namespace cricket {
|
|
|
|
class VideoMediaChannel;
|
|
class VoiceMediaChannel;
|
|
|
|
// Checks that the scalability_mode value of each encoding is supported by at
|
|
// least one video codec of the list. If the list is empty, no check is done.
|
|
webrtc::RTCError CheckScalabilityModeValues(
|
|
const webrtc::RtpParameters& new_parameters,
|
|
rtc::ArrayView<cricket::VideoCodec> codecs);
|
|
|
|
// Checks the parameters have valid and supported values, and checks parameters
|
|
// with CheckScalabilityModeValues().
|
|
webrtc::RTCError CheckRtpParametersValues(
|
|
const webrtc::RtpParameters& new_parameters,
|
|
rtc::ArrayView<cricket::VideoCodec> codecs);
|
|
|
|
// Checks that the immutable values have not changed in new_parameters and
|
|
// checks all parameters with CheckRtpParametersValues().
|
|
webrtc::RTCError CheckRtpParametersInvalidModificationAndValues(
|
|
const webrtc::RtpParameters& old_parameters,
|
|
const webrtc::RtpParameters& new_parameters,
|
|
rtc::ArrayView<cricket::VideoCodec> codecs);
|
|
|
|
// Checks that the immutable values have not changed in new_parameters and
|
|
// checks parameters (except SVC) with CheckRtpParametersValues(). It should
|
|
// usually be paired with a call to CheckScalabilityModeValues().
|
|
webrtc::RTCError CheckRtpParametersInvalidModificationAndValues(
|
|
const webrtc::RtpParameters& old_parameters,
|
|
const webrtc::RtpParameters& new_parameters);
|
|
|
|
struct RtpCapabilities {
|
|
RtpCapabilities();
|
|
~RtpCapabilities();
|
|
std::vector<webrtc::RtpExtension> header_extensions;
|
|
};
|
|
|
|
class RtpHeaderExtensionQueryInterface {
|
|
public:
|
|
virtual ~RtpHeaderExtensionQueryInterface() = default;
|
|
|
|
// Returns a vector of RtpHeaderExtensionCapability, whose direction is
|
|
// kStopped if the extension is stopped (not used) by default.
|
|
virtual std::vector<webrtc::RtpHeaderExtensionCapability>
|
|
GetRtpHeaderExtensions() const = 0;
|
|
};
|
|
|
|
class VoiceEngineInterface : public RtpHeaderExtensionQueryInterface {
|
|
public:
|
|
VoiceEngineInterface() = default;
|
|
virtual ~VoiceEngineInterface() = default;
|
|
|
|
VoiceEngineInterface(const VoiceEngineInterface&) = delete;
|
|
VoiceEngineInterface& operator=(const VoiceEngineInterface&) = delete;
|
|
|
|
// Initialization
|
|
// Starts the engine.
|
|
virtual void Init() = 0;
|
|
|
|
// TODO(solenberg): Remove once VoE API refactoring is done.
|
|
virtual rtc::scoped_refptr<webrtc::AudioState> GetAudioState() const = 0;
|
|
|
|
// MediaChannel creation
|
|
// Creates a voice media channel. Returns NULL on failure.
|
|
virtual VoiceMediaChannel* CreateMediaChannel(
|
|
MediaChannel::Role role,
|
|
webrtc::Call* call,
|
|
const MediaConfig& config,
|
|
const AudioOptions& options,
|
|
const webrtc::CryptoOptions& crypto_options,
|
|
webrtc::AudioCodecPairId codec_pair_id) {
|
|
// For the case where a subclass overrides the deprecated method
|
|
// but not the replacement method, call the deprecated method.
|
|
// TODO(bugs.webrtc.org/13931): Remove default implementation
|
|
// when downstream has migrated to new API.
|
|
RTC_CHECK(!recursion_guard_);
|
|
#pragma clang diagnostic push
|
|
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
|
|
RTC_LOG(LS_ERROR)
|
|
<< "Override of deprecated declaration detected - please update!";
|
|
return CreateMediaChannel(call, config, options, crypto_options);
|
|
#pragma clang diagnostic pop
|
|
}
|
|
|
|
// Backwards compatible version
|
|
[[deprecated("Use version with role parameter")]] virtual VoiceMediaChannel*
|
|
CreateMediaChannel(webrtc::Call* call,
|
|
const MediaConfig& config,
|
|
const AudioOptions& options,
|
|
const webrtc::CryptoOptions& crypto_options) {
|
|
recursion_guard_ = true;
|
|
auto new_channel =
|
|
CreateMediaChannel(MediaChannel::Role::kBoth, call, config, options,
|
|
crypto_options, webrtc::AudioCodecPairId::Create());
|
|
recursion_guard_ = false;
|
|
return new_channel;
|
|
}
|
|
|
|
virtual const std::vector<AudioCodec>& send_codecs() const = 0;
|
|
virtual const std::vector<AudioCodec>& recv_codecs() const = 0;
|
|
|
|
// Starts AEC dump using existing file, a maximum file size in bytes can be
|
|
// specified. Logging is stopped just before the size limit is exceeded.
|
|
// If max_size_bytes is set to a value <= 0, no limit will be used.
|
|
virtual bool StartAecDump(webrtc::FileWrapper file,
|
|
int64_t max_size_bytes) = 0;
|
|
|
|
// Stops recording AEC dump.
|
|
virtual void StopAecDump() = 0;
|
|
|
|
virtual absl::optional<webrtc::AudioDeviceModule::Stats>
|
|
GetAudioDeviceStats() = 0;
|
|
|
|
private:
|
|
// Workaround variable for avoiding recursion between old and new APIs.
|
|
// TODO(bugs.webrtc.org/13931): Remove when old interface is gone.
|
|
bool recursion_guard_ = false;
|
|
};
|
|
|
|
class VideoEngineInterface : public RtpHeaderExtensionQueryInterface {
|
|
public:
|
|
VideoEngineInterface() = default;
|
|
virtual ~VideoEngineInterface() = default;
|
|
|
|
VideoEngineInterface(const VideoEngineInterface&) = delete;
|
|
VideoEngineInterface& operator=(const VideoEngineInterface&) = delete;
|
|
|
|
// Creates a video media channel.
|
|
// Returns NULL on failure.
|
|
virtual VideoMediaChannel* CreateMediaChannel(
|
|
MediaChannel::Role role,
|
|
webrtc::Call* call,
|
|
const MediaConfig& config,
|
|
const VideoOptions& options,
|
|
const webrtc::CryptoOptions& crypto_options,
|
|
webrtc::VideoBitrateAllocatorFactory* video_bitrate_allocator_factory) {
|
|
// For the case where a subclass overrides the deprecated method
|
|
// but not the replacement method, call the deprecated method.
|
|
// TODO(bugs.webrtc.org/13931): Remove default implementation
|
|
// when downstream has migrated to new API.
|
|
RTC_CHECK(!recursion_guard_);
|
|
#pragma clang diagnostic push
|
|
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
|
|
RTC_LOG(LS_ERROR)
|
|
<< "Override of deprecated declaration detected - please update!";
|
|
return CreateMediaChannel(call, config, options, crypto_options,
|
|
video_bitrate_allocator_factory);
|
|
#pragma clang diagnostic pop
|
|
}
|
|
|
|
// Creates a video media channel.
|
|
// Returns NULL on failure.
|
|
// TODO(bugs.webrtc.org/13931): Stop downstream usage of this function.
|
|
[[deprecated("Please specify the role")]] virtual VideoMediaChannel*
|
|
CreateMediaChannel(
|
|
webrtc::Call* call,
|
|
const MediaConfig& config,
|
|
const VideoOptions& options,
|
|
const webrtc::CryptoOptions& crypto_options,
|
|
webrtc::VideoBitrateAllocatorFactory* video_bitrate_allocator_factory) {
|
|
recursion_guard_ = true;
|
|
auto new_channel =
|
|
CreateMediaChannel(MediaChannel::Role::kBoth, call, config, options,
|
|
crypto_options, video_bitrate_allocator_factory);
|
|
recursion_guard_ = false;
|
|
return new_channel;
|
|
}
|
|
|
|
// Retrieve list of supported codecs.
|
|
virtual std::vector<VideoCodec> send_codecs() const = 0;
|
|
virtual std::vector<VideoCodec> recv_codecs() const = 0;
|
|
// As above, but if include_rtx is false, don't include RTX codecs.
|
|
// TODO(bugs.webrtc.org/13931): Remove default implementation once
|
|
// upstream subclasses have converted.
|
|
virtual std::vector<VideoCodec> send_codecs(bool include_rtx) const {
|
|
RTC_DCHECK(include_rtx);
|
|
return send_codecs();
|
|
}
|
|
virtual std::vector<VideoCodec> recv_codecs(bool include_rtx) const {
|
|
RTC_DCHECK(include_rtx);
|
|
return recv_codecs();
|
|
}
|
|
|
|
private:
|
|
// Workaround variable for avoiding recursion between old and new APIs.
|
|
// TODO(bugs.webrtc.org/13931): Remove when old interface is gone.
|
|
bool recursion_guard_ = false;
|
|
};
|
|
|
|
// MediaEngineInterface is an abstraction of a media engine which can be
|
|
// subclassed to support different media componentry backends.
|
|
// It supports voice and video operations in the same class to facilitate
|
|
// proper synchronization between both media types.
|
|
class MediaEngineInterface {
|
|
public:
|
|
virtual ~MediaEngineInterface() {}
|
|
|
|
// Initialization. Needs to be called on the worker thread.
|
|
virtual bool Init() = 0;
|
|
|
|
virtual VoiceEngineInterface& voice() = 0;
|
|
virtual VideoEngineInterface& video() = 0;
|
|
virtual const VoiceEngineInterface& voice() const = 0;
|
|
virtual const VideoEngineInterface& video() const = 0;
|
|
};
|
|
|
|
// CompositeMediaEngine constructs a MediaEngine from separate
|
|
// voice and video engine classes.
|
|
// Optionally owns a FieldTrialsView trials map.
|
|
class CompositeMediaEngine : public MediaEngineInterface {
|
|
public:
|
|
CompositeMediaEngine(std::unique_ptr<webrtc::FieldTrialsView> trials,
|
|
std::unique_ptr<VoiceEngineInterface> audio_engine,
|
|
std::unique_ptr<VideoEngineInterface> video_engine);
|
|
CompositeMediaEngine(std::unique_ptr<VoiceEngineInterface> audio_engine,
|
|
std::unique_ptr<VideoEngineInterface> video_engine);
|
|
~CompositeMediaEngine() override;
|
|
|
|
// Always succeeds.
|
|
bool Init() override;
|
|
|
|
VoiceEngineInterface& voice() override;
|
|
VideoEngineInterface& video() override;
|
|
const VoiceEngineInterface& voice() const override;
|
|
const VideoEngineInterface& video() const override;
|
|
|
|
private:
|
|
const std::unique_ptr<webrtc::FieldTrialsView> trials_;
|
|
const std::unique_ptr<VoiceEngineInterface> voice_engine_;
|
|
const std::unique_ptr<VideoEngineInterface> video_engine_;
|
|
};
|
|
|
|
webrtc::RtpParameters CreateRtpParametersWithOneEncoding();
|
|
webrtc::RtpParameters CreateRtpParametersWithEncodings(StreamParams sp);
|
|
|
|
// Returns a vector of RTP extensions as visible from RtpSender/Receiver
|
|
// GetCapabilities(). The returned vector only shows what will definitely be
|
|
// offered by default, i.e. the list of extensions returned from
|
|
// GetRtpHeaderExtensions() that are not kStopped.
|
|
std::vector<webrtc::RtpExtension> GetDefaultEnabledRtpHeaderExtensions(
|
|
const RtpHeaderExtensionQueryInterface& query_interface);
|
|
|
|
} // namespace cricket
|
|
|
|
#endif // MEDIA_BASE_MEDIA_ENGINE_H_
|