summaryrefslogtreecommitdiff
path: root/compiler
diff options
context:
space:
mode:
Diffstat (limited to 'compiler')
-rw-r--r--compiler/GHC/CmmToAsm/X86/CodeGen.hs70
1 files changed, 33 insertions, 37 deletions
diff --git a/compiler/GHC/CmmToAsm/X86/CodeGen.hs b/compiler/GHC/CmmToAsm/X86/CodeGen.hs
index 34f907b4f2..d105453458 100644
--- a/compiler/GHC/CmmToAsm/X86/CodeGen.hs
+++ b/compiler/GHC/CmmToAsm/X86/CodeGen.hs
@@ -1288,7 +1288,7 @@ getAmode e = do
-- This is all just ridiculous, since it carefully undoes
-- what mangleIndexTree has just done.
CmmMachOp (MO_Sub _rep) [x, CmmLit lit@(CmmInt i _)]
- | is32BitLit is32Bit lit
+ | is32BitLit platform lit
-- assert (rep == II32)???
-> do
(x_reg, x_code) <- getSomeReg x
@@ -1296,7 +1296,7 @@ getAmode e = do
return (Amode (AddrBaseIndex (EABaseReg x_reg) EAIndexNone off) x_code)
CmmMachOp (MO_Add _rep) [x, CmmLit lit]
- | is32BitLit is32Bit lit
+ | is32BitLit platform lit
-- assert (rep == II32)???
-> do
(x_reg, x_code) <- getSomeReg x
@@ -1336,7 +1336,7 @@ getAmode e = do
-> return (Amode (AddrBaseIndex EABaseRip EAIndexNone (litToImm lit)) nilOL)
CmmLit lit
- | is32BitLit is32Bit lit
+ | is32BitLit platform lit
-> return (Amode (ImmAddr (litToImm lit) 0) nilOL)
-- Literal with offsets too big (> 32 bits) fails during the linking phase
@@ -1409,9 +1409,8 @@ getNonClobberedOperand (CmmLit lit) =
Amode addr code <- memConstant (mkAlignment $ widthInBytes w) lit
return (OpAddr addr, code)
else do
- is32Bit <- is32BitPlatform
platform <- getPlatform
- if is32BitLit is32Bit lit && not (isFloatType (cmmLitType platform lit))
+ if is32BitLit platform lit && not (isFloatType (cmmLitType platform lit))
then return (OpImm (litToImm lit), nilOL)
else getNonClobberedOperand_generic (CmmLit lit)
@@ -1468,9 +1467,8 @@ getOperand (CmmLit lit) = do
return (OpAddr addr, code)
else do
- is32Bit <- is32BitPlatform
platform <- getPlatform
- if is32BitLit is32Bit lit && not (isFloatType (cmmLitType platform lit))
+ if is32BitLit platform lit && not (isFloatType (cmmLitType platform lit))
then return (OpImm (litToImm lit), nilOL)
else getOperand_generic (CmmLit lit)
@@ -1491,9 +1489,10 @@ getOperand_generic e = do
(reg, code) <- getSomeReg e
return (OpReg reg, code)
-isOperand :: Bool -> CmmExpr -> Bool
+isOperand :: Platform -> CmmExpr -> Bool
isOperand _ (CmmLoad _ _ _) = True
-isOperand is32Bit (CmmLit lit) = is32BitLit is32Bit lit
+isOperand platform (CmmLit lit)
+ = is32BitLit platform lit
|| isSuitableFloatingPointLit lit
isOperand _ _ = False
@@ -1564,9 +1563,9 @@ getRegOrMem e = do
(reg, code) <- getNonClobberedReg e
return (OpReg reg, code)
-is32BitLit :: Bool -> CmmLit -> Bool
-is32BitLit is32Bit lit
- | not is32Bit = case lit of
+is32BitLit :: Platform -> CmmLit -> Bool
+is32BitLit platform lit
+ | not (target32Bit platform) = case lit of
CmmInt i W64 -> is32BitInteger i
-- assume that labels are in the range 0-2^31-1: this assumes the
-- small memory model. Note [%rip-relative addressing on x86-64].
@@ -1631,14 +1630,14 @@ machOpToCond mo = case mo of
-- passed back up the tree.
condIntCode :: Cond -> CmmExpr -> CmmExpr -> NatM CondCode
-condIntCode cond x y = do is32Bit <- is32BitPlatform
- condIntCode' is32Bit cond x y
+condIntCode cond x y = do platform <- getPlatform
+ condIntCode' platform cond x y
-condIntCode' :: Bool -> Cond -> CmmExpr -> CmmExpr -> NatM CondCode
+condIntCode' :: Platform -> Cond -> CmmExpr -> CmmExpr -> NatM CondCode
-- memory vs immediate
-condIntCode' is32Bit cond (CmmLoad x pk _) (CmmLit lit)
- | is32BitLit is32Bit lit = do
+condIntCode' platform cond (CmmLoad x pk _) (CmmLit lit)
+ | is32BitLit platform lit = do
Amode x_addr x_code <- getAmode x
let
imm = litToImm lit
@@ -1649,8 +1648,8 @@ condIntCode' is32Bit cond (CmmLoad x pk _) (CmmLit lit)
-- anything vs zero, using a mask
-- TODO: Add some sanity checking!!!!
-condIntCode' is32Bit cond (CmmMachOp (MO_And _) [x,o2]) (CmmLit (CmmInt 0 pk))
- | (CmmLit lit@(CmmInt mask _)) <- o2, is32BitLit is32Bit lit
+condIntCode' platform cond (CmmMachOp (MO_And _) [x,o2]) (CmmLit (CmmInt 0 pk))
+ | (CmmLit lit@(CmmInt mask _)) <- o2, is32BitLit platform lit
= do
(x_reg, x_code) <- getSomeReg x
let
@@ -1669,9 +1668,8 @@ condIntCode' _ cond x (CmmLit (CmmInt 0 pk)) = do
return (CondCode False cond code)
-- anything vs operand
-condIntCode' is32Bit cond x y
- | isOperand is32Bit y = do
- platform <- getPlatform
+condIntCode' platform cond x y
+ | isOperand platform y = do
(x_reg, x_code) <- getNonClobberedReg x
(y_op, y_code) <- getOperand y
let
@@ -1680,9 +1678,8 @@ condIntCode' is32Bit cond x y
return (CondCode False cond code)
-- operand vs. anything: invert the comparison so that we can use a
-- single comparison instruction.
- | isOperand is32Bit x
+ | isOperand platform x
, Just revcond <- maybeFlipCond cond = do
- platform <- getPlatform
(y_reg, y_code) <- getNonClobberedReg y
(x_op, x_code) <- getOperand x
let
@@ -1691,8 +1688,7 @@ condIntCode' is32Bit cond x y
return (CondCode False revcond code)
-- anything vs anything
-condIntCode' _ cond x y = do
- platform <- getPlatform
+condIntCode' platform cond x y = do
(y_reg, y_code) <- getNonClobberedReg y
(x_op, x_code) <- getRegOrMem x
let
@@ -1766,9 +1762,9 @@ assignMem_IntCode pk addr (CmmMachOp op [CmmLoad addr2 _ _,
-- general case
assignMem_IntCode pk addr src = do
- is32Bit <- is32BitPlatform
+ platform <- getPlatform
Amode addr code_addr <- getAmode addr
- (code_src, op_src) <- get_op_RI is32Bit src
+ (code_src, op_src) <- get_op_RI platform src
let
code = code_src `appOL`
code_addr `snocOL`
@@ -1780,8 +1776,8 @@ assignMem_IntCode pk addr src = do
--
return code
where
- get_op_RI :: Bool -> CmmExpr -> NatM (InstrBlock,Operand) -- code, operator
- get_op_RI is32Bit (CmmLit lit) | is32BitLit is32Bit lit
+ get_op_RI :: Platform -> CmmExpr -> NatM (InstrBlock,Operand) -- code, operator
+ get_op_RI platform (CmmLit lit) | is32BitLit platform lit
= return (nilOL, OpImm (litToImm lit))
get_op_RI _ op
= do (reg,code) <- getNonClobberedReg op
@@ -2610,12 +2606,12 @@ genCCall64 addr conv dest_regs args = do
-- pass the arg into the given register
reg_this_arg r
-- "operand" args can be directly assigned into r
- | isOperand False arg = do
+ | isOperand platform arg = do
arg_code <- getAnyReg arg
return (code, (acode `appOL` arg_code r))
-- The last non-operand arg can be directly assigned after its
-- computation without going into a temporary register
- | all (isOperand False) rest = do
+ | all (isOperand platform) rest = do
arg_code <- getAnyReg arg
return (code `appOL` arg_code r,acode)
@@ -3135,14 +3131,14 @@ trivialCode :: Width -> (Operand -> Operand -> Instr)
-> Maybe (Operand -> Operand -> Instr)
-> CmmExpr -> CmmExpr -> NatM Register
trivialCode width instr m a b
- = do is32Bit <- is32BitPlatform
- trivialCode' is32Bit width instr m a b
+ = do platform <- getPlatform
+ trivialCode' platform width instr m a b
-trivialCode' :: Bool -> Width -> (Operand -> Operand -> Instr)
+trivialCode' :: Platform -> Width -> (Operand -> Operand -> Instr)
-> Maybe (Operand -> Operand -> Instr)
-> CmmExpr -> CmmExpr -> NatM Register
-trivialCode' is32Bit width _ (Just revinstr) (CmmLit lit_a) b
- | is32BitLit is32Bit lit_a = do
+trivialCode' platform width _ (Just revinstr) (CmmLit lit_a) b
+ | is32BitLit platform lit_a = do
b_code <- getAnyReg b
let
code dst