diff options
author | Sylvain Henry <sylvain@haskus.fr> | 2019-08-13 17:26:32 +0200 |
---|---|---|
committer | Sylvain Henry <sylvain@haskus.fr> | 2019-09-10 00:04:50 +0200 |
commit | 447864a94a1679b5b079e08bb7208a0005381cef (patch) | |
tree | baa469c52620ce7ae02def3e5e6a6f109cc89f40 /compiler/GHC/Platform | |
parent | 270fbe8512f04b6107755fa22bdec62205c0a567 (diff) | |
download | haskell-447864a94a1679b5b079e08bb7208a0005381cef.tar.gz |
Module hierarchy: StgToCmm (#13009)
Add StgToCmm module hierarchy. Platform modules that are used in several
other places (NCG, LLVM codegen, Cmm transformations) are put into
GHC.Platform.
Diffstat (limited to 'compiler/GHC/Platform')
-rw-r--r-- | compiler/GHC/Platform/ARM.hs | 10 | ||||
-rw-r--r-- | compiler/GHC/Platform/ARM64.hs | 10 | ||||
-rw-r--r-- | compiler/GHC/Platform/NoRegs.hs | 9 | ||||
-rw-r--r-- | compiler/GHC/Platform/PPC.hs | 10 | ||||
-rw-r--r-- | compiler/GHC/Platform/Regs.hs | 107 | ||||
-rw-r--r-- | compiler/GHC/Platform/SPARC.hs | 10 | ||||
-rw-r--r-- | compiler/GHC/Platform/X86.hs | 10 | ||||
-rw-r--r-- | compiler/GHC/Platform/X86_64.hs | 10 |
8 files changed, 176 insertions, 0 deletions
diff --git a/compiler/GHC/Platform/ARM.hs b/compiler/GHC/Platform/ARM.hs new file mode 100644 index 0000000000..d0c7e5811a --- /dev/null +++ b/compiler/GHC/Platform/ARM.hs @@ -0,0 +1,10 @@ +{-# LANGUAGE CPP #-} + +module GHC.Platform.ARM where + +import GhcPrelude + +#define MACHREGS_NO_REGS 0 +#define MACHREGS_arm 1 +#include "../../../includes/CodeGen.Platform.hs" + diff --git a/compiler/GHC/Platform/ARM64.hs b/compiler/GHC/Platform/ARM64.hs new file mode 100644 index 0000000000..ebd66b92c5 --- /dev/null +++ b/compiler/GHC/Platform/ARM64.hs @@ -0,0 +1,10 @@ +{-# LANGUAGE CPP #-} + +module GHC.Platform.ARM64 where + +import GhcPrelude + +#define MACHREGS_NO_REGS 0 +#define MACHREGS_aarch64 1 +#include "../../../includes/CodeGen.Platform.hs" + diff --git a/compiler/GHC/Platform/NoRegs.hs b/compiler/GHC/Platform/NoRegs.hs new file mode 100644 index 0000000000..e8abf44253 --- /dev/null +++ b/compiler/GHC/Platform/NoRegs.hs @@ -0,0 +1,9 @@ +{-# LANGUAGE CPP #-} + +module GHC.Platform.NoRegs where + +import GhcPrelude + +#define MACHREGS_NO_REGS 1 +#include "../../../includes/CodeGen.Platform.hs" + diff --git a/compiler/GHC/Platform/PPC.hs b/compiler/GHC/Platform/PPC.hs new file mode 100644 index 0000000000..f405f95438 --- /dev/null +++ b/compiler/GHC/Platform/PPC.hs @@ -0,0 +1,10 @@ +{-# LANGUAGE CPP #-} + +module GHC.Platform.PPC where + +import GhcPrelude + +#define MACHREGS_NO_REGS 0 +#define MACHREGS_powerpc 1 +#include "../../../includes/CodeGen.Platform.hs" + diff --git a/compiler/GHC/Platform/Regs.hs b/compiler/GHC/Platform/Regs.hs new file mode 100644 index 0000000000..e7887fbe72 --- /dev/null +++ b/compiler/GHC/Platform/Regs.hs @@ -0,0 +1,107 @@ + +module GHC.Platform.Regs + (callerSaves, activeStgRegs, haveRegBase, globalRegMaybe, freeReg) + where + +import GhcPrelude + +import CmmExpr +import GHC.Platform +import Reg + +import qualified GHC.Platform.ARM as ARM +import qualified GHC.Platform.ARM64 as ARM64 +import qualified GHC.Platform.PPC as PPC +import qualified GHC.Platform.SPARC as SPARC +import qualified GHC.Platform.X86 as X86 +import qualified GHC.Platform.X86_64 as X86_64 +import qualified GHC.Platform.NoRegs as NoRegs + +-- | Returns 'True' if this global register is stored in a caller-saves +-- machine register. + +callerSaves :: Platform -> GlobalReg -> Bool +callerSaves platform + | platformUnregisterised platform = NoRegs.callerSaves + | otherwise + = case platformArch platform of + ArchX86 -> X86.callerSaves + ArchX86_64 -> X86_64.callerSaves + ArchSPARC -> SPARC.callerSaves + ArchARM {} -> ARM.callerSaves + ArchARM64 -> ARM64.callerSaves + arch + | arch `elem` [ArchPPC, ArchPPC_64 ELF_V1, ArchPPC_64 ELF_V2] -> + PPC.callerSaves + + | otherwise -> NoRegs.callerSaves + +-- | Here is where the STG register map is defined for each target arch. +-- The order matters (for the llvm backend anyway)! We must make sure to +-- maintain the order here with the order used in the LLVM calling conventions. +-- Note that also, this isn't all registers, just the ones that are currently +-- possbily mapped to real registers. +activeStgRegs :: Platform -> [GlobalReg] +activeStgRegs platform + | platformUnregisterised platform = NoRegs.activeStgRegs + | otherwise + = case platformArch platform of + ArchX86 -> X86.activeStgRegs + ArchX86_64 -> X86_64.activeStgRegs + ArchSPARC -> SPARC.activeStgRegs + ArchARM {} -> ARM.activeStgRegs + ArchARM64 -> ARM64.activeStgRegs + arch + | arch `elem` [ArchPPC, ArchPPC_64 ELF_V1, ArchPPC_64 ELF_V2] -> + PPC.activeStgRegs + + | otherwise -> NoRegs.activeStgRegs + +haveRegBase :: Platform -> Bool +haveRegBase platform + | platformUnregisterised platform = NoRegs.haveRegBase + | otherwise + = case platformArch platform of + ArchX86 -> X86.haveRegBase + ArchX86_64 -> X86_64.haveRegBase + ArchSPARC -> SPARC.haveRegBase + ArchARM {} -> ARM.haveRegBase + ArchARM64 -> ARM64.haveRegBase + arch + | arch `elem` [ArchPPC, ArchPPC_64 ELF_V1, ArchPPC_64 ELF_V2] -> + PPC.haveRegBase + + | otherwise -> NoRegs.haveRegBase + +globalRegMaybe :: Platform -> GlobalReg -> Maybe RealReg +globalRegMaybe platform + | platformUnregisterised platform = NoRegs.globalRegMaybe + | otherwise + = case platformArch platform of + ArchX86 -> X86.globalRegMaybe + ArchX86_64 -> X86_64.globalRegMaybe + ArchSPARC -> SPARC.globalRegMaybe + ArchARM {} -> ARM.globalRegMaybe + ArchARM64 -> ARM64.globalRegMaybe + arch + | arch `elem` [ArchPPC, ArchPPC_64 ELF_V1, ArchPPC_64 ELF_V2] -> + PPC.globalRegMaybe + + | otherwise -> NoRegs.globalRegMaybe + +freeReg :: Platform -> RegNo -> Bool +freeReg platform + | platformUnregisterised platform = NoRegs.freeReg + | otherwise + = case platformArch platform of + ArchX86 -> X86.freeReg + ArchX86_64 -> X86_64.freeReg + ArchSPARC -> SPARC.freeReg + ArchARM {} -> ARM.freeReg + ArchARM64 -> ARM64.freeReg + arch + | arch `elem` [ArchPPC, ArchPPC_64 ELF_V1, ArchPPC_64 ELF_V2] -> + PPC.freeReg + + | otherwise -> NoRegs.freeReg + diff --git a/compiler/GHC/Platform/SPARC.hs b/compiler/GHC/Platform/SPARC.hs new file mode 100644 index 0000000000..b0cdb27f44 --- /dev/null +++ b/compiler/GHC/Platform/SPARC.hs @@ -0,0 +1,10 @@ +{-# LANGUAGE CPP #-} + +module GHC.Platform.SPARC where + +import GhcPrelude + +#define MACHREGS_NO_REGS 0 +#define MACHREGS_sparc 1 +#include "../../../includes/CodeGen.Platform.hs" + diff --git a/compiler/GHC/Platform/X86.hs b/compiler/GHC/Platform/X86.hs new file mode 100644 index 0000000000..1570ba9fa0 --- /dev/null +++ b/compiler/GHC/Platform/X86.hs @@ -0,0 +1,10 @@ +{-# LANGUAGE CPP #-} + +module GHC.Platform.X86 where + +import GhcPrelude + +#define MACHREGS_NO_REGS 0 +#define MACHREGS_i386 1 +#include "../../../includes/CodeGen.Platform.hs" + diff --git a/compiler/GHC/Platform/X86_64.hs b/compiler/GHC/Platform/X86_64.hs new file mode 100644 index 0000000000..d2d1b15c71 --- /dev/null +++ b/compiler/GHC/Platform/X86_64.hs @@ -0,0 +1,10 @@ +{-# LANGUAGE CPP #-} + +module GHC.Platform.X86_64 where + +import GhcPrelude + +#define MACHREGS_NO_REGS 0 +#define MACHREGS_x86_64 1 +#include "../../../includes/CodeGen.Platform.hs" + |