gpu: implement Device.createBuffer
Signed-off-by: Stephen Gutekanst <stephen@hexops.com>
This commit is contained in:
parent
13fcf8aac5
commit
155c291c8e
3 changed files with 17 additions and 3 deletions
|
|
@ -78,7 +78,8 @@ pub inline fn unmap(buf: Buffer) void {
|
||||||
buf.vtable.unmap(buf.ptr);
|
buf.vtable.unmap(buf.ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub const Descriptor = struct {
|
pub const Descriptor = extern struct {
|
||||||
|
reserved: ?*anyopaque = null,
|
||||||
label: ?[*:0]const u8 = null,
|
label: ?[*:0]const u8 = null,
|
||||||
usage: BufferUsage,
|
usage: BufferUsage,
|
||||||
size: usize,
|
size: usize,
|
||||||
|
|
|
||||||
|
|
@ -18,6 +18,7 @@ const CommandEncoder = @import("CommandEncoder.zig");
|
||||||
const ComputePipeline = @import("ComputePipeline.zig");
|
const ComputePipeline = @import("ComputePipeline.zig");
|
||||||
const BindGroup = @import("BindGroup.zig");
|
const BindGroup = @import("BindGroup.zig");
|
||||||
const BindGroupLayout = @import("BindGroupLayout.zig");
|
const BindGroupLayout = @import("BindGroupLayout.zig");
|
||||||
|
const Buffer = @import("Buffer.zig");
|
||||||
|
|
||||||
const Device = @This();
|
const Device = @This();
|
||||||
|
|
||||||
|
|
@ -31,8 +32,7 @@ pub const VTable = struct {
|
||||||
release: fn (ptr: *anyopaque) void,
|
release: fn (ptr: *anyopaque) void,
|
||||||
createBindGroup: fn (ptr: *anyopaque, descriptor: *const BindGroup.Descriptor) BindGroup,
|
createBindGroup: fn (ptr: *anyopaque, descriptor: *const BindGroup.Descriptor) BindGroup,
|
||||||
createBindGroupLayout: fn (ptr: *anyopaque, descriptor: *const BindGroupLayout.Descriptor) BindGroupLayout,
|
createBindGroupLayout: fn (ptr: *anyopaque, descriptor: *const BindGroupLayout.Descriptor) BindGroupLayout,
|
||||||
// createBuffer: fn (ptr: *anyopaque, descriptor: *const Buffer.Descriptor) Buffer,
|
createBuffer: fn (ptr: *anyopaque, descriptor: *const Buffer.Descriptor) Buffer,
|
||||||
// WGPU_EXPORT WGPUBuffer wgpuDeviceCreateBuffer(WGPUDevice device, WGPUBufferDescriptor const * descriptor);
|
|
||||||
createCommandEncoder: fn (ptr: *anyopaque, descriptor: ?*const CommandEncoder.Descriptor) CommandEncoder,
|
createCommandEncoder: fn (ptr: *anyopaque, descriptor: ?*const CommandEncoder.Descriptor) CommandEncoder,
|
||||||
createComputePipeline: fn (ptr: *anyopaque, descriptor: *const ComputePipeline.Descriptor) ComputePipeline,
|
createComputePipeline: fn (ptr: *anyopaque, descriptor: *const ComputePipeline.Descriptor) ComputePipeline,
|
||||||
createComputePipelineAsync: fn (
|
createComputePipelineAsync: fn (
|
||||||
|
|
@ -126,6 +126,10 @@ pub inline fn destroy(device: Device) void {
|
||||||
device.vtable.destroy(device.ptr);
|
device.vtable.destroy(device.ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub inline fn createBuffer(device: Device, descriptor: *const Buffer.Descriptor) Buffer {
|
||||||
|
return device.vtable.createBuffer(device.ptr, descriptor);
|
||||||
|
}
|
||||||
|
|
||||||
pub inline fn createCommandEncoder(device: Device, descriptor: ?*const CommandEncoder.Descriptor) CommandEncoder {
|
pub inline fn createCommandEncoder(device: Device, descriptor: ?*const CommandEncoder.Descriptor) CommandEncoder {
|
||||||
return device.vtable.createCommandEncoder(device.ptr, descriptor);
|
return device.vtable.createCommandEncoder(device.ptr, descriptor);
|
||||||
}
|
}
|
||||||
|
|
@ -183,6 +187,7 @@ test {
|
||||||
_ = createShaderModule;
|
_ = createShaderModule;
|
||||||
_ = nativeCreateSwapChain;
|
_ = nativeCreateSwapChain;
|
||||||
_ = destroy;
|
_ = destroy;
|
||||||
|
_ = createBuffer;
|
||||||
_ = createCommandEncoder;
|
_ = createCommandEncoder;
|
||||||
_ = createComputePipeline;
|
_ = createComputePipeline;
|
||||||
_ = createComputePipelineAsync;
|
_ = createComputePipelineAsync;
|
||||||
|
|
|
||||||
|
|
@ -441,6 +441,14 @@ const device_vtable = Device.VTable{
|
||||||
c.wgpuDeviceDestroy(@ptrCast(c.WGPUDevice, ptr));
|
c.wgpuDeviceDestroy(@ptrCast(c.WGPUDevice, ptr));
|
||||||
}
|
}
|
||||||
}).destroy,
|
}).destroy,
|
||||||
|
.createBuffer = (struct {
|
||||||
|
pub fn createBuffer(ptr: *anyopaque, descriptor: *const Buffer.Descriptor) Buffer {
|
||||||
|
return wrapBuffer(c.wgpuDeviceCreateBuffer(
|
||||||
|
@ptrCast(c.WGPUDevice, ptr),
|
||||||
|
@ptrCast(*const c.WGPUBufferDescriptor, descriptor),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}).createBuffer,
|
||||||
.createCommandEncoder = (struct {
|
.createCommandEncoder = (struct {
|
||||||
pub fn createCommandEncoder(ptr: *anyopaque, descriptor: ?*const CommandEncoder.Descriptor) CommandEncoder {
|
pub fn createCommandEncoder(ptr: *anyopaque, descriptor: ?*const CommandEncoder.Descriptor) CommandEncoder {
|
||||||
const desc: ?*c.WGPUCommandEncoderDescriptor = if (descriptor) |d| &.{
|
const desc: ?*c.WGPUCommandEncoderDescriptor = if (descriptor) |d| &.{
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue