模型功能
- FPGA的运行是并行的
- FPGA的串行依赖状态机
- FPGA的并行依赖流水线
- FPGA的大规模设计依赖精确设计
模型框图
FPGA是并行的系统,所有的代码同时运行,这是FPGA高效的根本所在
实现步骤
- FPGA的并行特性
- 和一般意义上的高级语言不同,verilog更多地是低级语言特性
- 这一点可以从其描述而非高级可以得知
- 如何应用这种并行特性
- 如果一个模块持续性运行,则对FPGA来说是最高效率的,可以得到最高的性能
- 如果一个模块是灵活多变的,则对FPGA来说获得了最佳的拓展性,可以解决各种复杂的场景
- 而掌握两者的平衡,就是对并行特性的最大化利用
- 状态机的最大灵活性
- 使用状态机,可以实现类似高级语言的串行逻辑
- 信号在状态机的控制下,实现信号的逐个状态控制
- 这种严格的执行顺序,实际上削弱了FPGA的性能,但是增加了控制的灵活性
- 适合处理具备复杂控制交互的逻辑
!不要试图使用流水线替代状态机,那样虽然可以提高性能,但是付出的时间和后续的维护成本不可接收
- 流水线的最大性能
- 流水线是FPGA最关键的结构
- 使用流水线至少可以节约1倍的资源和时间,是少有的完全适配FPGA的模型
- 流水线的实现方法多种多样,最关键的就是建立数据总线,将数据从模块提取到总线中
- 只有在总线中的数据才具备在多个不同模块之间进行流水操作
- 如果只是在一个模块里面搭建流水线,那可维护性较差,无法适应复杂的流水处理逻辑,而且容易偷懒将信号随意跨流水线导致维护困难
- 将数据从定义在模块内,修改为将数据定义在总线中,所有的模块挂在总线上,才能实现无限拓展且顺序可调的流水线
- 这种流水线可以实现类似大状态机的结构,但是又可以匹配状态机的低效率,是大型数据处理(如图像)的必选方法
- FPGA的精确设计
- 一般来说,FPGA的各个参数不需要进行严格的控制
- FPGA为了拓展性等原因多会使用更大的位宽
- 但是对于大规模设计,位宽的控制是必要的
- 多余的位宽会导致一些简单逻辑占据多余的空位宽
- 虽然FPGA会自动优化一部分
- 但是对于信号,多余的位宽精度是无法自动优化的
- 所以,精确的位宽控制是保证最小面积的根本方法
- 同时是最简时序控制也是一个重要的部分
- 简化时序的关键在于信号独立控制
- 将信号进行混合控制除了不利于和电路对应
- 更大的问题是无法实现控制简化
- 这种信号交叉容易带来额外的时序控制
- 而这种时序又会进一步复杂控制
- 所以,信号在命名的时候应该就带时序信息
最终效果
- 状态机之前的文章已经实现过了,找一个模块实现即可
- 流水线则是需要依据实际的需求进行搭建,本文只是在于回顾verilog的重点内容,这里也不展开
- 精确化的设计在之前的例子也是有体现的,位宽的参数化,信号的时序化,为整个的控制提供了基础
调用接口
- 略
verilog模型总结
- 用了一周的时间,大致回顾FPGA中的verilog中一些比较实用的部分,
- 按照本人喜欢的编码模板,逐个分析模块每个内容所包含的细节
- 回顾了之前忽略的部分,修复目前设计模型中的一些问题
- 如无意外,本合集到此结束,后续应该会继续回顾system verilog模型的一些细节