{-| Copyright : (C) 2019, Myrtle Software Ltd License : BSD2 (see the file LICENSE) Maintainer : Christiaan Baaij Blackbox generation for GHC.Word.WordX# data constructors. (System)Verilog only! -} {-# LANGUAGE OverloadedStrings #-} module Clash.Primitives.GHC.Word (wordTF) where import Clash.Core.Literal (Literal(WordLiteral)) import Clash.Core.Term (Term(Literal)) import Clash.Core.Type (Type) import Clash.Primitives.GHC.Literal (literalTF, unsigned, unsignedLiteral, assign) import Clash.Netlist.Types (BlackBox(BBTemplate)) import Clash.Netlist.BlackBox.Types (BlackBoxFunction, Element(Arg, Result), emptyBlackBoxMeta ,BlackBoxMeta, bbKind, TemplateKind(TDecl)) -- | Template function for Word8,Word16,.. Constructs "clean" literals. This -- function generates valid (System)Verilog only! wordTF :: BlackBoxFunction wordTF = literalTF "GHC.Word.W" wordTF' wordTF' :: Bool -- ^ Is declaration -> [Either Term Type] -- ^ Arguments -> Int -- ^ Word size -> (BlackBoxMeta, BlackBox) wordTF' False [Left (Literal (WordLiteral n))] wordSize = -- Literal as expression: ( emptyBlackBoxMeta , BBTemplate [unsignedLiteral wordSize n]) wordTF' True [Left (Literal (WordLiteral n))] wordSize = -- Literal as declaration: ( emptyBlackBoxMeta , BBTemplate (assign Result [unsignedLiteral wordSize n])) wordTF' _isDecl _args _wordSize = -- Not a literal. We need an assignment as Verilog does not support truncating -- arbitrary expression. ( emptyBlackBoxMeta {bbKind = TDecl } , BBTemplate (assign Result (unsigned (Arg 0))))