Add field VideoEncoderConfig::codec_type.

First step of the transition needed to reland cl
https://webrtc-review.googlesource.com/62062, and move payload_name
and payload_type out of VideoSendStream::Config::EncoderSettings.

If the new field is set to something different than kVideoCodecUnkown,
payload_name from EncoderSettings is ignored.

Bug: webrtc:8830
Change-Id: I515a91f8291cda79017332102cc6a10736d8a648
Reviewed-on: https://webrtc-review.googlesource.com/64001
Reviewed-by: Rasmus Brandt <brandtr@webrtc.org>
Commit-Queue: Niels Moller <nisse@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#22555}
This commit is contained in:
Niels Möller
2018-03-22 08:52:50 +01:00
committed by Commit Bot
parent 48cca02799
commit 24a842a15c
4 changed files with 30 additions and 17 deletions

View File

@ -46,7 +46,8 @@ std::string VideoStream::ToString() const {
} }
VideoEncoderConfig::VideoEncoderConfig() VideoEncoderConfig::VideoEncoderConfig()
: content_type(ContentType::kRealtimeVideo), : codec_type(kVideoCodecUnknown),
content_type(ContentType::kRealtimeVideo),
encoder_specific_settings(nullptr), encoder_specific_settings(nullptr),
min_transmit_bitrate_bps(0), min_transmit_bitrate_bps(0),
max_bitrate_bps(0), max_bitrate_bps(0),
@ -59,7 +60,9 @@ VideoEncoderConfig::~VideoEncoderConfig() = default;
std::string VideoEncoderConfig::ToString() const { std::string VideoEncoderConfig::ToString() const {
std::stringstream ss; std::stringstream ss;
ss << "{content_type: "; ss << "{codec_type: ";
ss << CodecTypeToPayloadString(codec_type);
ss << ", content_type: ";
switch (content_type) { switch (content_type) {
case ContentType::kRealtimeVideo: case ContentType::kRealtimeVideo:
ss << "kRealtimeVideo"; ss << "kRealtimeVideo";

View File

@ -126,6 +126,11 @@ class VideoEncoderConfig {
~VideoEncoderConfig(); ~VideoEncoderConfig();
std::string ToString() const; std::string ToString() const;
// TODO(nisse): This codec_type member is intended to be the new way
// to say which codec to use, when
// VideoSendStream::Config::EncoderSettings::payload_name is
// deleted. For the transition, both need to coexist.
VideoCodecType codec_type;
rtc::scoped_refptr<VideoStreamFactoryInterface> video_stream_factory; rtc::scoped_refptr<VideoStreamFactoryInterface> video_stream_factory;
std::vector<SpatialLayer> spatial_layers; std::vector<SpatialLayer> spatial_layers;
ContentType content_type; ContentType content_type;

View File

@ -49,8 +49,8 @@ class VideoCodecInitializer {
static VideoCodec VideoEncoderConfigToVideoCodec( static VideoCodec VideoEncoderConfigToVideoCodec(
const VideoEncoderConfig& config, const VideoEncoderConfig& config,
const std::vector<VideoStream>& streams, const std::vector<VideoStream>& streams,
const std::string& payload_name, // TODO(nisse): Delete when we can rely on config.codec_type.
int payload_type, VideoCodecType codec_type,
bool nack_enabled); bool nack_enabled);
}; };

View File

@ -31,13 +31,18 @@ bool VideoCodecInitializer::SetupCodec(
bool nack_enabled, bool nack_enabled,
VideoCodec* codec, VideoCodec* codec,
std::unique_ptr<VideoBitrateAllocator>* bitrate_allocator) { std::unique_ptr<VideoBitrateAllocator>* bitrate_allocator) {
if (PayloadStringToCodecType(settings.payload_name) == kVideoCodecMultiplex) { VideoCodecType codec_type = config.codec_type;
VideoSendStream::Config::EncoderSettings associated_codec_settings = // TODO(nisse): Transition hack, the intention is to delete the
settings; // |settings| argument and require configuration via
associated_codec_settings.payload_name = // config.codec_type.
CodecTypeToPayloadString(kVideoCodecVP9); if (codec_type == kVideoCodecUnknown) {
if (!SetupCodec(config, associated_codec_settings, streams, nack_enabled, codec_type = PayloadStringToCodecType(settings.payload_name);
codec, bitrate_allocator)) { }
if (codec_type == kVideoCodecMultiplex) {
VideoEncoderConfig associated_config = config.Copy();
associated_config.codec_type = kVideoCodecVP9;
if (!SetupCodec(associated_config, settings /* ignored */, streams,
nack_enabled, codec, bitrate_allocator)) {
RTC_LOG(LS_ERROR) << "Failed to create stereo encoder configuration."; RTC_LOG(LS_ERROR) << "Failed to create stereo encoder configuration.";
return false; return false;
} }
@ -46,8 +51,7 @@ bool VideoCodecInitializer::SetupCodec(
} }
*codec = *codec =
VideoEncoderConfigToVideoCodec(config, streams, settings.payload_name, VideoEncoderConfigToVideoCodec(config, streams, codec_type, nack_enabled);
settings.payload_type, nack_enabled);
*bitrate_allocator = CreateBitrateAllocator(*codec); *bitrate_allocator = CreateBitrateAllocator(*codec);
return true; return true;
@ -73,8 +77,7 @@ VideoCodecInitializer::CreateBitrateAllocator(const VideoCodec& codec) {
VideoCodec VideoCodecInitializer::VideoEncoderConfigToVideoCodec( VideoCodec VideoCodecInitializer::VideoEncoderConfigToVideoCodec(
const VideoEncoderConfig& config, const VideoEncoderConfig& config,
const std::vector<VideoStream>& streams, const std::vector<VideoStream>& streams,
const std::string& payload_name, VideoCodecType codec_type,
int payload_type,
bool nack_enabled) { bool nack_enabled) {
static const int kEncoderMinBitrateKbps = 30; static const int kEncoderMinBitrateKbps = 30;
RTC_DCHECK(!streams.empty()); RTC_DCHECK(!streams.empty());
@ -82,7 +85,7 @@ VideoCodec VideoCodecInitializer::VideoEncoderConfigToVideoCodec(
VideoCodec video_codec; VideoCodec video_codec;
memset(&video_codec, 0, sizeof(video_codec)); memset(&video_codec, 0, sizeof(video_codec));
video_codec.codecType = PayloadStringToCodecType(payload_name); video_codec.codecType = codec_type;
switch (config.content_type) { switch (config.content_type) {
case VideoEncoderConfig::ContentType::kRealtimeVideo: case VideoEncoderConfig::ContentType::kRealtimeVideo:
@ -155,7 +158,9 @@ VideoCodec VideoCodecInitializer::VideoEncoderConfigToVideoCodec(
break; break;
} }
video_codec.plType = payload_type; // TODO(nisse): The plType field should be deleted. Luckily, our
// callers don't need it.
video_codec.plType = 0;
video_codec.numberOfSimulcastStreams = video_codec.numberOfSimulcastStreams =
static_cast<unsigned char>(streams.size()); static_cast<unsigned char>(streams.size());
video_codec.minBitrate = streams[0].min_bitrate_bps / 1000; video_codec.minBitrate = streams[0].min_bitrate_bps / 1000;