FPGA开发之算法开发System Generator

FPGA开发之算法开发System Generator,第1张

现在的FPGA算法的实现有下面几种方法:
1. Verilog/VHDL 语言的开发 ;
2. system Generator;
3. ImpulsC 编译器实现从 C代码到 HDL 语言;
4. Vivado HLS。

本文主要讲述第二种方法的配置方法。

system Generator
System generator 可以和 ISE or Vivado 进行无缝连接。 但是需要有个版本的对应关系:

System generator 安装之后会在Simulin模块库中添加一些Xilinx FPGA专用的模块库,包括Basic Element,C++ommunicaTIon,Control Logic,DataTypes,DSP,Math,Memory,Shared Momory,Tool等模块库,只有使用这里的模块才能进行FPGA算法的仿真以及进行综合等等。使用这些模块就可以简单的选一些模块,连一些线就能自动生成你需要的HDL代码,将开发人员从底层枯燥的代码编写中解脱出来,将更多的精力放在算法上,非常完美的体现了工具为人服务的理念。 ISE14.7 ,Vavido HLS 已经能够使用C和C++生成HDL代码,那个主要是针对Xilinx公司7系列的FPGA,有兴趣的同学可以尝试。另外 Matlab2013a 将HDL coder作为一个独立的工具添加进来,已经能够支持Xilinx公司的FPGA。

一、System Generator快速入门

(一).Xilinx Blockset库的基本介绍

System Generator和Simulink是无缝链接的,可以在MATLAB标准工具栏中直接启动,如图1-1所示。这些模块都根据其功能划分为不同的库,为了易于使用,又在某些库中添加了部分有广泛应用的模块,所有的模块都按字母顺序排列在Xilinx Index库中。读者需要注意的是:在Simulink环境中,只有通过Xilinx模块搭建的系统才能保证硬件可实现,其地位类似于HDL语言中的可综合语句。

FPGA开发之算法开发System Generator,FPGA开发之算法开发System Generator,第2张

FPGA开发之算法开发System Generator,图1-1 Xilinx DSP模块集 (Xilinx Blockset),第3张

图1-1 Xilinx DSP模块集 (Xilinx Blockset)

从设计流程中可以看出,熟悉Xilinx DSP基本模块库是设计流程中的关键环节,只有掌握了基本模块的特性和功能,才能更好地实现算法。由Xilinx模块库和System Generator一起,可生成Xilinx可编程器件的最优逻辑,这属于最低层的设计模块,地位等效于IP Core,共有90多个。Xilinx模块库简要说明如表1-1所列。

FPGA开发之算法开发System Generator,表1-1 System Generator库的简要说明,第4张

表1-1 System Generator库的简要说明

1.基本单元模块 (Basic Elements)

基本单元模块库中包含了数字逻辑的标准组件模块,使用这些模块可插入时间延迟、改变信号速率、引入常数、计数器以及多路复用器等。此外,还包含了3个特殊的模块System Generator标志、黑盒子模块(Black Box)以及边界定义模块,后文将对其进行详细说明。该库中简要的模块说明如表1-2所列。

FPGA开发之算法开发System Generator,表1-2 基本单元模块的说明列表,第5张

表1-2 基本单元模块的说明列表

2.通信模块 (communicaTIon )

通信应用是FPGA的主要应用领域之一,因此Xilinx的通信模块库提供了用于实现数字通信的各种函数,包括卷积编解码、RS编解码以及交织器等模块。该库中简要的模块说明如表1-3所列。

FPGA开发之算法开发System Generator,表1-3 通信模块的说明列表,第6张

表1-3 通信模块的说明列表

3.控制逻辑模块 (Control Logic)

控制逻辑主要包括了用于创建各种控制逻辑和状态机的资源,包括了逻辑表达式模块、软核控制器、复用器以及存储器,其简要说明如表1-4所列。

FPGA开发之算法开发System Generator,表1-4 控制逻辑模块的说明列表,第7张

表1-4 控制逻辑模块的说明列表

4.数据类型模块 (Data Types)

数据类型模块主要用于信号的数据类型转换,包括移位、量化、并/串、串/并转换以及精度调整模块,其简要说明如表1-5所列。

FPGA开发之算法开发System Generator,表1-5 数据类型模块的说明列表,第8张

表1-5 数据类型模块的说明列表

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/dianzi/2607242.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-08-09
下一篇 2022-08-09

发表评论

登录后才能评论

评论列表(0条)

保存