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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
/* -*- Mode: C++; tab-width: 4; 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/. */
#ifndef GPU_RenderPassEncoder_H_
#define GPU_RenderPassEncoder_H_
#include "mozilla/dom/TypedArray.h"
#include "ObjectModel.h"
namespace mozilla {
class ErrorResult;
namespace dom {
class DoubleSequenceOrGPUColorDict;
struct GPURenderPassDescriptor;
template <typename T>
class Sequence;
namespace binding_detail {
template <typename T>
class AutoSequence;
} // namespace binding_detail
} // namespace dom
namespace webgpu {
namespace ffi {
struct WGPURenderPass;
} // namespace ffi
class BindGroup;
class Buffer;
class CommandEncoder;
class RenderBundle;
class RenderPipeline;
class TextureView;
struct ffiWGPURenderPassDeleter {
void operator()(ffi::WGPURenderPass*);
};
class RenderPassEncoder final : public ObjectBase,
public ChildOf<CommandEncoder> {
public:
GPU_DECL_CYCLE_COLLECTION(RenderPassEncoder)
GPU_DECL_JS_WRAP(RenderPassEncoder)
RenderPassEncoder(CommandEncoder* const aParent,
const dom::GPURenderPassDescriptor& aDesc);
protected:
virtual ~RenderPassEncoder();
void Cleanup() {}
std::unique_ptr<ffi::WGPURenderPass, ffiWGPURenderPassDeleter> mPass;
// keep all the used objects alive while the pass is recorded
nsTArray<RefPtr<const BindGroup>> mUsedBindGroups;
nsTArray<RefPtr<const Buffer>> mUsedBuffers;
nsTArray<RefPtr<const RenderPipeline>> mUsedPipelines;
nsTArray<RefPtr<const TextureView>> mUsedTextureViews;
nsTArray<RefPtr<const RenderBundle>> mUsedRenderBundles;
public:
// programmable pass encoder
void SetBindGroup(uint32_t aSlot, const BindGroup& aBindGroup,
const dom::Sequence<uint32_t>& aDynamicOffsets);
// render encoder base
void SetPipeline(const RenderPipeline& aPipeline);
void SetIndexBuffer(const Buffer& aBuffer,
const dom::GPUIndexFormat& aIndexFormat, uint64_t aOffset,
uint64_t aSize);
void SetVertexBuffer(uint32_t aSlot, const Buffer& aBuffer, uint64_t aOffset,
uint64_t aSize);
void Draw(uint32_t aVertexCount, uint32_t aInstanceCount,
uint32_t aFirstVertex, uint32_t aFirstInstance);
void DrawIndexed(uint32_t aIndexCount, uint32_t aInstanceCount,
uint32_t aFirstIndex, int32_t aBaseVertex,
uint32_t aFirstInstance);
void DrawIndirect(const Buffer& aIndirectBuffer, uint64_t aIndirectOffset);
void DrawIndexedIndirect(const Buffer& aIndirectBuffer,
uint64_t aIndirectOffset);
// self
void SetViewport(float x, float y, float width, float height, float minDepth,
float maxDepth);
void SetScissorRect(uint32_t x, uint32_t y, uint32_t width, uint32_t height);
void SetBlendConstant(const dom::DoubleSequenceOrGPUColorDict& color);
void SetStencilReference(uint32_t reference);
void PushDebugGroup(const nsAString& aString);
void PopDebugGroup();
void InsertDebugMarker(const nsAString& aString);
void ExecuteBundles(
const dom::Sequence<OwningNonNull<RenderBundle>>& aBundles);
void End();
};
} // namespace webgpu
} // namespace mozilla
#endif // GPU_RenderPassEncoder_H_
|