blob: 854ad8cf7eadf1d5f3c979869810b232bbca502a [file] [log] [blame]
// Copyright 2016 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/cdm/simple_cdm_allocator.h"
#include <memory>
#include "base/bind.h"
#include "media/base/video_frame.h"
#include "media/cdm/cdm_helpers.h"
#include "media/cdm/simple_cdm_buffer.h"
#include "ui/gfx/geometry/rect.h"
#include "ui/gfx/geometry/size.h"
namespace media {
namespace {
class SimpleCdmVideoFrame final : public VideoFrameImpl {
public:
SimpleCdmVideoFrame() = default;
SimpleCdmVideoFrame(const SimpleCdmVideoFrame&) = delete;
SimpleCdmVideoFrame& operator=(const SimpleCdmVideoFrame&) = delete;
~SimpleCdmVideoFrame() override = default;
// VideoFrameImpl implementation.
scoped_refptr<media::VideoFrame> TransformToVideoFrame(
gfx::Size natural_size) override {
DCHECK(FrameBuffer());
cdm::Buffer* buffer = FrameBuffer();
gfx::Size frame_size(Size().width, Size().height);
scoped_refptr<media::VideoFrame> frame =
media::VideoFrame::WrapExternalYuvData(
PIXEL_FORMAT_I420, frame_size, gfx::Rect(frame_size), natural_size,
Stride(cdm::kYPlane), Stride(cdm::kUPlane), Stride(cdm::kVPlane),
buffer->Data() + PlaneOffset(cdm::kYPlane),
buffer->Data() + PlaneOffset(cdm::kUPlane),
buffer->Data() + PlaneOffset(cdm::kVPlane),
base::Microseconds(Timestamp()));
frame->set_color_space(MediaColorSpace().ToGfxColorSpace());
// The FrameBuffer needs to remain around until |frame| is destroyed.
frame->AddDestructionObserver(
base::BindOnce(&cdm::Buffer::Destroy, base::Unretained(buffer)));
// Clear FrameBuffer so that SimpleCdmVideoFrame no longer has a reference
// to it.
SetFrameBuffer(nullptr);
return frame;
}
};
} // namespace
SimpleCdmAllocator::SimpleCdmAllocator() = default;
SimpleCdmAllocator::~SimpleCdmAllocator() = default;
// Creates a new SimpleCdmBuffer on every request. It does not keep track of
// the memory allocated, so the caller is responsible for calling Destroy()
// on the buffer when it is no longer needed.
cdm::Buffer* SimpleCdmAllocator::CreateCdmBuffer(size_t capacity) {
if (!capacity)
return nullptr;
return SimpleCdmBuffer::Create(capacity);
}
// Creates a new SimpleCdmVideoFrame on every request.
std::unique_ptr<VideoFrameImpl> SimpleCdmAllocator::CreateCdmVideoFrame() {
return std::make_unique<SimpleCdmVideoFrame>();
}
} // namespace media