diff options
Diffstat (limited to 'compiler/llvmGen/LlvmCodeGen/CodeGen.hs')
| -rw-r--r-- | compiler/llvmGen/LlvmCodeGen/CodeGen.hs | 11 | 
1 files changed, 6 insertions, 5 deletions
| diff --git a/compiler/llvmGen/LlvmCodeGen/CodeGen.hs b/compiler/llvmGen/LlvmCodeGen/CodeGen.hs index cde3276e9f..aa3a0c3f1e 100644 --- a/compiler/llvmGen/LlvmCodeGen/CodeGen.hs +++ b/compiler/llvmGen/LlvmCodeGen/CodeGen.hs @@ -476,11 +476,12 @@ genCallWithOverflow    :: ForeignTarget -> Width -> [CmmFormal] -> [CmmActual] -> LlvmM StmtData  genCallWithOverflow t@(PrimTarget op) w [dstV, dstO] [lhs, rhs] = do      -- So far this was only tested for the following four CallishMachOps. -    MASSERT((op `elem`  [ MO_Add2 w -                        , MO_AddIntC w -                        , MO_SubIntC w -                        , MO_SubWordC w -                        ])) +    let valid = op `elem`   [ MO_Add2 w +                            , MO_AddIntC w +                            , MO_SubIntC w +                            , MO_SubWordC w +                            ] +    MASSERT(valid)      let width = widthToLlvmInt w      -- This will do most of the work of generating the call to the intrinsic and      -- extracting the values from the struct. | 
