mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
f2854bc42a
--HG-- extra : rebase_source : 13101216d6e5eccfb0a19c14b783b3878644b665
139 lines
3.4 KiB
C++
139 lines
3.4 KiB
C++
/* -*- 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 "GLContext.h" // for GLContext, etc
|
|
#include "SurfaceStream.h"
|
|
#include "mozilla/Assertions.h" // for MOZ_ASSERT, etc
|
|
#include "mozilla/layers/ISurfaceAllocator.h"
|
|
#include "mozilla/layers/TextureClientOGL.h"
|
|
#include "nsSize.h" // for nsIntSize
|
|
|
|
using namespace mozilla::gl;
|
|
|
|
namespace mozilla {
|
|
namespace layers {
|
|
|
|
class CompositableForwarder;
|
|
|
|
////////////////////////////////////////////////////////////////////////
|
|
// EGLImageTextureClient
|
|
|
|
EGLImageTextureClient::EGLImageTextureClient(TextureFlags aFlags,
|
|
EGLImage aImage,
|
|
gfx::IntSize aSize,
|
|
bool aInverted)
|
|
: TextureClient(aFlags)
|
|
, mImage(aImage)
|
|
, mSize(aSize)
|
|
, mIsLocked(false)
|
|
{
|
|
MOZ_ASSERT(XRE_GetProcessType() == GeckoProcessType_Default,
|
|
"Can't pass an `EGLImage` between processes.");
|
|
|
|
// Our data is always owned externally.
|
|
AddFlags(TextureFlags::DEALLOCATE_CLIENT);
|
|
|
|
if (aInverted) {
|
|
AddFlags(TextureFlags::NEEDS_Y_FLIP);
|
|
}
|
|
}
|
|
|
|
EGLImageTextureClient::~EGLImageTextureClient()
|
|
{
|
|
// Our data is always owned externally.
|
|
}
|
|
|
|
bool
|
|
EGLImageTextureClient::ToSurfaceDescriptor(SurfaceDescriptor& aOutDescriptor)
|
|
{
|
|
MOZ_ASSERT(IsValid());
|
|
MOZ_ASSERT(IsAllocated());
|
|
|
|
aOutDescriptor = EGLImageDescriptor((uintptr_t)mImage, mSize);
|
|
return true;
|
|
}
|
|
|
|
bool
|
|
EGLImageTextureClient::Lock(OpenMode mode)
|
|
{
|
|
MOZ_ASSERT(!mIsLocked);
|
|
if (!IsValid() || !IsAllocated()) {
|
|
return false;
|
|
}
|
|
mIsLocked = true;
|
|
return true;
|
|
}
|
|
|
|
void
|
|
EGLImageTextureClient::Unlock()
|
|
{
|
|
MOZ_ASSERT(mIsLocked);
|
|
mIsLocked = false;
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////
|
|
// SurfaceTextureClient
|
|
|
|
#ifdef MOZ_WIDGET_ANDROID
|
|
|
|
SurfaceTextureClient::SurfaceTextureClient(TextureFlags aFlags,
|
|
nsSurfaceTexture* aSurfTex,
|
|
gfx::IntSize aSize,
|
|
bool aInverted)
|
|
: TextureClient(aFlags)
|
|
, mSurfTex(aSurfTex)
|
|
, mSize(aSize)
|
|
, mIsLocked(false)
|
|
{
|
|
MOZ_ASSERT(XRE_GetProcessType() == GeckoProcessType_Default,
|
|
"Can't pass pointers between processes.");
|
|
|
|
// Our data is always owned externally.
|
|
AddFlags(TextureFlags::DEALLOCATE_CLIENT);
|
|
|
|
if (aInverted) {
|
|
AddFlags(TextureFlags::NEEDS_Y_FLIP);
|
|
}
|
|
}
|
|
|
|
SurfaceTextureClient::~SurfaceTextureClient()
|
|
{
|
|
// Our data is always owned externally.
|
|
}
|
|
|
|
bool
|
|
SurfaceTextureClient::ToSurfaceDescriptor(SurfaceDescriptor& aOutDescriptor)
|
|
{
|
|
MOZ_ASSERT(IsValid());
|
|
MOZ_ASSERT(IsAllocated());
|
|
|
|
aOutDescriptor = SurfaceTextureDescriptor((uintptr_t)mSurfTex.get(),
|
|
mSize);
|
|
return true;
|
|
}
|
|
|
|
bool
|
|
SurfaceTextureClient::Lock(OpenMode mode)
|
|
{
|
|
MOZ_ASSERT(!mIsLocked);
|
|
if (!IsValid() || !IsAllocated()) {
|
|
return false;
|
|
}
|
|
mIsLocked = true;
|
|
return true;
|
|
}
|
|
|
|
void
|
|
SurfaceTextureClient::Unlock()
|
|
{
|
|
MOZ_ASSERT(mIsLocked);
|
|
mIsLocked = false;
|
|
}
|
|
|
|
#endif // MOZ_WIDGET_ANDROID
|
|
|
|
} // namespace
|
|
} // namespace
|