diff options
| author | Johan Tibell <johan.tibell@gmail.com> | 2012-12-05 19:08:48 -0800 | 
|---|---|---|
| committer | Johan Tibell <johan.tibell@gmail.com> | 2012-12-13 13:54:22 -0800 | 
| commit | 2e8c769422740c001e0a247bfec61d4f78598582 (patch) | |
| tree | dc9ad5736694e1c9282800d88e9a110d13290a72 /compiler/nativeGen | |
| parent | 589b628be71cda75f4a225db0f1d1fd678c06368 (diff) | |
| download | haskell-2e8c769422740c001e0a247bfec61d4f78598582.tar.gz | |
Implement word2Float# and word2Double#
Diffstat (limited to 'compiler/nativeGen')
| -rw-r--r-- | compiler/nativeGen/CPrim.hs | 12 | ||||
| -rw-r--r-- | compiler/nativeGen/PPC/CodeGen.hs | 2 | ||||
| -rw-r--r-- | compiler/nativeGen/SPARC/CodeGen.hs | 2 | ||||
| -rw-r--r-- | compiler/nativeGen/X86/CodeGen.hs | 13 | 
4 files changed, 28 insertions, 1 deletions
| diff --git a/compiler/nativeGen/CPrim.hs b/compiler/nativeGen/CPrim.hs index 09707ac5ae..dd9d38f434 100644 --- a/compiler/nativeGen/CPrim.hs +++ b/compiler/nativeGen/CPrim.hs @@ -1,5 +1,8 @@  -- | Generating C symbol names emitted by the compiler. -module CPrim (popCntLabel) where +module CPrim +    ( popCntLabel +    , word2FloatLabel +    ) where  import CmmType  import Outputable @@ -12,3 +15,10 @@ popCntLabel w = "hs_popcnt" ++ pprWidth w      pprWidth W32 = "32"      pprWidth W64 = "64"      pprWidth w   = pprPanic "popCntLabel: Unsupported word width " (ppr w) + +word2FloatLabel :: Width -> String +word2FloatLabel w = "hs_word2float" ++ pprWidth w +  where +    pprWidth W32 = "32" +    pprWidth W64 = "64" +    pprWidth w   = pprPanic "word2FloatLabel: Unsupported word width " (ppr w) diff --git a/compiler/nativeGen/PPC/CodeGen.hs b/compiler/nativeGen/PPC/CodeGen.hs index 5e05047f34..e9a5b433f6 100644 --- a/compiler/nativeGen/PPC/CodeGen.hs +++ b/compiler/nativeGen/PPC/CodeGen.hs @@ -1149,6 +1149,8 @@ genCCall' dflags gcp target dest_regs args0                      MO_F64_Tanh  -> (fsLit "tanh", False)                      MO_F64_Pwr   -> (fsLit "pow", False) +                    MO_UF_Conv w -> (fsLit $ word2FloatLabel w, False) +                      MO_Memcpy    -> (fsLit "memcpy", False)                      MO_Memset    -> (fsLit "memset", False)                      MO_Memmove   -> (fsLit "memmove", False) diff --git a/compiler/nativeGen/SPARC/CodeGen.hs b/compiler/nativeGen/SPARC/CodeGen.hs index f3b70e7e61..880b5c6bba 100644 --- a/compiler/nativeGen/SPARC/CodeGen.hs +++ b/compiler/nativeGen/SPARC/CodeGen.hs @@ -641,6 +641,8 @@ outOfLineMachOp_table mop          MO_F64_Cosh   -> fsLit "cosh"          MO_F64_Tanh   -> fsLit "tanh" +        MO_UF_Conv w -> fsLit $ word2FloatLabel w +          MO_Memcpy    -> fsLit "memcpy"          MO_Memset    -> fsLit "memset"          MO_Memmove   -> fsLit "memmove" diff --git a/compiler/nativeGen/X86/CodeGen.hs b/compiler/nativeGen/X86/CodeGen.hs index 36f9e2d231..30cf060e74 100644 --- a/compiler/nativeGen/X86/CodeGen.hs +++ b/compiler/nativeGen/X86/CodeGen.hs @@ -1659,6 +1659,17 @@ genCCall is32Bit (PrimTarget (MO_PopCnt width)) dest_regs@[dst]      size = intSize width      lbl = mkCmmCodeLabel primPackageId (fsLit (popCntLabel width)) +genCCall is32Bit (PrimTarget (MO_UF_Conv width)) dest_regs args = do +    dflags <- getDynFlags +    targetExpr <- cmmMakeDynamicReference dflags addImportNat +                  CallReference lbl +    let target = ForeignTarget targetExpr (ForeignConvention CCallConv +                                           [NoHint] [NoHint] +                                           CmmMayReturn) +    genCCall is32Bit target dest_regs args +  where +    lbl = mkCmmCodeLabel primPackageId (fsLit (word2FloatLabel width)) +  genCCall is32Bit target dest_regs args   | is32Bit   = genCCall32 target dest_regs args   | otherwise = genCCall64 target dest_regs args @@ -2280,6 +2291,8 @@ outOfLineCmmOp mop res args                MO_PopCnt _  -> fsLit "popcnt" +              MO_UF_Conv _ -> unsupported +                MO_S_QuotRem {}  -> unsupported                MO_U_QuotRem {}  -> unsupported                MO_U_QuotRem2 {} -> unsupported | 
