From 5ca830963e427d4eac3fcb752d2df7536e08350b Mon Sep 17 00:00:00 2001 From: PepperCode1 <44146161+PepperCode1@users.noreply.github.com> Date: Wed, 10 Aug 2022 20:47:53 -0700 Subject: [PATCH] Wait, it's all unsafe? Always has been. - Create MemoryBlock utility for easier management of memory allocation - Replace most usage of direct ByteBuffer with MemoryBlock - Remove all usage of Mojang's MemoryTracker - Simplifier StructWriter - Rename some classes and packages --- .../flywheel/api/struct/StructType.java | 11 +- .../flywheel/api/struct/StructWriter.java | 14 +- .../flywheel/backend/FlywheelMemory.java | 57 ------- .../backend/gl/versioned/GlCompat.java | 14 +- .../instancing/batching/DrawBuffer.java | 35 +++-- .../instancing/batching/TransformSet.java | 6 +- .../blockentity/BlockEntityInstance.java | 2 +- .../instancing/instancing/GPUInstancer.java | 16 +- .../instancing/instancing/MeshPool.java | 5 +- .../backend/memory/FlwMemoryTracker.java | 141 ++++++++++++++++++ .../flywheel/backend/memory/MemoryBlock.java | 45 ++++++ .../backend/memory/MemoryBlockImpl.java | 76 ++++++++++ .../memory/TrackedMemoryBlockImpl.java | 38 +++++ .../flywheel/backend/struct/BufferWriter.java | 40 ----- .../backend/struct/UnsafeBufferWriter.java | 45 ------ .../flywheel/backend/struct/package-info.java | 6 - .../flywheel/core/hardcoded/ModelPart.java | 20 +-- .../jozufozu/flywheel/core/model/Mesh.java | 6 +- .../flywheel/core/model/ModelUtil.java | 8 +- .../flywheel/core/model/SimpleMesh.java | 25 ++-- .../model/buffering/BakedModelBuilder.java | 6 +- .../model/buffering/BlockModelBuilder.java | 6 +- .../buffering/MultiBlockModelBuilder.java | 6 +- .../core/structs/ColoredLitWriter.java | 17 +++ .../core/structs/ColoredLitWriterUnsafe.java | 26 ---- .../flywheel/core/structs/StructTypes.java | 4 +- .../model/TransformedWriterUnsafe.java | 23 --- .../core/structs/oriented/OrientedType.java | 8 +- ...dWriterUnsafe.java => OrientedWriter.java} | 16 +- .../TransformedPart.java | 2 +- .../TransformedType.java | 10 +- .../transformed/TransformedWriter.java | 17 +++ .../{model => transformed}/package-info.java | 2 +- .../flywheel/core/uniform/FogProvider.java | 2 - .../flywheel/core/uniform/UniformBuffer.java | 4 +- .../jozufozu/flywheel/event/ForgeEvents.java | 7 +- .../jozufozu/flywheel/light/LightVolume.java | 9 +- .../jozufozu/flywheel/util/StringUtil.java | 12 +- .../flywheel/vanilla/ChestInstance.java | 2 +- .../flywheel/vanilla/MinecartInstance.java | 2 +- .../flywheel/vanilla/ShulkerBoxInstance.java | 2 +- .../vanilla/effect/ExampleEffect.java | 2 +- 42 files changed, 445 insertions(+), 350 deletions(-) delete mode 100644 src/main/java/com/jozufozu/flywheel/backend/FlywheelMemory.java create mode 100644 src/main/java/com/jozufozu/flywheel/backend/memory/FlwMemoryTracker.java create mode 100644 src/main/java/com/jozufozu/flywheel/backend/memory/MemoryBlock.java create mode 100644 src/main/java/com/jozufozu/flywheel/backend/memory/MemoryBlockImpl.java create mode 100644 src/main/java/com/jozufozu/flywheel/backend/memory/TrackedMemoryBlockImpl.java delete mode 100644 src/main/java/com/jozufozu/flywheel/backend/struct/BufferWriter.java delete mode 100644 src/main/java/com/jozufozu/flywheel/backend/struct/UnsafeBufferWriter.java delete mode 100644 src/main/java/com/jozufozu/flywheel/backend/struct/package-info.java create mode 100644 src/main/java/com/jozufozu/flywheel/core/structs/ColoredLitWriter.java delete mode 100644 src/main/java/com/jozufozu/flywheel/core/structs/ColoredLitWriterUnsafe.java delete mode 100644 src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedWriterUnsafe.java rename src/main/java/com/jozufozu/flywheel/core/structs/oriented/{OrientedWriterUnsafe.java => OrientedWriter.java} (54%) rename src/main/java/com/jozufozu/flywheel/core/structs/{model => transformed}/TransformedPart.java (97%) rename src/main/java/com/jozufozu/flywheel/core/structs/{model => transformed}/TransformedType.java (86%) create mode 100644 src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedWriter.java rename src/main/java/com/jozufozu/flywheel/core/structs/{model => transformed}/package-info.java (75%) diff --git a/src/main/java/com/jozufozu/flywheel/api/struct/StructType.java b/src/main/java/com/jozufozu/flywheel/api/struct/StructType.java index 7841f92de..7bdeab3a0 100644 --- a/src/main/java/com/jozufozu/flywheel/api/struct/StructType.java +++ b/src/main/java/com/jozufozu/flywheel/api/struct/StructType.java @@ -1,7 +1,5 @@ package com.jozufozu.flywheel.api.struct; -import java.nio.ByteBuffer; - import com.jozufozu.flywheel.api.instancer.InstancedPart; import com.jozufozu.flywheel.api.vertex.MutableVertexList; import com.jozufozu.flywheel.core.layout.BufferLayout; @@ -25,16 +23,11 @@ public interface StructType { */ BufferLayout getLayout(); - /** - * Create a {@link StructWriter} that will consume instances of S and write them to the given buffer. - * - * @param backing The buffer that the StructWriter will write to. - */ - StructWriter getWriter(ByteBuffer backing); + StructWriter getWriter(); FileResolution getInstanceShader(); - VertexTransformer getVertexTransformer(); + VertexTransformer getVertexTransformer(); public interface VertexTransformer { void transform(MutableVertexList vertexList, S struct, ClientLevel level); diff --git a/src/main/java/com/jozufozu/flywheel/api/struct/StructWriter.java b/src/main/java/com/jozufozu/flywheel/api/struct/StructWriter.java index abebee807..beb89d025 100644 --- a/src/main/java/com/jozufozu/flywheel/api/struct/StructWriter.java +++ b/src/main/java/com/jozufozu/flywheel/api/struct/StructWriter.java @@ -1,17 +1,13 @@ package com.jozufozu.flywheel.api.struct; +import com.jozufozu.flywheel.api.instancer.InstancedPart; + /** * StructWriters can quickly consume many instances of S and write them to some backing buffer. */ -public interface StructWriter { - +public interface StructWriter { /** - * Write the given struct to the backing array. + * Write the given struct to given memory address. */ - void write(S struct); - - /** - * Seek to the given position. The next write will occur there. - */ - void seek(int pos); + void write(long ptr, S struct); } diff --git a/src/main/java/com/jozufozu/flywheel/backend/FlywheelMemory.java b/src/main/java/com/jozufozu/flywheel/backend/FlywheelMemory.java deleted file mode 100644 index 3d3f8bd60..000000000 --- a/src/main/java/com/jozufozu/flywheel/backend/FlywheelMemory.java +++ /dev/null @@ -1,57 +0,0 @@ -package com.jozufozu.flywheel.backend; - -import java.lang.ref.Cleaner; -import java.nio.ByteBuffer; - -import org.lwjgl.system.MemoryUtil; - -public class FlywheelMemory { - - public static final Cleaner CLEANER = Cleaner.create(); - - private static int gpuMemory = 0; - private static int cpuMemory = 0; - - public static void _freeCPUMemory(long size) { - cpuMemory -= size; - } - - public static void _allocCPUMemory(long size) { - cpuMemory += size; - } - - public static void _freeGPUMemory(long size) { - gpuMemory -= size; - } - - public static void _allocGPUMemory(long size) { - gpuMemory += size; - } - - public static int getGPUMemory() { - return gpuMemory; - } - - public static int getCPUMemory() { - return cpuMemory; - } - - public static Cleaner.Cleanable track(Object owner, ByteBuffer buffer) { - return CLEANER.register(owner, new Tracked(buffer)); - } - - public static class Tracked implements Runnable { - - private final ByteBuffer buffer; - - public Tracked(ByteBuffer buffer) { - this.buffer = buffer; - _allocCPUMemory(buffer.capacity()); - } - - public void run() { - _freeCPUMemory(buffer.capacity()); - MemoryUtil.memFree(buffer); - } - } -} diff --git a/src/main/java/com/jozufozu/flywheel/backend/gl/versioned/GlCompat.java b/src/main/java/com/jozufozu/flywheel/backend/gl/versioned/GlCompat.java index 059dd15b1..97a9f6850 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/gl/versioned/GlCompat.java +++ b/src/main/java/com/jozufozu/flywheel/backend/gl/versioned/GlCompat.java @@ -8,7 +8,6 @@ import org.lwjgl.opengl.GL; import org.lwjgl.opengl.GL20C; import org.lwjgl.opengl.GLCapabilities; import org.lwjgl.system.MemoryStack; -import org.lwjgl.system.MemoryUtil; import net.minecraft.Util; @@ -75,7 +74,7 @@ public class GlCompat { } /** - * Copied from: + * Modified from: *
canvas * *

Identical in function to {@link GL20C#glShaderSource(int, CharSequence)} but @@ -87,18 +86,11 @@ public class GlCompat { *

Hat tip to fewizz for the find and the fix. */ public static void safeShaderSource(int glId, CharSequence source) { - final MemoryStack stack = MemoryStack.stackGet(); - final int stackPointer = stack.getPointer(); - - try { - final ByteBuffer sourceBuffer = MemoryUtil.memUTF8(source, true); + try (MemoryStack stack = MemoryStack.stackPush()) { + final ByteBuffer sourceBuffer = stack.UTF8(source, true); final PointerBuffer pointers = stack.mallocPointer(1); pointers.put(sourceBuffer); - GL20C.nglShaderSource(glId, 1, pointers.address0(), 0); - org.lwjgl.system.APIUtil.apiArrayFree(pointers.address0(), 1); - } finally { - stack.setPointer(stackPointer); } } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/DrawBuffer.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/DrawBuffer.java index 50a099bae..8559680ea 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/DrawBuffer.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/DrawBuffer.java @@ -2,12 +2,10 @@ package com.jozufozu.flywheel.backend.instancing.batching; import java.nio.ByteBuffer; -import org.lwjgl.system.MemoryUtil; - import com.jozufozu.flywheel.api.vertex.ReusableVertexList; import com.jozufozu.flywheel.api.vertex.VertexListProvider; +import com.jozufozu.flywheel.backend.memory.MemoryBlock; import com.jozufozu.flywheel.core.vertex.VertexListProviderRegistry; -import com.mojang.blaze3d.platform.MemoryTracker; import com.mojang.blaze3d.vertex.VertexFormat; import net.minecraft.client.renderer.RenderType; @@ -23,9 +21,10 @@ public class DrawBuffer { private final int stride; private final VertexListProvider provider; - private ByteBuffer backingBuffer; + private MemoryBlock memory; + private ByteBuffer buffer; + private int expectedVertices; - private long ptr; public DrawBuffer(RenderType parent) { this.parent = parent; @@ -41,7 +40,7 @@ public class DrawBuffer { */ public void prepare(int vertexCount) { if (expectedVertices != 0) { - throw new IllegalStateException("Already drawing"); + throw new IllegalStateException("Already drawing!"); } this.expectedVertices = vertexCount; @@ -51,20 +50,20 @@ public class DrawBuffer { // is called and reallocates the buffer if there is not space for one more vertex. int byteSize = stride * (vertexCount + 1); - if (backingBuffer == null) { - backingBuffer = MemoryTracker.create(byteSize); - } else if (byteSize > backingBuffer.capacity()) { - backingBuffer = MemoryTracker.resize(backingBuffer, byteSize); + if (memory == null) { + memory = MemoryBlock.malloc(byteSize); + buffer = memory.asBuffer(); + } else if (byteSize > memory.size()) { + memory = memory.realloc(byteSize); + buffer = memory.asBuffer(); } - backingBuffer.clear(); - ptr = MemoryUtil.memAddress(backingBuffer); - MemoryUtil.memSet(ptr, 0, byteSize); + memory.clear(); } public ReusableVertexList slice(int startVertex, int vertexCount) { ReusableVertexList vertexList = provider.createVertexList(); - vertexList.ptr(ptr + startVertex * stride); + vertexList.ptr(memory.ptr() + startVertex * stride); vertexList.setVertexCount(vertexCount); return vertexList; } @@ -74,7 +73,8 @@ public class DrawBuffer { * @param bufferBuilder The buffer builder to inject into. */ public void inject(BufferBuilderExtension bufferBuilder) { - bufferBuilder.flywheel$injectForRender(backingBuffer, format, expectedVertices); + buffer.clear(); + bufferBuilder.flywheel$injectForRender(buffer, format, expectedVertices); } public int getVertexCount() { @@ -96,4 +96,9 @@ public class DrawBuffer { public void reset() { this.expectedVertices = 0; } + + public void free() { + buffer = null; + memory.free(); + } } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/TransformSet.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/TransformSet.java index 4dc4a1bef..8b27d389d 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/TransformSet.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/batching/TransformSet.java @@ -5,7 +5,6 @@ import java.util.List; import com.jozufozu.flywheel.api.instancer.InstancedPart; import com.jozufozu.flywheel.api.material.Material; import com.jozufozu.flywheel.api.struct.StructType; -import com.jozufozu.flywheel.api.struct.StructType.VertexTransformer; import com.jozufozu.flywheel.api.vertex.MutableVertexList; import com.jozufozu.flywheel.api.vertex.ReusableVertexList; import com.jozufozu.flywheel.backend.instancing.TaskEngine; @@ -71,11 +70,10 @@ public class TransformSet { int meshVertexCount = mesh.getVertexCount(); vertexList.setVertexCount(meshVertexCount); - @SuppressWarnings("unchecked") - StructType.VertexTransformer structVertexTransformer = (VertexTransformer) instancer.type.getVertexTransformer(); + StructType.VertexTransformer structVertexTransformer = instancer.type.getVertexTransformer(); for (D d : list) { - mesh.writeInto(vertexList); + mesh.write(vertexList); structVertexTransformer.transform(vertexList, d, level); diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/blockentity/BlockEntityInstance.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/blockentity/BlockEntityInstance.java index 39a53e444..add54b13b 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/blockentity/BlockEntityInstance.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/blockentity/BlockEntityInstance.java @@ -10,8 +10,8 @@ import com.jozufozu.flywheel.api.instancer.InstancerFactory; import com.jozufozu.flywheel.api.instancer.InstancerManager; import com.jozufozu.flywheel.backend.instancing.AbstractInstance; import com.jozufozu.flywheel.core.structs.StructTypes; -import com.jozufozu.flywheel.core.structs.model.TransformedPart; import com.jozufozu.flywheel.core.structs.oriented.OrientedPart; +import com.jozufozu.flywheel.core.structs.transformed.TransformedPart; import com.jozufozu.flywheel.util.box.GridAlignedBB; import com.jozufozu.flywheel.util.box.ImmutableBox; diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/GPUInstancer.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/GPUInstancer.java index 759afd2c0..95015766a 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/GPUInstancer.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/GPUInstancer.java @@ -3,6 +3,8 @@ package com.jozufozu.flywheel.backend.instancing.instancing; import java.util.HashSet; import java.util.Set; +import org.lwjgl.system.MemoryUtil; + import com.jozufozu.flywheel.Flywheel; import com.jozufozu.flywheel.api.instancer.InstancedPart; import com.jozufozu.flywheel.api.struct.StructType; @@ -89,20 +91,14 @@ public class GPUInstancer extends AbstractInstancer buf.clear(clearStart, clearLength); if (size > 0) { + final long ptr = MemoryUtil.memAddress(buf.unwrap()); + final int stride = structType.getLayout().getStride(); + final StructWriter writer = structType.getWriter(); - final StructWriter writer = structType.getWriter(buf.unwrap()); - - boolean sequential = true; for (int i = 0; i < size; i++) { final D element = data.get(i); if (element.checkDirtyAndClear()) { - if (!sequential) { - writer.seek(i); - } - writer.write(element); - sequential = true; - } else { - sequential = false; + writer.write(ptr + i * stride, element); } } } diff --git a/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/MeshPool.java b/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/MeshPool.java index 39a0b4a48..a5d7b6051 100644 --- a/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/MeshPool.java +++ b/src/main/java/com/jozufozu/flywheel/backend/instancing/instancing/MeshPool.java @@ -10,6 +10,7 @@ import java.util.Set; import org.jetbrains.annotations.Nullable; import org.lwjgl.opengl.GL32; +import org.lwjgl.system.MemoryUtil; import com.jozufozu.flywheel.Flywheel; import com.jozufozu.flywheel.api.vertex.VertexType; @@ -240,7 +241,9 @@ public class MeshPool { } private void buffer(ByteBuffer buffer) { - this.mesh.writeInto(buffer, this.byteIndex); + buffer.position((int) this.byteIndex); + long ptr = MemoryUtil.memAddress(buffer); + this.mesh.write(ptr); this.boundTo.clear(); this.gpuResident = true; diff --git a/src/main/java/com/jozufozu/flywheel/backend/memory/FlwMemoryTracker.java b/src/main/java/com/jozufozu/flywheel/backend/memory/FlwMemoryTracker.java new file mode 100644 index 000000000..c398eb223 --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/backend/memory/FlwMemoryTracker.java @@ -0,0 +1,141 @@ +package com.jozufozu.flywheel.backend.memory; + +import java.lang.ref.Cleaner; +import java.nio.ByteBuffer; + +import org.lwjgl.system.MemoryUtil; + +public class FlwMemoryTracker { + private static final Cleaner CLEANER = Cleaner.create(); + + private static long cpuMemory = 0; + private static long gpuMemory = 0; + + public static long malloc(long size) { + long ptr = MemoryUtil.nmemAlloc(size); + if (ptr == MemoryUtil.NULL) { + throw new OutOfMemoryError("Failed to allocate " + size + " bytes"); + } + return ptr; + } + + public static MemoryBlock mallocBlock(long size) { + MemoryBlock block = new MemoryBlockImpl(malloc(size), size); + cpuMemory += block.size(); + return block; + } + + public static MemoryBlock mallocBlockTracked(long size) { + TrackedMemoryBlockImpl block = new TrackedMemoryBlockImpl(malloc(size), size); + block.cleanable = CLEANER.register(block, () -> { + if (!block.isFreed()) { + block.free(); + } + }); + cpuMemory += block.size(); + return block; + } + + @Deprecated + public static ByteBuffer mallocBuffer(int size) { + ByteBuffer buffer = MemoryUtil.memByteBuffer(malloc(size), size); + cpuMemory += buffer.capacity(); + return buffer; + } + + public static long calloc(long num, long size) { + long ptr = MemoryUtil.nmemCalloc(num, size); + if (ptr == MemoryUtil.NULL) { + throw new OutOfMemoryError("Failed to allocate " + num + " blocks of size " + size + " bytes"); + } + return ptr; + } + + public static MemoryBlock callocBlock(long num, long size) { + MemoryBlock block = new MemoryBlockImpl(calloc(num, size), num * size); + cpuMemory += block.size(); + return block; + } + + public static MemoryBlock callocBlockTracked(long num, long size) { + TrackedMemoryBlockImpl block = new TrackedMemoryBlockImpl(calloc(num, size), num * size); + block.cleanable = CLEANER.register(block, () -> { + if (!block.isFreed()) { + block.free(); + } + }); + cpuMemory += block.size(); + return block; + } + + public static long realloc(long ptr, long size) { + ptr = MemoryUtil.nmemRealloc(ptr, size); + if (ptr == MemoryUtil.NULL) { + throw new OutOfMemoryError("Failed to reallocate " + size + " bytes for address 0x" + Long.toHexString(ptr)); + } + return ptr; + } + + public static MemoryBlock reallocBlock(MemoryBlock block, long size) { + MemoryBlock newBlock = new MemoryBlockImpl(realloc(block.ptr(), size), size); + cpuMemory += -block.size() + newBlock.size(); + return newBlock; + } + + public static MemoryBlock reallocBlockTracked(MemoryBlock block, long size) { + TrackedMemoryBlockImpl newBlock = new TrackedMemoryBlockImpl(realloc(block.ptr(), size), size); + newBlock.cleanable = CLEANER.register(newBlock, () -> { + if (!newBlock.isFreed()) { + newBlock.free(); + } + }); + cpuMemory += -block.size() + newBlock.size(); + return newBlock; + } + + @Deprecated + public static ByteBuffer reallocBuffer(ByteBuffer buffer, int size) { + ByteBuffer newBuffer = MemoryUtil.memByteBuffer(realloc(MemoryUtil.memAddress(buffer), size), size); + cpuMemory += -buffer.capacity() + newBuffer.capacity(); + return newBuffer; + } + + public static void free(long ptr) { + MemoryUtil.nmemFree(ptr); + } + + public static void freeBlock(MemoryBlock block) { + free(block.ptr()); + cpuMemory -= block.size(); + } + + @Deprecated + public static void freeBuffer(ByteBuffer buffer) { + free(MemoryUtil.memAddress(buffer)); + cpuMemory -= buffer.capacity(); + } + + public static void _allocCPUMemory(long size) { + cpuMemory += size; + } + + public static void _freeCPUMemory(long size) { + cpuMemory -= size; + } + + public static void _allocGPUMemory(long size) { + gpuMemory += size; + } + + public static void _freeGPUMemory(long size) { + gpuMemory -= size; + } + + public static long getCPUMemory() { + return cpuMemory; + } + + public static long getGPUMemory() { + return gpuMemory; + } +} diff --git a/src/main/java/com/jozufozu/flywheel/backend/memory/MemoryBlock.java b/src/main/java/com/jozufozu/flywheel/backend/memory/MemoryBlock.java new file mode 100644 index 000000000..c78b8c193 --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/backend/memory/MemoryBlock.java @@ -0,0 +1,45 @@ +package com.jozufozu.flywheel.backend.memory; + +import java.nio.ByteBuffer; + +public sealed interface MemoryBlock permits MemoryBlockImpl { + long ptr(); + + long size(); + + boolean isFreed(); + + boolean isTracked(); + + void copyTo(long ptr, long bytes); + + default void copyTo(long ptr) { + copyTo(ptr, size()); + } + + void clear(); + + ByteBuffer asBuffer(); + + MemoryBlock realloc(long size); + + MemoryBlock reallocTracked(long size); + + void free(); + + static MemoryBlock malloc(long size) { + return FlwMemoryTracker.mallocBlock(size); + } + + static MemoryBlock calloc(long num, long size) { + return FlwMemoryTracker.callocBlock(num, size); + } + + static MemoryBlock mallocTracked(long size) { + return FlwMemoryTracker.mallocBlockTracked(size); + } + + static MemoryBlock callocTracked(long num, long size) { + return FlwMemoryTracker.callocBlockTracked(num, size); + } +} diff --git a/src/main/java/com/jozufozu/flywheel/backend/memory/MemoryBlockImpl.java b/src/main/java/com/jozufozu/flywheel/backend/memory/MemoryBlockImpl.java new file mode 100644 index 000000000..1b6d984a6 --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/backend/memory/MemoryBlockImpl.java @@ -0,0 +1,76 @@ +package com.jozufozu.flywheel.backend.memory; + +import java.nio.ByteBuffer; + +import org.lwjgl.system.MemoryUtil; + +sealed class MemoryBlockImpl implements MemoryBlock permits TrackedMemoryBlockImpl { + final long ptr; + final long size; + + boolean freed; + + MemoryBlockImpl(long ptr, long size) { + this.ptr = ptr; + this.size = size; + } + + @Override + public long ptr() { + return ptr; + } + + @Override + public long size() { + return size; + } + + @Override + public boolean isFreed() { + return freed; + } + + @Override + public boolean isTracked() { + return false; + } + + @Override + public void copyTo(long ptr, long bytes) { + MemoryUtil.memCopy(this.ptr, ptr, bytes); + } + + @Override + public void clear() { + MemoryUtil.memSet(ptr, 0, size); + } + + @Override + public ByteBuffer asBuffer() { + int intSize = (int) size; + if (intSize != size) { + throw new UnsupportedOperationException("Cannot create buffer with long capacity!"); + } + return MemoryUtil.memByteBuffer(ptr, intSize); + } + + @Override + public MemoryBlock realloc(long size) { + MemoryBlock block = FlwMemoryTracker.reallocBlock(this, size); + freed = true; + return block; + } + + @Override + public MemoryBlock reallocTracked(long size) { + MemoryBlock block = FlwMemoryTracker.reallocBlockTracked(this, size); + freed = true; + return block; + } + + @Override + public void free() { + FlwMemoryTracker.freeBlock(this); + freed = true; + } +} diff --git a/src/main/java/com/jozufozu/flywheel/backend/memory/TrackedMemoryBlockImpl.java b/src/main/java/com/jozufozu/flywheel/backend/memory/TrackedMemoryBlockImpl.java new file mode 100644 index 000000000..40b1a15eb --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/backend/memory/TrackedMemoryBlockImpl.java @@ -0,0 +1,38 @@ +package com.jozufozu.flywheel.backend.memory; + +import java.lang.ref.Cleaner; + +final class TrackedMemoryBlockImpl extends MemoryBlockImpl { + Cleaner.Cleanable cleanable; + + TrackedMemoryBlockImpl(long ptr, long size) { + super(ptr, size); + } + + @Override + public boolean isTracked() { + return true; + } + + @Override + public MemoryBlock realloc(long size) { + MemoryBlock block = FlwMemoryTracker.reallocBlock(this, size); + freed = true; + cleanable.clean(); + return block; + } + + @Override + public MemoryBlock reallocTracked(long size) { + MemoryBlock block = FlwMemoryTracker.reallocBlockTracked(this, size); + freed = true; + cleanable.clean(); + return block; + } + + @Override + public void free() { + cleanable.clean(); + freed = true; + } +} diff --git a/src/main/java/com/jozufozu/flywheel/backend/struct/BufferWriter.java b/src/main/java/com/jozufozu/flywheel/backend/struct/BufferWriter.java deleted file mode 100644 index 49ce4969d..000000000 --- a/src/main/java/com/jozufozu/flywheel/backend/struct/BufferWriter.java +++ /dev/null @@ -1,40 +0,0 @@ -package com.jozufozu.flywheel.backend.struct; - -import java.nio.ByteBuffer; - -import com.jozufozu.flywheel.api.instancer.InstancedPart; -import com.jozufozu.flywheel.api.struct.StructType; -import com.jozufozu.flywheel.api.struct.StructWriter; - -public abstract class BufferWriter implements StructWriter { - protected final ByteBuffer backingBuffer; - - protected final int stride; - - protected BufferWriter(StructType structType, ByteBuffer byteBuffer) { - this.backingBuffer = byteBuffer; - - this.stride = structType.getLayout().getStride(); - } - - @Override - public final void write(S struct) { - writeInternal(struct); - advance(); - } - - /** - * Advances the write pointer forward by the stride of one vertex. - * This will always be called after a struct is written, implementors need not call it themselves. - * - * @see #write - */ - protected abstract void advance(); - - protected abstract void writeInternal(S s); - - @Override - public void seek(int pos) { - backingBuffer.position(pos * stride); - } -} diff --git a/src/main/java/com/jozufozu/flywheel/backend/struct/UnsafeBufferWriter.java b/src/main/java/com/jozufozu/flywheel/backend/struct/UnsafeBufferWriter.java deleted file mode 100644 index 7aa852de1..000000000 --- a/src/main/java/com/jozufozu/flywheel/backend/struct/UnsafeBufferWriter.java +++ /dev/null @@ -1,45 +0,0 @@ -package com.jozufozu.flywheel.backend.struct; - -import java.nio.ByteBuffer; - -import org.lwjgl.system.MemoryUtil; - -import com.jozufozu.flywheel.api.instancer.InstancedPart; -import com.jozufozu.flywheel.api.struct.StructType; - -/** - * This class copied/adapted from jellysquid's - * - * An unsafe {@link BufferWriter} implementation which uses direct memory operations to enable fast blitting of - * data into memory buffers. Only available on JVMs which support {@link sun.misc.Unsafe}, but generally produces much - * better optimized code than other implementations. The implementation does not check for invalid memory accesses, - * meaning that errors can corrupt process memory. - */ -public abstract class UnsafeBufferWriter extends BufferWriter { - /** - * The write pointer into the buffer storage. This is advanced by the stride every time - * {@link UnsafeBufferWriter#advance()} is called. - */ - protected long writePointer; - - protected UnsafeBufferWriter(StructType structType, ByteBuffer byteBuffer) { - super(structType, byteBuffer); - - acquireWritePointer(); - } - - @Override - public void seek(int pos) { - super.seek(pos); - acquireWritePointer(); - } - - @Override - protected void advance() { - this.writePointer += this.stride; - } - - private void acquireWritePointer() { - this.writePointer = MemoryUtil.memAddress(this.backingBuffer, this.backingBuffer.position()); - } -} diff --git a/src/main/java/com/jozufozu/flywheel/backend/struct/package-info.java b/src/main/java/com/jozufozu/flywheel/backend/struct/package-info.java deleted file mode 100644 index d4cbaadf2..000000000 --- a/src/main/java/com/jozufozu/flywheel/backend/struct/package-info.java +++ /dev/null @@ -1,6 +0,0 @@ -@ParametersAreNonnullByDefault @MethodsReturnNonnullByDefault -package com.jozufozu.flywheel.backend.struct; - -import javax.annotation.ParametersAreNonnullByDefault; - -import net.minecraft.MethodsReturnNonnullByDefault; diff --git a/src/main/java/com/jozufozu/flywheel/core/hardcoded/ModelPart.java b/src/main/java/com/jozufozu/flywheel/core/hardcoded/ModelPart.java index 7369df882..4dc301213 100644 --- a/src/main/java/com/jozufozu/flywheel/core/hardcoded/ModelPart.java +++ b/src/main/java/com/jozufozu/flywheel/core/hardcoded/ModelPart.java @@ -1,20 +1,17 @@ package com.jozufozu.flywheel.core.hardcoded; -import java.nio.ByteBuffer; import java.util.List; -import org.lwjgl.system.MemoryUtil; - import com.jozufozu.flywheel.api.vertex.MutableVertexList; import com.jozufozu.flywheel.api.vertex.ReusableVertexList; +import com.jozufozu.flywheel.backend.memory.MemoryBlock; import com.jozufozu.flywheel.core.model.Mesh; import com.jozufozu.flywheel.core.vertex.Formats; import com.jozufozu.flywheel.core.vertex.PosTexNormalVertex; -import com.mojang.blaze3d.platform.MemoryTracker; public class ModelPart implements Mesh { private final int vertexCount; - private final ByteBuffer contents; + private final MemoryBlock contents; private final ReusableVertexList vertexList; private final String name; @@ -29,8 +26,8 @@ public class ModelPart implements Mesh { this.vertexCount = vertices; } - contents = MemoryTracker.create(size()); - long ptr = MemoryUtil.memAddress(contents); + contents = MemoryBlock.malloc(size()); + long ptr = contents.ptr(); VertexWriter writer = new VertexWriterImpl(ptr); for (PartBuilder.CuboidBuilder cuboid : cuboids) { cuboid.write(writer); @@ -56,19 +53,18 @@ public class ModelPart implements Mesh { } @Override - public void writeInto(ByteBuffer buffer, long byteIndex) { - buffer.position((int) byteIndex); - MemoryUtil.memCopy(contents, buffer); + public void write(long ptr) { + contents.copyTo(ptr); } @Override - public void writeInto(MutableVertexList dst) { + public void write(MutableVertexList dst) { vertexList.writeAll(dst); } @Override public void close() { - MemoryUtil.memFree(contents); + contents.free(); } @Override diff --git a/src/main/java/com/jozufozu/flywheel/core/model/Mesh.java b/src/main/java/com/jozufozu/flywheel/core/model/Mesh.java index f09c5ec58..a1a4f10c2 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/Mesh.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/Mesh.java @@ -1,7 +1,5 @@ package com.jozufozu.flywheel.core.model; -import java.nio.ByteBuffer; - import com.jozufozu.flywheel.api.vertex.MutableVertexList; import com.jozufozu.flywheel.api.vertex.VertexType; import com.jozufozu.flywheel.backend.instancing.instancing.ElementBuffer; @@ -51,9 +49,9 @@ public interface Mesh { return getVertexType().byteOffset(getVertexCount()); } - void writeInto(ByteBuffer buffer, long byteIndex); + void write(long ptr); - void writeInto(MutableVertexList vertexList); + void write(MutableVertexList vertexList); /** * Create an element buffer object that indexes the vertices of this mesh. diff --git a/src/main/java/com/jozufozu/flywheel/core/model/ModelUtil.java b/src/main/java/com/jozufozu/flywheel/core/model/ModelUtil.java index dfcd1435a..9a68168ff 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/ModelUtil.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/ModelUtil.java @@ -10,10 +10,10 @@ import com.jozufozu.flywheel.Flywheel; import com.jozufozu.flywheel.api.material.Material; import com.jozufozu.flywheel.api.vertex.ReusableVertexList; import com.jozufozu.flywheel.api.vertex.VertexType; +import com.jozufozu.flywheel.backend.memory.MemoryBlock; import com.jozufozu.flywheel.core.Materials; import com.jozufozu.flywheel.core.vertex.Formats; import com.jozufozu.flywheel.core.vertex.VertexListProviderRegistry; -import com.mojang.blaze3d.platform.MemoryTracker; import com.mojang.blaze3d.vertex.BufferBuilder.DrawState; import com.mojang.blaze3d.vertex.VertexFormat; import com.mojang.datafixers.util.Pair; @@ -47,16 +47,16 @@ public class ModelUtil { return dispatcher; } - public static Pair convertBlockBuffer(Pair pair) { + public static Pair convertBlockBuffer(Pair pair) { DrawState drawState = pair.getFirst(); int vertexCount = drawState.vertexCount(); VertexFormat srcFormat = drawState.format(); VertexType dstVertexType = Formats.BLOCK; ByteBuffer src = pair.getSecond(); - ByteBuffer dst = MemoryTracker.create(src.capacity()); + MemoryBlock dst = MemoryBlock.malloc(src.capacity()); long srcPtr = MemoryUtil.memAddress(src); - long dstPtr = MemoryUtil.memAddress(dst); + long dstPtr = dst.ptr(); ReusableVertexList srcList = VertexListProviderRegistry.getOrInfer(srcFormat).createVertexList(); ReusableVertexList dstList = dstVertexType.createVertexList(); diff --git a/src/main/java/com/jozufozu/flywheel/core/model/SimpleMesh.java b/src/main/java/com/jozufozu/flywheel/core/model/SimpleMesh.java index f95423005..d184a05d6 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/SimpleMesh.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/SimpleMesh.java @@ -1,35 +1,31 @@ package com.jozufozu.flywheel.core.model; -import java.nio.ByteBuffer; - -import org.lwjgl.system.MemoryUtil; - import com.jozufozu.flywheel.api.vertex.MutableVertexList; import com.jozufozu.flywheel.api.vertex.ReusableVertexList; import com.jozufozu.flywheel.api.vertex.VertexType; +import com.jozufozu.flywheel.backend.memory.MemoryBlock; public class SimpleMesh implements Mesh { private final VertexType vertexType; private final int vertexCount; - private final ByteBuffer contents; + private final MemoryBlock contents; private final ReusableVertexList vertexList; private final String name; - public SimpleMesh(VertexType vertexType, ByteBuffer contents, String name) { + public SimpleMesh(VertexType vertexType, MemoryBlock contents, String name) { this.vertexType = vertexType; this.contents = contents; this.name = name; - contents.clear(); - int bytes = contents.remaining(); + int bytes = (int) contents.size(); int stride = vertexType.getStride(); if (bytes % stride != 0) { - throw new IllegalArgumentException("Buffer contains non-whole amount of vertices!"); + throw new IllegalArgumentException("MemoryBlock contains non-whole amount of vertices!"); } vertexCount = bytes / stride; vertexList = getVertexType().createVertexList(); - vertexList.ptr(MemoryUtil.memAddress(contents)); + vertexList.ptr(contents.ptr()); vertexList.setVertexCount(vertexCount); } @@ -44,19 +40,18 @@ public class SimpleMesh implements Mesh { } @Override - public void writeInto(ByteBuffer buffer, long byteIndex) { - buffer.position((int) byteIndex); - MemoryUtil.memCopy(contents, buffer); + public void write(long ptr) { + contents.copyTo(ptr); } @Override - public void writeInto(MutableVertexList dst) { + public void write(MutableVertexList dst) { vertexList.writeAll(dst); } @Override public void close() { - MemoryUtil.memFree(contents); + contents.free(); } @Override diff --git a/src/main/java/com/jozufozu/flywheel/core/model/buffering/BakedModelBuilder.java b/src/main/java/com/jozufozu/flywheel/core/model/buffering/BakedModelBuilder.java index d7c138d00..e0ca37b16 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/buffering/BakedModelBuilder.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/buffering/BakedModelBuilder.java @@ -1,11 +1,11 @@ package com.jozufozu.flywheel.core.model.buffering; -import java.nio.ByteBuffer; import java.util.function.BiFunction; import com.google.common.collect.ImmutableMap; import com.jozufozu.flywheel.api.material.Material; import com.jozufozu.flywheel.api.vertex.VertexType; +import com.jozufozu.flywheel.backend.memory.MemoryBlock; import com.jozufozu.flywheel.core.model.Mesh; import com.jozufozu.flywheel.core.model.ModelUtil; import com.jozufozu.flywheel.core.model.SimpleMesh; @@ -104,7 +104,7 @@ public class BakedModelBuilder { buffer.end(); Material material = materialFunc.apply(renderType, shaded); if (material != null) { - Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); + Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); meshMapBuilder.put(material, new SimpleMesh(pair.getFirst(), pair.getSecond(), "bakedModel=" + bakedModel.toString() + ",renderType=" + renderType.toString() + ",shaded=" + shaded)); } }; @@ -119,7 +119,7 @@ public class BakedModelBuilder { buffer.end(); Material material = materialFunc.apply(renderType, false); if (material != null) { - Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); + Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); meshMapBuilder.put(material, new SimpleMesh(pair.getFirst(), pair.getSecond(), "bakedModel=" + bakedModel.toString() + ",renderType=" + renderType.toString())); } }; diff --git a/src/main/java/com/jozufozu/flywheel/core/model/buffering/BlockModelBuilder.java b/src/main/java/com/jozufozu/flywheel/core/model/buffering/BlockModelBuilder.java index f5d0c485e..84686aa74 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/buffering/BlockModelBuilder.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/buffering/BlockModelBuilder.java @@ -1,11 +1,11 @@ package com.jozufozu.flywheel.core.model.buffering; -import java.nio.ByteBuffer; import java.util.function.BiFunction; import com.google.common.collect.ImmutableMap; import com.jozufozu.flywheel.api.material.Material; import com.jozufozu.flywheel.api.vertex.VertexType; +import com.jozufozu.flywheel.backend.memory.MemoryBlock; import com.jozufozu.flywheel.core.model.Mesh; import com.jozufozu.flywheel.core.model.ModelUtil; import com.jozufozu.flywheel.core.model.SimpleMesh; @@ -93,7 +93,7 @@ public class BlockModelBuilder { buffer.end(); Material material = materialFunc.apply(renderType, shaded); if (material != null) { - Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); + Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); meshMapBuilder.put(material, new SimpleMesh(pair.getFirst(), pair.getSecond(), "state=" + state.toString() + ",renderType=" + renderType.toString() + ",shaded=" + shaded)); } }; @@ -108,7 +108,7 @@ public class BlockModelBuilder { buffer.end(); Material material = materialFunc.apply(renderType, false); if (material != null) { - Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); + Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); meshMapBuilder.put(material, new SimpleMesh(pair.getFirst(), pair.getSecond(), "state=" + state.toString() + ",renderType=" + renderType.toString())); } }; diff --git a/src/main/java/com/jozufozu/flywheel/core/model/buffering/MultiBlockModelBuilder.java b/src/main/java/com/jozufozu/flywheel/core/model/buffering/MultiBlockModelBuilder.java index c951acfbd..b329a46c6 100644 --- a/src/main/java/com/jozufozu/flywheel/core/model/buffering/MultiBlockModelBuilder.java +++ b/src/main/java/com/jozufozu/flywheel/core/model/buffering/MultiBlockModelBuilder.java @@ -1,6 +1,5 @@ package com.jozufozu.flywheel.core.model.buffering; -import java.nio.ByteBuffer; import java.util.Collection; import java.util.Collections; import java.util.Map; @@ -9,6 +8,7 @@ import java.util.function.BiFunction; import com.google.common.collect.ImmutableMap; import com.jozufozu.flywheel.api.material.Material; import com.jozufozu.flywheel.api.vertex.VertexType; +import com.jozufozu.flywheel.backend.memory.MemoryBlock; import com.jozufozu.flywheel.core.model.Mesh; import com.jozufozu.flywheel.core.model.ModelUtil; import com.jozufozu.flywheel.core.model.SimpleMesh; @@ -100,7 +100,7 @@ public class MultiBlockModelBuilder { buffer.end(); Material material = materialFunc.apply(renderType, shaded); if (material != null) { - Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); + Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); meshMapBuilder.put(material, new SimpleMesh(pair.getFirst(), pair.getSecond(), "renderType=" + renderType.toString() + ",shaded=" + shaded)); } }; @@ -115,7 +115,7 @@ public class MultiBlockModelBuilder { buffer.end(); Material material = materialFunc.apply(renderType, false); if (material != null) { - Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); + Pair pair = ModelUtil.convertBlockBuffer(buffer.popNextBuffer()); meshMapBuilder.put(material, new SimpleMesh(pair.getFirst(), pair.getSecond(), "renderType=" + renderType.toString())); } }; diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/ColoredLitWriter.java b/src/main/java/com/jozufozu/flywheel/core/structs/ColoredLitWriter.java new file mode 100644 index 000000000..dcd23aca0 --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/core/structs/ColoredLitWriter.java @@ -0,0 +1,17 @@ +package com.jozufozu.flywheel.core.structs; + +import org.lwjgl.system.MemoryUtil; + +import com.jozufozu.flywheel.api.struct.StructWriter; + +public abstract class ColoredLitWriter implements StructWriter { + @Override + public void write(long ptr, D d) { + MemoryUtil.memPutByte(ptr, d.blockLight); + MemoryUtil.memPutByte(ptr + 1, d.skyLight); + MemoryUtil.memPutByte(ptr + 2, d.r); + MemoryUtil.memPutByte(ptr + 3, d.g); + MemoryUtil.memPutByte(ptr + 4, d.b); + MemoryUtil.memPutByte(ptr + 5, d.a); + } +} diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/ColoredLitWriterUnsafe.java b/src/main/java/com/jozufozu/flywheel/core/structs/ColoredLitWriterUnsafe.java deleted file mode 100644 index 985fc7046..000000000 --- a/src/main/java/com/jozufozu/flywheel/core/structs/ColoredLitWriterUnsafe.java +++ /dev/null @@ -1,26 +0,0 @@ -package com.jozufozu.flywheel.core.structs; - -import java.nio.ByteBuffer; - -import org.lwjgl.system.MemoryUtil; - -import com.jozufozu.flywheel.api.struct.StructType; -import com.jozufozu.flywheel.backend.struct.UnsafeBufferWriter; - -public abstract class ColoredLitWriterUnsafe extends UnsafeBufferWriter { - - public ColoredLitWriterUnsafe(StructType structType, ByteBuffer byteBuffer) { - super(structType, byteBuffer); - } - - @Override - protected void writeInternal(D d) { - long ptr = writePointer; - MemoryUtil.memPutByte(ptr, d.blockLight); - MemoryUtil.memPutByte(ptr + 1, d.skyLight); - MemoryUtil.memPutByte(ptr + 2, d.r); - MemoryUtil.memPutByte(ptr + 3, d.g); - MemoryUtil.memPutByte(ptr + 4, d.b); - MemoryUtil.memPutByte(ptr + 5, d.a); - } -} diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/StructTypes.java b/src/main/java/com/jozufozu/flywheel/core/structs/StructTypes.java index 96015bf27..597a2a43c 100644 --- a/src/main/java/com/jozufozu/flywheel/core/structs/StructTypes.java +++ b/src/main/java/com/jozufozu/flywheel/core/structs/StructTypes.java @@ -2,10 +2,10 @@ package com.jozufozu.flywheel.core.structs; import com.jozufozu.flywheel.api.struct.StructType; import com.jozufozu.flywheel.core.ComponentRegistry; -import com.jozufozu.flywheel.core.structs.model.TransformedPart; -import com.jozufozu.flywheel.core.structs.model.TransformedType; import com.jozufozu.flywheel.core.structs.oriented.OrientedPart; import com.jozufozu.flywheel.core.structs.oriented.OrientedType; +import com.jozufozu.flywheel.core.structs.transformed.TransformedPart; +import com.jozufozu.flywheel.core.structs.transformed.TransformedType; public class StructTypes { public static final StructType TRANSFORMED = ComponentRegistry.register(new TransformedType()); diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedWriterUnsafe.java b/src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedWriterUnsafe.java deleted file mode 100644 index 8634e0db7..000000000 --- a/src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedWriterUnsafe.java +++ /dev/null @@ -1,23 +0,0 @@ -package com.jozufozu.flywheel.core.structs.model; - -import java.nio.ByteBuffer; - -import com.jozufozu.flywheel.api.struct.StructType; -import com.jozufozu.flywheel.core.structs.ColoredLitWriterUnsafe; -import com.jozufozu.flywheel.util.MatrixWrite; - -public class TransformedWriterUnsafe extends ColoredLitWriterUnsafe { - - public TransformedWriterUnsafe(StructType structType, ByteBuffer byteBuffer) { - super(structType, byteBuffer); - } - - @Override - protected void writeInternal(TransformedPart d) { - super.writeInternal(d); - long ptr = writePointer + 6; - - ((MatrixWrite) (Object) d.model).flywheel$writeUnsafe(ptr); - ((MatrixWrite) (Object) d.normal).flywheel$writeUnsafe(ptr + 4 * 16); - } -} diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedType.java b/src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedType.java index 93a0226ef..66f2653f5 100644 --- a/src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedType.java +++ b/src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedType.java @@ -1,7 +1,5 @@ package com.jozufozu.flywheel.core.structs.oriented; -import java.nio.ByteBuffer; - import com.jozufozu.flywheel.api.struct.StructType; import com.jozufozu.flywheel.api.struct.StructWriter; import com.jozufozu.flywheel.core.Components; @@ -32,8 +30,8 @@ public class OrientedType implements StructType { } @Override - public StructWriter getWriter(ByteBuffer backing) { - return new OrientedWriterUnsafe(this, backing); + public StructWriter getWriter() { + return OrientedWriter.INSTANCE; } @Override @@ -42,7 +40,7 @@ public class OrientedType implements StructType { } @Override - public VertexTransformer getVertexTransformer() { + public VertexTransformer getVertexTransformer() { return (vertexList, struct, level) -> { Vector4f pos = new Vector4f(); Vector3f normal = new Vector3f(); diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedWriterUnsafe.java b/src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedWriter.java similarity index 54% rename from src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedWriterUnsafe.java rename to src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedWriter.java index fb03c4d1e..8aa99cef4 100644 --- a/src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedWriterUnsafe.java +++ b/src/main/java/com/jozufozu/flywheel/core/structs/oriented/OrientedWriter.java @@ -1,21 +1,15 @@ package com.jozufozu.flywheel.core.structs.oriented; -import java.nio.ByteBuffer; - import org.lwjgl.system.MemoryUtil; -import com.jozufozu.flywheel.api.struct.StructType; -import com.jozufozu.flywheel.core.structs.ColoredLitWriterUnsafe; +import com.jozufozu.flywheel.core.structs.ColoredLitWriter; -public class OrientedWriterUnsafe extends ColoredLitWriterUnsafe { - public OrientedWriterUnsafe(StructType structType, ByteBuffer byteBuffer) { - super(structType, byteBuffer); - } +public class OrientedWriter extends ColoredLitWriter { + public static final OrientedWriter INSTANCE = new OrientedWriter(); @Override - protected void writeInternal(OrientedPart d) { - long ptr = writePointer; - super.writeInternal(d); + public void write(long ptr, OrientedPart d) { + super.write(ptr, d); MemoryUtil.memPutFloat(ptr + 6, d.posX); MemoryUtil.memPutFloat(ptr + 10, d.posY); diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedPart.java b/src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedPart.java similarity index 97% rename from src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedPart.java rename to src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedPart.java index 865f5bccd..215bfd913 100644 --- a/src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedPart.java +++ b/src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedPart.java @@ -1,4 +1,4 @@ -package com.jozufozu.flywheel.core.structs.model; +package com.jozufozu.flywheel.core.structs.transformed; import com.jozufozu.flywheel.core.structs.ColoredLitPart; import com.jozufozu.flywheel.core.structs.StructTypes; diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedType.java b/src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedType.java similarity index 86% rename from src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedType.java rename to src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedType.java index 30d750672..8eb36eeb6 100644 --- a/src/main/java/com/jozufozu/flywheel/core/structs/model/TransformedType.java +++ b/src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedType.java @@ -1,6 +1,4 @@ -package com.jozufozu.flywheel.core.structs.model; - -import java.nio.ByteBuffer; +package com.jozufozu.flywheel.core.structs.transformed; import com.jozufozu.flywheel.api.struct.StructType; import com.jozufozu.flywheel.api.struct.StructWriter; @@ -29,8 +27,8 @@ public class TransformedType implements StructType { } @Override - public StructWriter getWriter(ByteBuffer backing) { - return new TransformedWriterUnsafe(this, backing); + public StructWriter getWriter() { + return TransformedWriter.INSTANCE; } @Override @@ -39,7 +37,7 @@ public class TransformedType implements StructType { } @Override - public VertexTransformer getVertexTransformer() { + public VertexTransformer getVertexTransformer() { return (vertexList, struct, level) -> { Vector4f pos = new Vector4f(); Vector3f normal = new Vector3f(); diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedWriter.java b/src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedWriter.java new file mode 100644 index 000000000..eb910d6fb --- /dev/null +++ b/src/main/java/com/jozufozu/flywheel/core/structs/transformed/TransformedWriter.java @@ -0,0 +1,17 @@ +package com.jozufozu.flywheel.core.structs.transformed; + +import com.jozufozu.flywheel.core.structs.ColoredLitWriter; +import com.jozufozu.flywheel.util.MatrixWrite; + +public class TransformedWriter extends ColoredLitWriter { + public static final TransformedWriter INSTANCE = new TransformedWriter(); + + @Override + public void write(long ptr, TransformedPart d) { + super.write(ptr, d); + ptr += 6; + + ((MatrixWrite) (Object) d.model).flywheel$writeUnsafe(ptr); + ((MatrixWrite) (Object) d.normal).flywheel$writeUnsafe(ptr + 4 * 16); + } +} diff --git a/src/main/java/com/jozufozu/flywheel/core/structs/model/package-info.java b/src/main/java/com/jozufozu/flywheel/core/structs/transformed/package-info.java similarity index 75% rename from src/main/java/com/jozufozu/flywheel/core/structs/model/package-info.java rename to src/main/java/com/jozufozu/flywheel/core/structs/transformed/package-info.java index 759c3a038..2ca2a5ed4 100644 --- a/src/main/java/com/jozufozu/flywheel/core/structs/model/package-info.java +++ b/src/main/java/com/jozufozu/flywheel/core/structs/transformed/package-info.java @@ -1,5 +1,5 @@ @ParametersAreNonnullByDefault @MethodsReturnNonnullByDefault -package com.jozufozu.flywheel.core.structs.model; +package com.jozufozu.flywheel.core.structs.transformed; import javax.annotation.ParametersAreNonnullByDefault; diff --git a/src/main/java/com/jozufozu/flywheel/core/uniform/FogProvider.java b/src/main/java/com/jozufozu/flywheel/core/uniform/FogProvider.java index 9a7586c41..9bea01220 100644 --- a/src/main/java/com/jozufozu/flywheel/core/uniform/FogProvider.java +++ b/src/main/java/com/jozufozu/flywheel/core/uniform/FogProvider.java @@ -9,8 +9,6 @@ import com.mojang.blaze3d.systems.RenderSystem; public class FogProvider extends UniformProvider { - - @Override public int getSize() { return 16 + 8 + 4; diff --git a/src/main/java/com/jozufozu/flywheel/core/uniform/UniformBuffer.java b/src/main/java/com/jozufozu/flywheel/core/uniform/UniformBuffer.java index 5f3b10bb7..068fbc4c0 100644 --- a/src/main/java/com/jozufozu/flywheel/core/uniform/UniformBuffer.java +++ b/src/main/java/com/jozufozu/flywheel/core/uniform/UniformBuffer.java @@ -12,9 +12,9 @@ import com.google.common.collect.ImmutableList; import com.jozufozu.flywheel.api.uniform.UniformProvider; import com.jozufozu.flywheel.backend.gl.buffer.GlBufferType; import com.jozufozu.flywheel.backend.gl.buffer.MappedGlBuffer; +import com.jozufozu.flywheel.backend.memory.FlwMemoryTracker; import com.jozufozu.flywheel.core.ComponentRegistry; import com.jozufozu.flywheel.util.RenderMath; -import com.mojang.blaze3d.platform.MemoryTracker; public class UniformBuffer { @@ -57,7 +57,7 @@ public class UniformBuffer { allocatedProviders = builder.build(); - data = MemoryTracker.create(totalBytes); + data = FlwMemoryTracker.mallocBuffer(totalBytes); changedBytes = new BitSet(totalBytes); for (Allocated p : allocatedProviders) { diff --git a/src/main/java/com/jozufozu/flywheel/event/ForgeEvents.java b/src/main/java/com/jozufozu/flywheel/event/ForgeEvents.java index 1310235f7..26bc79290 100644 --- a/src/main/java/com/jozufozu/flywheel/event/ForgeEvents.java +++ b/src/main/java/com/jozufozu/flywheel/event/ForgeEvents.java @@ -4,8 +4,8 @@ import java.util.ArrayList; import com.jozufozu.flywheel.Flywheel; import com.jozufozu.flywheel.backend.Backend; -import com.jozufozu.flywheel.backend.FlywheelMemory; import com.jozufozu.flywheel.backend.instancing.InstancedRenderDispatcher; +import com.jozufozu.flywheel.backend.memory.FlwMemoryTracker; import com.jozufozu.flywheel.light.LightUpdater; import com.jozufozu.flywheel.util.WorldAttached; @@ -24,10 +24,7 @@ public class ForgeEvents { InstancedRenderDispatcher.getDebugString(debug); - // TODO: compress into one line - debug.add("Memory used:"); - debug.add("GPU: " + FlywheelMemory.getGPUMemory()); - debug.add("CPU: " + FlywheelMemory.getCPUMemory()); + debug.add("Memory Usage: CPU: " + FlwMemoryTracker.getCPUMemory() / 1024 + "KiB GPU: " + FlwMemoryTracker.getGPUMemory() / 1024 + "KiB"); } } diff --git a/src/main/java/com/jozufozu/flywheel/light/LightVolume.java b/src/main/java/com/jozufozu/flywheel/light/LightVolume.java index 31245dea9..cf4abacb1 100644 --- a/src/main/java/com/jozufozu/flywheel/light/LightVolume.java +++ b/src/main/java/com/jozufozu/flywheel/light/LightVolume.java @@ -2,8 +2,7 @@ package com.jozufozu.flywheel.light; import java.nio.ByteBuffer; -import org.lwjgl.system.MemoryUtil; - +import com.jozufozu.flywheel.backend.memory.FlwMemoryTracker; import com.jozufozu.flywheel.util.box.GridAlignedBB; import com.jozufozu.flywheel.util.box.ImmutableBox; @@ -21,7 +20,7 @@ public class LightVolume implements ImmutableBox, LightListener { this.level = level; this.setBox(sampleVolume); - this.lightData = MemoryUtil.memAlloc(this.box.volume() * 2); + this.lightData = FlwMemoryTracker.mallocBuffer(this.box.volume() * 2); } protected void setBox(ImmutableBox box) { @@ -66,7 +65,7 @@ public class LightVolume implements ImmutableBox, LightListener { setBox(newSampleVolume); int neededCapacity = box.volume() * 2; if (neededCapacity > lightData.capacity()) { - lightData = MemoryUtil.memRealloc(lightData, neededCapacity); + lightData = FlwMemoryTracker.reallocBuffer(lightData, neededCapacity); } initialize(); } @@ -168,7 +167,7 @@ public class LightVolume implements ImmutableBox, LightListener { } public void delete() { - MemoryUtil.memFree(lightData); + FlwMemoryTracker.freeBuffer(lightData); lightData = null; } diff --git a/src/main/java/com/jozufozu/flywheel/util/StringUtil.java b/src/main/java/com/jozufozu/flywheel/util/StringUtil.java index 054bf0f43..4b7049b74 100644 --- a/src/main/java/com/jozufozu/flywheel/util/StringUtil.java +++ b/src/main/java/com/jozufozu/flywheel/util/StringUtil.java @@ -15,6 +15,8 @@ import java.util.stream.Collectors; import org.lwjgl.system.MemoryUtil; +import com.jozufozu.flywheel.backend.memory.FlwMemoryTracker; + public class StringUtil { private static final NumberFormat timeFormat = new DecimalFormat("#0.000"); @@ -56,11 +58,11 @@ public class StringUtil { ((Buffer) bytebuffer).rewind(); return MemoryUtil.memASCII(bytebuffer, i); } catch (IOException ignored) { + // } finally { if (bytebuffer != null) { - MemoryUtil.memFree(bytebuffer); + FlwMemoryTracker.freeBuffer(bytebuffer); } - } return null; @@ -75,12 +77,12 @@ public class StringUtil { } private static ByteBuffer readInputStream(InputStream is) throws IOException { - ByteBuffer bytebuffer = MemoryUtil.memAlloc(8192); + ByteBuffer bytebuffer = FlwMemoryTracker.mallocBuffer(8192); ReadableByteChannel readablebytechannel = Channels.newChannel(is); while (readablebytechannel.read(bytebuffer) != -1) { if (bytebuffer.remaining() == 0) { - bytebuffer = MemoryUtil.memRealloc(bytebuffer, bytebuffer.capacity() * 2); + bytebuffer = FlwMemoryTracker.reallocBuffer(bytebuffer, bytebuffer.capacity() * 2); } } return bytebuffer; @@ -88,7 +90,7 @@ public class StringUtil { private static ByteBuffer readFileInputStream(FileInputStream fileinputstream) throws IOException { FileChannel filechannel = fileinputstream.getChannel(); - ByteBuffer bytebuffer = MemoryUtil.memAlloc((int) filechannel.size() + 1); + ByteBuffer bytebuffer = FlwMemoryTracker.mallocBuffer((int) filechannel.size() + 1); while (filechannel.read(bytebuffer) != -1) { } diff --git a/src/main/java/com/jozufozu/flywheel/vanilla/ChestInstance.java b/src/main/java/com/jozufozu/flywheel/vanilla/ChestInstance.java index 39e6650fb..0089766d2 100644 --- a/src/main/java/com/jozufozu/flywheel/vanilla/ChestInstance.java +++ b/src/main/java/com/jozufozu/flywheel/vanilla/ChestInstance.java @@ -15,8 +15,8 @@ import com.jozufozu.flywheel.core.Materials; import com.jozufozu.flywheel.core.hardcoded.ModelPart; import com.jozufozu.flywheel.core.model.SimpleLazyModel; import com.jozufozu.flywheel.core.structs.StructTypes; -import com.jozufozu.flywheel.core.structs.model.TransformedPart; import com.jozufozu.flywheel.core.structs.oriented.OrientedPart; +import com.jozufozu.flywheel.core.structs.transformed.TransformedPart; import com.jozufozu.flywheel.util.AnimationTickHolder; import com.mojang.math.Quaternion; import com.mojang.math.Vector3f; diff --git a/src/main/java/com/jozufozu/flywheel/vanilla/MinecartInstance.java b/src/main/java/com/jozufozu/flywheel/vanilla/MinecartInstance.java index e12f6d37e..d1ae67501 100644 --- a/src/main/java/com/jozufozu/flywheel/vanilla/MinecartInstance.java +++ b/src/main/java/com/jozufozu/flywheel/vanilla/MinecartInstance.java @@ -12,7 +12,7 @@ import com.jozufozu.flywheel.core.model.Mesh; import com.jozufozu.flywheel.core.model.Models; import com.jozufozu.flywheel.core.model.SimpleLazyModel; import com.jozufozu.flywheel.core.structs.StructTypes; -import com.jozufozu.flywheel.core.structs.model.TransformedPart; +import com.jozufozu.flywheel.core.structs.transformed.TransformedPart; import com.jozufozu.flywheel.util.AnimationTickHolder; import com.jozufozu.flywheel.util.transform.TransformStack; import com.mojang.blaze3d.vertex.PoseStack; diff --git a/src/main/java/com/jozufozu/flywheel/vanilla/ShulkerBoxInstance.java b/src/main/java/com/jozufozu/flywheel/vanilla/ShulkerBoxInstance.java index cc9aadb8a..cfe63f41d 100644 --- a/src/main/java/com/jozufozu/flywheel/vanilla/ShulkerBoxInstance.java +++ b/src/main/java/com/jozufozu/flywheel/vanilla/ShulkerBoxInstance.java @@ -12,7 +12,7 @@ import com.jozufozu.flywheel.core.Materials; import com.jozufozu.flywheel.core.hardcoded.ModelPart; import com.jozufozu.flywheel.core.model.SimpleLazyModel; import com.jozufozu.flywheel.core.structs.StructTypes; -import com.jozufozu.flywheel.core.structs.model.TransformedPart; +import com.jozufozu.flywheel.core.structs.transformed.TransformedPart; import com.jozufozu.flywheel.util.AnimationTickHolder; import com.jozufozu.flywheel.util.transform.TransformStack; import com.mojang.blaze3d.vertex.PoseStack; diff --git a/src/main/java/com/jozufozu/flywheel/vanilla/effect/ExampleEffect.java b/src/main/java/com/jozufozu/flywheel/vanilla/effect/ExampleEffect.java index 5c583534c..c0adede2e 100644 --- a/src/main/java/com/jozufozu/flywheel/vanilla/effect/ExampleEffect.java +++ b/src/main/java/com/jozufozu/flywheel/vanilla/effect/ExampleEffect.java @@ -13,7 +13,7 @@ import com.jozufozu.flywheel.backend.instancing.InstancedRenderDispatcher; import com.jozufozu.flywheel.backend.instancing.effect.Effect; import com.jozufozu.flywheel.core.model.Models; import com.jozufozu.flywheel.core.structs.StructTypes; -import com.jozufozu.flywheel.core.structs.model.TransformedPart; +import com.jozufozu.flywheel.core.structs.transformed.TransformedPart; import com.jozufozu.flywheel.event.ReloadRenderersEvent; import com.jozufozu.flywheel.util.AnimationTickHolder; import com.jozufozu.flywheel.util.box.GridAlignedBB;