WebRTC combines VP9 SVC spatial layer frames into superframe and passes it to a decoder. The chromium HW VP9 decoder (wrapper) needs to know location of each spatial layer frame in the frame buffer. To provide decoder with such information this CL: - Adds Set/SpatialLayerFrameSize methods to EncodedImage. - Sets size of each spatial layer frame on superframe at assembly stage. Bug: webrtc:10495 Change-Id: I68c3c0d668c67dfa1740e004059d860dd98f67f9 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/136922 Reviewed-by: Karl Wiberg <kwiberg@webrtc.org> Reviewed-by: Ilya Nikolaevskiy <ilnik@webrtc.org> Commit-Queue: Sergey Silkin <ssilkin@webrtc.org> Cr-Commit-Position: refs/heads/master@{#28032}
65 lines
2.0 KiB
C++
65 lines
2.0 KiB
C++
/*
|
|
* Copyright (c) 2012 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.
|
|
*/
|
|
|
|
#include "api/video/encoded_image.h"
|
|
|
|
#include <string.h>
|
|
|
|
namespace webrtc {
|
|
|
|
EncodedImage::EncodedImage() : EncodedImage(nullptr, 0, 0) {}
|
|
|
|
EncodedImage::EncodedImage(EncodedImage&&) = default;
|
|
EncodedImage::EncodedImage(const EncodedImage&) = default;
|
|
|
|
EncodedImage::EncodedImage(uint8_t* buffer, size_t size, size_t capacity)
|
|
: size_(size), buffer_(buffer), capacity_(capacity) {}
|
|
|
|
EncodedImage::~EncodedImage() = default;
|
|
|
|
EncodedImage& EncodedImage::operator=(EncodedImage&&) = default;
|
|
EncodedImage& EncodedImage::operator=(const EncodedImage&) = default;
|
|
|
|
void EncodedImage::Retain() {
|
|
if (buffer_) {
|
|
encoded_data_.SetData(buffer_, size_);
|
|
buffer_ = nullptr;
|
|
}
|
|
}
|
|
|
|
void EncodedImage::SetEncodeTime(int64_t encode_start_ms,
|
|
int64_t encode_finish_ms) {
|
|
timing_.encode_start_ms = encode_start_ms;
|
|
timing_.encode_finish_ms = encode_finish_ms;
|
|
}
|
|
|
|
absl::optional<size_t> EncodedImage::SpatialLayerFrameSize(
|
|
int spatial_index) const {
|
|
RTC_DCHECK_GE(spatial_index, 0);
|
|
RTC_DCHECK_LE(spatial_index, spatial_index_.value_or(0));
|
|
|
|
auto it = spatial_layer_frame_size_bytes_.find(spatial_index);
|
|
if (it == spatial_layer_frame_size_bytes_.end()) {
|
|
return absl::nullopt;
|
|
}
|
|
|
|
return it->second;
|
|
}
|
|
|
|
void EncodedImage::SetSpatialLayerFrameSize(int spatial_index,
|
|
size_t size_bytes) {
|
|
RTC_DCHECK_GE(spatial_index, 0);
|
|
RTC_DCHECK_LE(spatial_index, spatial_index_.value_or(0));
|
|
RTC_DCHECK_GE(size_bytes, 0);
|
|
spatial_layer_frame_size_bytes_[spatial_index] = size_bytes;
|
|
}
|
|
|
|
} // namespace webrtc
|