{-# LANGUAGE ForeignFunctionInterface #-}
module Raaz.Core.CpuSupports
( sse, sse2, sse3
, sse4_1, sse4_2
, avx, avx2
) where
import Foreign.C
import System.IO.Unsafe(unsafePerformIO)
foreign import ccall unsafe "raaz_supports_sse"
c_sse :: IO CInt
foreign import ccall unsafe "raaz_supports_sse2"
c_sse2 :: IO CInt
foreign import ccall unsafe "raaz_supports_sse3"
c_sse3 :: IO CInt
foreign import ccall unsafe "raaz_supports_sse4_1"
c_sse4_1 :: IO CInt
foreign import ccall unsafe "raaz_supports_sse4_2"
c_sse4_2 :: IO CInt
foreign import ccall unsafe "raaz_supports_avx"
c_avx :: IO CInt
foreign import ccall unsafe "raaz_supports_avx2"
c_avx2 :: IO CInt
{-# NOINLINE gccBuiltInToBool #-}
gccBuiltInToBool :: IO CInt -> Bool
gccBuiltInToBool = unsafePerformIO . fmap (>0)
sse :: Bool
sse = gccBuiltInToBool c_sse
sse2 :: Bool
sse2 = gccBuiltInToBool c_sse2
sse3 :: Bool
sse3 = gccBuiltInToBool c_sse3
sse4_1 :: Bool
sse4_1 = gccBuiltInToBool c_sse4_1
sse4_2 :: Bool
sse4_2 = gccBuiltInToBool c_sse4_2
avx :: Bool
avx = gccBuiltInToBool c_avx
avx2 :: Bool
avx2 = gccBuiltInToBool c_avx2