From 61d79facd1740264dadb6c62a0af21179bf6672b Mon Sep 17 00:00:00 2001 From: gdkchan Date: Mon, 9 Mar 2020 19:29:34 -0300 Subject: Optimize x64 loads and stores using complex addressing modes (#972) * Optimize x64 loads and stores using complex addressing modes * This was meant to be used for testing --- ARMeilleure/Translation/Compiler.cs | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) (limited to 'ARMeilleure/Translation') diff --git a/ARMeilleure/Translation/Compiler.cs b/ARMeilleure/Translation/Compiler.cs index 4075a7f0..c2a2c746 100644 --- a/ARMeilleure/Translation/Compiler.cs +++ b/ARMeilleure/Translation/Compiler.cs @@ -9,11 +9,16 @@ namespace ARMeilleure.Translation { static class Compiler { - public static T Compile( - ControlFlowGraph cfg, - OperandType[] funcArgTypes, - OperandType funcReturnType, - CompilerOptions options) + public static T Compile(ControlFlowGraph cfg, OperandType[] argTypes, OperandType retType, CompilerOptions options) + { + CompiledFunction func = CompileAndGetCf(cfg, argTypes, retType, options); + + IntPtr codePtr = JitCache.Map(func); + + return Marshal.GetDelegateForFunctionPointer(codePtr); + } + + public static CompiledFunction CompileAndGetCf(ControlFlowGraph cfg, OperandType[] argTypes, OperandType retType, CompilerOptions options) { Logger.StartPass(PassName.Dominance); @@ -35,13 +40,9 @@ namespace ARMeilleure.Translation Logger.EndPass(PassName.SsaConstruction, cfg); - CompilerContext cctx = new CompilerContext(cfg, funcArgTypes, funcReturnType, options); - - CompiledFunction func = CodeGenerator.Generate(cctx); + CompilerContext cctx = new CompilerContext(cfg, argTypes, retType, options); - IntPtr codePtr = JitCache.Map(func); - - return Marshal.GetDelegateForFunctionPointer(codePtr); + return CodeGenerator.Generate(cctx); } } } \ No newline at end of file -- cgit v1.2.3