/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set ts=8 sts=2 et sw=2 tw=80: */ /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include "GPUVideoTextureClient.h" #include "GPUVideoImage.h" #include "mozilla/gfx/2D.h" namespace mozilla { namespace layers { using namespace gfx; GPUVideoTextureData::GPUVideoTextureData(IGPUVideoSurfaceManager* aManager, const SurfaceDescriptorGPUVideo& aSD, const gfx::IntSize& aSize) : mManager(aManager), mSD(aSD), mSize(aSize) {} GPUVideoTextureData::~GPUVideoTextureData() = default; bool GPUVideoTextureData::Serialize(SurfaceDescriptor& aOutDescriptor) { aOutDescriptor = mSD; return true; } void GPUVideoTextureData::FillInfo(TextureData::Info& aInfo) const { aInfo.size = mSize; // TODO: We should probably try do better for this. // layers::Image doesn't expose a format, so it's hard // to figure out in VideoDecoderParent. aInfo.format = SurfaceFormat::B8G8R8X8; aInfo.hasSynchronization = false; aInfo.supportsMoz2D = false; aInfo.canExposeMappedData = false; } already_AddRefed<SourceSurface> GPUVideoTextureData::GetAsSourceSurface() { return mManager->Readback(mSD); } void GPUVideoTextureData::Deallocate(LayersIPCChannel* aAllocator) { mManager->DeallocateSurfaceDescriptor(mSD); mSD = SurfaceDescriptorGPUVideo(); } void GPUVideoTextureData::Forget(LayersIPCChannel* aAllocator) { // We always need to manually deallocate on the client side. // Ideally we'd set up our TextureClient with the DEALLOCATE_CLIENT // flag, but that forces texture destruction to be synchronous. // Instead let's just deallocate from here as well. Deallocate(aAllocator); } } // namespace layers } // namespace mozilla