quartus中调用宏模块中文介绍
- 格式:doc
- 大小:30.00 KB
- 文档页数:2
实验3 宏功能模块的应用实验目的:熟悉Quartus Ⅱ的宏功能模块的应用。
实验工具:Quartus Ⅱ8.0 实验步骤: 工程设计步骤:实验内容:一、采用Quartus II 软件的宏功能模块lpm_counter 设计一个模为60的加法计数器,进行编译和仿真,查看仿真结果。
(1)原理图设计:如图3-1-1图3-1-1 模60加法计数器(2)综合模60加法计数器:如图 3-1-2图 3-1-2 模60加法计数器综合报告流动状态 软件版本 修复名称 顶层文件 器件系列所有逻辑资源所有寄存器 所有引脚 所有虚拟引脚 所有存储器 器件型号时间模型(3)功能仿真模60加法计数器功能仿真波形图:如图3-1-3图 3-1-3 模60加法计数器功能仿真结论:图3-3宏功能模块中从上到下有以下几个引脚:异步清零端,时钟使能端,时钟,同步置数端使能端,计数使能端,计数方向,置数输入端,输出端,进位输出端。
每个端口功能如图3-3解释,每个端口都实现了理论中的功能,所以功能仿真成功。
(4)时序仿真模60加法计数器时序仿真波形图:如图3-1-4图 3-1-4模60加法计数器时序仿真结论:图3-4中时序仿真的引脚与图3-3相同,每个引脚实现的功能与图3-3相一致。
所不同的是在时序仿真中输出出现了微小的延时,并且输出之间出现了许多细小的毛刺,在进位输出端也出现了一个明显的毛刺。
不过整体仿真的结果是正确的。
最大工作频率:310.37MHz 如图 3-1-5图 3-1-5 最大工作频率延时情况:注:tsu(建立时间),th(保持时间),tco(时钟至输出延时),tpd(引脚至引脚延时)tpd(引脚至引脚延时)tsu(建立时间)tco(时钟至输出延时)th(保持时间)二、先利用LPM_ROM设计8位×8位乘法器,进行编译和仿真,查看仿真结果。
(1)原理图设计:1、用MATLAB产生一个8_8_mult_rom.mif文件。
2. 宏功能模块定制方法
下面以计数器为例来介绍宏功能模块的使用方法。
2.1计数器LPM模块文本文件的调用
(1)打开宏功能模块调用管理器
图30 定制新的宏功能模块
图31 LPM宏功能模块设定
(2)单击Next按钮后打开如图6-3所示的对话框
图32 设4位可加减计数器
(3)再单击Next按钮,打开如下图所示的对话框
图33 设定计数器,含时钟使能和进位输出(4)再单击Next按钮,打开如下图所示的对话框
图34 加入4位并行数据预置数功能
2.2 LPM计数器程序与参数传递语句
QuartusII生成的计数器文件CNT4B.v
defparam <宏模块元件例化名>.<宏模块参数名>=<参数值> 例
2.3 创建工程与仿真测试
图35 CNT4BIT.v波形仿真文件
图36 原理图输入设计。
quartus 宏编译
Quartus是一款可编程逻辑设备(PLD)设计软件,被广泛应用于数字逻辑电路的设计和仿真。
它提供了一套强大的工具和特性,用于创建、优化和验证各种电路设计。
在使用Quartus进行PLD设计时,我们可以利用宏来简化和优化代码。
宏是一种在编译过程中被替换为特定文本的预定义指令。
它可以显著提高代码的可读性和可维护性,并减少代码冗余。
在使用宏编译时,我们需要遵循一些规则和最佳实践。
首先,我们应该选择有意义的宏名称,以便于其他开发人员理解和使用。
其次,我们应该避免定义与已有变量或函数重名的宏,以免造成命名冲突。
另外,我们还应该注意宏的作用域,确保它们只在需要的地方生效。
使用宏编译可以大大简化代码,提高开发效率。
例如,我们可以使用宏来定义常量,避免在代码中多次重复写入相同的数值。
此外,我们还可以利用宏来定义复杂的逻辑操作,从而简化代码的编写和理解。
然而,宏编译也存在一些注意事项。
首先,我们应该避免在宏定义中包含复杂的逻辑操作,以免导致代码难以理解和维护。
其次,我们需要注意宏的使用方式,确保它们在不同的上下文中能够正常工作。
Quartus宏编译是一种强大的工具,可以优化PLD设计的效率和可
维护性。
通过合理地使用宏,我们可以简化代码,提高开发效率,并确保代码的正确性和可读性。
希望通过这篇文章的介绍,读者能够更好地理解和应用Quartus宏编译。
-----------------------------------------------------RAM宏模块宏模块名称功能描述csdpram 参数化循环共享双端口RAMlpm_ram_dp 参数化双端口RAMlpm_ram_dq 参数化RAM,输入/输出端分离lpm_ram_io 参数化RAM,输入/输出端公用一个端口FIFO宏模块宏模块名称功能描述csfifo 参数化循环共享FIFOdcfifo 参数化双时钟FIFOscfifo 参数化单时钟FIFOlpm_fifo 参数化单时钟FIFOlpm_fifo_dc 参数化双时钟FIFOROM的设计lpm_romQuartus II开发软件中的宏模块--时序电路宏模块触发器宏模块名称功能描述lpm_ff 参数化D或T触发器lpm_dff 参数化D触发器和移位寄存器lpm_tff 参数化T触发器enadff 带使能端的D触发器expdff 用扩展电路实现的D触发器7470 带预置和清零端的与门JK触发器7471 带预置端的JK触发器7472 带预置和清零端的与门JK触发器7473 带清零端的双JK触发器7474 带异步预置和异步清零端的双D触发器7476 带异步预置和异步清零端的双JK触发器7478 带异步预置、公共清零和公共时钟端的双JK触发器74107 带清零端的双JK触发器74109 带预置和清零端的双JK触发器74112 带预置和清零端的双JK时钟下降沿触发器74113 带预置端的双JK时钟下降沿触发器74114 带异步预置、公共清零和公共时钟端的双JK时钟下降沿触发器74171 带清零端的4D触发器74172 带三态输出的多端口寄存器74173 4位D型寄存器74174 带公共清零端的16进制D触发器74174b 带公共清零端的16进制D触发器74175 带公共时钟和清零端的4D触发器74273 带异步清零端的8进制触发器74273b 带异步清零端的8进制触发器74276 带公共预置和清零端的4JK触发器寄存器74374 带三态输出和输出使能端的8进制D触发器74374b 带三态输出和输出使能端的8进制D触发器74376 带公共时钟和公共清零端4JK触发器74377 带使能端的8进制D触发器74377b 带使能端的8进制D触发器74378 带使能端的16进制D触发器74379 带使能端的4D触发器74396 8进制存储寄存器74548 带三态输出的8位两级流水线寄存器74670 带三态输出的4位寄存器74821 带三态输出的10位总线接口触发器74821b 带三态输出的10位D触发器74822 带三态反相输出的10位总线接口触发器74822b 带三态反相输出的10位D触发器74823 带三态输出的9位总线接口触发器74823b 带三态输出的9位D触发器74824 带三态反相输出的9位总线接口触发器74824b 带三态反相输出的9位D触发器74825 带三态反相输出的8位总线接口触发器74825b 带三态输出的8进制D触发器74826 带三态反相输出的9位总线接口触发器74826b 带三态反相输出的8进制D触发器锁存器宏模块名称功能描述lpm_latch参数化锁存器explatch用扩展电路实现的锁存器Inpltch 用扩展电路实现的输入锁存器nandltch用扩展电路实现的SR(非)与非门锁存器norltch 用扩展电路实现的SR或非门锁存器7475 4位双稳态锁存器7477 4位双稳态锁存器74116 带清零端的双4位锁存器74259 带清零端、可设定地址的锁存器74279 4路SR(非)锁存器74373 带三态输出的8进制透明D锁存器74373b 带三态输出的8进制透明D锁存器74375 4位双稳态锁存器74549 8位二级流水线锁存器74604 带三态输出的8进制2输入多路锁存器74841 带三态输出的10位总线接口D锁存器74841b 带三态输出的10位总线接口D锁存器74842 带三态输出的10位总线接口D锁存器74842b 带三态输出的10位总线接口D反相锁存器74843 带三态输出的9位总线接口D锁存器74844 带三态输出的9位总线接口D反相锁存器74845 带三态输出的8位总线接口D锁存器74846 带三态输出的8位总线接口D反相锁存器74990 8位透明读回锁存器计数器宏模块名称功能描述lpm_conter参数化计数器(仅限FLEX系列器件)gray4 格雷码计数器unicnt 通用4位加/减计数器,可异步设置、读取、清零和级联的左/右移位寄存器16cudslr 16位2进制加/减计数器,带异步设置的左/右移位寄存器16cudsrb 16位2进制加/减计数器,带异步清零和设置的左/右移位寄存器4count 4位2进制加/减计数器,同步/异步读取,异步清零8count 8位2进制加/减计数器,同步/异步读取,异步清零7468 双10进制计数器7469 双12进制计数器7490 10/2进制计数器7492 12进制计数器7493 4位2进制计数器74143 4位计数/锁存器,带7位输出驱动器74160 4位10进制计数器,同步读取,异步清零74161 4位2进制加法计数器,同步读取,异步清零74162 4位2进制加法计数器,同步读取,同步清零74163 4位2进制加法计数器,同步读取,同步清零74168 同步4位10进制加/减计数器74169 同步4位2进制加/减计数器74176 可预置10进制计数器74177 可预置2进制计数器74190 4位10进制加/减计数器,异步读取74191 4位2进制加/减计数器,异步读取74192 4位10进制加/减计数器,异步清零74193 4位2进制加/减计数器,异步清零74196 可预置10进制计数器74197 可预置2进制计数器74290 10进制计数器74292 可编程分频器/数字定时器74293 2进制计数器74294 可编程分频器/数字定时器74390 双10进制计数器74393 双4位加法计数器,异步清零74490 双4位10进制计数器74568 10进制加/减计数器,同步读取,同步和异步清零74569 2进制加/减计数器,同步读取,同步和异步清零74590 8位2进制计数器,带三态输出寄存器74592 8位2进制计数器,带输入寄存器74668 同步10进制加/减计数器74669 同步4位2进制加/减计数器74690 同步10进制计数器,带输出寄存器,多重三态输出,异步清零74691 同步2进制计数器,带输出寄存器,多重三态输出,异步清零74693 同步2进制计数器,带输出寄存器,多重三态输出,同步清零74696 同步10进制加/减计数器,带输出寄存器,多重三态输出,异步清零74697 同步2进制加/减计数器,带输出寄存器,多重三态输出,异步清零74698 同步10进制加/减计数器,带输出寄存器,多重三态输出,同步清零74699 同步2进制加/减计数器,带输出寄存器,多重三态输出,同步清零分频器宏模块名称功能描述Freqdiv 2,4,8,16分频器7456 双时钟5,10分频器7457 双时钟5,6,10分频器多路复用器宏模块名称功能描述lpm_mux 参数化多路复用器2lmux 2线-1线多路复用器16lmux 16线-1线多路复用器2X8mux 8位总线的2线-1线多路复用器8lmux 8线-1线多路复用器74151 8线-1线多路复用器74151b 8线-1线多路复用器74153 双4线-1线多路复用器74157 四2线-1线多路复用器74158 带反相输出的四2线-1线多路复用器74251 带三态输出的8线-1线数据选择器74253 带三态输出的双4线-1线数据选择器74257 带三态输出的四2线-1线多路复用器74258 带三态反相输出的四2线-1线多路复用器74298 带存储功能的四2输入多路复用器74352 带反相输出的双4线-1线数据选择器/多路复用器74353 带三态反相输出的双4线-1线数据选择器/多路复用器74354 带三态输出的8线-1线数据选择器/多路复用器74356 带三态输出的8线-1线数据选择器/多路复用器74398 带存储功能的四2输入多路复用器74399 带存储功能的四2输入多路复用器移位寄存器宏模块名称功能描述lpm_clshift参数化组合逻辑移位器lpm_shiftreg参数化移位寄存器barrelst 8位桶形移位器barrlstb 8位桶形移位器7491 串入串出移位寄存器7494 带异步预置和异步清零端的4位移位寄存器7495 4位并行移位寄存器7496 5位移位寄存器7499 带JK串入串出端的4位移位寄存器74164 串入并出移位寄存器74164b 串入并出移位寄存器74165 并行读入8位移位寄存器74165b 并行读入8位移位寄存器74166 带时钟禁止端的8位移位寄存器74178 4位移位寄存器74179 带清零端的4位移位寄存器74194 带并行读入端的4位双向移位寄存器74195 4位并行移位寄存器74198 8位双向移位寄存器74199 8位双向移位寄存器74295 带三态输出端的4位左右移位寄存器74299 8位通用移位/存储寄存器74350 带三态输出端的4位移位寄存器74395 带三态输出端的4位可级联移位寄存器74589 带输入锁存和三态输出端的8位移位寄存器74594 带输入锁存的8位移位寄存器74595 带输入锁存和三态输出端的8位移位寄存器74597 带输入寄存器的8位移位寄存器74671 带强制清零和三态输出端的4位通用移位寄存器/锁存器Quartus II开发软件中的宏模块--运算电路宏模块加法器和减法器宏模块名称功能描述lpm_add_sub 参数化加法器/减法器8fadd 8位全加器8faddb 8位全加器7480 门控全加器7482 2位2进制全加器7483 带快速进位的4位2进制全加器74183 双进位存储全加器74283 带快速进位的4位全加器74385 带清零端的4位加法器/减法器乘法器宏模块名称功能描述lpm_mult 参数化乘法器mult2 2位带符号数乘法器mult24 2X4位并行2进制乘法器mult4 4位并行2进制乘法器mult4b 4位并行2进制乘法器tmult4 4X4位并行2进制乘法器7497 同步6位速率乘法器74261 2位并行2进制乘法器74284 4X4位并行2进制乘法器(输出结果的最高4位)74285 4X4位并行2进制乘法器(输出结果的最低4位)除法器divide和lpm_divide绝对值运算lpm_abs数值比较器宏模块名称功能描述lpm_compare 参数化比较器8mcomp 8位数值比较器8mcompb 8位数值比较器7485 4位数值比较器74518 8位恒等比较器74518b 8位恒等比较器74684 8位数值/恒等比较器74686 8位数值/恒等比较器74688 8位恒等比较器编码器模块名称功能描述74147 10线-3线BCD编码器74148 8线-3线8进制编码器74384 带三态输出的8线-3线优先权编码器译码器宏模块名称功能描述lpm_decode 参数化译码器16dmux 4位2进制-16线译码器16ndmux 4位2进制-16线译码器7442 1线-10线BCD-10进制译码器7443 余3码-10进制译码器7444 余3格雷码-10进制译码器7445 BCD码-10进制译码器7446 BCD码-7段译码器7447 BCD码-7段译码器7448 BCD码-7段译码器7449 BCD码-7段译码器74137 带地址锁存的3线-8线译码器74138 3线-8线译码器74139 双2线-4线译码器74145 BCD码-10进制译码器74154 4线-16线译码器74155 双2线-4线译码器/多路输出选择器74156 双2线-4线译码器/多路输出选择器74246 BCD码-7段译码器74247 BCD码-7段译码器74248 BCD码-7段译码器74445 BCD码-10进制译码器奇偶校验器宏模块名称功能描述74180 9位奇偶产生器/校验器74180b 9位奇偶产生器/校验器74280 9位奇偶产生器/校验器74280b 9位奇偶产生器/校验器LPM库单元列表模块分类宏单元简要说明门单元模块lpm_and 参数化与门lpm_bustri 参数化三态缓冲器lpm_clshift 参数化组合逻辑移位器lpm_constant 参数化常数产生器lpm_decode 参数化译码器lpm_inv 参数化反向器lpm_mux 参数化多路选择器busmux 参数化总线选择器mux 多路选择器lpm_or 参数化或门lpm_xor 参数化异或门算术运算模块lpm_abs 参数化绝对值运算lpm_add_sub 参数化的加/减法器lpm_compare 参数化比较器lpm_counter 参数化计数器lpm_mult 参数化乘法器存储器模块lpm_ff 参数化D触发器lpm_latch 参数化锁存器lpm_ram_dq 输入输出分开的参数化RAMlpm_ram_io 输入输出复用的参数化RAMlpm_rom 参数化ROMlpm_shitreg 参数化移位寄存器csfifo class="style8">参数化先进先出队列csdpram 参数化双口RAM其它功能模块pll 参数化锁相环电路。
quartus 宏编译摘要:1.介绍Quartus2.介绍宏编译3.Quartus 与宏编译的关系4.如何使用Quartus 进行宏编译5.宏编译的优点正文:Quartus 是一种用于编译FPGA(现场可编程门阵列)设计的专业工具,它由Altera 公司开发。
FPGA 是一种集成电路,可以根据需要进行重新配置,以实现不同的功能。
通过使用Quartus,工程师可以设计、验证和编译FPGA 设计,并将其下载到目标FPGA 设备。
宏编译是Quartus 中的一种编译技术,它可以将整个设计一次性编译为底层硬件电路,从而提高编译速度和性能。
与传统的FPGA 设计流程相比,使用宏编译可以大大减少编译时间,提高生产效率。
Quartus 与宏编译的关系密切,因为Quartus 提供了宏编译所需的各种工具和功能。
通过Quartus,工程师可以利用宏编译技术,将FPGA 设计编译为高效的硬件电路。
使用Quartus 进行宏编译的具体步骤如下:1.打开Quartus 软件,并创建一个新的项目。
2.将FPGA 设计文件添加到项目中,包括HDL 源文件、库文件等。
3.在Quartus 中配置FPGA 设备,包括芯片类型、封装类型等。
4.设置编译选项,选择宏编译技术。
5.启动编译,等待编译完成。
6.将编译好的硬件电路下载到FPGA 设备。
宏编译技术具有以下优点:1.提高编译速度:宏编译可以一次性编译整个设计,避免传统的编译流程中需要多次编译、链接等操作,从而大大提高编译速度。
2.提高性能:宏编译可以将设计优化为底层硬件电路,从而提高FPGA 设备的性能。
3.简化设计流程:通过使用宏编译,工程师可以更方便地进行FPGA 设计,无需关心底层硬件电路的实现细节。
总之,Quartus 作为一种专业的FPGA 设计工具,提供了强大的宏编译技术,可以帮助工程师快速、高效地完成FPGA 设计。
Quartus II 的使用 (1)1 工程建立 (1)2 原理图的输入 (5)3 文本编辑(verilog) (14)4 波形仿真 (16)Quartus II 的使用在这里,首先用最简单的实例向读者展示使用Quartus II软件的全过程。
进入WINDOWS XP后,双击Quartus II图标,屏幕如图1.1所示。
图 1.1 Quartus II 管理器1.1 工程建立使用 New Project Wizard,可以为工程指定工作目录、分配工程名称以及指定最高层设计实体的名称。
还可以指定要在工程中使用的设计文件、其它源文件、用户库和 EDA 工具,以及目标器件系列和器件(也可以让Quartus II 软件自动选择器件)。
建立工程的步骤如下:(1)选择File菜单下New Project Wizard ,如图1.2所示。
图 1.2 建立项目的屏幕(2)输入工作目录和项目名称,如图1.3所示。
可以直接选择Finish,以下的设置过程可以在设计过程中完成。
图 1.3 项目目录和名称(3)加入已有的设计文件到项目,可以直接选择Next,设计文件可以在设计过程中加入,如图1.4所示。
图 1.4 加入设计文件(4)选择设计器件:选择仿真器和综合器类型(默认“None”为选择QuartusII自带的),选择目标芯片(开发板上的芯片类型),如图1.5所示。
图 1.5 选择器件(5)选择第三方EDA综合、仿真和时序分析工具(若都不选择,则使用QuartusII自带的所有设计工具)如图1.6所示。
图 1.6 选择EDA 工具(6)建立项目完成,显示项目概要,如图1.7所示。
图 1.7 项目概要工程建立后,若需要新增设计文件,可以通过 Project/Add_Remove……在工程中添加新建立的设计文件,也可以删除不需要的设计文件。
编译时将按此选项卡中显示文件处理。
注意:通过工程向导做作的设置都是可以在Assignments/settings下再进行修改的。
QuartusII中⽂完整教程Quartus II 的使⽤ (1)1 ⼯程建⽴ (1)2 原理图的输⼊ (5)3 ⽂本编辑(verilog) (13)4 波形仿真 (15)Quartus II 的使⽤在这⾥,⾸先⽤最简单的实例向读者展⽰使⽤Quartus II软件的全过程。
进⼊WINDOWS XP后,双击Quartus II图标,屏幕如图1.1所⽰。
图 1.1 Quartus II 管理器1.1 ⼯程建⽴使⽤New Project Wizard,可以为⼯程指定⼯作⽬录、分配⼯程名称以及指定最⾼层设计实体的名称。
还可以指定要在⼯程中使⽤的设计⽂件、其它源⽂件、⽤户库和EDA ⼯具,以及⽬标器件系列和器件(也可以让Quartus II 软件⾃动选择器件)。
建⽴⼯程的步骤如下:(1)选择File菜单下New Project Wizard ,如图1.2所⽰。
图 1.2 建⽴项⽬的屏幕(2)输⼊⼯作⽬录和项⽬名称,如图1.3所⽰。
可以直接选择Finish,以下的设置过程可以在设计过程中完成。
图 1.3 项⽬⽬录和名称(3)加⼊已有的设计⽂件到项⽬,可以直接选择Next,设计⽂件可以在设计过程中加⼊,如图1.4所⽰。
图 1.4 加⼊设计⽂件(4)选择设计器件:选择仿真器和综合器类型(默认“None”为选择QuartusII⾃带的),选择⽬标芯⽚(开发板上的芯⽚类型),如图1.5所⽰。
图 1.5 选择器件(5)选择第三⽅EDA综合、仿真和时序分析⼯具(若都不选择,则使⽤QuartusII⾃带的所有设计⼯具)如图1.6所⽰。
图 1.6 选择EDA ⼯具(6)建⽴项⽬完成,显⽰项⽬概要,如图1.7所⽰。
图 1.7 项⽬概要⼯程建⽴后,若需要新增设计⽂件,可以通过 Project/Add_Remove……在⼯程中添加新建⽴的设计⽂件,也可以删除不需要的设计⽂件。
编译时将按此选项卡中显⽰⽂件处理。
注意:通过⼯程向导做作的设置都是可以在Assignments/settings下再进⾏修改的。
Quartus II如何输入和显示中文注释说明a) Quartus II 8.0以前的版本,可以输入中文也可以显示中文;b) Quartus II 8.0以后,Quartus II 9.1以前版本的版本可以显示中文,但是不能输入中文;c) Quartus II 9.1之后,Quartus II 11以前的版本不能输入中文,同时也不可以显示中文;d) Quartus II 11.0目前最新版本,可以显示中文字符,同时又能也能输入中文。
注意:由于ModelSim功能强大,Quartus II 11.0以后的软件很多功能都被剔除了,所以不见得版本越高越好,建议大家使用9.0或者9.5的版本。
Quartus II 软件可以到官网下载/?edition=web或者:/category-954833971.htm?spm=2013.1.w4010-542 0703609.9.I9BngM&search=y&parentCatId=914376443&parentCatName=%B5%E7%D7%D3%B5%E 7%C6%F8&catName=FPGA%2FVerilog#bd。
这里还有《verilog视频教程和源代码》和吴厚航(特权同学)的《深入浅出玩转FPGA 》等其他Verilog和FPGA学习视频。
Quartus II输入和显示中文注释的方法方法一:下载Quartus II 11.0以后的版本,11.0以后的版本都支持中英文显示和输入。
但Quartus II 11.0以后的版本功能被阉割了很多,不建议使用。
方法二:Quartus II 9.1以前的版本可以显示中文但不能输入中文注释,因此可以用复制粘贴的方法显示中文注释:即在Txt文档或者Word文档编辑好再复制再Quartus II的编辑窗口。
方法三:强烈推荐:(1)即在Quartus II的窗口调用其他编辑器,如调用Txt文本编辑、Notepad++或者UltraEdit 等编辑器。
Quartus II 的使用 (1)1 工程建立 (1)2 原理图的输入 (5)3 文本编辑〔verilog〕 (14)4 波形仿真 (16)Quartus II 的使用在这里,首先用最简单的实例向读者展示使用Quartus II软件的全过程。
进入WINDOWS XP后,双击Quartus II图标,屏幕如图1.1所示。
图Quartus II 管理器工程建立使用New Project Wizard,可以为工程指定工作目录、分配工程名称以及指定最高层设计实体的名称。
还可以指定要在工程中使用的设计文件、其它源文件、用户库和EDA 工具,以及目标器件系列和器件〔也可以让Quartus II 软件自动选择器件〕。
建立工程的步骤如下:(1)选择File菜单下New Project Wizard ,如图1.2所示。
图 1.2 建立工程的屏幕(2)输入工作目录和工程名称,如图1.3所示。
可以直接选择Finish,以下的设置过程可以在设计过程中完成。
图 1.3 工程目录和名称(3)参加已有的设计文件到工程,可以直接选择Next,设计文件可以在设计过程中参加,如图1.4所示。
图 1.4 参加设计文件(4)选择设计器件:选择仿真器和综合器类型〔默认“None〞为选择QuartusII自带的〕,选择目标芯片〔开发板上的芯片类型〕,如图1.5所示。
图 1.5 选择器件(5)选择第三方EDA综合、仿真和时序分析工具〔假设都不选择,那么使用QuartusII自带的所有设计工具〕如图1.6所示。
图 1.6 选择EDA 工具(6)建立工程完成,显示工程概要,如图1.7所示。
图 1.7 工程概要工程建立后,假设需要新增设计文件,可以通过 Project/Add_Remove……在工程中添加新建立的设计文件,也可以删除不需要的设计文件。
编译时将按此选项卡中显示文件处理。
注意:通过工程向导做作的设置都是可以在Assignments/settings下再进行修改的。
QUARTUS__LPM模块功能介绍中文版QUARTUS8.0LPM模块功能介绍中文版(lwg9982004's Blog转载)QUARTUS8.0LPM模块功能介绍中文版(lwg9982004's Blog转载)本人英语很好很多地方都翻译的不太专业,现在贴出来请高手修改下,同时也方便我们这些初学者。
Megafunctions/LPMThe Quartus II software offers a variety of megafunctions, including the library of parameterized modules(LPM) functions and other parameterized functions. Megafunctions are listed below by function.Functions indicated by an asterisk(*)are provided for backward compatibility only.Arithmetic MegaWizards and Megafunctions: Arithmetic components include accumulators,adders, multipliers,and LPM arithmetic functions.MegaWizardMegafunction(s)CommentsALTACCUMULATEaltaccumulateParameterized accumulator megafunction.参数化的寄存器模块ALTECCaltecc_decoderError correction code(ECC)megafunction.数据代码纠正模块altecc_encoderError correction code(ECC)megafunction.数据代码纠正模块ALTFP_ADD_SUBaltfp_add_subFloating-point adder/subtractor megafunction.浮点、加法器/减法器模块ALTFP_COMPAREaltfp_compareParameterized floating-point comparator megafunction.参数化的浮点比较器模块ALTFP_CONVERTaltfp_convertParameterized floating-point conversion megafunction.参数化的浮点转换器模块ALTFP_DIValtfp_divParameterized floating-point divider megafunction.参数化的浮点分配器模块ALTFP_MULTaltfp_multParameterized floating-point multiplier megafunction.参数化的浮点乘法器模块ALTFP_SQRTaltfp_sqrtParameterized floating-point square root megafunction.参数化的浮点平方根模块ALTMEMMULTaltmemmultParameterized memory multiplier megafunction.数化的记忆乘法器模块ALTMULT_ACCUM(MAC)altmult_accumParameterized multiply-accumulate megafunction.参数化的乘-累积模块ALTMULT_ADDaltmult_addParameterized multiplier/adder megafunction.参数化的乘法器/加法器模块ALMULT_COMPLEXaltmult_complexParameterized complex multiplier megafunction.参数化的综合乘法器模块ALTSQRTaltsqrtParameterized integer square root megafunction.参数化的整数平方根模块LPM_ABSlpm_absParameterized absolute value megafunction.参数化的绝对值模块LPM_ADD_SUBlpm_add_subParameterized adder/subtractor megafunction.参数化的加法器/减法器模块LPM_COMPARElpm_compareParameterized comparator megafunction.参数化的比较器模块LPM_COUNTERlpm_counterParameterized counter megafunction.参数化的计数器模块LPM_DIVIDElpm_divideParameterized divider megafunction.参数化的分配器模块divide*Parameterized divider megafunction.参数化的分配器模块Use the divide megafunction with mature device families. For newer device families,use the lpm_divide megafunction.LPM_MULTlpm_multParameterized multiplier megafunction.参数化的乘法器模块altsquareParameterized squarer megafunction.参数化的squarer模块PARALLEL_ADDparallel_addParallel adder megafunction.参数化的并联加法器模块Gates MegaWizards and Megafunctions:Gates include multiplexers and LPM gate functions. MegaWizardMegafunction(s)CommentsLPM_ANDlpm_andParameterized AND gate megafunction.参数化的与门模块LPM_BUSTRIlpm_bustriParameterized tri-state buffer megafunction.参数化的三态缓冲器模块LPM_CLSHIFTlpm_clshiftParameterized combinational logic shifter or barrel shifter megafunction.参数化的组合逻辑转换模块LPM_CONSTANTlpm_constantParameterized constant generator megafunction.参数化的常数发生器模块LPM_DECODElpm_decodeDecoder megafunction.参数化的解码器模块LPM_INVlpm_invParameterized inverter megafunction.参数化的反相器模块LPM_MUXlpm_muxParameterized multiplexer megafunctions.参数化的多路转换器模块LPM_ORlpm_orParameterized OR gate megafunction.参数化的或门模块LPM_XORlpm_xorParameterized XOR gate megafunction.参数化的异或门模块I/O MegaWizards and Megafunctions:I/O components include Clock Data Recovery(CDR), phase locked loop(PLL),double data rate(DDR),gigabit transceiver block(GXB),LVDS receiver,LVDS transmitter,PLL reconfiguration,and remote update megafunctions.MegaWizardMegafunction(s)CommentsALT2GXBalt2gxbGXB megafunction.千兆位收发器ALT2GXB_RECONFIGalt2gxb_reconfigGXB dynamic reconfiguration megafunction.千兆位动态配置收发器ALTASMI_PARALLELaltasmi_parallelActive serial memory interface parallel megafunction.并联接口的串行存储器ALTCLKCTRLaltclkctrlClock control block megafunction.时钟控制模块ALTCLKLOCKaltclklockParameterized PLL megafunction.参数化的锁相环模块ALTDDIO_BIDIRaltddio_bidirDDR bidirectional megafunction.双倍数双向模块ALTDDIO_INaltddio_inDDR input megafunction.双倍数输入模块ALTDDIO_OUTaltddio_outDDR output megafunction.双倍数输出模块ALTDLLaltdllDelay locked loop(DDL)megafunction.锁相环模块ALTDQaltdqData strobe megafunction.数据滤波模块ATLDQSaltdqsParameterized bidirectional data strobe megafunction.参数化的双向数据滤波器atldq_dqsParameterized data strobe megafunction.参数化的数据滤波器ALTGXHigh-Speed Serial Interface(HSSI)GXBmegafunction.高速串行千兆收发器ALTGXBaltgxbGXB megafunction.千兆位收发器ALTIOBUFaltiobuf_bidirBidirectional I/O buffer megafunction.双向I/O缓冲模块altiobuf_inInput I/O buffer megafunction.输入缓冲模块altiobuf_outOutput I/O buffer megafunction.输出缓冲模块ALTLVDSaltlvds_rxLow voltage differential signalling(LVDS)receiver megafunction.低电压差分信号接收器altlvds_txLow voltage differential signalling(LVDS)transmitter megafunction.低电压差分信号发送器ALTMEMPHYALTMEMPHYExternal DDR Memory PHY interface megafunction.PHY接口的外部的DDR存储器alt_octOn-chip termination(OCT)megafunction.片上终端模块ALTPLLaltpllParameterized PLL megafunction.参数化的锁相环模块ALTPLL_RECONFIGaltpll_reconfigParameterized PLL reconfiguration megafunction.参数化可重配置的锁相环模块ALTREMOTE_UPDATEaltremote_updateParameterized remote update megafunction.参数化的远程更新模块altstratixii_octParameterized OCT megafunction.参数化的片上终端模块MAX II oscillatoraltufm_oscOscillator megafunction.震荡器模块JTAG-accessible Extensions MegaWizards and Megafunctions:MegaWizardMegafunction(s)CommentsIn-System Sources and Probesaltsource_probeIn-system debugging megafunction.在系统调试模块Parallel Flash Loaderaltparallel_flash_loaderParallel flash loader(PFL)megafunction.并行的快速载入模块Serial Flash Loaderaltserial_flash_loaderSerial flash loader megafunction.串行的快速载入模块SignalTap II Logic Analyzersld_signaltapSignalTap II Logic Analyzer megafunction.SignalTap II逻辑分析模块Virtual JTAGsld_virtual_jtagVirtual JTAG Interface(VJI)megafunction.虚拟的JTAG接口模块Memory Compiler MegaWizards and Megafunctions: Memory Compiler includes FIFO Partitioner,RAM,ROM, and memory functions.MegaWizardMegafunction(s)CommentsRam initializeraltmem_initRAM initialization from ROM megafunction.ROM中载入数据初始化RAMCAMaltcamContent-addressable memory(CAM)megafunction.可设地址的存储器模块FIFOdcfifoParameterized dual-clock FIFO megafunction.参数化的双时钟先入先出模块dcfifo_mixed_widthsParameterized dual-clock mixed-widths FIFO megafunction.参数化的双时钟混合宽度的先入先出模块scfifoParameterized single-clock FIFO megafunction.参数化的单时钟先入先出模块FIFO partitioneraltcsmemFIFO partitioner megafunction.先入先出区分模块Flash Memoryaltufm_i2cUser flash memory megafunction with the inter-integrated circuit(I2C)interface protocol.IIC接口的闪存模块altufm_noneUser flash memory megafunction(no interface protocol).无接口协议的闪存模块altufm_parallelUser flash memory megafunction with the parallel interface protocol.并行接口的闪存模块altufm_spiUser flash memory megafunction with the serial peripheral interface(SPI)protocol.SPI接口的闪存模块RAM:1-PORTaltdpram*Parameterized dual-port RAM megafunction.。
-----------------------------------------------------RAM宏模块宏模块名称功能描述csdpram 参数化循环共享双端口RAMlpm_ram_dp 参数化双端口RAMlpm_ram_dq 参数化RAM,输入/输出端分离lpm_ram_io 参数化RAM,输入/输出端公用一个端口FIFO宏模块宏模块名称功能描述csfifo 参数化循环共享FIFOdcfifo 参数化双时钟FIFOscfifo 参数化单时钟FIFOlpm_fifo 参数化单时钟FIFOlpm_fifo_dc 参数化双时钟FIFOROM的设计lpm_romQuartus II开发软件中的宏模块--时序电路宏模块触发器宏模块名称功能描述lpm_ff 参数化D或T触发器lpm_dff 参数化D触发器和移位寄存器lpm_tff 参数化T触发器enadff 带使能端的D触发器expdff 用扩展电路实现的D触发器7470 带预置和清零端的与门JK触发器7471 带预置端的JK触发器7472 带预置和清零端的与门JK触发器7473 带清零端的双JK触发器7474 带异步预置和异步清零端的双D触发器7476 带异步预置和异步清零端的双JK触发器7478 带异步预置、公共清零和公共时钟端的双JK触发器74107 带清零端的双JK触发器74109 带预置和清零端的双JK触发器74112 带预置和清零端的双JK时钟下降沿触发器74113 带预置端的双JK时钟下降沿触发器74114 带异步预置、公共清零和公共时钟端的双JK时钟下降沿触发器74171 带清零端的4D触发器74172 带三态输出的多端口寄存器74173 4位D型寄存器74174 带公共清零端的16进制D触发器74174b 带公共清零端的16进制D触发器74175 带公共时钟和清零端的4D触发器74273 带异步清零端的8进制触发器74273b 带异步清零端的8进制触发器74276 带公共预置和清零端的4JK触发器寄存器74374 带三态输出和输出使能端的8进制D触发器74374b 带三态输出和输出使能端的8进制D触发器74376 带公共时钟和公共清零端4JK触发器74377 带使能端的8进制D触发器74377b 带使能端的8进制D触发器74378 带使能端的16进制D触发器74379 带使能端的4D触发器74396 8进制存储寄存器74548 带三态输出的8位两级流水线寄存器74670 带三态输出的4位寄存器74821 带三态输出的10位总线接口触发器74821b 带三态输出的10位D触发器74822 带三态反相输出的10位总线接口触发器74822b 带三态反相输出的10位D触发器74823 带三态输出的9位总线接口触发器74823b 带三态输出的9位D触发器74824 带三态反相输出的9位总线接口触发器74824b 带三态反相输出的9位D触发器74825 带三态反相输出的8位总线接口触发器74825b 带三态输出的8进制D触发器74826 带三态反相输出的9位总线接口触发器74826b 带三态反相输出的8进制D触发器锁存器宏模块名称功能描述lpm_latch参数化锁存器explatch用扩展电路实现的锁存器Inpltch 用扩展电路实现的输入锁存器nandltch用扩展电路实现的SR(非)与非门锁存器norltch 用扩展电路实现的SR或非门锁存器7475 4位双稳态锁存器7477 4位双稳态锁存器74116 带清零端的双4位锁存器74259 带清零端、可设定地址的锁存器74279 4路SR(非)锁存器74373 带三态输出的8进制透明D锁存器74373b 带三态输出的8进制透明D锁存器74375 4位双稳态锁存器74549 8位二级流水线锁存器74604 带三态输出的8进制2输入多路锁存器74841 带三态输出的10位总线接口D锁存器74841b 带三态输出的10位总线接口D锁存器74842 带三态输出的10位总线接口D锁存器74842b 带三态输出的10位总线接口D反相锁存器74843 带三态输出的9位总线接口D锁存器74844 带三态输出的9位总线接口D反相锁存器74845 带三态输出的8位总线接口D锁存器74846 带三态输出的8位总线接口D反相锁存器74990 8位透明读回锁存器计数器宏模块名称功能描述lpm_conter参数化计数器(仅限FLEX系列器件)gray4 格雷码计数器unicnt 通用4位加/减计数器,可异步设置、读取、清零和级联的左/右移位寄存器16cudslr 16位2进制加/减计数器,带异步设置的左/右移位寄存器16cudsrb 16位2进制加/减计数器,带异步清零和设置的左/右移位寄存器4count 4位2进制加/减计数器,同步/异步读取,异步清零8count 8位2进制加/减计数器,同步/异步读取,异步清零7468 双10进制计数器7469 双12进制计数器7490 10/2进制计数器7492 12进制计数器7493 4位2进制计数器74143 4位计数/锁存器,带7位输出驱动器74160 4位10进制计数器,同步读取,异步清零74161 4位2进制加法计数器,同步读取,异步清零74162 4位2进制加法计数器,同步读取,同步清零74163 4位2进制加法计数器,同步读取,同步清零74168 同步4位10进制加/减计数器74169 同步4位2进制加/减计数器74176 可预置10进制计数器74177 可预置2进制计数器74190 4位10进制加/减计数器,异步读取74191 4位2进制加/减计数器,异步读取74192 4位10进制加/减计数器,异步清零74193 4位2进制加/减计数器,异步清零74196 可预置10进制计数器74197 可预置2进制计数器74290 10进制计数器74292 可编程分频器/数字定时器74293 2进制计数器74294 可编程分频器/数字定时器74390 双10进制计数器74393 双4位加法计数器,异步清零74490 双4位10进制计数器74568 10进制加/减计数器,同步读取,同步和异步清零74569 2进制加/减计数器,同步读取,同步和异步清零74590 8位2进制计数器,带三态输出寄存器74592 8位2进制计数器,带输入寄存器74668 同步10进制加/减计数器74669 同步4位2进制加/减计数器74690 同步10进制计数器,带输出寄存器,多重三态输出,异步清零74691 同步2进制计数器,带输出寄存器,多重三态输出,异步清零74693 同步2进制计数器,带输出寄存器,多重三态输出,同步清零74696 同步10进制加/减计数器,带输出寄存器,多重三态输出,异步清零74697 同步2进制加/减计数器,带输出寄存器,多重三态输出,异步清零74698 同步10进制加/减计数器,带输出寄存器,多重三态输出,同步清零74699 同步2进制加/减计数器,带输出寄存器,多重三态输出,同步清零分频器宏模块名称功能描述Freqdiv 2,4,8,16分频器7456 双时钟5,10分频器7457 双时钟5,6,10分频器多路复用器宏模块名称功能描述lpm_mux 参数化多路复用器2lmux 2线-1线多路复用器16lmux 16线-1线多路复用器2X8mux 8位总线的2线-1线多路复用器8lmux 8线-1线多路复用器74151 8线-1线多路复用器74151b 8线-1线多路复用器74153 双4线-1线多路复用器74157 四2线-1线多路复用器74158 带反相输出的四2线-1线多路复用器74251 带三态输出的8线-1线数据选择器74253 带三态输出的双4线-1线数据选择器74257 带三态输出的四2线-1线多路复用器74258 带三态反相输出的四2线-1线多路复用器74298 带存储功能的四2输入多路复用器74352 带反相输出的双4线-1线数据选择器/多路复用器74353 带三态反相输出的双4线-1线数据选择器/多路复用器74354 带三态输出的8线-1线数据选择器/多路复用器74356 带三态输出的8线-1线数据选择器/多路复用器74398 带存储功能的四2输入多路复用器74399 带存储功能的四2输入多路复用器移位寄存器宏模块名称功能描述lpm_clshift参数化组合逻辑移位器lpm_shiftreg参数化移位寄存器barrelst 8位桶形移位器barrlstb 8位桶形移位器7491 串入串出移位寄存器7494 带异步预置和异步清零端的4位移位寄存器7495 4位并行移位寄存器7496 5位移位寄存器7499 带JK串入串出端的4位移位寄存器74164 串入并出移位寄存器74164b 串入并出移位寄存器74165 并行读入8位移位寄存器74165b 并行读入8位移位寄存器74166 带时钟禁止端的8位移位寄存器74178 4位移位寄存器74179 带清零端的4位移位寄存器74194 带并行读入端的4位双向移位寄存器74195 4位并行移位寄存器74198 8位双向移位寄存器74199 8位双向移位寄存器74295 带三态输出端的4位左右移位寄存器74299 8位通用移位/存储寄存器74350 带三态输出端的4位移位寄存器74395 带三态输出端的4位可级联移位寄存器74589 带输入锁存和三态输出端的8位移位寄存器74594 带输入锁存的8位移位寄存器74595 带输入锁存和三态输出端的8位移位寄存器74597 带输入寄存器的8位移位寄存器74671 带强制清零和三态输出端的4位通用移位寄存器/锁存器Quartus II开发软件中的宏模块--运算电路宏模块加法器和减法器宏模块名称功能描述lpm_add_sub 参数化加法器/减法器8fadd 8位全加器8faddb 8位全加器7480 门控全加器7482 2位2进制全加器7483 带快速进位的4位2进制全加器74183 双进位存储全加器74283 带快速进位的4位全加器74385 带清零端的4位加法器/减法器乘法器宏模块名称功能描述lpm_mult 参数化乘法器mult2 2位带符号数乘法器mult24 2X4位并行2进制乘法器mult4 4位并行2进制乘法器mult4b 4位并行2进制乘法器tmult4 4X4位并行2进制乘法器7497 同步6位速率乘法器74261 2位并行2进制乘法器74284 4X4位并行2进制乘法器(输出结果的最高4位)74285 4X4位并行2进制乘法器(输出结果的最低4位)除法器divide和lpm_divide绝对值运算lpm_abs数值比较器宏模块名称功能描述lpm_compare 参数化比较器8mcomp 8位数值比较器8mcompb 8位数值比较器7485 4位数值比较器74518 8位恒等比较器74518b 8位恒等比较器74684 8位数值/恒等比较器74686 8位数值/恒等比较器74688 8位恒等比较器编码器模块名称功能描述74147 10线-3线BCD编码器74148 8线-3线8进制编码器74384 带三态输出的8线-3线优先权编码器译码器宏模块名称功能描述lpm_decode 参数化译码器16dmux 4位2进制-16线译码器16ndmux 4位2进制-16线译码器7442 1线-10线BCD-10进制译码器7443 余3码-10进制译码器7444 余3格雷码-10进制译码器7445 BCD码-10进制译码器7446 BCD码-7段译码器7447 BCD码-7段译码器7448 BCD码-7段译码器7449 BCD码-7段译码器74137 带地址锁存的3线-8线译码器74138 3线-8线译码器74139 双2线-4线译码器74145 BCD码-10进制译码器74154 4线-16线译码器74155 双2线-4线译码器/多路输出选择器74156 双2线-4线译码器/多路输出选择器74246 BCD码-7段译码器74247 BCD码-7段译码器74248 BCD码-7段译码器74445 BCD码-10进制译码器奇偶校验器宏模块名称功能描述74180 9位奇偶产生器/校验器74180b 9位奇偶产生器/校验器74280 9位奇偶产生器/校验器74280b 9位奇偶产生器/校验器LPM库单元列表模块分类宏单元简要说明门单元模块lpm_and 参数化与门lpm_bustri 参数化三态缓冲器lpm_clshift 参数化组合逻辑移位器lpm_constant 参数化常数产生器lpm_decode 参数化译码器lpm_inv 参数化反向器lpm_mux 参数化多路选择器busmux 参数化总线选择器mux 多路选择器lpm_or 参数化或门lpm_xor 参数化异或门算术运算模块lpm_abs 参数化绝对值运算lpm_add_sub 参数化的加/减法器lpm_compare 参数化比较器lpm_counter 参数化计数器lpm_mult 参数化乘法器存储器模块lpm_ff 参数化D触发器lpm_latch 参数化锁存器lpm_ram_dq 输入输出分开的参数化RAMlpm_ram_io 输入输出复用的参数化RAMlpm_rom 参数化ROMlpm_shitreg 参数化移位寄存器csfifo class="style8">参数化先进先出队列csdpram 参数化双口RAM其它功能模块pll 参数化锁相环电路。
quartus -->tool -->MegaWizard Plug-In Manager 就可以进入了置于参数设置要看是什么模块了,你根据自己的需求选择就是了quarts 最后会自动生成一个你命名的这个模块文件verilog语言就是"你为这个模块起的名字.v"
你可以在工程里面找到它打开看看你只需在你的工程里面例化它就可以了就像你例化自定义模块一样。
Gate Function
LPM_and : 可编程的按位做与运算的与门
LPM_bustri :可编程的三态门(可单向,也可双向)
enabletr(高电平有效)使能tridata => result
enabledt(高电平有效)使能data => tridata
LPM_clshift : 可编程的组合逻辑移位器。
方向和距离是可以编程的。
LPM_constant: 可编程常数生成器
LPM_decode : 可编程译码器
LPM_inv : 可编程反向器(位数可控)
LPM_mux : 可编程多路选择器(sel选择哪路输出)
busmus : 可编程2路选择器(LPM_mux的特殊情况)
mux : 可编程多路选择器,只有一位输出结果(LPM_mux的宽度为1) LPM_or : 可编程的按位做或运算的或门
LPM_xor : 可编程的按位做异或运算的异或门
Arithmetic Funtions
LMP_abs : 求绝对值(如果data = 1000000,overflow=1)
LPM_add_sub : 可编程加减法器(可以由管脚决定)
LPM_compare : 可编程的比较器(可以设定各种输出)
LPM_counter : 可编程计数器
LPM_mult : 可编程乘法器
LPM_divide : 可编程除法器
divide : 可编程除法器(与LPM_divide没有什么区别)
Parallel_add : 可编程多路并行加法器
altmult_accum : 可编程乘加器
altaccumulate : 可编程累加器
altmemmult :
Storage Functions
LPM_ff : 可编程的触发器(D触发器或T触发器)
LPM_latch : 可编程的锁存器(gate=0锁存)
LPM_ram_dq : 可编程的同步或异步单端口RAM(两套地址线).
LPM_ram_dp : 可编程的简单双端口和真正双端口RAM().
LPM_ram_io : 可编程的RAM(地址线一套,数据线为双向的IO)
LPM_rom : 可编程的ROM
LPM_shiftreg : 可编程的移位寄存器Custom Parameterized Functions csfifo : 可编程的FIFO
csdpram : 可编程的双口RAM。