diff options
| author | sewardj <unknown> | 2002-01-08 10:59:42 +0000 | 
|---|---|---|
| committer | sewardj <unknown> | 2002-01-08 10:59:42 +0000 | 
| commit | 20d7560469e59d78c17992ce4be75360c91587bb (patch) | |
| tree | e01fcb601571b3d61343858cdcd26702b6681a5c | |
| parent | d1a3ff224190eed70da56f68cb06e92d691fe131 (diff) | |
| download | haskell-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).
| -rw-r--r-- | ghc/compiler/nativeGen/AsmCodeGen.lhs | 29 | ||||
| -rw-r--r-- | ghc/compiler/nativeGen/MachMisc.lhs | 2 | 
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 ... | 
