Fix bug in CachedStorage that would drop writes

If block 0 of the storage was written to before the cache was filled and then another block was accessed, any writes to block 0 would be lost.
This commit is contained in:
Alex Barney 2019-05-10 14:49:23 -05:00
parent b83fb6c7fc
commit b9236b973a

View file

@ -1,5 +1,4 @@
using System; using System;
using System.Buffers;
using System.Collections.Generic; using System.Collections.Generic;
namespace LibHac.IO namespace LibHac.IO
@ -23,8 +22,7 @@ namespace LibHac.IO
for (int i = 0; i < cacheSize; i++) for (int i = 0; i < cacheSize; i++)
{ {
// todo why is this rented? var block = new CacheBlock { Buffer = new byte[blockSize], Index = -1 };
var block = new CacheBlock { Buffer = ArrayPool<byte>.Shared.Rent(blockSize) };
Blocks.AddLast(block); Blocks.AddLast(block);
} }
} }
@ -124,7 +122,11 @@ namespace LibHac.IO
CacheBlock block = node.Value; CacheBlock block = node.Value;
Blocks.RemoveLast(); Blocks.RemoveLast();
if (block.Index != -1)
{
BlockDict.Remove(block.Index); BlockDict.Remove(block.Index);
}
FlushBlock(block); FlushBlock(block);
ReadBlock(block, blockIndex); ReadBlock(block, blockIndex);