summaryrefslogtreecommitdiff
path: root/ghc
diff options
context:
space:
mode:
authorsewardj <unknown>2002-01-08 10:59:42 +0000
committersewardj <unknown>2002-01-08 10:59:42 +0000
commit20d7560469e59d78c17992ce4be75360c91587bb (patch)
treee01fcb601571b3d61343858cdcd26702b6681a5c /ghc
parentd1a3ff224190eed70da56f68cb06e92d691fe131 (diff)
downloadhaskell-20d7560469e59d78c17992ce4be75360c91587bb.tar.gz
[project @ 2002-01-08 10:59:42 by sewardj]
merge from stable branch: 1.46.4.3 +14 -7 fptools/ghc/compiler/nativeGen/AsmCodeGen.lhs 1.47.4.3 +2 -0 fptools/ghc/compiler/nativeGen/MachMisc.lhs Treat literal appearances of BaseReg in Stix trees uniformly. This is now taken to mean the &MainCapability.r, regardless of whether BaseReg is in a register (x86) or synthesised (sparc).
Diffstat (limited to 'ghc')
-rw-r--r--ghc/compiler/nativeGen/AsmCodeGen.lhs29
-rw-r--r--ghc/compiler/nativeGen/MachMisc.lhs2
2 files changed, 21 insertions, 10 deletions
diff --git a/ghc/compiler/nativeGen/AsmCodeGen.lhs b/ghc/compiler/nativeGen/AsmCodeGen.lhs
index 354b3fcdda..a9ce466713 100644
--- a/ghc/compiler/nativeGen/AsmCodeGen.lhs
+++ b/ghc/compiler/nativeGen/AsmCodeGen.lhs
@@ -16,7 +16,7 @@ import MachCode
import PprMach
import AbsCStixGen ( genCodeAbstractC )
-import AbsCSyn ( AbstractC )
+import AbsCSyn ( AbstractC, MagicId(..) )
import AbsCUtils ( mkAbsCStmtList, magicIdPrimRep )
import AsmRegAlloc ( runRegAllocate )
import MachOp ( MachOp(..), isCommutableMachOp, isComparisonMachOp )
@@ -228,13 +228,17 @@ stixStmt_ConFold stmt
-> StAssignReg pk reg (stixExpr_ConFold src)
StAssignReg pk reg@(StixMagicId mid) src
-- Replace register leaves with appropriate StixTrees for
- -- the given target.
- -> case get_MagicId_reg_or_addr mid of
- Left realreg
- -> StAssignReg pk reg (stixExpr_ConFold src)
- Right baseRegAddr
- -> stixStmt_ConFold
- (StAssignMem pk baseRegAddr src)
+ -- the given target. MagicIds which map to a reg on this arch are left unchanged.
+ -- Assigning to BaseReg is always illegal, so we check for that.
+ -> case mid of {
+ BaseReg -> panic "stixStmt_ConFold: assignment to BaseReg";
+ other ->
+ case get_MagicId_reg_or_addr mid of
+ Left realreg
+ -> StAssignReg pk reg (stixExpr_ConFold src)
+ Right baseRegAddr
+ -> stixStmt_ConFold (StAssignMem pk baseRegAddr src)
+ }
StAssignMem pk addr src
-> StAssignMem pk (stixExpr_ConFold addr) (stixExpr_ConFold src)
StVoidable expr
@@ -275,11 +279,16 @@ stixExpr_ConFold expr
-> stixMachOpFold mop (map stixExpr_ConFold args)
StReg (StixMagicId mid)
-- Replace register leaves with appropriate StixTrees for
- -- the given target.
+ -- the given target. MagicIds which map to a reg on this arch are left unchanged.
+ -- For the rest, BaseReg is taken to mean the address of the reg table
+ -- in MainCapability, and for all others we generate an indirection to
+ -- its location in the register table.
-> case get_MagicId_reg_or_addr mid of
Left realreg -> expr
Right baseRegAddr
- -> stixExpr_ConFold (StInd (magicIdPrimRep mid) baseRegAddr)
+ -> case mid of
+ BaseReg -> stixExpr_ConFold baseRegAddr
+ other -> stixExpr_ConFold (StInd (magicIdPrimRep mid) baseRegAddr)
other
-> other
\end{code}
diff --git a/ghc/compiler/nativeGen/MachMisc.lhs b/ghc/compiler/nativeGen/MachMisc.lhs
index de69ab6516..ad711882d5 100644
--- a/ghc/compiler/nativeGen/MachMisc.lhs
+++ b/ghc/compiler/nativeGen/MachMisc.lhs
@@ -113,6 +113,8 @@ volatileSavesOrRestores do_saves vols
= catMaybes (map mkCode vols)
where
mkCode mid
+ | case mid of { BaseReg -> True; _ -> False }
+ = panic "volatileSavesOrRestores:BaseReg"
| not (callerSaves mid)
= Nothing
| otherwise -- must be callee-saves ...