forked from mirrors/gecko-dev
WebGPU uses CompositableInProcessManager to push TextureHost directly from WebGPUParent to WebRender. But CompositableInProcessManager plumbing has a problem and caused Bug 1805209. gecko already has a similar mechanism, called RemoteTextureMap. It is used in oop WebGL. If WebGPU uses RemoteTextureMap instead of CompositableInProcessManager, both WebGPU and oop WebGL use same mechanism. WebGPUParent pushes a new texture to RemoteTextureMap. The RemoteTextureMap notifies the pushed texture to WebRenderImageHost. Before the change, only one TextureHost is used for one swap chain. With the change, multiple TextureHosts are used for one swap chain with recycling. The changes are followings. - Use RemoteTextureMap instead of CompositableInProcessManager. - Use RemoteTextureOwnerId instead of CompositableHandle. - Use WebRenderCanvasData instead of WebRenderInProcessImageData. - Add remote texture pushed callback functionality to RemoteTextureMap. With it, RemoteTextureMap notifies a new pushed remote texture to WebRenderImageHost. - Remove CompositableInProcessManager. Differential Revision: https://phabricator.services.mozilla.com/D164890
151 lines
4.7 KiB
C++
151 lines
4.7 KiB
C++
/* -*- 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/. */
|
|
|
|
#ifndef GFX_CANVASRENDERER_H
|
|
#define GFX_CANVASRENDERER_H
|
|
|
|
#include <memory> // for weak_ptr
|
|
#include <stdint.h> // for uint32_t
|
|
#include "GLContextTypes.h" // for GLContext
|
|
#include "gfxContext.h" // for gfxContext, etc
|
|
#include "gfxTypes.h"
|
|
#include "gfxPlatform.h" // for gfxImageFormat
|
|
#include "mozilla/Assertions.h" // for MOZ_ASSERT, etc
|
|
#include "mozilla/Preferences.h" // for Preferences
|
|
#include "mozilla/RefPtr.h" // for RefPtr
|
|
#include "mozilla/gfx/2D.h" // for DrawTarget
|
|
#include "mozilla/Maybe.h"
|
|
#include "mozilla/mozalloc.h" // for operator delete, etc
|
|
#include "mozilla/WeakPtr.h" // for WeakPtr
|
|
#include "nsISupportsImpl.h" // for MOZ_COUNT_CTOR, etc
|
|
#include "nsICanvasRenderingContextInternal.h"
|
|
|
|
namespace mozilla {
|
|
namespace layers {
|
|
|
|
class KnowsCompositor;
|
|
class PersistentBufferProvider;
|
|
class WebRenderCanvasRendererAsync;
|
|
|
|
TextureType TexTypeForWebgl(KnowsCompositor*);
|
|
|
|
struct CanvasRendererData final {
|
|
CanvasRendererData();
|
|
~CanvasRendererData();
|
|
|
|
WeakPtr<nsICanvasRenderingContextInternal> mContext;
|
|
|
|
// The size of the canvas content
|
|
gfx::IntSize mSize = {0, 0};
|
|
|
|
bool mDoPaintCallbacks = false;
|
|
bool mIsOpaque = true;
|
|
bool mIsAlphaPremult = true;
|
|
|
|
gl::OriginPos mOriginPos = gl::OriginPos::TopLeft;
|
|
|
|
// Used in remote texture push callback
|
|
Maybe<RemoteTextureOwnerId> mRemoteTextureOwnerIdOfPushCallback = Nothing();
|
|
|
|
nsICanvasRenderingContextInternal* GetContext() const {
|
|
return mContext.get();
|
|
}
|
|
};
|
|
|
|
// Based class which used for canvas rendering. There are many derived classes
|
|
// for different purposes. such as:
|
|
//
|
|
// ShareableCanvasRenderer provides IPC capabilities that allow sending canvas
|
|
// content over IPC. This is pure virtual class because the IPC handling is
|
|
// different in different LayerManager. So that we have following classes
|
|
// inherit ShareableCanvasRenderer.
|
|
//
|
|
// WebRenderCanvasRenderer inherits ShareableCanvasRenderer and provides all
|
|
// functionality that WebRender uses.
|
|
// WebRenderCanvasRendererAsync inherits WebRenderCanvasRenderer and be used in
|
|
// layers-free mode of WebRender.
|
|
//
|
|
// class diagram:
|
|
//
|
|
// +--------------+
|
|
// |CanvasRenderer|
|
|
// +-------+------+
|
|
// ^
|
|
// |
|
|
// +-----------+-----------+
|
|
// |ShareableCanvasRenderer|
|
|
// +-----+-----------------+
|
|
// ^
|
|
// |
|
|
// +-----------+-----------+
|
|
// |WebRenderCanvasRenderer|
|
|
// +-----------+-----------+
|
|
// ^
|
|
// |
|
|
// +-------------+--------------+
|
|
// |WebRenderCanvasRendererAsync|
|
|
// +----------------------------+
|
|
|
|
class BorrowedSourceSurface final {
|
|
public:
|
|
const WeakPtr<PersistentBufferProvider> mReturnTo;
|
|
const RefPtr<gfx::SourceSurface> mSurf; /// non-null
|
|
|
|
BorrowedSourceSurface(PersistentBufferProvider*, RefPtr<gfx::SourceSurface>);
|
|
~BorrowedSourceSurface();
|
|
};
|
|
|
|
// -
|
|
|
|
class CanvasRenderer : public RefCounted<CanvasRenderer> {
|
|
friend class CanvasRendererSourceSurface;
|
|
|
|
public:
|
|
MOZ_DECLARE_REFCOUNTED_TYPENAME(CanvasRenderer)
|
|
|
|
private:
|
|
bool mDirty = false;
|
|
|
|
protected:
|
|
CanvasRendererData mData;
|
|
|
|
public:
|
|
explicit CanvasRenderer();
|
|
virtual ~CanvasRenderer();
|
|
|
|
public:
|
|
virtual void Initialize(const CanvasRendererData&);
|
|
virtual bool IsDataValid(const CanvasRendererData&) const;
|
|
|
|
virtual void ClearCachedResources() {}
|
|
virtual void DisconnectClient() {}
|
|
|
|
const gfx::IntSize& GetSize() const { return mData.mSize; }
|
|
bool IsOpaque() const { return mData.mIsOpaque; }
|
|
bool YIsDown() const { return mData.mOriginPos == gl::OriginPos::TopLeft; }
|
|
Maybe<RemoteTextureOwnerId> GetRemoteTextureOwnerIdOfPushCallback() {
|
|
return mData.mRemoteTextureOwnerIdOfPushCallback;
|
|
}
|
|
|
|
void SetDirty() { mDirty = true; }
|
|
void ResetDirty() { mDirty = false; }
|
|
bool IsDirty() const { return mDirty; }
|
|
|
|
virtual WebRenderCanvasRendererAsync* AsWebRenderCanvasRendererAsync() {
|
|
return nullptr;
|
|
}
|
|
|
|
std::shared_ptr<BorrowedSourceSurface> BorrowSnapshot(
|
|
bool requireAlphaPremult = true) const;
|
|
|
|
void FirePreTransactionCallback() const;
|
|
void FireDidTransactionCallback() const;
|
|
};
|
|
|
|
} // namespace layers
|
|
} // namespace mozilla
|
|
|
|
#endif
|