blob: 8e851b2fc0dfaa97d8a90a853e2f7268db0f1040 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
/* -*- 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 MOZILLA_GFX_RENDERCOMPOSITOR_EGL_H
#define MOZILLA_GFX_RENDERCOMPOSITOR_EGL_H
#include "GLTypes.h"
#include "mozilla/webrender/RenderCompositor.h"
namespace mozilla {
namespace wr {
class RenderCompositorEGL : public RenderCompositor {
public:
static UniquePtr<RenderCompositor> Create(
const RefPtr<widget::CompositorWidget>& aWidget, nsACString& aError);
explicit RenderCompositorEGL(const RefPtr<widget::CompositorWidget>& aWidget,
RefPtr<gl::GLContext>&& aGL);
virtual ~RenderCompositorEGL();
bool BeginFrame() override;
RenderedFrameId EndFrame(const nsTArray<DeviceIntRect>& aDirtyRects) final;
void Pause() override;
bool Resume() override;
bool IsPaused() override;
gl::GLContext* gl() const override { return mGL; }
bool MakeCurrent() override;
bool UseANGLE() const override { return false; }
LayoutDeviceIntSize GetBufferSize() override;
// Interface for partial present
bool UsePartialPresent() override;
bool RequestFullRender() override;
uint32_t GetMaxPartialPresentRects() override;
bool ShouldDrawPreviousPartialPresentRegions() override;
size_t GetBufferAge() const override;
void SetBufferDamageRegion(const wr::DeviceIntRect* aRects,
size_t aNumRects) override;
ipc::FileDescriptor GetAndResetReleaseFence() override;
protected:
EGLSurface CreateEGLSurface();
void DestroyEGLSurface();
RefPtr<gl::GLContext> mGL;
EGLSurface mEGLSurface;
// Whether we are in the process of handling a NEW_SURFACE error. On Android
// this is used to allow the widget an opportunity to recover from the first
// instance, before raising a WebRenderError on subsequent occurences.
bool mHandlingNewSurfaceError = false;
// FileDescriptor of release fence.
// Release fence is a fence that is used for waiting until usage/composite of
// AHardwareBuffer is ended. The fence is delivered to client side via
// ImageBridge. It is used only on android.
ipc::FileDescriptor mReleaseFenceFd;
};
} // namespace wr
} // namespace mozilla
#endif // MOZILLA_GFX_RENDERCOMPOSITOR_EGL_H
|