diff options
author | tomsmeding <tom.smeding@gmail.com> | 2017-08-20 11:17:05 +0200 |
---|---|---|
committer | tomsmeding <tom.smeding@gmail.com> | 2017-08-20 11:17:05 +0200 |
commit | 965f8bf85d7850be074bad735d815b15a85a3de0 (patch) | |
tree | 915cb183c943c503c4b4a561679b7edc2e4a2938 /X64Optimiser.hs | |
parent | 694ec05bcad01fd27606aace73b49cdade16945e (diff) |
Second
Diffstat (limited to 'X64Optimiser.hs')
-rw-r--r-- | X64Optimiser.hs | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/X64Optimiser.hs b/X64Optimiser.hs new file mode 100644 index 0000000..9cae96d --- /dev/null +++ b/X64Optimiser.hs @@ -0,0 +1,15 @@ +module X64Optimiser(x64Optimise) where + +import Defs +import X64 + + +x64Optimise :: Asm -> Error Asm +x64Optimise (Asm funcs) = return $ Asm [(name, concat $ map goI inss) | (name, inss) <- funcs] + where + goI :: Ins -> [Ins] + goI (MOV (RegMem a) (RegMem b)) | a == b = [] + goI (MOVi (RegMem a) (Imm (XImm 0))) | isXReg a = [XOR (RegMem a) (RegMemImm a)] + goI (MOVi64 (Reg a) (Imm (XImm 0))) = [XOR (RegMem a) (RegMemImm a)] + goI (MOVSX (Reg a) (RegMem b)) | a == b = [] + goI ins = [ins] |