diff options
| author | LDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com> | 2021-02-22 03:23:48 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-02-22 03:23:48 +0100 |
| commit | dc0adb533dc15a007e9ca2dc0533ef6a61f13393 (patch) | |
| tree | 4b3588600cfd163e9f7a72b176b15befe078e941 /ARMeilleure/IntermediateRepresentation/OperandHelper.cs | |
| parent | 15868801148129802173f2162ebff24835cb20ba (diff) | |
PPTC & Pool Enhancements. (#1968)
* PPTC & Pool Enhancements.
* Avoid buffer allocations in CodeGenContext.GetCode(). Avoid stream allocations in PTC.PtcInfo.
Refactoring/nits.
* Use XXHash128, for Ptc.Load & Ptc.Save, x10 faster than Md5.
* Why not a nice Span.
* Added a simple PtcFormatter library for deserialization/serialization, which does not require reflection, in use at PtcJumpTable and PtcProfiler; improves maintainability and simplicity/readability of affected code.
* Nits.
* Revert #1987.
* Revert "Revert #1987."
This reverts commit 998be765cf7f7da5ff0c1c08de704c9012b0f49c.
Diffstat (limited to 'ARMeilleure/IntermediateRepresentation/OperandHelper.cs')
| -rw-r--r-- | ARMeilleure/IntermediateRepresentation/OperandHelper.cs | 40 |
1 files changed, 21 insertions, 19 deletions
diff --git a/ARMeilleure/IntermediateRepresentation/OperandHelper.cs b/ARMeilleure/IntermediateRepresentation/OperandHelper.cs index f7381d86..26d66478 100644 --- a/ARMeilleure/IntermediateRepresentation/OperandHelper.cs +++ b/ARMeilleure/IntermediateRepresentation/OperandHelper.cs @@ -4,16 +4,6 @@ namespace ARMeilleure.IntermediateRepresentation { static class OperandHelper { - private static MemoryOperand MemoryOperand() - { - return ThreadStaticPool<MemoryOperand>.Instance.Allocate(); - } - - private static Operand Operand() - { - return ThreadStaticPool<Operand>.Instance.Allocate(); - } - public static Operand Const(OperandType type, long value) { return type == OperandType.I32 ? Operand().With((int)value) : Operand().With(value); @@ -84,22 +74,34 @@ namespace ARMeilleure.IntermediateRepresentation return MemoryOperand().With(type, baseAddress, index, scale, displacement); } - public static void PrepareOperandPool(bool highCq) + #region "ThreadStaticPool" + public static void PrepareOperandPool(int groupId = 0) { - ThreadStaticPool<Operand>.PreparePool(highCq ? 1 : 0); - ThreadStaticPool<MemoryOperand>.PreparePool(highCq ? 1 : 0); + ThreadStaticPool<Operand>.PreparePool(groupId, ChunkSizeLimit.Large); + ThreadStaticPool<MemoryOperand>.PreparePool(groupId, ChunkSizeLimit.Small); + } + + private static Operand Operand() + { + return ThreadStaticPool<Operand>.Instance.Allocate(); + } + + private static MemoryOperand MemoryOperand() + { + return ThreadStaticPool<MemoryOperand>.Instance.Allocate(); } - public static void ReturnOperandPool(bool highCq) + public static void ResetOperandPool(int groupId = 0) { - ThreadStaticPool<Operand>.ReturnPool(highCq ? 1 : 0); - ThreadStaticPool<MemoryOperand>.ReturnPool(highCq ? 1 : 0); + ThreadStaticPool<MemoryOperand>.ResetPool(groupId); + ThreadStaticPool<Operand>.ResetPool(groupId); } - public static void ResetOperandPools() + public static void DisposeOperandPools() { - ThreadStaticPool<Operand>.ResetPools(); - ThreadStaticPool<MemoryOperand>.ResetPools(); + ThreadStaticPool<Operand>.DisposePools(); + ThreadStaticPool<MemoryOperand>.DisposePools(); } + #endregion } } |
