Skip to content

Commit

Permalink
[GPU Optimisation]: Separate VertexBuffers per RenderType
Browse files Browse the repository at this point in the history
  • Loading branch information
thr3343 committed Nov 9, 2023
1 parent 92c2873 commit 1831112
Showing 1 changed file with 17 additions and 14 deletions.
31 changes: 17 additions & 14 deletions src/main/java/net/vulkanmod/render/chunk/DrawBuffers.java
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ public class DrawBuffers {
private final Vector3i origin;
final StaticQueue<DrawBuffers.DrawParameters[]> sectionQueue = new StaticQueue<>(512);
private boolean allocated = false;
AreaBuffer vertexBuffer;
AreaBuffer SvertexBuffer, TvertexBuffer;
AreaBuffer indexBuffer;
public DrawBuffers(int areaIndex, Vector3i origin) {

Expand All @@ -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;
}
Expand All @@ -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;

Expand Down Expand Up @@ -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());
Expand Down Expand Up @@ -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));
}

Expand All @@ -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;
}
Expand All @@ -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) {
Expand All @@ -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);
}
}
}
Expand Down

0 comments on commit 1831112

Please sign in to comment.