diff options
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 } } |
