[go: nahoru, domu]

blob: 35e00c786bd6e220b86117d46a9629b1e1c3985d [file] [log] [blame]
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "media/video/video_encode_accelerator.h"
#include <inttypes.h>
#include "base/callback.h"
#include "base/strings/stringprintf.h"
namespace media {
Vp8Metadata::Vp8Metadata()
: non_reference(false), temporal_idx(0), layer_sync(false) {}
Vp9Metadata::Vp9Metadata() = default;
Vp9Metadata::~Vp9Metadata() = default;
Vp9Metadata::Vp9Metadata(const Vp9Metadata&) = default;
BitstreamBufferMetadata::BitstreamBufferMetadata()
: payload_size_bytes(0), key_frame(false) {}
BitstreamBufferMetadata::BitstreamBufferMetadata(
const BitstreamBufferMetadata& other) = default;
BitstreamBufferMetadata& BitstreamBufferMetadata::operator=(
const BitstreamBufferMetadata& other) = default;
BitstreamBufferMetadata::BitstreamBufferMetadata(
BitstreamBufferMetadata&& other) = default;
BitstreamBufferMetadata::BitstreamBufferMetadata(size_t payload_size_bytes,
bool key_frame,
base::TimeDelta timestamp)
: payload_size_bytes(payload_size_bytes),
key_frame(key_frame),
timestamp(timestamp) {}
BitstreamBufferMetadata::~BitstreamBufferMetadata() = default;
VideoEncodeAccelerator::Config::Config()
: input_format(PIXEL_FORMAT_UNKNOWN),
output_profile(VIDEO_CODEC_PROFILE_UNKNOWN),
initial_bitrate(0),
content_type(ContentType::kCamera) {}
VideoEncodeAccelerator::Config::Config(const Config& config) = default;
VideoEncodeAccelerator::Config::Config(
VideoPixelFormat input_format,
const gfx::Size& input_visible_size,
VideoCodecProfile output_profile,
uint32_t initial_bitrate,
base::Optional<uint32_t> initial_framerate,
base::Optional<uint32_t> gop_length,
base::Optional<uint8_t> h264_output_level,
bool is_constrained_h264,
base::Optional<StorageType> storage_type,
ContentType content_type,
const std::vector<SpatialLayer>& spatial_layers)
: input_format(input_format),
input_visible_size(input_visible_size),
output_profile(output_profile),
initial_bitrate(initial_bitrate),
initial_framerate(initial_framerate.value_or(
VideoEncodeAccelerator::kDefaultFramerate)),
gop_length(gop_length),
h264_output_level(h264_output_level),
is_constrained_h264(is_constrained_h264),
storage_type(storage_type),
content_type(content_type),
spatial_layers(spatial_layers) {}
VideoEncodeAccelerator::Config::~Config() = default;
std::string VideoEncodeAccelerator::Config::AsHumanReadableString() const {
std::string str = base::StringPrintf(
"input_format: %s, input_visible_size: %s, output_profile: %s, "
"initial_bitrate: %u",
VideoPixelFormatToString(input_format).c_str(),
input_visible_size.ToString().c_str(),
GetProfileName(output_profile).c_str(), initial_bitrate);
if (initial_framerate) {
str += base::StringPrintf(", initial_framerate: %u",
initial_framerate.value());
}
if (gop_length)
str += base::StringPrintf(", gop_length: %u", gop_length.value());
if (VideoCodecProfileToVideoCodec(output_profile) == kCodecH264) {
if (h264_output_level) {
str += base::StringPrintf(", h264_output_level: %u",
h264_output_level.value());
}
str += base::StringPrintf(", is_constrained_h264: %u", is_constrained_h264);
}
if (spatial_layers.empty())
return str;
for (size_t i = 0; i < spatial_layers.size(); ++i) {
const auto& sl = spatial_layers[i];
str += base::StringPrintf(
", {SatialLayer#%zu: width=%" PRId32 ", height=%" PRId32
", bitrate_bps=%" PRIu32 ", framerate=%" PRId32
", max_qp=%u, num_of_temporal_layers=%u}",
i, sl.width, sl.height, sl.bitrate_bps, sl.framerate, sl.max_qp,
sl.num_of_temporal_layers);
}
return str;
}
bool VideoEncodeAccelerator::Config::HasTemporalLayer() const {
return std::any_of(
spatial_layers.begin(), spatial_layers.end(),
[](const SpatialLayer& sl) { return sl.num_of_temporal_layers > 1u; });
}
bool VideoEncodeAccelerator::Config::HasSpatialLayer() const {
return spatial_layers.size() > 1u;
}
void VideoEncodeAccelerator::Client::NotifyEncoderInfoChange(
const VideoEncoderInfo& info) {
// Do nothing if a client doesn't use the info.
}
VideoEncodeAccelerator::~VideoEncodeAccelerator() = default;
VideoEncodeAccelerator::SupportedProfile::SupportedProfile()
: profile(media::VIDEO_CODEC_PROFILE_UNKNOWN),
max_framerate_numerator(0),
max_framerate_denominator(0) {
}
VideoEncodeAccelerator::SupportedProfile::SupportedProfile(
VideoCodecProfile profile,
const gfx::Size& max_resolution,
uint32_t max_framerate_numerator,
uint32_t max_framerate_denominator)
: profile(profile),
max_resolution(max_resolution),
max_framerate_numerator(max_framerate_numerator),
max_framerate_denominator(max_framerate_denominator) {}
VideoEncodeAccelerator::SupportedProfile::~SupportedProfile() = default;
void VideoEncodeAccelerator::Flush(FlushCallback flush_callback) {
// TODO(owenlin): implements this https://crbug.com/755889.
NOTIMPLEMENTED();
std::move(flush_callback).Run(false);
}
bool VideoEncodeAccelerator::IsFlushSupported() {
return false;
}
void VideoEncodeAccelerator::RequestEncodingParametersChange(
const VideoBitrateAllocation& bitrate_allocation,
uint32_t framerate) {
RequestEncodingParametersChange(bitrate_allocation.GetSumBps(), framerate);
}
bool operator==(const Vp8Metadata& l, const Vp8Metadata& r) {
return l.non_reference == r.non_reference &&
l.temporal_idx == r.temporal_idx && l.layer_sync == r.layer_sync;
}
bool operator==(const Vp9Metadata& l, const Vp9Metadata& r) {
return l.has_reference == r.has_reference &&
l.temporal_up_switch == r.temporal_up_switch &&
l.temporal_idx == r.temporal_idx && l.p_diffs == r.p_diffs;
}
bool operator==(const BitstreamBufferMetadata& l,
const BitstreamBufferMetadata& r) {
return l.payload_size_bytes == r.payload_size_bytes &&
l.key_frame == r.key_frame && l.timestamp == r.timestamp &&
l.vp8 == r.vp8 && l.vp9 == r.vp9;
}
bool operator==(const VideoEncodeAccelerator::Config::SpatialLayer& l,
const VideoEncodeAccelerator::Config::SpatialLayer& r) {
return l.width == r.width && l.height == r.height &&
l.bitrate_bps == r.bitrate_bps && l.framerate == r.framerate &&
l.max_qp == r.max_qp &&
l.num_of_temporal_layers == r.num_of_temporal_layers;
}
bool operator==(const VideoEncodeAccelerator::Config& l,
const VideoEncodeAccelerator::Config& r) {
return l.input_format == r.input_format &&
l.input_visible_size == r.input_visible_size &&
l.output_profile == r.output_profile &&
l.initial_bitrate == r.initial_bitrate &&
l.initial_framerate == r.initial_framerate &&
l.gop_length == r.gop_length &&
l.h264_output_level == r.h264_output_level &&
l.storage_type == r.storage_type && l.content_type == r.content_type &&
l.spatial_layers == r.spatial_layers;
}
} // namespace media
namespace std {
void default_delete<media::VideoEncodeAccelerator>::operator()(
media::VideoEncodeAccelerator* vea) const {
vea->Destroy();
}
} // namespace std