SpinalHDL之结构(八)

本文作为SpinalHDL学习笔记第六十八篇,介绍SpinalHDL的参数化(Parametrization)。

目录:

1.简介(Introduction)

2.细化阶段的参数(Elaboration time parameters)

3.可选择的硬件⽣成(Optional hardware)

⼀、简介(Introduction)

SpinalHDL的参数化概念涉及多个⽅⾯:
◆给设计提供细化阶段(elaboration time)的参数
◆可选择的硬件⽣成

⼆、细化阶段的参数(Elaboration time parameters)

你可以⽤整个Scala语⾔来提供细化时间时的参数。

下⾯是类参数的例⼦:

Scala 复制代码
case class MyBus(width: Int) extends Bundle {
val mySignal = UInt(width bits)
}
Scala 复制代码
case class MyComponent(width: Int) extends Component {
val bus = MyBus(width)
}

你也可以在scala对象中定义全局变量, 但是需要注意最近增加的ScopeProperty特点能提供更好的解决办法。

三、可选择的硬件⽣成(Optional hardware)

对于可选择的信号:

Scala 复制代码
case class MyComponent(flag: Boolean) extends Component {
val mySignal = flag generate (Bool()) //等价于"if(flag) in Bool() else null"
}

你也可以在Bundle中做相同的事情。

如果你想⽆效⼀块硬件的⽣成:

Scala 复制代码
case class MyComponent(flag: Boolean) extends Component {
val myHardware = flag generate new Area {
//可选择的电路
}
}

你也可以⽤scala循环:

Scala 复制代码
case class MyComponent(amount: Int) extends Component {
val myHardware = for(i <- 0 until amount) yield new Area {
//可选择的电路
}
}

所以, 在细化期间你想怎么运⽤Scala就怎么运⽤, 包括始终整个Scala集合(List, Set, Map, ...)来搭建数据模型并把他们以程序的⽅式转化成硬件(例如对列表元素迭代)。

相关推荐
枫叶梨花15 分钟前
使用Go语言获取Windows系统信息:从CPU到电池的全维度监控
开发语言·windows·golang
C_Liu_20 分钟前
从C语言到C++:拥抱面向对象编程的全新世界
c语言·开发语言·c++
哈基咩23 分钟前
Go 语言模糊测试 (Fuzz Testing) 深度解析与实践
开发语言·后端·golang
元气少女小圆丶25 分钟前
Mirror学习笔记
java·开发语言·学习
lly20240626 分钟前
Perl 面向对象编程深入解析
开发语言
瓦特what?32 分钟前
C + +
c语言·开发语言·c++·经验分享·笔记·算法·程序员创富
@十八子德月生33 分钟前
第三阶段—8天Python从入门到精通【itheima】-143节(pyspark实战——数据计算——flatmap方法)
大数据·开发语言·python·数据分析·pyspark·好好学习,天天向上·question answer
素界UI设计43 分钟前
开源网页生态掘金:从Bootstrap二次开发到行业专属组件库的技术变现
前端·开源·bootstrap
潘小安1 小时前
【译】六个开发高手使用的 css 动画秘诀
前端·css·性能优化
沐知全栈开发1 小时前
C# 运算符重载
开发语言