gpu: implement ComputePassEncoder.dispatchIndirect
Signed-off-by: Stephen Gutekanst <stephen@hexops.com>
This commit is contained in:
parent
061ca10f78
commit
fad7c847d0
2 changed files with 24 additions and 2 deletions
|
|
@ -2,6 +2,7 @@ const ComputePassTimestampWrite = @import("structs.zig").ComputePassTimestampWri
|
||||||
const ComputePipeline = @import("ComputePipeline.zig");
|
const ComputePipeline = @import("ComputePipeline.zig");
|
||||||
const QuerySet = @import("QuerySet.zig");
|
const QuerySet = @import("QuerySet.zig");
|
||||||
const BindGroup = @import("BindGroup.zig");
|
const BindGroup = @import("BindGroup.zig");
|
||||||
|
const Buffer = @import("Buffer.zig");
|
||||||
|
|
||||||
const ComputePassEncoder = @This();
|
const ComputePassEncoder = @This();
|
||||||
|
|
||||||
|
|
@ -14,8 +15,7 @@ pub const VTable = struct {
|
||||||
reference: fn (ptr: *anyopaque) void,
|
reference: fn (ptr: *anyopaque) void,
|
||||||
release: fn (ptr: *anyopaque) void,
|
release: fn (ptr: *anyopaque) void,
|
||||||
dispatch: fn (ptr: *anyopaque, workgroup_count_x: u32, workgroup_count_y: u32, workgroup_count_z: u32) void,
|
dispatch: fn (ptr: *anyopaque, workgroup_count_x: u32, workgroup_count_y: u32, workgroup_count_z: u32) void,
|
||||||
// dispatchIndirect: fn (ptr: *anyopaque, indirect_buffer: Buffer, indirect_offset: u64) void,
|
dispatchIndirect: fn (ptr: *anyopaque, indirect_buffer: Buffer, indirect_offset: u64) void,
|
||||||
// WGPU_EXPORT void wgpuComputePassEncoderDispatchIndirect(WGPUComputePassEncoder computePassEncoder, WGPUBuffer indirectBuffer, uint64_t indirectOffset);
|
|
||||||
end: fn (ptr: *anyopaque) void,
|
end: fn (ptr: *anyopaque) void,
|
||||||
insertDebugMarker: fn (ptr: *anyopaque, marker_label: [*:0]const u8) void,
|
insertDebugMarker: fn (ptr: *anyopaque, marker_label: [*:0]const u8) void,
|
||||||
popDebugGroup: fn (ptr: *anyopaque) void,
|
popDebugGroup: fn (ptr: *anyopaque) void,
|
||||||
|
|
@ -43,6 +43,14 @@ pub inline fn dispatch(
|
||||||
enc.vtable.dispatch(enc.ptr, workgroup_count_x, workgroup_count_y, workgroup_count_z);
|
enc.vtable.dispatch(enc.ptr, workgroup_count_x, workgroup_count_y, workgroup_count_z);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub inline fn dispatchIndirect(
|
||||||
|
enc: ComputePassEncoder,
|
||||||
|
indirect_buffer: Buffer,
|
||||||
|
indirect_offset: u64,
|
||||||
|
) void {
|
||||||
|
enc.vtable.dispatchIndirect(enc.ptr, indirect_buffer, indirect_offset);
|
||||||
|
}
|
||||||
|
|
||||||
pub inline fn end(enc: ComputePassEncoder) void {
|
pub inline fn end(enc: ComputePassEncoder) void {
|
||||||
enc.vtable.end(enc.ptr);
|
enc.vtable.end(enc.ptr);
|
||||||
}
|
}
|
||||||
|
|
@ -90,6 +98,7 @@ test {
|
||||||
_ = reference;
|
_ = reference;
|
||||||
_ = release;
|
_ = release;
|
||||||
_ = dispatch;
|
_ = dispatch;
|
||||||
|
_ = dispatchIndirect;
|
||||||
_ = end;
|
_ = end;
|
||||||
_ = insertDebugMarker;
|
_ = insertDebugMarker;
|
||||||
_ = popDebugGroup;
|
_ = popDebugGroup;
|
||||||
|
|
|
||||||
|
|
@ -1625,6 +1625,19 @@ const compute_pass_encoder_vtable = ComputePassEncoder.VTable{
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}).dispatch,
|
}).dispatch,
|
||||||
|
.dispatchIndirect = (struct {
|
||||||
|
pub fn dispatchIndirect(
|
||||||
|
ptr: *anyopaque,
|
||||||
|
indirect_buffer: Buffer,
|
||||||
|
indirect_offset: u64,
|
||||||
|
) void {
|
||||||
|
c.wgpuComputePassEncoderDispatchIndirect(
|
||||||
|
@ptrCast(c.WGPUComputePassEncoder, ptr),
|
||||||
|
@ptrCast(c.WGPUBuffer, indirect_buffer.ptr),
|
||||||
|
indirect_offset,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}).dispatchIndirect,
|
||||||
.end = (struct {
|
.end = (struct {
|
||||||
pub fn end(ptr: *anyopaque) void {
|
pub fn end(ptr: *anyopaque) void {
|
||||||
c.wgpuComputePassEncoderEnd(@ptrCast(c.WGPUComputePassEncoder, ptr));
|
c.wgpuComputePassEncoderEnd(@ptrCast(c.WGPUComputePassEncoder, ptr));
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue