diff options
author | jhorv <38920027+jhorv@users.noreply.github.com> | 2024-03-09 19:01:51 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-03-09 21:01:51 -0300 |
commit | a3a63d43948b79450d1a0ee963ea4796cb3532a0 (patch) | |
tree | b97c0c19bac9ce065fdf4acad7b0c170f7a6b1dc /src/Ryujinx.Cpu/VirtualMemoryManagerRefCountedBase.cs | |
parent | 3924bd1a4364455ab8a5747e3cb0b3000dbaa589 (diff) |
Refactor memory managers to a common base class, consolidate Read() method logic (#6360)1.1.1222
* - add new abstract class `VirtualMemoryManagerBase`
- rename `MemoryManagerBase` to `VirtualMemoryManagerRefCountedBase` and derive from `VirtualMemoryManagerBase`
- change `AddressSpaceManager`, `HvMemoryManager`, `MemoryManager`, and `MemoryManagerHostMapped` to implement abstract members and use the inherited `void VirtualMemoryManagerBase.Read(TVirtual va, Span<byte> data)` implementation.
* move property `AddressSpaceSize` up by the other properties
Diffstat (limited to 'src/Ryujinx.Cpu/VirtualMemoryManagerRefCountedBase.cs')
-rw-r--r-- | src/Ryujinx.Cpu/VirtualMemoryManagerRefCountedBase.cs | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/src/Ryujinx.Cpu/VirtualMemoryManagerRefCountedBase.cs b/src/Ryujinx.Cpu/VirtualMemoryManagerRefCountedBase.cs new file mode 100644 index 00000000..c2d8cfb1 --- /dev/null +++ b/src/Ryujinx.Cpu/VirtualMemoryManagerRefCountedBase.cs @@ -0,0 +1,35 @@ +using Ryujinx.Memory; +using System.Diagnostics; +using System.Numerics; +using System.Threading; + +namespace Ryujinx.Cpu +{ + public abstract class VirtualMemoryManagerRefCountedBase<TVirtual, TPhysical> : VirtualMemoryManagerBase<TVirtual, TPhysical>, IRefCounted + where TVirtual : IBinaryInteger<TVirtual> + where TPhysical : IBinaryInteger<TPhysical> + { + private int _referenceCount; + + public void IncrementReferenceCount() + { + int newRefCount = Interlocked.Increment(ref _referenceCount); + + Debug.Assert(newRefCount >= 1); + } + + public void DecrementReferenceCount() + { + int newRefCount = Interlocked.Decrement(ref _referenceCount); + + Debug.Assert(newRefCount >= 0); + + if (newRefCount == 0) + { + Destroy(); + } + } + + protected abstract void Destroy(); + } +} |