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, ...)来搭建数据模型并把他们以程序的⽅式转化成硬件(例如对列表元素迭代)。

相关推荐
小糖学代码5 小时前
LLM系列:1.python入门:15.JSON 数据处理与操作
开发语言·python·json·aigc
空中海5 小时前
第七章:vue工程化与构建工具
前端·javascript·vue.js
handler015 小时前
从源码到二进制:深度拆解 Linux 下 C 程序的编译与链接全流程
linux·c语言·开发语言·c++·笔记·学习
zhensherlock5 小时前
Protocol Launcher 系列:Trello 看板管理的协议自动化
前端·javascript·typescript·node.js·自动化·github·js
zhuà!5 小时前
element的el-form提交校验没反应问题
前端·elementui
小白学大数据5 小时前
现代Python爬虫开发范式:基于Asyncio的高可用架构实战
开发语言·爬虫·python·架构
龙猫里的小梅啊5 小时前
CSS(一)CSS基础语法与样式引入
前端·css
小码哥_常5 小时前
从0到1,开启Android音视频开发之旅
前端
渔舟小调5 小时前
P19 | 前端加密通信层 pikachuNetwork.js 完整实现
开发语言·前端·javascript
不爱吃炸鸡柳5 小时前
数据结构精讲:树 → 二叉树 → 堆 从入门到实战
开发语言·数据结构