| Copyright | (C) 2012-2016 University of Twente 2017 Myrtle Software Ltd 2017-2018 Google Inc. | 
|---|---|
| License | BSD2 (see the file LICENSE) | 
| Maintainer | Christiaan Baaij <christiaan.baaij@gmail.com> | 
| Safe Haskell | None | 
| Language | Haskell2010 | 
Clash.Netlist.Types
Description
Type and instance definitions for Netlist modules
Synopsis
- data Declaration where- Assignment !Identifier !Expr
- CondAssignment !Identifier !HWType !Expr !HWType [(Maybe Literal, Expr)]
- InstDecl EntityOrComponent (Maybe Comment) !Identifier !Identifier [(Expr, HWType, Expr)] [(Expr, PortDirection, HWType, Expr)]
- BlackBoxD !Text [BlackBoxTemplate] [BlackBoxTemplate] [((Text, Text), BlackBox)] !BlackBox BlackBoxContext
- NetDecl' (Maybe Comment) WireOrReg !Identifier (Either Identifier HWType)
- TickDecl Comment
- pattern NetDecl :: Maybe Comment -> Identifier -> HWType -> Declaration
 
- newtype NetlistMonad a = NetlistMonad {- runNetlist :: StateT NetlistState (ReaderT NetlistEnv IO) a
 
- data BlackBox
- data Expr- = Literal !(Maybe (HWType, Size)) !Literal
- | DataCon !HWType !Modifier [Expr]
- | Identifier !Identifier !(Maybe Modifier)
- | DataTag !HWType !(Either Identifier Identifier)
- | BlackBoxE !Text [BlackBoxTemplate] [BlackBoxTemplate] [((Text, Text), BlackBox)] !BlackBox !BlackBoxContext !Bool
- | ConvBV (Maybe Identifier) HWType Bool Expr
- | IfThenElse Expr Expr Expr
 
- data Component = Component {- componentName :: !Identifier
- inputs :: [(Identifier, HWType)]
- outputs :: [(WireOrReg, (Identifier, HWType))]
- declarations :: [Declaration]
 
- data Declaration- = Assignment !Identifier !Expr
- | CondAssignment !Identifier !HWType !Expr !HWType [(Maybe Literal, Expr)]
- | InstDecl EntityOrComponent (Maybe Comment) !Identifier !Identifier [(Expr, HWType, Expr)] [(Expr, PortDirection, HWType, Expr)]
- | BlackBoxD !Text [BlackBoxTemplate] [BlackBoxTemplate] [((Text, Text), BlackBox)] !BlackBox BlackBoxContext
- | NetDecl' (Maybe Comment) WireOrReg !Identifier (Either Identifier HWType)
- | TickDecl Comment
 
- data HWType- = Void (Maybe HWType)
- | String
- | Integer
- | Bool
- | Bit
- | BitVector !Size
- | Index !Integer
- | Signed !Size
- | Unsigned !Size
- | Vector !Size !HWType
- | RTree !Size !HWType
- | Sum !Identifier [Identifier]
- | Product !Identifier (Maybe [Text]) [HWType]
- | SP !Identifier [(Identifier, [HWType])]
- | Clock !Identifier
- | Reset !Identifier
- | BiDirectional !PortDirection !HWType
- | CustomSP !Identifier !DataRepr' !Size [(ConstrRepr', Identifier, [HWType])]
- | CustomSum !Identifier !DataRepr' !Size [(ConstrRepr', Identifier)]
- | Annotated [Attr'] !HWType
- | KnownDomain !Identifier !Integer !ActiveEdge !ResetKind !InitBehavior !ResetPolarity
 
- type Identifier = Text
- data TemplateFunction where- TemplateFunction :: [Int] -> (BlackBoxContext -> Bool) -> (forall s. Backend s => BlackBoxContext -> State s Doc) -> TemplateFunction
 
- type BBHash = Int
- type BBName = String
- data BlackBoxContext = Context {- bbName :: Text
- bbResult :: (Expr, HWType)
- bbInputs :: [(Expr, HWType, Bool)]
- bbFunctions :: IntMap (Either BlackBox (Identifier, [Declaration]), WireOrReg, [BlackBoxTemplate], [BlackBoxTemplate], [((Text, Text), BlackBox)], BlackBoxContext)
- bbQsysIncName :: [Identifier]
- bbLevel :: Int
- bbCompName :: Identifier
 
- data Bit
- data Literal
- data Modifier
- data PortDirection
- data WireOrReg
- data EntityOrComponent
- data FilteredHWType = FilteredHWType HWType [[(IsVoid, FilteredHWType)]]
- type IsVoid = Bool
- type Size = Int
- type Comment = Text
- data NetlistState = NetlistState {- _bindings :: BindingMap
- _varCount :: !Int
- _components :: VarEnv ([Bool], SrcSpan, HashMap Identifier Word, Component)
- _primitives :: CompiledPrimMap
- _typeTranslator :: CustomReprs -> TyConMap -> Type -> State HWMap (Maybe (Either String FilteredHWType))
- _tcCache :: TyConMap
- _curCompNm :: !(Identifier, SrcSpan)
- _intWidth :: Int
- _mkIdentifierFn :: IdType -> Identifier -> Identifier
- _extendIdentifierFn :: IdType -> Identifier -> Identifier -> Identifier
- _seenIds :: HashMap Identifier Word
- _seenComps :: HashMap Identifier Word
- _seenPrimitives :: Set Text
- _componentNames :: VarEnv Identifier
- _topEntityAnns :: VarEnv (Type, Maybe TopEntity)
- _hdlDir :: FilePath
- _curBBlvl :: Int
- _componentPrefix :: (Maybe Identifier, Maybe Identifier)
- _customReprs :: CustomReprs
- _clashOpts :: ClashOpts
- _isTestBench :: Bool
- _backEndITE :: Bool
- _htyCache :: HWMap
 
- data NetlistEnv = NetlistEnv {}
- type HWMap = HashMap Type (Either String FilteredHWType)
- pattern NetDecl :: Maybe Comment -> Identifier -> HWType -> Declaration
- hwTypeAttrs :: HWType -> [Attr']
- toBit :: Integer -> Integer -> Bit
- emptyBBContext :: Text -> BlackBoxContext
- prefixName :: Lens' NetlistEnv Identifier
- setName :: Lens' NetlistEnv (Maybe Identifier)
- suffixName :: Lens' NetlistEnv Identifier
- backEndITE :: Lens' NetlistState Bool
- bindings :: Lens' NetlistState BindingMap
- clashOpts :: Lens' NetlistState ClashOpts
- componentNames :: Lens' NetlistState (VarEnv Identifier)
- componentPrefix :: Lens' NetlistState (Maybe Identifier, Maybe Identifier)
- components :: Lens' NetlistState (VarEnv ([Bool], SrcSpan, HashMap Identifier Word, Component))
- curBBlvl :: Lens' NetlistState Int
- curCompNm :: Lens' NetlistState (Identifier, SrcSpan)
- customReprs :: Lens' NetlistState CustomReprs
- extendIdentifierFn :: Lens' NetlistState (IdType -> Identifier -> Identifier -> Identifier)
- hdlDir :: Lens' NetlistState FilePath
- htyCache :: Lens' NetlistState HWMap
- intWidth :: Lens' NetlistState Int
- isTestBench :: Lens' NetlistState Bool
- mkIdentifierFn :: Lens' NetlistState (IdType -> Identifier -> Identifier)
- primitives :: Lens' NetlistState CompiledPrimMap
- seenComps :: Lens' NetlistState (HashMap Identifier Word)
- seenIds :: Lens' NetlistState (HashMap Identifier Word)
- seenPrimitives :: Lens' NetlistState (Set Text)
- tcCache :: Lens' NetlistState TyConMap
- topEntityAnns :: Lens' NetlistState (VarEnv (Type, Maybe TopEntity))
- typeTranslator :: Lens' NetlistState (CustomReprs -> TyConMap -> Type -> State HWMap (Maybe (Either String FilteredHWType)))
- varCount :: Lens' NetlistState Int
Documentation
data Declaration Source #
Internals of a Component
Constructors
| Assignment | Signal assignment | 
| Fields 
 | |
| CondAssignment | Conditional signal assignment: | 
| InstDecl | Instantiation of another component: | 
| Fields 
 | |
| BlackBoxD | Instantiation of blackbox declaration | 
| Fields 
 | |
| NetDecl' | Signal declaration | 
| Fields 
 | |
| TickDecl Comment | HDL tick corresponding to a Core tick | 
Bundled Patterns
| pattern NetDecl | |
| Fields 
 | |
Instances
| Show Declaration Source # | |
| Defined in Clash.Netlist.Types Methods showsPrec :: Int -> Declaration -> ShowS # show :: Declaration -> String # showList :: [Declaration] -> ShowS # | |
| NFData Declaration Source # | |
| Defined in Clash.Netlist.Types Methods rnf :: Declaration -> () # | |
newtype NetlistMonad a Source #
Monad that caches generated components (StateT) and remembers hidden inputs of components that are being generated (WriterT)
Constructors
| NetlistMonad | |
| Fields 
 | |
Instances
Constructors
| BBTemplate BlackBoxTemplate | |
| BBFunction BBName BBHash TemplateFunction | 
Instances
| Show BlackBox Source # | |
| Generic BlackBox Source # | |
| Binary BlackBox Source # | |
| NFData BlackBox Source # | |
| Defined in Clash.Netlist.Types | |
| type Rep BlackBox Source # | |
| Defined in Clash.Netlist.Types type Rep BlackBox = D1 ('MetaData "BlackBox" "Clash.Netlist.Types" "clash-lib-0.9999-inplace" 'False) (C1 ('MetaCons "BBTemplate" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 BlackBoxTemplate)) :+: C1 ('MetaCons "BBFunction" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 BBName) :*: (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 BBHash) :*: S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 TemplateFunction)))) | |
Expression used in RHS of a declaration
Constructors
| Literal !(Maybe (HWType, Size)) !Literal | Literal expression | 
| DataCon !HWType !Modifier [Expr] | DataCon application | 
| Identifier !Identifier !(Maybe Modifier) | Signal reference | 
| DataTag !HWType !(Either Identifier Identifier) | 
 | 
| BlackBoxE | Instantiation of a BlackBox expression | 
| Fields 
 | |
| ConvBV (Maybe Identifier) HWType Bool Expr | |
| IfThenElse Expr Expr Expr | |
Component: base unit of a Netlist
Constructors
| Component | |
| Fields 
 | |
data Declaration Source #
Internals of a Component
Constructors
| Assignment | Signal assignment | 
| Fields 
 | |
| CondAssignment | Conditional signal assignment: | 
| InstDecl | Instantiation of another component: | 
| Fields 
 | |
| BlackBoxD | Instantiation of blackbox declaration | 
| Fields 
 | |
| NetDecl' | Signal declaration | 
| Fields 
 | |
| TickDecl Comment | HDL tick corresponding to a Core tick | 
Instances
| Show Declaration Source # | |
| Defined in Clash.Netlist.Types Methods showsPrec :: Int -> Declaration -> ShowS # show :: Declaration -> String # showList :: [Declaration] -> ShowS # | |
| NFData Declaration Source # | |
| Defined in Clash.Netlist.Types Methods rnf :: Declaration -> () # | |
Representable hardware types
Constructors
| Void (Maybe HWType) | Empty type.  | 
| String | String type | 
| Integer | Integer type (for parameters only) | 
| Bool | Boolean type | 
| Bit | Bit type | 
| BitVector !Size | BitVector of a specified size | 
| Index !Integer | Unsigned integer with specified (exclusive) upper bounder | 
| Signed !Size | Signed integer of a specified size | 
| Unsigned !Size | Unsigned integer of a specified size | 
| Vector !Size !HWType | Vector type | 
| RTree !Size !HWType | RTree type | 
| Sum !Identifier [Identifier] | Sum type: Name and Constructor names | 
| Product !Identifier (Maybe [Text]) [HWType] | Product type: Name, field names, and field types. Field names will be populated when using records. | 
| SP !Identifier [(Identifier, [HWType])] | Sum-of-Product type: Name and Constructor names + field types | 
| Clock !Identifier | Clock type corresponding to domain Identifier | 
| Reset !Identifier | Reset type corresponding to domain Identifier | 
| BiDirectional !PortDirection !HWType | Tagging type indicating a bidirectional (inout) port | 
| CustomSP !Identifier !DataRepr' !Size [(ConstrRepr', Identifier, [HWType])] | Same as Sum-Of-Product, but with a user specified bit representation. For more info, see: Clash.Annotations.BitRepresentations. | 
| CustomSum !Identifier !DataRepr' !Size [(ConstrRepr', Identifier)] | Same as Sum, but with a user specified bit representation. For more info, see: Clash.Annotations.BitRepresentations. | 
| Annotated [Attr'] !HWType | Annotated with HDL attributes | 
| KnownDomain !Identifier !Integer !ActiveEdge !ResetKind !InitBehavior !ResetPolarity | Domain name, period, active edge, reset kind, initial value behavior | 
Instances
type Identifier = Text Source #
Signal reference
data TemplateFunction where Source #
Constructors
| TemplateFunction :: [Int] -> (BlackBoxContext -> Bool) -> (forall s. Backend s => BlackBoxContext -> State s Doc) -> TemplateFunction | 
Instances
| Binary TemplateFunction Source # | NB: serialisation doesn't preserve the embedded function | 
| Defined in Clash.Netlist.Types Methods put :: TemplateFunction -> Put # get :: Get TemplateFunction # putList :: [TemplateFunction] -> Put # | |
| NFData TemplateFunction Source # | |
| Defined in Clash.Netlist.Types Methods rnf :: TemplateFunction -> () # | |
data BlackBoxContext Source #
Context used to fill in the holes of a BlackBox template
Constructors
| Context | |
| Fields 
 | |
Instances
| Show BlackBoxContext Source # | |
| Defined in Clash.Netlist.Types Methods showsPrec :: Int -> BlackBoxContext -> ShowS # show :: BlackBoxContext -> String # showList :: [BlackBoxContext] -> ShowS # | |
Literals used in an expression
Expression Modifier
Constructors
| Indexed (HWType, Int, Int) | Index the expression: (Type of expression,DataCon tag,Field Tag) | 
| DC (HWType, Int) | See expression in a DataCon context: (Type of the expression, DataCon tag) | 
| VecAppend | See the expression in the context of a Vector append operation | 
| RTreeAppend | See the expression in the context of a Tree append operation | 
| Sliced (HWType, Int, Int) | Slice the identifier of the given type from start to end | 
| Nested Modifier Modifier | 
data PortDirection Source #
Instances
data EntityOrComponent Source #
Instances
| Show EntityOrComponent Source # | |
| Defined in Clash.Netlist.Types Methods showsPrec :: Int -> EntityOrComponent -> ShowS # show :: EntityOrComponent -> String # showList :: [EntityOrComponent] -> ShowS # | |
data FilteredHWType Source #
Tree structure indicating which constructor fields were filtered from a type due to them being void. We need this information to generate stable and/or user-defined port mappings.
Constructors
| FilteredHWType HWType [[(IsVoid, FilteredHWType)]] | 
Instances
| Eq FilteredHWType Source # | |
| Defined in Clash.Netlist.Types Methods (==) :: FilteredHWType -> FilteredHWType -> Bool # (/=) :: FilteredHWType -> FilteredHWType -> Bool # | |
| Show FilteredHWType Source # | |
| Defined in Clash.Netlist.Types Methods showsPrec :: Int -> FilteredHWType -> ShowS # show :: FilteredHWType -> String # showList :: [FilteredHWType] -> ShowS # | |
data NetlistState Source #
State of the NetlistMonad
Constructors
| NetlistState | |
| Fields 
 | |
Instances
| MonadState NetlistState NetlistMonad Source # | |
| Defined in Clash.Netlist.Types Methods get :: NetlistMonad NetlistState # put :: NetlistState -> NetlistMonad () # state :: (NetlistState -> (a, NetlistState)) -> NetlistMonad a # | |
data NetlistEnv Source #
Environment of the NetlistMonad
Constructors
| NetlistEnv | |
| Fields 
 | |
Instances
| MonadReader NetlistEnv NetlistMonad Source # | |
| Defined in Clash.Netlist.Types Methods ask :: NetlistMonad NetlistEnv # local :: (NetlistEnv -> NetlistEnv) -> NetlistMonad a -> NetlistMonad a # reader :: (NetlistEnv -> a) -> NetlistMonad a # | |
Arguments
| :: Maybe Comment | Note; will be inserted as a comment in target hdl | 
| -> Identifier | Name of signal | 
| -> HWType | Type of signal | 
| -> Declaration | 
hwTypeAttrs :: HWType -> [Attr'] Source #
Extract hardware attributes from Annotated. Returns an empty list if non-Annotated given or if Annotated has an empty list of attributes.
emptyBBContext :: Text -> BlackBoxContext Source #
setName :: Lens' NetlistEnv (Maybe Identifier) Source #
components :: Lens' NetlistState (VarEnv ([Bool], SrcSpan, HashMap Identifier Word, Component)) Source #
customReprs :: Lens' NetlistState CustomReprs Source #
extendIdentifierFn :: Lens' NetlistState (IdType -> Identifier -> Identifier -> Identifier) Source #
mkIdentifierFn :: Lens' NetlistState (IdType -> Identifier -> Identifier) Source #
topEntityAnns :: Lens' NetlistState (VarEnv (Type, Maybe TopEntity)) Source #
typeTranslator :: Lens' NetlistState (CustomReprs -> TyConMap -> Type -> State HWMap (Maybe (Either String FilteredHWType))) Source #