From 916ba4edaf803bffd9b24b165ee95b17c967b9f9 Mon Sep 17 00:00:00 2001 From: "Unknown W. Brackets" Date: Mon, 16 Mar 2020 21:17:23 -0700 Subject: [PATCH] Vpl: Correct allocation order when splitting block. More fuzz testing produced cases that were still off. This is simpler. --- Core/HLE/sceKernelMemory.cpp | 11 ++--------- 1 file changed, 2 insertions(+), 9 deletions(-) diff --git a/Core/HLE/sceKernelMemory.cpp b/Core/HLE/sceKernelMemory.cpp index ab71ca4d6723..46e53753979c 100644 --- a/Core/HLE/sceKernelMemory.cpp +++ b/Core/HLE/sceKernelMemory.cpp @@ -213,10 +213,6 @@ struct SceKernelVplHeader { do { auto b = prev->next; if (b->sizeInBlocks > allocBlocks) { - if (nextFreeBlock_ == b) { - nextFreeBlock_ = prev; - } - prev = b; b = SplitBlock(b, allocBlocks); } @@ -289,16 +285,13 @@ struct SceKernelVplHeader { void UnlinkFreeBlock(PSPPointer b, PSPPointer prev) { allocatedInBlocks_ += b->sizeInBlocks; prev->next = b->next; - if (nextFreeBlock_ == b) { - nextFreeBlock_ = prev; - } + nextFreeBlock_ = prev; b->next = SentinelPtr(); } PSPPointer SplitBlock(PSPPointer b, u32 allocBlocks) { - u32 prev = b->next.ptr; + u32 prev = b.ptr; b->sizeInBlocks -= allocBlocks; - b->next = b + b->sizeInBlocks; b += b->sizeInBlocks; b->sizeInBlocks = allocBlocks;