From 5f8de423f190bbb79a62f804151bc24824fa32d8 Mon Sep 17 00:00:00 2001 From: "Matt A. Tobin" Date: Fri, 2 Feb 2018 04:16:08 -0500 Subject: Add m-esr52 at 52.6.0 --- gfx/layers/ipc/VideoBridgeParent.cpp | 125 +++++++++++++++++++++++++++++++++++ 1 file changed, 125 insertions(+) create mode 100644 gfx/layers/ipc/VideoBridgeParent.cpp (limited to 'gfx/layers/ipc/VideoBridgeParent.cpp') diff --git a/gfx/layers/ipc/VideoBridgeParent.cpp b/gfx/layers/ipc/VideoBridgeParent.cpp new file mode 100644 index 000000000..fce2184c8 --- /dev/null +++ b/gfx/layers/ipc/VideoBridgeParent.cpp @@ -0,0 +1,125 @@ +/* vim: set ts=2 sw=2 et tw=80: */ +/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 2 -*- + * 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 "VideoBridgeParent.h" +#include "mozilla/layers/TextureHost.h" + +namespace mozilla { +namespace layers { + +using namespace mozilla::ipc; +using namespace mozilla::gfx; +using namespace mozilla::media; + + +static VideoBridgeParent* sVideoBridgeSingleton; + +VideoBridgeParent::VideoBridgeParent() + : mClosed(false) +{ + mSelfRef = this; + sVideoBridgeSingleton = this; +} + +VideoBridgeParent::~VideoBridgeParent() +{ + sVideoBridgeSingleton = nullptr; +} + +/* static */ VideoBridgeParent* +VideoBridgeParent::GetSingleton() +{ + return sVideoBridgeSingleton; +} + +TextureHost* +VideoBridgeParent::LookupTexture(uint64_t aSerial) +{ + return TextureHost::AsTextureHost(mTextureMap[aSerial]); +} + +void +VideoBridgeParent::ActorDestroy(ActorDestroyReason aWhy) +{ + // Can't alloc/dealloc shmems from now on. + mClosed = true; +} + +void +VideoBridgeParent::DeallocPVideoBridgeParent() +{ + mSelfRef = nullptr; +} + +PTextureParent* +VideoBridgeParent::AllocPTextureParent(const SurfaceDescriptor& aSharedData, + const LayersBackend& aLayersBackend, + const TextureFlags& aFlags, + const uint64_t& aSerial) +{ + PTextureParent* parent = + TextureHost::CreateIPDLActor(this, aSharedData, aLayersBackend, aFlags, aSerial); + mTextureMap[aSerial] = parent; + return parent; +} + +bool +VideoBridgeParent::DeallocPTextureParent(PTextureParent* actor) +{ + mTextureMap.erase(TextureHost::GetTextureSerial(actor)); + return TextureHost::DestroyIPDLActor(actor); +} + +void +VideoBridgeParent::SendAsyncMessage(const InfallibleTArray& aMessage) +{ + MOZ_ASSERT(false, "AsyncMessages not supported"); +} + +bool +VideoBridgeParent::AllocShmem(size_t aSize, + ipc::SharedMemory::SharedMemoryType aType, + ipc::Shmem* aShmem) +{ + if (mClosed) { + return false; + } + return PVideoBridgeParent::AllocShmem(aSize, aType, aShmem); +} + +bool +VideoBridgeParent::AllocUnsafeShmem(size_t aSize, + ipc::SharedMemory::SharedMemoryType aType, + ipc::Shmem* aShmem) +{ + if (mClosed) { + return false; + } + return PVideoBridgeParent::AllocUnsafeShmem(aSize, aType, aShmem); +} + +void +VideoBridgeParent::DeallocShmem(ipc::Shmem& aShmem) +{ + if (mClosed) { + return; + } + PVideoBridgeParent::DeallocShmem(aShmem); +} + +bool +VideoBridgeParent::IsSameProcess() const +{ + return OtherPid() == base::GetCurrentProcId(); +} + +void +VideoBridgeParent::NotifyNotUsed(PTextureParent* aTexture, uint64_t aTransactionId) +{ +} + +} // namespace layers +} // namespace mozilla -- cgit v1.2.3