buffered TLAS
This commit is contained in:
parent
1576d9a8b3
commit
642cef78b1
4 changed files with 23 additions and 64 deletions
|
|
@ -52,19 +52,19 @@ RenderingElement3DVulkan::RenderingElement3DVulkan(Mesh& mesh) {
|
|||
};
|
||||
}
|
||||
|
||||
void RenderingElement3DVulkan::BuildTLAS(VkCommandBuffer cmd) {
|
||||
instanceBuffer.Resize(VK_BUFFER_USAGE_SHADER_DEVICE_ADDRESS_BIT | VK_BUFFER_USAGE_TRANSFER_DST_BIT | VK_BUFFER_USAGE_ACCELERATION_STRUCTURE_BUILD_INPUT_READ_ONLY_BIT_KHR, VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT, elements.size());
|
||||
void RenderingElement3DVulkan::BuildTLAS(VkCommandBuffer cmd, std::uint32_t index) {
|
||||
tlases[index].instanceBuffer.Resize(VK_BUFFER_USAGE_SHADER_DEVICE_ADDRESS_BIT | VK_BUFFER_USAGE_TRANSFER_DST_BIT | VK_BUFFER_USAGE_ACCELERATION_STRUCTURE_BUILD_INPUT_READ_ONLY_BIT_KHR, VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT, elements.size());
|
||||
|
||||
for(std::uint32_t i = 0; i < elements.size(); i++) {
|
||||
instanceBuffer.value[i] = elements[i].instance;
|
||||
tlases[index].instanceBuffer.value[i] = elements[i].instance;
|
||||
}
|
||||
|
||||
instanceBuffer.FlushDevice(cmd, VK_ACCESS_MEMORY_READ_BIT, VK_PIPELINE_STAGE_ACCELERATION_STRUCTURE_BUILD_BIT_KHR);
|
||||
tlases[index].instanceBuffer.FlushDevice(cmd, VK_ACCESS_MEMORY_READ_BIT, VK_PIPELINE_STAGE_ACCELERATION_STRUCTURE_BUILD_BIT_KHR);
|
||||
|
||||
VkAccelerationStructureGeometryInstancesDataKHR instancesData = VkAccelerationStructureGeometryInstancesDataKHR {
|
||||
.sType = VK_STRUCTURE_TYPE_ACCELERATION_STRUCTURE_GEOMETRY_INSTANCES_DATA_KHR,
|
||||
.arrayOfPointers = VK_FALSE,
|
||||
.data = {instanceBuffer.address}
|
||||
.data = {tlases[index].instanceBuffer.address}
|
||||
};
|
||||
|
||||
VkAccelerationStructureGeometryDataKHR geometryData;
|
||||
|
|
@ -101,19 +101,19 @@ void RenderingElement3DVulkan::BuildTLAS(VkCommandBuffer cmd) {
|
|||
scratchBuffer.Resize(VK_BUFFER_USAGE_STORAGE_BUFFER_BIT | VK_BUFFER_USAGE_SHADER_DEVICE_ADDRESS_BIT, VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT, tlasBuildSizes.buildScratchSize);
|
||||
tlasBuildGeometryInfo.scratchData.deviceAddress = scratchBuffer.address;
|
||||
|
||||
tlasBuffer.Resize(VK_BUFFER_USAGE_ACCELERATION_STRUCTURE_STORAGE_BIT_KHR | VK_BUFFER_USAGE_SHADER_DEVICE_ADDRESS_BIT | VK_BUFFER_USAGE_ACCELERATION_STRUCTURE_BUILD_INPUT_READ_ONLY_BIT_KHR, VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT, tlasBuildSizes.accelerationStructureSize);
|
||||
tlases[index].buffer.Resize(VK_BUFFER_USAGE_ACCELERATION_STRUCTURE_STORAGE_BIT_KHR | VK_BUFFER_USAGE_SHADER_DEVICE_ADDRESS_BIT | VK_BUFFER_USAGE_ACCELERATION_STRUCTURE_BUILD_INPUT_READ_ONLY_BIT_KHR, VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT, tlasBuildSizes.accelerationStructureSize);
|
||||
|
||||
// Create and store the TLAS handle
|
||||
VkAccelerationStructureCreateInfoKHR tlasCreateInfo {
|
||||
.sType = VK_STRUCTURE_TYPE_ACCELERATION_STRUCTURE_CREATE_INFO_KHR,
|
||||
.buffer = tlasBuffer.buffer,
|
||||
.buffer = tlases[index].buffer.buffer,
|
||||
.offset = 0,
|
||||
.size = tlasBuildSizes.accelerationStructureSize,
|
||||
.type = VK_ACCELERATION_STRUCTURE_TYPE_TOP_LEVEL_KHR,
|
||||
};
|
||||
|
||||
VulkanDevice::CheckVkResult(VulkanDevice::vkCreateAccelerationStructureKHR(VulkanDevice::device, &tlasCreateInfo, nullptr, &accelerationStructure));
|
||||
tlasBuildGeometryInfo.dstAccelerationStructure = accelerationStructure;
|
||||
VulkanDevice::CheckVkResult(VulkanDevice::vkCreateAccelerationStructureKHR(VulkanDevice::device, &tlasCreateInfo, nullptr, &tlases[index].accelerationStructure));
|
||||
tlasBuildGeometryInfo.dstAccelerationStructure = tlases[index].accelerationStructure;
|
||||
|
||||
// Prepare the build range for the TLAS
|
||||
VkAccelerationStructureBuildRangeInfoKHR tlasRangeInfo {
|
||||
|
|
|
|||
|
|
@ -297,54 +297,6 @@ WindowVulkan::WindowVulkan(std::uint32_t width, std::uint32_t height) : Window(w
|
|||
subpassDescription.pPreserveAttachments = nullptr;
|
||||
subpassDescription.pResolveAttachments = nullptr;
|
||||
|
||||
// // Subpass dependencies for layout transitions
|
||||
// std::array<VkSubpassDependency, 2> dependencies{};
|
||||
|
||||
// dependencies[0].srcSubpass = VK_SUBPASS_EXTERNAL;
|
||||
// dependencies[0].dstSubpass = 0;
|
||||
// dependencies[0].srcStageMask = VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT | VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT;
|
||||
// dependencies[0].dstStageMask = VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT | VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT;
|
||||
// dependencies[0].srcAccessMask = 0;
|
||||
// dependencies[0].dstAccessMask = 0;
|
||||
// dependencies[0].dependencyFlags = 0;
|
||||
|
||||
// dependencies[1].srcSubpass = VK_SUBPASS_EXTERNAL;
|
||||
// dependencies[1].dstSubpass = 0;
|
||||
// dependencies[1].srcStageMask = VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT;
|
||||
// dependencies[1].dstStageMask = VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT;
|
||||
// dependencies[1].srcAccessMask = 0;
|
||||
// dependencies[1].dstAccessMask = VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT | VK_ACCESS_COLOR_ATTACHMENT_READ_BIT;
|
||||
// dependencies[1].dependencyFlags = 0;
|
||||
|
||||
// VkRenderPassCreateInfo renderPassInfo = {};
|
||||
// renderPassInfo.sType = VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO;
|
||||
// renderPassInfo.attachmentCount = static_cast<uint32_t>(attachments.size());
|
||||
// renderPassInfo.pAttachments = attachments.data();
|
||||
// renderPassInfo.subpassCount = 1;
|
||||
// renderPassInfo.pSubpasses = &subpassDescription;
|
||||
// renderPassInfo.dependencyCount = static_cast<uint32_t>(dependencies.size());
|
||||
// renderPassInfo.pDependencies = dependencies.data();
|
||||
|
||||
// VulkanDevice::CheckVkResult(vkCreateRenderPass(VulkanDevice::device, &renderPassInfo, nullptr, &renderPass));
|
||||
|
||||
// Create frame buffers for every swap chain image
|
||||
// frameBuffers.resize(images.size());
|
||||
// for (uint32_t i = 0; i < frameBuffers.size(); i++)
|
||||
// {
|
||||
// const VkImageView attachments[1] = {
|
||||
// imageViews[i]
|
||||
// };
|
||||
// VkFramebufferCreateInfo frameBufferCreateInfo{};
|
||||
// frameBufferCreateInfo.sType = VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO;
|
||||
// frameBufferCreateInfo.renderPass = VK_NULL_HANDLE;
|
||||
// frameBufferCreateInfo.attachmentCount = 1;
|
||||
// frameBufferCreateInfo.pAttachments = attachments;
|
||||
// frameBufferCreateInfo.width = width;
|
||||
// frameBufferCreateInfo.height = height;
|
||||
// frameBufferCreateInfo.layers = 1;
|
||||
// VulkanDevice::CheckVkResult(vkCreateFramebuffer(VulkanDevice::device, &frameBufferCreateInfo, nullptr, &frameBuffers[i]));
|
||||
// }
|
||||
|
||||
drawCmdBuffers.resize(images.size());
|
||||
|
||||
VkCommandBufferAllocateInfo cmdBufAllocateInfo {};
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue