adding command descriptors and buffer base
This commit is contained in:
@@ -2,12 +2,42 @@ const std = @import("std");
|
|||||||
const vk = @import("vulkan");
|
const vk = @import("vulkan");
|
||||||
|
|
||||||
const VkError = @import("error_set.zig").VkError;
|
const VkError = @import("error_set.zig").VkError;
|
||||||
|
const DeviceMemory = @import("DeviceMemory.zig");
|
||||||
const Device = @import("Device.zig");
|
const Device = @import("Device.zig");
|
||||||
|
|
||||||
const Self = @This();
|
const Self = @This();
|
||||||
pub const ObjectType: vk.ObjectType = .buffer;
|
pub const ObjectType: vk.ObjectType = .buffer;
|
||||||
|
|
||||||
owner: *const Device,
|
owner: *Device,
|
||||||
size: vk.DeviceSize,
|
size: vk.DeviceSize,
|
||||||
offset: vk.DeviceSize,
|
offset: vk.DeviceSize,
|
||||||
usage: vk.BufferUsageFlags,
|
usage: vk.BufferUsageFlags,
|
||||||
|
memory: ?*DeviceMemory,
|
||||||
|
allowed_memory_types: u32,
|
||||||
|
|
||||||
|
vtable: *const VTable,
|
||||||
|
|
||||||
|
pub const VTable = struct {
|
||||||
|
getMemoryRequirements: *const fn (*Self, *vk.MemoryRequirements) void,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub fn init(device: *Device, allocator: std.mem.Allocator, info: *const vk.BufferCreateInfo) VkError!Self {
|
||||||
|
_ = allocator;
|
||||||
|
return .{
|
||||||
|
.owner = device,
|
||||||
|
.size = info.size,
|
||||||
|
.offset = 0,
|
||||||
|
.usage = info.usage,
|
||||||
|
.memory = null,
|
||||||
|
.allowed_memory_types = 0,
|
||||||
|
.vtable = undefined,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
pub inline fn bindMemory(self: *Self, memory: *DeviceMemory, offset: vk.DeviceSize) VkError!void {
|
||||||
|
if (offset >= self.size or self.allowed_memory_types & memory.memory_type_index == 0) {
|
||||||
|
return VkError.ValidationFailed;
|
||||||
|
}
|
||||||
|
self.memory = memory;
|
||||||
|
self.offset = offset;
|
||||||
|
}
|
||||||
|
|||||||
61
src/vulkan/commands.zig
git.filemode.normal_file
61
src/vulkan/commands.zig
git.filemode.normal_file
@@ -0,0 +1,61 @@
|
|||||||
|
const std = @import("std");
|
||||||
|
const vk = @import("vulkan");
|
||||||
|
|
||||||
|
const Buffer = @import("Buffer.zig");
|
||||||
|
|
||||||
|
pub const CommandType = enum {
|
||||||
|
BindVertexBuffer,
|
||||||
|
Draw,
|
||||||
|
DrawIndexed,
|
||||||
|
DrawIndirect,
|
||||||
|
DrawIndexedIndirect,
|
||||||
|
BindPipeline,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub const CommandBindVertexBuffer = struct {
|
||||||
|
buffers: std.ArrayList(Buffer),
|
||||||
|
offsets: std.ArrayList(vk.DeviceSize),
|
||||||
|
first_binding: u32,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub const CommandDraw = struct {
|
||||||
|
vertex_count: u32,
|
||||||
|
instance_count: u32,
|
||||||
|
first_vertex: u32,
|
||||||
|
first_instance: u32,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub const CommandDrawIndexed = struct {
|
||||||
|
index_count: u32,
|
||||||
|
instance_count: u32,
|
||||||
|
first_index: u32,
|
||||||
|
vertex_offset: i32,
|
||||||
|
first_instance: u32,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub const CommandDrawIndirect = struct {
|
||||||
|
buffer: *Buffer,
|
||||||
|
offset: vk.DeviceSize,
|
||||||
|
count: u32,
|
||||||
|
stride: u32,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub const CommandDrawIndexedIndirect = struct {
|
||||||
|
buffer: *Buffer,
|
||||||
|
offset: vk.DeviceSize,
|
||||||
|
count: u32,
|
||||||
|
stride: u32,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub const CommandBindPipeline = struct {
|
||||||
|
bind_point: vk.PipelineBindPoint,
|
||||||
|
};
|
||||||
|
|
||||||
|
pub const Command = union(CommandType) {
|
||||||
|
BindVertexBuffer: CommandBindVertexBuffer,
|
||||||
|
Draw: CommandDraw,
|
||||||
|
DrawIndexed: CommandDrawIndexed,
|
||||||
|
DrawIndirect: CommandDrawIndirect,
|
||||||
|
DrawIndexedIndirect: CommandDrawIndexedIndirect,
|
||||||
|
BindPipeline: CommandBindPipeline,
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user