aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0346-Guard-against-serializing-mismatching-chunk-coordina.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0346-Guard-against-serializing-mismatching-chunk-coordina.patch')
-rw-r--r--patches/server/0346-Guard-against-serializing-mismatching-chunk-coordina.patch57
1 files changed, 57 insertions, 0 deletions
diff --git a/patches/server/0346-Guard-against-serializing-mismatching-chunk-coordina.patch b/patches/server/0346-Guard-against-serializing-mismatching-chunk-coordina.patch
new file mode 100644
index 0000000000..64048f55c3
--- /dev/null
+++ b/patches/server/0346-Guard-against-serializing-mismatching-chunk-coordina.patch
@@ -0,0 +1,57 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Spottedleaf <[email protected]>
+Date: Fri, 27 Dec 2019 09:42:26 -0800
+Subject: [PATCH] Guard against serializing mismatching chunk coordinate
+
+Should help if something dumb happens
+
+diff --git a/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java b/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java
+index 9a4fe42da43037a65738b978c0c6c9969de59e76..73d26c9eb902f19b0c3ffdd911898845277655b0 100644
+--- a/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java
++++ b/src/main/java/net/minecraft/world/level/chunk/storage/ChunkSerializer.java
+@@ -77,6 +77,18 @@ public class ChunkSerializer {
+
+ public ChunkSerializer() {}
+
++ // Paper start - guard against serializing mismatching coordinates
++ // TODO Note: This needs to be re-checked each update
++ public static ChunkPos getChunkCoordinate(CompoundTag chunkData) {
++ final int dataVersion = ChunkStorage.getVersion(chunkData);
++ if (dataVersion < 2842) { // Level tag is removed after this version
++ final CompoundTag levelData = chunkData.getCompound("Level");
++ return new ChunkPos(levelData.getInt("xPos"), levelData.getInt("zPos"));
++ } else {
++ return new ChunkPos(chunkData.getInt("xPos"), chunkData.getInt("zPos"));
++ }
++ }
++ // Paper end
+ // Paper start
+ public static final class InProgressChunkHolder {
+
+@@ -102,7 +114,7 @@ public class ChunkSerializer {
+ public static InProgressChunkHolder loadChunk(ServerLevel world, PoiManager poiStorage, ChunkPos chunkPos, CompoundTag nbt, boolean distinguish) {
+ java.util.ArrayDeque<Runnable> tasksToExecuteOnMain = new java.util.ArrayDeque<>();
+ // Paper end
+- ChunkPos chunkcoordintpair1 = new ChunkPos(nbt.getInt("xPos"), nbt.getInt("zPos"));
++ ChunkPos chunkcoordintpair1 = new ChunkPos(nbt.getInt("xPos"), nbt.getInt("zPos")); // Paper - diff on change, see ChunkSerializer#getChunkCoordinate
+
+ if (!Objects.equals(chunkPos, chunkcoordintpair1)) {
+ ChunkSerializer.LOGGER.error("Chunk file at {} is in the wrong location; relocating. (Expected {}, got {})", new Object[]{chunkPos, chunkPos, chunkcoordintpair1});
+diff --git a/src/main/java/net/minecraft/world/level/chunk/storage/ChunkStorage.java b/src/main/java/net/minecraft/world/level/chunk/storage/ChunkStorage.java
+index ba677f282f2c8a05d1bad88226655549a81679bb..392fd2f5919d6a8f37c9f2b0421831d6ce381e0c 100644
+--- a/src/main/java/net/minecraft/world/level/chunk/storage/ChunkStorage.java
++++ b/src/main/java/net/minecraft/world/level/chunk/storage/ChunkStorage.java
+@@ -148,6 +148,13 @@ public class ChunkStorage implements AutoCloseable {
+
+ // Paper start - async chunk io
+ public void write(ChunkPos chunkPos, CompoundTag nbt) throws IOException {
++ // Paper start
++ if (!chunkPos.equals(ChunkSerializer.getChunkCoordinate(nbt))) {
++ String world = (this instanceof net.minecraft.server.level.ChunkMap) ? ((net.minecraft.server.level.ChunkMap)this).level.getWorld().getName() : null;
++ throw new IllegalArgumentException("Chunk coordinate and serialized data do not have matching coordinates, trying to serialize coordinate " + chunkPos.toString()
++ + " but compound says coordinate is " + ChunkSerializer.getChunkCoordinate(nbt).toString() + (world == null ? " for an unknown world" : (" for world: " + world)));
++ }
++ // Paper end
+ this.regionFileCache.write(chunkPos, nbt);
+ // Paper end - Async chunk loading
+ if (this.legacyStructureHandler != null) {