Skip to content

Commit

Permalink
Bug 1817541 - Update load and store op handling to match webgpu spec …
Browse files Browse the repository at this point in the history
…changes. r=gfx-reviewers,webidl,jimb,smaug

Differential Revision: https://phabricator.services.mozilla.com/D174802
  • Loading branch information
kdashg committed Apr 15, 2023
1 parent bead76a commit a3b2d1b
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 47 deletions.
96 changes: 55 additions & 41 deletions dom/webgpu/RenderPassEncoder.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,27 +26,31 @@ void ScopedFfiRenderTraits::release(ffi::WGPURenderPass* raw) {
}
}

ffi::WGPULoadOp ConvertLoadOp(const dom::GPULoadOp& aOp) {
static ffi::WGPULoadOp ConvertLoadOp(const dom::GPULoadOp& aOp) {
switch (aOp) {
case dom::GPULoadOp::Load:
return ffi::WGPULoadOp_Load;
default:
MOZ_CRASH("Unexpected load op");
case dom::GPULoadOp::Clear:
return ffi::WGPULoadOp_Clear;
case dom::GPULoadOp::EndGuard_:
break;
}
MOZ_CRASH("bad GPULoadOp");
}

ffi::WGPUStoreOp ConvertStoreOp(const dom::GPUStoreOp& aOp) {
static ffi::WGPUStoreOp ConvertStoreOp(const dom::GPUStoreOp& aOp) {
switch (aOp) {
case dom::GPUStoreOp::Store:
return ffi::WGPUStoreOp_Store;
case dom::GPUStoreOp::Discard:
return ffi::WGPUStoreOp_Discard;
default:
MOZ_CRASH("Unexpected load op");
case dom::GPUStoreOp::EndGuard_:
break;
}
MOZ_CRASH("bad GPUStoreOp");
}

ffi::WGPUColor ConvertColor(const dom::Sequence<double>& aSeq) {
static ffi::WGPUColor ConvertColor(const dom::Sequence<double>& aSeq) {
ffi::WGPUColor color;
color.r = aSeq.SafeElementAt(0, 0.0);
color.g = aSeq.SafeElementAt(1, 0.0);
Expand All @@ -55,21 +59,34 @@ ffi::WGPUColor ConvertColor(const dom::Sequence<double>& aSeq) {
return color;
}

ffi::WGPUColor ConvertColor(const dom::GPUColorDict& aColor) {
static ffi::WGPUColor ConvertColor(const dom::GPUColorDict& aColor) {
ffi::WGPUColor color = {aColor.mR, aColor.mG, aColor.mB, aColor.mA};
return color;
}

ffi::WGPUColor ConvertColor(const dom::DoubleSequenceOrGPUColorDict& aColor) {
static ffi::WGPUColor ConvertColor(
const dom::DoubleSequenceOrGPUColorDict& aColor) {
if (aColor.IsDoubleSequence()) {
return ConvertColor(aColor.GetAsDoubleSequence());
} else if (aColor.IsGPUColorDict()) {
}
if (aColor.IsGPUColorDict()) {
return ConvertColor(aColor.GetAsGPUColorDict());
}
MOZ_ASSERT_UNREACHABLE(
"Unexpected dom::DoubleSequenceOrGPUColorDict variant");
return ffi::WGPUColor();
}
static ffi::WGPUColor ConvertColor(
const dom::OwningDoubleSequenceOrGPUColorDict& aColor) {
if (aColor.IsDoubleSequence()) {
return ConvertColor(aColor.GetAsDoubleSequence());
}
if (aColor.IsGPUColorDict()) {
return ConvertColor(aColor.GetAsGPUColorDict());
} else {
MOZ_ASSERT_UNREACHABLE(
"Unexpected dom::DoubleSequenceOrGPUColorDict variant");
return ffi::WGPUColor();
}
MOZ_ASSERT_UNREACHABLE(
"Unexpected dom::OwningDoubleSequenceOrGPUColorDict variant");
return ffi::WGPUColor();
}

ffi::WGPURenderPass* BeginRenderPass(
Expand All @@ -84,26 +101,31 @@ ffi::WGPURenderPass* BeginRenderPass(
const auto& dsa = aDesc.mDepthStencilAttachment.Value();
dsDesc.view = dsa.mView->mId;

if (dsa.mDepthLoadValue.IsFloat()) {
dsDesc.depth.load_op = ffi::WGPULoadOp_Clear;
dsDesc.depth.clear_value = dsa.mDepthLoadValue.GetAsFloat();
// -

if (dsa.mDepthClearValue.WasPassed()) {
dsDesc.depth.clear_value = dsa.mDepthClearValue.Value();
}
if (dsa.mDepthLoadOp.WasPassed()) {
dsDesc.depth.load_op = ConvertLoadOp(dsa.mDepthLoadOp.Value());
}
if (dsa.mDepthLoadValue.IsGPULoadOp()) {
dsDesc.depth.load_op =
ConvertLoadOp(dsa.mDepthLoadValue.GetAsGPULoadOp());
if (dsa.mDepthStoreOp.WasPassed()) {
dsDesc.depth.store_op = ConvertStoreOp(dsa.mDepthStoreOp.Value());
}
dsDesc.depth.store_op = ConvertStoreOp(dsa.mDepthStoreOp);
dsDesc.depth.read_only = dsa.mDepthReadOnly;

if (dsa.mStencilLoadValue.IsRangeEnforcedUnsignedLong()) {
dsDesc.stencil.load_op = ffi::WGPULoadOp_Clear;
dsDesc.stencil.clear_value =
dsa.mStencilLoadValue.GetAsRangeEnforcedUnsignedLong();
// -

dsDesc.stencil.clear_value = dsa.mStencilClearValue;
if (dsa.mStencilLoadOp.WasPassed()) {
dsDesc.stencil.load_op = ConvertLoadOp(dsa.mStencilLoadOp.Value());
}
if (dsa.mStencilLoadValue.IsGPULoadOp()) {
dsDesc.stencil.load_op =
ConvertLoadOp(dsa.mStencilLoadValue.GetAsGPULoadOp());
if (dsa.mStencilStoreOp.WasPassed()) {
dsDesc.stencil.store_op = ConvertStoreOp(dsa.mStencilStoreOp.Value());
}
dsDesc.stencil.store_op = ConvertStoreOp(dsa.mStencilStoreOp);
dsDesc.stencil.read_only = dsa.mStencilReadOnly;

// -

desc.depth_stencil_attachment = &dsDesc;
}
Expand All @@ -128,18 +150,10 @@ ffi::WGPURenderPass* BeginRenderPass(
if (ca.mResolveTarget.WasPassed()) {
cd.resolve_target = ca.mResolveTarget.Value().mId;
}
if (ca.mLoadValue.IsGPULoadOp()) {
cd.channel.load_op = ConvertLoadOp(ca.mLoadValue.GetAsGPULoadOp());
} else {
cd.channel.load_op = ffi::WGPULoadOp_Clear;
if (ca.mLoadValue.IsDoubleSequence()) {
cd.channel.clear_value =
ConvertColor(ca.mLoadValue.GetAsDoubleSequence());
}
if (ca.mLoadValue.IsGPUColorDict()) {
cd.channel.clear_value =
ConvertColor(ca.mLoadValue.GetAsGPUColorDict());
}

cd.channel.load_op = ConvertLoadOp(ca.mLoadOp);
if (ca.mClearValue.WasPassed()) {
cd.channel.clear_value = ConvertColor(ca.mClearValue.Value());
}
}

Expand Down
1 change: 1 addition & 0 deletions dom/webgpu/moz.build
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ UNIFIED_SOURCES += [

if CONFIG["CC_TYPE"] in ("clang", "clang-cl"):
CXXFLAGS += ["-Werror=implicit-int-conversion"]
CXXFLAGS += ["-Werror=switch"]

include("/ipc/chromium/chromium-config.mozbuild")

Expand Down
18 changes: 12 additions & 6 deletions dom/webidl/WebGPU.webidl
Original file line number Diff line number Diff line change
Expand Up @@ -968,22 +968,28 @@ dictionary GPURenderPassColorAttachment {
required GPUTextureView view;
GPUTextureView resolveTarget;

required (GPULoadOp or GPUColor) loadValue;
GPUColor clearValue;
required GPULoadOp loadOp;
required GPUStoreOp storeOp;
};

dictionary GPURenderPassDepthStencilAttachment {
required GPUTextureView view;

required (GPULoadOp or float) depthLoadValue;
required GPUStoreOp depthStoreOp;
float depthClearValue;
GPULoadOp depthLoadOp;
GPUStoreOp depthStoreOp;
boolean depthReadOnly = false;

required (GPULoadOp or GPUStencilValue) stencilLoadValue;
required GPUStoreOp stencilStoreOp;
GPUStencilValue stencilClearValue = 0;
GPULoadOp stencilLoadOp;
GPUStoreOp stencilStoreOp;
boolean stencilReadOnly = false;
};

enum GPULoadOp {
"load"
"load",
"clear"
};

enum GPUStoreOp {
Expand Down

0 comments on commit a3b2d1b

Please sign in to comment.