From 18311121a5b325d405dba0b933331d586caf250d Mon Sep 17 00:00:00 2001 From: thr3343 <125277899+thr3343@users.noreply.github.com> Date: Wed, 8 Nov 2023 23:29:16 +0000 Subject: [PATCH] [GPU Optimisation]: Separate VertexBuffers per RenderType --- .../vulkanmod/render/chunk/DrawBuffers.java | 31 ++++++++++--------- 1 file changed, 17 insertions(+), 14 deletions(-) diff --git a/src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java b/src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java index 331fcb2b1d..1f8cd7650e 100644 --- a/src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java +++ b/src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java @@ -25,7 +25,7 @@ public class DrawBuffers { private final Vector3i origin; final StaticQueue sectionQueue = new StaticQueue<>(512); private boolean allocated = false; - AreaBuffer vertexBuffer; + AreaBuffer SvertexBuffer, TvertexBuffer; AreaBuffer indexBuffer; public DrawBuffers(int areaIndex, Vector3i origin) { @@ -34,8 +34,9 @@ public DrawBuffers(int areaIndex, Vector3i origin) { } public void allocateBuffers() { - this.vertexBuffer = new AreaBuffer(VK_BUFFER_USAGE_VERTEX_BUFFER_BIT, 3500000, VERTEX_SIZE); - this.indexBuffer = new AreaBuffer(VK_BUFFER_USAGE_INDEX_BUFFER_BIT, 1000000, INDEX_SIZE); + this.SvertexBuffer = new AreaBuffer(VK_BUFFER_USAGE_VERTEX_BUFFER_BIT, 3145728, VERTEX_SIZE); + this.TvertexBuffer = new AreaBuffer(VK_BUFFER_USAGE_VERTEX_BUFFER_BIT, 524288, VERTEX_SIZE); + this.indexBuffer = new AreaBuffer(VK_BUFFER_USAGE_INDEX_BUFFER_BIT, 131072, INDEX_SIZE); this.allocated = true; } @@ -46,7 +47,8 @@ public DrawParameters upload(int xOffset, int yOffset, int zOffset, UploadBuffer drawParameters.baseInstance = encodeSectionOffset(xOffset, yOffset, zOffset); if(!buffer.indexOnly) { - this.vertexBuffer.upload(buffer.getVertexBuffer(), drawParameters.vertexBufferSegment); + if(buffer.autoIndices) this.SvertexBuffer.upload(buffer.getVertexBuffer(), drawParameters.vertexBufferSegment); + else this.TvertexBuffer.upload(buffer.getVertexBuffer(), drawParameters.vertexBufferSegment); // drawParameters.vertexOffset = drawParameters.vertexBufferSegment.getOffset() / VERTEX_SIZE; vertexOffset = drawParameters.vertexBufferSegment.getOffset() / VERTEX_SIZE; @@ -124,7 +126,7 @@ public void buildDrawBatchesIndirect(IndirectBuffer indirectBuffer, TerrainRende indirectBuffer.recordCopyCmd(byteBuffer); - nvkCmdBindVertexBuffers(commandBuffer, 0, 1, (stack.npointer(vertexBuffer.getId())), (stack.npointer(0))); + nvkCmdBindVertexBuffers(commandBuffer, 0, 1, (stack.npointer(isTranslucent ? TvertexBuffer : SvertexBuffer).getId())), (stack.npointer(0))); // pipeline.bindDescriptorSets(Drawer.getCommandBuffer(), WorldRenderer.getInstance().getUniformBuffers(), Drawer.getCurrentFrame()); // pipeline.bindDescriptorSets(Renderer.getCommandBuffer(), Renderer.getCurrentFrame()); @@ -188,7 +190,7 @@ public void buildDrawBatchesDirect(TerrainRenderType terrainRenderType, double c VkCommandBuffer commandBuffer = Renderer.getCommandBuffer(); try(MemoryStack stack = MemoryStack.stackPush()) { - nvkCmdBindVertexBuffers(commandBuffer, 0, 1, stack.npointer(vertexBuffer.getId()), stack.npointer(0)); + nvkCmdBindVertexBuffers(commandBuffer, 0, 1, stack.npointer((isTranslucent ? TvertexBuffer : SvertexBuffer).getId()), stack.npointer(0)); updateChunkAreaOrigin(camX, camY, camZ, commandBuffer, stack.nmalloc(16)); } @@ -211,10 +213,12 @@ public void releaseBuffers() { if(!this.allocated) return; - this.vertexBuffer.freeBuffer(); + this.SvertexBuffer.freeBuffer(); + this.TvertexBuffer.freeBuffer(); this.indexBuffer.freeBuffer(); - this.vertexBuffer = null; + this.SvertexBuffer = null; + this.TvertexBuffer = null; this.indexBuffer = null; this.allocated = false; } @@ -228,14 +232,12 @@ public static class DrawParameters { int firstIndex; int vertexOffset; int baseInstance; - AreaBuffer.Segment vertexBufferSegment = new AreaBuffer.Segment(); - AreaBuffer.Segment indexBufferSegment; + final AreaBuffer.Segment vertexBufferSegment = new AreaBuffer.Segment(); + final AreaBuffer.Segment indexBufferSegment; boolean ready = false; DrawParameters(boolean translucent) { - if(translucent) { - indexBufferSegment = new AreaBuffer.Segment(); - } + indexBufferSegment = (translucent) ? new AreaBuffer.Segment() : null; } public void reset(ChunkArea chunkArea) { @@ -246,7 +248,8 @@ public void reset(ChunkArea chunkArea) { int segmentOffset = this.vertexBufferSegment.getOffset(); if(chunkArea != null && chunkArea.drawBuffers.isAllocated() && segmentOffset != -1) { // this.chunkArea.drawBuffers.vertexBuffer.setSegmentFree(segmentOffset); - chunkArea.drawBuffers.vertexBuffer.setSegmentFree(this.vertexBufferSegment); + if(this.indexBufferSegment==null) chunkArea.drawBuffers.SvertexBuffer.setSegmentFree(this.vertexBufferSegment); + else chunkArea.drawBuffers.TvertexBuffer.setSegmentFree(this.vertexBufferSegment); } } }