《第7章可编程逻辑器件精选文档.ppt》由会员分享,可在线阅读,更多相关《第7章可编程逻辑器件精选文档.ppt(35页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第7章 可编程逻辑器件本讲稿第一页,共三十五页第第第第7 7章章章章 可编程逻辑器件可编程逻辑器件可编程逻辑器件可编程逻辑器件学习要点学习要点了解简单可编程逻辑器件的构造和了解简单可编程逻辑器件的构造和工作原理工作原理掌握用掌握用PROMPROM和和PLAPLA实现组合逻辑函实现组合逻辑函数的方法数的方法了解高密度可编程逻辑器件的构了解高密度可编程逻辑器件的构造及应用造及应用本讲稿第二页,共三十五页l7.1 简单可编程逻辑器件简单可编程逻辑器件l l7.2 高密度可编程逻辑器件高密度可编程逻辑器件l l7.3 PLD开发工具开发工具Max+plus第第第第7 7章章章章 可编程逻辑器件可编程逻
2、辑器件可编程逻辑器件可编程逻辑器件本讲稿第三页,共三十五页7.1 简单可编程逻辑器件简单可编程逻辑器件7.1.1 7.1.1 PLD的结构、分类和内部电路表示方法的结构、分类和内部电路表示方法的结构、分类和内部电路表示方法的结构、分类和内部电路表示方法PLD的基本结构的基本结构PLD内部电路的简化画法内部电路的简化画法本讲稿第四页,共三十五页本讲稿第五页,共三十五页SPLD的分类的分类本讲稿第六页,共三十五页7.1.2 7.1.2 PROMPROM及其应用及其应用及其应用及其应用P PR RO OM M的的的的阵阵阵阵列列列列结结结结构构构构本讲稿第七页,共三十五页例例用PROM实现下列一组函
3、数用PROM实现组合逻辑函数的方法与ROM相同,即首先列出要实现的逻辑函数的真值表,然后再根据真值表画出用PROM实现这些逻辑函数的阵列图。本讲稿第八页,共三十五页真真值值表表本讲稿第九页,共三十五页阵阵列列图图本讲稿第十页,共三十五页7.1.3 7.1.3 PLAPLA及其应用及其应用及其应用及其应用PLPLPLPLA A A A的的的的阵阵阵阵列列列列结结结结构构构构本讲稿第十一页,共三十五页用用PLA实现逻辑函数的基本原理是基于函数的最实现逻辑函数的基本原理是基于函数的最简与或表达式,故简与或表达式,故首先需要将逻辑函数化为最简首先需要将逻辑函数化为最简与或表达式,然后根据最简与或表达式
4、画出与或表达式,然后根据最简与或表达式画出PLAPLA的的阵列图。阵列图。例例用PLA实现下列一组函数本讲稿第十二页,共三十五页化化简简阵阵列列图图本讲稿第十三页,共三十五页7.1.4 7.1.4 PAL及其应用及其应用及其应用及其应用PALPALPALPAL的阵列结构的阵列结构的阵列结构的阵列结构本讲稿第十四页,共三十五页专专用用输输出出结结构构可可编编程程I/I/O O结结构构本讲稿第十五页,共三十五页带反馈的寄存器结构带反馈的寄存器结构异或型输出结构异或型输出结构本讲稿第十六页,共三十五页例例 如图所示为用PAL实现的一组组合逻辑函数,试写出该组逻辑函数的表达式。解解 根据如图所示PAL
5、与阵列的编程情况可知,函数Y3是由4个与项相加组成的,这4个与项分别为ABC、BCD、ACD和ABD,所以函数Y3的表达式为:同理,函数Y2是由3个与项、和相加组成的,函数Y1是由2个与项和相加组成的,函数Y0是由个与项AB和相加组成的,所以:本讲稿第十七页,共三十五页7.1.5 7.1.5 GALGAL器件在制造工艺上采用了EECMOS工艺,可以反复编程,且集成度比PAL有了较大的提高,其与阵列的规模大大超过了PAL,每个或门的输入端数增加到810个,可实现较为复杂的逻辑函数。在结构上,GAL不但直接继承了PAL器件的由一个可编程与阵列驱动一个固定或阵列的结构,而且还具有可编程的输出逻辑宏单
6、元(简称OLMC)。通过对OLMC编程,可实现多种形式的输出,使用起来比PAL更加灵活方便。本讲稿第十八页,共三十五页GAL16V8GAL16V8中中OLMCOLMC的结构的结构本讲稿第十九页,共三十五页本讲稿第二十页,共三十五页7.2 高密度可编程逻辑器件高密度可编程逻辑器件CPLD基本上沿用了GAL的阵列结构,在一个器件内集成了多个类似GAL的大模块,大模块之间通过一个可编程集中布线区连接起来。在GAL中只有一部分引脚是可编程的(OLMC),其他引脚都是固定的输入脚。而在CPLD中,所有的信号引脚都可编程,既可做输入,又可做输出,故称为I/O脚。7.2.1 CPLDCPLD如图所示给出了一
7、个典型CPLD的内部结构框图。总布线区(GRP)是一个二维的开关阵列,负责将输入信号送入通用逻辑模块,并提供通用逻辑模块之间的连接通路。在GRP两侧各有一个巨模块,每个巨模块含8个通用逻辑模块(GLB)、一个输出布线区(ORP)、一组输入总线和16个输入/输出模块(IOC)。本讲稿第二十一页,共三十五页7.2.2 7.2.2 FPGAFPGAFPGA是由普通的门阵列(需在制造厂加工,又称为掩膜门阵列)发展而来的,其结构与CPLD大不相同,其内部含有成千上万个较小的逻辑单元,所以在布局上呈二维分布。要将如此众多的逻辑单元连接起来,需要丰富的连线资源,其布线的难度和复杂性较高。Xilinx公司的X
8、C系列FPGA器件由可编程输入/输出模块(简称IOB)、可编程逻辑模块(简称CLB)和可编程连线资源(简称PI)3种可编程逻辑单元组成。本讲稿第二十二页,共三十五页 XCXC系列系列FPGAFPGA的内部结的内部结构框图构框图可编程输入可编程输入/输出输出模块(模块(I/OBI/OB)本讲稿第二十三页,共三十五页XCXC系列系列FPGAFPGA的的CLBCLB结构结构本讲稿第二十四页,共三十五页XCXC系列系列FPGAFPGA的的PIPI连接方式连接方式本讲稿第二十五页,共三十五页7.2.3 CPLD/FPGA的编程技术的编程技术在系统编程技术在系统编程技术在系统编程技术在系统编程技术ISPI
9、SPISPISP:ISP技术采用EECMOS工艺,其编程数据存储在EEPROM中,通过电信号擦写,无需专用的编程器就可编程,可预先将器件安装在电路板上,预留编程口(插座),用微机通过编程电缆就可以在线对器件编程,使用非常方便。ISP技术采取了在信号引脚上增加三态门和增加编程接口与控制电路两项措施来实现在系统编程。在线配置技术在线配置技术在线配置技术在线配置技术ICRICR:ICR技术采用SRAM工艺,在线写入,无需专用的写入器。由于SRAM所存信息掉电时无法保存,因此每次通电都必须重新写入编程数据,这类FPGA的编程称为配置。由于SRAM的写入次数没有限制,因此可无穷多次的配置。FPGA有多种
10、在线配置方式可分成被动配置和主动配置两类。反熔丝编程技术反熔丝编程技术反熔丝编程技术反熔丝编程技术:反熔丝开关是由在多晶硅与扩散层之间夹有特殊介质的可编程低阻元件构成的开关。未编程时多晶硅与扩散层呈高阻状态;在多晶硅和扩散层两端加上编程电压时介质击穿,多晶硅与扩散层导通。由于介质一旦被击穿就无法还原,所以这是一种一次性编程方法。本讲稿第二十六页,共三十五页7.3 PLD开发工具开发工具MAX+plus7.3.1 PLD的设计过程的设计过程设计输入设计输入设计输入设计输入:将所设计的电路以开发软件要求的某种形式表达出来,并输入到相应的软件中。主要包括原理图输入方式、硬件描述语言输入方式、高级设计
11、输入方式、波形设计输入方式、层次设计输入方式和底层设计输入方式,最常用的是原理图输入方式和硬件描述语言输入方式两种。设计实现设计实现设计实现设计实现:由EDA开发工具根据设计输入文件自动生成用于器件编程、波形仿真及延时分析等所需的数据文件。通常设计实现是由EDA开发工具自动完成的,设计者只能通过设置一些控制参数来控制设计实现过程。设计实现时主要完成优化和合并、映射、布局和布线以及生成编程文件4个任务。本讲稿第二十七页,共三十五页设计校验设计校验设计校验设计校验:包括功能仿真和时序仿真两部分,这一步通过功能仿真器和时序分析器来完成,利用编译器产生的数据文件自动完成逻辑功能仿真和时序特性仿真。在仿
12、真文件中加载不同的激励,可以观察中间结果以及输出波形。必要时,可以返回设计输入阶段,修改设计输入,最终达到设计要求。下载编程下载编程下载编程下载编程:将设计阶段生成的编程文件(熔丝图文件或位流文件)装入到可编程器件中。由于器件编程需要满足一定的条件,如编程电压、编程时序、编程算法等,因此,对于不能进行在系统编程(ISP)的CPLD器件和不能在线配置(ICR)的FPGA器件,需要编程专用设备(编程器)完成器件编程。本讲稿第二十八页,共三十五页7.3.2 设计输入设计输入指定项目名称指定项目名称指定项目名称指定项目名称:在管理器窗口的FileProject菜单中选择Name项打开Project N
13、ame对话框,从Project Name对话框中选择适当的驱动器和目录,键入项目名后点击OK。1 1建立原理图设计文件建立原理图设计文件建立原理图设计文件建立原理图设计文件(1)打开原理图编辑器。在管理器窗口的File 菜单中选择New打开New列表框。从New列表框中选择Graphic Editor File和.gdf项,然后点击OK。此时便会出现一个原理图编辑窗口。(2)输入元件和模块。在原理图编辑窗口空白处双击鼠标左键或在Symbol菜单中选择Enter Symbol,打开Enter Symbol对话框。从Enter Symbol对话框中选择适当的库及所需的器件(模块),然后点击OK。这
14、样所选元件(模块)就会出现在编辑窗口。重复这一步,选择需要的所有模块。相同的模块可以采用复制的方法产生。用鼠标左键选中器件并按住左键拖动,可以将模块放到适当的位置。本讲稿第二十九页,共三十五页(3)放置输入、输出引脚。输入、输出引脚的处理方法与元件一样。在原理图编辑窗口空白处双击鼠标左键或在Symbol菜单中选择Enter Symbol便打开了Enter Symbol对话框。在Symbol Name框中键入input、output或bidir,分别代表输入、输出和双向I/O。点击OK。这样输入或输出引脚便会出现在编辑窗口中。重复这一步产生所有的输入和输出引脚,也可以通过复制的方法得到所有引脚。
15、电源和地与输入、输出引脚类似,也作为特殊元件,采用上述方法在Symbol Name中键入VCC(电源)或GND(地),即可使它们出现在编辑窗口中。(4)连线。将电路图中的两个端口相连的方法:将鼠标指向一个端口,鼠标箭头会自动变成十字“+”。一直按住鼠标左键拖至另一端口。放开左键,则会在两个端口间产生一根连线。连线时若需要转弯,则在转折处松一下左键,再按住继续移动。连线的粗细通过点鼠标右键弹出菜单中的Line Style来选择,粗线代表总线。(5)输入/输出引脚和内部连线命名。输入/输出引脚命名:在引脚的PIN-NAME位置双击鼠标左键,然后键入信号名。内部连线的命名方法是:选中连线,然后键入信
16、号名。总线的信号名一般用Xn-1.0表示,其中的单个信号名为Xn-1、Xn-2、X0。本讲稿第三十页,共三十五页(6)保存文件。在File菜单中选择Save As或Save,如是第一次保存,需输入文件名。(7)建立默认的符号文件。在层次化设计中,如果当前编辑的文件不是顶层文件,则往往需要为其产生一个符号,将其打包成一个模块,以便在上层电路设计时加以引用。建立符号文件的方法是,在File菜单中选择Create Default Symbol项即可。2 2建立建立建立建立HDLHDL设计文件设计文件设计文件设计文件(1)打开文本编辑器。在管理器窗口的File 菜单中选择New打开New列表框。选择T
17、ext Editor File,此时便会出现一个文本编辑窗口。点击OK。(2)选择HDL种类。在File菜单中选择Save As或Save,或在工具栏点击按钮,打开Save As对话框,键入文件名并选择文件扩展名,MAX+plus支持3种HDL:VHDL、Verilog HDL和Altera HDL,对应的扩展名依次为vhd、v和tdf。这一步也可以等到HDL源码输入完以后再做,但先确定HDL种类可以在键入HDL源码时自动检查并显示其中的语法错误。本讲稿第三十一页,共三十五页(3)输入HDL源码。(4)保存文件。在File菜单中选择Save,保存输入的HDL源码。(5)建立默认的符号文件。与由
18、原理图生成符号文件的方法一样。7.3.3 设计实现设计实现1 1编译与网络表提取编译与网络表提取编译与网络表提取编译与网络表提取运行编译器的方法:在MAX+plus菜单中选Compiler选项。启动编译器后首先进行编译与电路网络表提取工作。做完这一工作后编译器便停下来等待用户的指示。如果编译中未发现错误,则可以点击窗口中的Start,接着做设计实现的工作。2 2参数设置参数设置参数设置参数设置编译器有很多参数设置,但并不是每一项都需要用户去设置,有些设置编译器可自动选择(如器件选择、引脚分配等),而其他的设置往往有默认值。3 3运行设计实现运行设计实现运行设计实现运行设计实现做好必要的设置后,
19、在编译器窗口中按Start就可以连续执行后续的设计步骤,产生的数据文件的扩展名会出现在各个执行框的下方。本讲稿第三十二页,共三十五页7.3.4 设计校验设计校验1 1建立波形文件建立波形文件建立波形文件建立波形文件(1)打开波形图编辑器。在管理器窗口的File菜单中选择New打开New列表框。选择Waveform Editor File和.scf项,按OK。此时便会出现一个波形图编辑窗口。(2)设定时间参数。从File菜单中选择End Time项,键入仿真结束时间,按OK。在Options菜单中选择Grid Time项,键入显示网格间距的时间,按OK。(3)确定需观察的信号。在Node菜单中选
20、择Enter Nodes From SNF(SNF指仿真网络表文件)项,打开Enter Nodes From SNF对话框。在Type框中选择信号类别,最常用的是Input和Output(输入、输出)。点List按钮,将所选类别的所有信号均列于Available Nodes&Groups框中。从Available Nodes&Groups框中选择信号,然后按“=”箭头,使所选信号名进入Selected Nodes&Groups框。按OK,所选信号将出现在波形图编辑窗口中。然后根据需要编辑输入波形。最后在File菜单中选择Save As或Save。如是第一次保存,需输入文件名。本讲稿第三十三页,
21、共三十五页2 2运行仿真程序运行仿真程序运行仿真程序运行仿真程序在MAX+plusII菜单中选Simulator选项,打开仿真对话框。按Start开始仿真。仿真结束后按Open SCF,在波形编辑窗口中将显示出仿真结果(波形)。3 3仿真结果分析仿真结果分析仿真结果分析仿真结果分析仿真结果分析由用户人工进行。7.3.5 下载编程下载编程1 1选择编程文件选择编程文件选择编程文件选择编程文件在编程界面下,从File菜单中选择Convert SRAM Object Files命令可以由*.SOF文件产生*.POF文件,选择Save Programming Data As命令可读出已编程器件中的数据
22、或由*.JED文件生成*.POF文件。本讲稿第三十四页,共三十五页2 2下载编程步骤下载编程步骤下载编程步骤下载编程步骤(1)打开编程窗口。在MAX+plusII菜单中选Programmer选项,打开编程窗口。(2)硬件连接。在编程界面下,从Options菜单中选择Hardware Setup,再在Hardware Setup对话框中选择ByteBlaster或BitBlaster,然后用下载电缆将PC机并口(若选ByteBlaster)或串口(若选BitBlaster)与电路板上的PLD连接起来(通过接插件)。请注意:这一步工作最好在关断PC机和电路板电源的情况下进行,可以在开机前预先接好。(3)选择编程文件。默认情况下,编程文件已根据当前项目名选好,并显示在编程窗口的右上角。如果发现编程文件名不对,可在File菜单中点Select Programming File项进行选择。(4)下载。在编程窗口中按Program(对CPLD或配置用EPROM,此时文件为*.POF)或Configure(对FPGA,此时文件为*.SOF)。本讲稿第三十五页,共三十五页