mirror of
https://github.com/Ryujinx/Ryujinx.git
synced 2025-01-18 17:37:19 +00:00
61634dd415
* Initial cache memory allocator implementation * Get rid of CallFlag * Perform cache cleanup on exit * Basic cache invalidation * Thats not how conditionals works in C# it seems * Set PTC version to PR number * Address PR feedback * Update InstEmitFlowHelper.cs * Flag clear on address is no longer needed * Do not include exit block in function size calculation * Dispose jump table * For future use * InternalVersion = 1519 (force retest). Co-authored-by: LDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com>
59 lines
1.7 KiB
C#
59 lines
1.7 KiB
C#
using System;
|
|
|
|
namespace ARMeilleure.Memory
|
|
{
|
|
class ReservedRegion
|
|
{
|
|
private const int DefaultGranularity = 65536; // Mapping granularity in Windows.
|
|
|
|
public IJitMemoryBlock Block { get; }
|
|
|
|
public IntPtr Pointer => Block.Pointer;
|
|
|
|
private readonly ulong _maxSize;
|
|
private readonly ulong _sizeGranularity;
|
|
private ulong _currentSize;
|
|
|
|
public ReservedRegion(IJitMemoryAllocator allocator, ulong maxSize, ulong granularity = 0)
|
|
{
|
|
if (granularity == 0)
|
|
{
|
|
granularity = DefaultGranularity;
|
|
}
|
|
|
|
Block = allocator.Reserve(maxSize);
|
|
_maxSize = maxSize;
|
|
_sizeGranularity = granularity;
|
|
_currentSize = 0;
|
|
}
|
|
|
|
public void ExpandIfNeeded(ulong desiredSize)
|
|
{
|
|
if (desiredSize > _maxSize)
|
|
{
|
|
throw new OutOfMemoryException();
|
|
}
|
|
|
|
if (desiredSize > _currentSize)
|
|
{
|
|
// Lock, and then check again. We only want to commit once.
|
|
lock (this)
|
|
{
|
|
if (desiredSize >= _currentSize)
|
|
{
|
|
ulong overflowBytes = desiredSize - _currentSize;
|
|
ulong moreToCommit = (((_sizeGranularity - 1) + overflowBytes) / _sizeGranularity) * _sizeGranularity; // Round up.
|
|
Block.Commit(_currentSize, moreToCommit);
|
|
_currentSize += moreToCommit;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
Block.Dispose();
|
|
}
|
|
}
|
|
}
|