《硕士论文MCS51单片机与FPGA的接口逻辑设计.doc》由会员分享,可在线阅读,更多相关《硕士论文MCS51单片机与FPGA的接口逻辑设计.doc(43页珍藏版)》请在三一办公上搜索。
1、MCS-51单片机与FPGA的接口逻辑设计摘 要数字电路由早期的电子管、晶体管、中小规模集成电路发展到超大规模集成电路以及具有特定功能的专用集成电路ASIC(Application Specific Integrated Circuit)。随着微电子技术的发展,出现了现场可编程逻辑器件FPLD,其中应用最广泛的是现场可编程门阵列FPGA。FPGA(Field-Programmable Gate Array)具有使用灵活、高集成度、低功耗、设计快速、现场可编程等优势,在系统设计中经常会用到FPGA来扩展单片机的相关资源。单片机具有性价比高、功能灵活、易于人机对话、强大的数据处理能力等特点,因此,
2、系统设计中将单片机数据处理的优势与FPGA高速集成、执行快速的特点相结合,能够设计出既有强大控制功能又能使各项功能快速执行的系统。基于这种需求,MCS-51单片机与FPGA之间的通信便显得尤为主要,有很强的现实意义。 本课题通过研究FPGA的技术特点及应用、单片机接口的实现方式以及软件的仿真等,设计了MCS-51单片机与FPGA通信的接口逻辑电路,实现单片机与可编程逻辑器件数据与控制信息的可靠通信。接口主要有并行接口和串行接口。设计采用的是VHDL语言的文本输入方式,设计比较灵活,按照接口的要求设计逻辑电路。并行接口是利用单片机的I/O口,并按照读写时序设计逻辑,使得单片机与FPGA之间的数据
3、可以相互传送。串行接口是由波特率发生器、接收器和发送器模块组成,通过各模块的功能设计接口逻辑。利用仿真软件Quartus 进行分析综合、功能仿真与时序仿真,生成分析报告以及内部逻辑电路,并得出仿真结果,验证接口的可行性。关键词:单片机,FPGA,接口逻辑,数据通信MCS-51 MICROCONTROLLER INTERFACEAND FPGA LOGIC DESIGNABSTRACTDigital circuit developed from the early electron tubes, transistors, small and medium-scale integrated cir
4、cuits to a very large scale integrated circuits and application specific integrated circuit with a specific function ASIC. With the development of microelectronics, there have been field-programmable logic devices, in which field-programmable gate array is the most widely application. FPGA with flex
5、ible application, highly integrated, low power consumption, fast design, field-programmable and other advantages is often used to expand the microcontroller related resources in the system. SCM has higher cost-effective, flexible function, easy dialogue to man-machine, powerful data processing capab
6、ilities and other characteristics. Therefore, combined the advantages of SCM data processing to the high-speed integration and fast implementation of FPGA, it can design the system with power control function and rapid implementation of the various functions. Based on the demand, the communication b
7、etween MCS-51 microcontroller and FPGA becomes more important and has a strong practical significance. By studying the technical characteristics and application of FPGA, the implementations of MCU interfaces and the software simulation, the interfaces logic circuits of MCS-51 MCU and FPGA communicat
8、ion have been designed to realize the reliable communication between Single Chip Microcomputer and programmable logic device data and control information. The interfaces include parallel interface and serial interface. The design uses the VHDL language text methods which have flexibly designed. Acco
9、rding to demand of the interface, design logic circuit. Using the I/O ports and following read-write timing of microcontroller, deigned the logic circuit of parallel interface to make data transfer each other between MCU and FPGA. Serial interface include baud rate generator, receiver and transmitte
10、r. Use the function design of each module to design the interface logic. Run Analysis and Synthesis, functional simulation and timing simulation using simulation software Quartus .Finally, generate analysis reports and the internal logic circuits. Based simulation result, verify the feasibility of t
11、he interface. KYE WORDS: single chip microcomputer, FPGA, interface logic, data communication目 录第一章 绪论11-1 论文的选题背景11-2 FPGA技术发展概况11-2-1 国内外发展状况11-2-2 FPGA技术的应用及发展趋势21-3 论文的主要工作3第二章 FPGA技术及设计工具52-1 FPGA器件的发展及分类52-2 FPGA的基本结构及功能62-3 FPGA器件的配置92-4 FPGA的设计流程102-5 Quartus 仿真软件112-5-1 Quartus 软件的特点及支持的器件1
12、22-5-2 Quartus 软件的集成工具及功能12第三章 单片机与FPGA接口通信143-1 FPGA的接口技术及特点143-2 FPGA的特点及优势153-3 单片机与FPGA的通信163-3-1 串行通信163-3-2 并行通信16第四章 MCS_51单片机与FPGA并行接口的逻辑设计174-1 MCS_51单片机与FPGA并行接口设计184-1-1 接口方式184-1-2 总线接口逻辑设计184-2 芯片的选取及器件配置204-2-1 单片机的选取204-2-2 FPGA器件的选取204-3 仿真模块及结果214-3-1 各模块设计214-3-2 总线接口逻辑24第五章 MCS_51
13、单片机与FPGA串行接口设计285-1 单片机与FPGA串行通信285-2 串行接口的各模块设计285-2-1 波特率发生器295-2-2 串行接口信的发送器295-2-3 串行接口的接收器315-3 串行接口的仿真结果325-4 小结34第六章 结论355-1 结论355-2 展望35参考文献36致 谢38攻读硕士学位期间所取得的相关科研成果39第一章 绪论1-1论文的选题背景当今社会是数字化的社会,数字集成电路应用非常广泛,其发展从电子管、晶体管、小规模集成SSI、MSI、LSI 到超大规模集成电路ULSI和超位集成电路GSI,其规模平均每12年翻一番。集成电路的发展大大促进了EDA技术的
14、发展,半导体厂商已经不再完全独立设计和制造专用集成电路(ASIC),开始转向可编程逻辑器件,特别是现场可编程逻辑器件,使系统设计师在实验室里就可以设计出合适的ASIC芯片,直接投入使用。现在应用最广的主要是现场可编程门阵列(FPGA)、复杂可编程逻辑器件(CPLD)和可擦除可编程逻辑器件(EPLD)。现场可编程门阵列FPGA器件是Xlinx公司1985年首家推出的,它是一种新型的高密度PLD,采用CMOS-SRAM工艺制造1。自Xilinx公司推出第一片现场可编程逻辑器件(FPGA)至今,FPGA已经历了十几年的发展历程,以FPGA为代表的数字系统集成技术取得了惊人的发展,从最初的1200门发
15、展到现在的数百万门FPGA芯片,将FPGA芯片的集成度提高到一个新的水平。FPGA市场之所以有这么大的吸引力,主要源于FPGA不仅可以解决电子系统小型化、低功耗、高可靠性等问题,而且缩短了开发周期、节省开发成本、芯片的价格越来越低,使FPGA取代了ASIC的市场。另外,FPGA的功能完全由用户编制的配置程序决定,在不改变其外部接口的情况下,可以很方便的改变电路的逻辑功能,特别是对小批量、多品种的军品设备的研制,FPGA非常适合作为开发芯片。所以,国内外已普遍地使用FPGA来设计产品或进行科研2。随着可编程逻辑器件及EDA技术的不断发展,各方面优势逐渐显现,在系统设计中经常会用到FPGA来扩展单
16、片机的相关资源,使其有机结合,缩短开发周期,适应市场需要。在功能上,单片机具有性价比高、功能灵活、控制能力强、良好的数据处理能力,而FPGA具有高速、高可靠以及开发便捷、组合逻辑能力强、规范等优点,与单片机有很强的互补性。系统设计中将单片机数据处理的优势与FPGA高集成度、执行快速的特点相结合,能够设计出既有强大控制功能又能使各项功能快速执行的系统。基于这种需求,本课题设计了MCS-51单片机与FPGA的接口逻辑电路,实现单片机与FPGA数据与控制信息的可靠通信,结合FPGA与单片机的优势,组成灵活、可靠性高、软硬件可现场编程的控制系统,广泛应用在各个领域。1-2 FPGA技术发展概况1-2-
17、1 国内外发展状况世界上主要的EDA 技术公司纷纷在EDA工具上开发FPGA应用设计,推动了应用设计的通用化。正是在这样的技术应用背景下,世界上一些主要的微电子技术公司,开始深入研究和制造FPGA器件,在FPGA器件性能、价格、新品种方面相互竞争,推陈出新。目前,FPGA技术凭借它的独特优势,已经跃之为电子应用(包括通讯技术、计算机应用、自动控制、仪器仪表、ASIC 设计)领域广受欢迎的实用化技术,成为数字系统的科研实验、样机试制、小批量产品的即时实现的最佳途径。同时,FPGA 器件的新功能、新构思正在不断出现,向更高密度、更大容量、更低功耗和集成更多IP的方向发展,国际各大公司都在积极扩充其
18、IP库,以优化的资源越好来满足用户的需求,不断扩大市场,特别是引人注目的FPGA可动态可重构技术的开拓,将推动数字系统设计的巨大变革。目前FPGA/ CPLD供货商全部来自美国公司,主要是Xilinx、Altera、Lattice、Actel、Atmel 等。其中以Xilinx和Altera的市场占有率最大,是最大的可编程集成电路供货商。两大公司不断地推出了FPGA系列产品来满足市场的需求,逐步提高平台的整体性能,完善器件的功能,相互竞争,以推动FPGA市场的快速发展。由于它使用方便,改变逻辑功能易于实现,这也迎合了现代通信发展的要求,所以,国外已普遍地使用FPGA来设计产品或进行科研工作。国
19、内的FPGA技术发展也非常迅速,很多公司通过和国际上的大公司保持长期的合作,提高专业的技术指导和培训,培养更多的FPGA人才,凭借国内巨大的市场需求、丰富的人力资源,以及稳定的经济发展和优越的政府扶持等众多优势条件,近几年,可编程逻辑器件产业取得了飞速发展,不断研制出性能更好的产品,价格也不断降低,很大程度上降低了设计者的开发成本。1-2-2 FPGA技术的应用及发展趋势由于FPGA应用与EDA技术是面向解决电子系统最基本最低层硬件实现问题的技术,因此从其发展趋势的横向看,势必涉及越来越广阔的电子设计技术领域,其中包括电子信息、通信、航天航空、工业自动化、家电、生物工程等等,而且随着大规模集成
20、电路技术的发展和基于EDA技术的FPGA开发工具软件功能的不断加强,所涉及的领域还将不断扩大3;而从纵向看,EDA技术的不断发展,采用深亚微米及超深亚微米工艺技术,使得芯片中可以集成巨大数量的晶体管,奠定了在单个芯片上设计完整系统,即单片系统SOC或SOPC4。另外,目前FPGA和很多处理器结合起来使用,比如DSP,ARM,单片机等。在DSP应用领域中,用户要求越来越高,DSP已克服不了处理速度、硬件灵活、开发效率等方面的缺点。大容量、高速度的FPGA中内嵌可配置高速RAM、PLL以及硬件乘法累加器等模块,弥补了DSP的不足。DSP Builder就是Altera推出的一个面向DSP开发的系统
21、级工具5。 FPGA技术不同于常规集成电路应用技术,其依赖并带动电子设计的变革,不同的设计思想和设计方式的发展和变革,促进了电子设计通用化的发展。但是,也对从事电子设计的人员要求提高到新的高度和层次,因此,专业的技术支持和技术培训是必不可少的环节。目前,国际上EDA技术公司和FPGA技术公司进行合作交流,开设一些专业培训和设计实验辅导,以推动中国FPGA技术应用和硬件语言技术的普及,为FPGA行业未来的快速发展奠定了基础6。目前最主流的硬件描述语言是VHDL和Verilog HDL。VHDL发展的比较早并且语法严格,而Verilog HDL的书写是在C语言的基础上发展起来的一种硬件描述语言,语
22、法比较自由。在设计者中使用VHDL的相对比较多。FPGA的主要发展方向:(1)规模越来越大,集成度越来越高。早期的FPGA规模只有几千门,2006年5月份,Xilinx公司推出世界上第一个65nm FPGA系列Virtex-5,它是基于65nm三极栅氧化层技术、11层铜布线工艺、低K材料、新型镍硅自对准技术、新型Express Fabric技术和ASMBL架构,可以提供330000个逻辑单元(可编程逻辑门约660万门)和1200个用户I /O,FPGA的规模大大提高了,逐步向系统级高密度技术发展,同时芯片的面积也不断缩小,节约成本。(2)速度不断提高,性能不断提升。随着FPGA器件集成度的提高
23、,生产商不断生产高性能、高效率的器件。Xilinx公司2006年推出的Virtex-5 LX性能和利用率都很高,同时功耗大幅度降低。Virtex-5 LX FPGA比上一代90nmFPGA提供高出30%的性能,硅片面积少占用45%,以及功耗比上一代低了35%,是当时业界最低动态功耗。Virtex-5 LX平台具有更高性能的逻辑,以提高设计余量和加快时序收敛,更低功耗,以满足功耗预算,降低系统成本和防止热失控,简化的可靠高带宽接口设计,更高的集成度,以提高性能和降低成本,更短的设计周期,以提高生产率和缩短上市时间,这些专门用于满足用户的各种需求。Altera公司于2006年11月份推出Strat
24、ix III的65nmFPGA系列,速度比前一代器件快25%,密度比前一代FPGA提高了1倍,功耗降低了50%,支持四十多个I/O接口标准,具有业界一流的性能、灵活性和信号完整性7。(3)I P库的利用。随着嵌入式技术的不断发展,FPGA也开始将IP核嵌入到FPGA中,以满足用户更高的需求,实现更高效的功能。具有IP内核的系统级FPGA的开发主要体现在两个方面:一方面是FPGA厂商在生产时将IP 硬核嵌入到FPGA器件中,IP硬核指完成版图设计的功能单元模块;另一方面是扩充优化的IP软核。它是利用HDL语言设计并经过综合验证的功能单元模块,用户可以直接利用这些预定义的、经过测试和验证的IP核资
25、源,有效地完成片上系统的设计,缩短设计周期,节约成本。(4)价格越来越低。目前国际上各大FPGA生产厂商都在不断推出新的产品,FPGA市场的激烈竞争推动了价格的不断下调。基于SRAM的FPGA的价格下降很快,在2004年底每1万门的单价降至1美元,到2005年降至0.5美元,这样也给用户节省了开发成本。Altera公司于2005年第二季度开始批量生产的低端FPGA Cyc1oneII,其约33万门的产品以22美元的价格供货,这样的价格在市场上很占优势,销量也在不断攀升。(5)向可编程系统芯片(SOPC)方向发展。可编程系统级芯片(SOPC)是ASIC发展的新阶段,代表了当代电子的发展方向,结合
26、了ASIC和FPGA的优势,具有高集成度、功耗小、设计灵活、成本低等特点。Altera推出的支持新款Cyclone II FPGA系列的Nios II嵌入式处理器,允许设计者在很短的时间内构建一个完整的可编程系统芯片,风险和成本都比较小。实现PSOC主要有两种途径,一种是在FPGA中嵌入专用功能的IP核,实现SOC的功能,另一种是将可编程逻辑IP核嵌入到SOC中。SOPC的出现是市场和技术共同推动的结果8。1-3论文的主要工作论文介绍了FPGA技术的发展和基本原理、FPGA的设计流程及仿真工具Quartus ,并应用VHDL硬件描述语言对MCS-51单片机与FPGA通信接口逻辑进行设计,主要对
27、并行接口和串行接口进行重点研究,并进行仿真分析。(1)并行接口:分析并行接口方式的特点,选择合适的接口方式。根据接口方式的工作原理,使用VHDL语言编写各模块的程序,生成模块图,将各模块连接起来完成总的逻辑电路设计。为了验证逻辑的可行性,建立相应的波形文件(激励),使用仿真软件Quartus 对接口逻辑电路进行功能仿真与时序仿真,得出仿真结果,并对仿真过程中可能遇到的问题进行分析。(2)串行接口:相对于并行通信,串行通信的数据传输方式是串行的,即数据是一位一位地进行传输。论文了解了串行通信的工作方式及要求,使用硬件描述语言并按要求设计串行接口的总体逻辑电路,逻辑电路包括波特率发生器、发生器、接
28、收器三个模块,并通过Quartus 软件对串行接口的逻辑设计进行仿真,检测是否可行,并对占有资源、时序分析等相关因素进行分析,反复调试并分析得出的仿真结果,生成逻辑设计的内部电路,证明单片机与FPGA串行接口逻辑可行。第二章 FPGA技术及设计工具2-1 FPGA器件的发展及分类当今世界是数字化的世界,而电子系统设计最终必将是数字化。数字集成电路从应用小规模集成电路(SSI) 芯片构成电路系统,到广泛地应用微控制器或单片机(MCU),再到今天面临的另一次更大意义的突破,即CPLD/FPGA(复杂可编程逻辑器件/现场可编程逻辑门阵列)的广泛应用,有着突飞猛进的变革,为电子行业注入了新的活力。随着
29、超大规模集成电路工艺的不断提高, 同时集成度也在不断提高,单一芯片内部可以容纳上百个晶体管, FPGA芯片的规模也越来越大,从一开始的1200门已达到上百万门,所能实现的功能越来越强,同时还可以实现系统集成,使电子产品达到小型化、微型化、集成化。另外,FPGA器件内部有丰富的触发器和I/O引脚,用户可以反复地编程、擦除、使用,与门阵列等其他ASCI相比,它们又具有设计开发周期短、设计制造成本低、开发工具先进、质量稳定以及功耗低等优点9。相对于其他处理器,可编程器件拥有较高的成本,在一些中、高批量的应用中很多使用者不再愿意采用PLD器件。John Danne介绍说,Altera公司通过市场调查,
30、意识到产业发展模式正在发生改变,成本是客户关注最多的。虽然PLD器件仍可以应用在一些小批量如工业控制和自动化等应用,但对于公司传统通信应用等领域影响很大。Altera公司同时也意识到,随着“摩尔定律”发展到超深亚微米,更先进工艺的成本也在快速提高,使得ASIC 的设计成本难以承受,PLD 产业得以有机会进入传统ASIC 应用领域10。但要达到该目标,首先必须解决FPGA在中、高批量应用中的成本问题,设计出适合中、高批量应用的全新可编程器件,因此Altera公司对这两个市场进行了考察。FPGA在成本和功耗方面得到明显改善,而可编程器件CPLD在未来增长的动力将越来越小,FPGA将会应用到更广泛的
31、领域,体现它的价值11。FPGA器件目前生产商主要是Xilinx、Altera、Lattice、Actel、Atmel 等,其中以Xilinx和Altera的市场占有率最大,是最大的可编程集成电路供货商。两大公司各自推出了一系列的产品来满足市场的需要,从低成本应用、容量中等、性能满足一般的逻辑设计需要到高性能要求、容量大、性能满足各类高端应用。Xilinx公司自从事FPGA的研制开发以来,不断地进行技术创新,研制新的产品,提高器件的逻辑门和引脚的个数,减少功耗等。目前主流的产品有Spartan系列和Virtex系列。Virtex 是目前主流的产品,Xilinx公司在2002年推出的新型高端FP
32、GA12,其内部结构有了很大的改进,内嵌专用乘法器、更大容量的Block RAM,支持更多的I/O口标准。2006年5月,Xilinx公司推出了世界上第一个65nmFPGA系列Virtex-513。Xilinx公司FPGA产品的发展历程如表2.1所示:Altera主要有FLEX10KE、APEX20K、Cyclone系列、Arria系列、Stratix系列。随着新产品的不断推出,系统性能、系统门数、内部RAM的容量、I/O总数等都有很大的改进,有一些产品也逐渐被淘汰,价格方面也比以前便宜了,可以满足不同人群的需求,在各个领域有更广泛的应用。Altera FPGA发展历程6,如表2.2所示:表2
33、.1 Xilinx FPGA产品的发展历程Table 2.1 Xilinx FPGA Products development process年份 主要发展19981998199819981998199920002001200220022004200520062006XC9500:FLASH工艺的PLDXC9500XLSPARTAN 中规模SRAM工艺,芯片支持5v和3.3v的电压,CLB数量有限SPARTAN :2.5v SRAM工艺FPGA,Spartan的升级产品14Virtex:大规模SRAM工艺,采用0.15um和0.12um混合工艺设计,内核电压1.5vXC9500XVCoolRu
34、nner XPLA3:Philips的产品,99年被Xilinx收购、特点是功耗低Virtex :新一代大规模SRAM工艺FPGA产品,主流产品CoolRunner-:新一代低功耗产品Virtex- Pro基于Virtex 的结构,集成CPU和高速接口的FPGA产品SpartanTM-3:新一代FPGA产品,结构与Virtex 类似,90nm工艺Virtex-4TMLX:侧重普通逻辑应用,预计2005年底开始量产Virtex-4TMSX:侧重数字信号处理DSP模块比较多,2006年年初开始量产Virtex-4TMFX:集成PowerPC和高速接口模块,2006年初开始量产;Virtex-5问世
35、表2.2 Altera FPGA发展历程Table 2.2 Altera FPGA development process年份 主要发展19921995199619971998200020012002200320042006FLEX 800FPGAs问世第一个带嵌入式存储器的FPGAFLEX 10K FPGAs第一个10万门嵌入式FPGAEPF10K100 FPGAs问世APEX FPGAs系列问世FLEX 10KE FPGAs系列发布,EPF10K250发布世界上最大的FPGAs第一个0.15um、全铜互连的FPGAAPEX 20KC面世第一个0.13umFPGAAPEX 面世,Strati
36、x FPGAs面世Stratix FPGAs:0.13um工艺,1.5v内核电压,集成硬件乘法器和GX收发器Stratix GX FPGAs:集成3.125G高速CDR传输接口Cyclone FPGAs:0.13um工艺,1.5v内核电压,低功耗 HardCopy Stratix 面世Stratix :90um工艺,1.2v内核电压,大容量高性能Stratix :业界功耗最低的高性能65-nmFPGA2-2 FPGA的基本结构及功能FPGA器件的发展非常迅速,形成了各种不同的结构。按逻辑功能块的大小,FPGA可分为细粒度FPGA和粗粒度FPGA。细粒度FPGA的逻辑功能块较小,资源可以充分利用
37、,但连线和开关多,速度慢;粗粒度FPGA的逻辑功能块规模大,功能强,但资源不能充分利用,两者各有优劣。从逻辑功能块的结构上分类,可分为查找表结构、多路开关结构和多级与非门结构。根据FPGA内部连线的结构不同,可分为分段互联型和连续互联型。根据编程方式,FPGA可分为一次编程和可重复编程两种15。FPGA一般可由三种可编程电路和一个用于存放编程数据的SRAM组成,这三种可编程电路是:可编程逻辑块(CLB)、输入/ 输出模块( IOB)和互联资源( IR)。CLB是FPGA 的主要组成部分,是实现逻辑功能的基本单元。它主要是由逻辑函数发生器、触发器、译码器等电路组成。IOB提供了器件引脚和内部逻辑
38、阵列之间的连接,通常排列在芯片的四周。其主要是由输入触发器、输入缓冲器、输出触发/锁存器和输出缓冲器组成。每一个IOB控制一个引脚,有输入、输出或双向I/O三种功能。可编程互联资源包括各种长度的金属连线和一些可编程连接开关,它们将各个CLB之间和IOB之间互相连接起来,构成各种复杂功能的系统。FPGA是采用查找表(LUT) 结构的可编程逻辑器件的统称,目前FPGA使用最广泛的是基于SRAM的查找表逻辑结构形式,但不同公司的产品结构也有差异。(一)SRAM查找表是通过存储方式,把输入与输出的关系保存起来,通过输入查找到对应得输出。N个输入的查找表要实现N个输入的逻辑功能,需要2N位存储单元。下面
39、是4输入LUT,其内部结构如图2.1所示。如果N很大时,存储容量将像PROM器件一样增大,因此,N很大时,要采用几个查找表分开实现15。0000输入A输入B输入C输入D查找表输出多路选择器000100100011010001010110011110001001101010111100110111101111图2.1 FPGA查找表的内部结构16Fig. 2.1 The internal structure of FPGA LUT(二)Altera公司FPGA的基本结构ltera公司的FPGA都采用基于SRAM的查找表逻辑结构形式,现以FLEX10K系列器件为例介绍。FLEX10K系列器件主要由
40、嵌入式阵列块(EAB)、逻辑阵列块(LAB)、快速通道互连(FT)和I/O单元(IOE)四部分组成。1. 嵌入式阵列块EAB嵌入式阵列块EAB是在输入输出口上的RAM块,在实现存储功能时,每个EAB提供2048个位,可以单独使用或组合起来使用。EAB可以非常方便地构造成一些小规模的RAM、双口RAM、FIFO ROM和ROM,也可以在实现计数器、地址译码器等较复杂的逻辑时。作为100600个等效门来用。2. 逻辑阵列块LAB逻辑阵列块LAB是FPGA内部的主要组成部分,LAB通过快速通道互连FT相互连接,如图2.2所示:。LAB是由若干个逻辑单元(LE)再加上相连的进位链和级联链输入输出以及L
41、AB控制信号、LAB局部互连等构成,FLEX10K的LAB有8个LE,加上相连的进位链和级联链输入输出以及LAB控制信号、LAB局部互连等构成了LAB。逻辑单元LE是FPGA的基本结构单元,主要由一个4输入LUT、一个进位链、一个级联链和一个带同步使能的触发器组成,可以通过编程实现各种逻辑功能。每2个LE有2个输出,分别驱动局部互连和快速通道互连。逻辑单元LE中的LUT用于组合逻辑,实现逻辑函数。逻辑单元LE中的可编程触发器用于时序逻辑,可通过编程配置为带可编程时钟的D、T、JK、SR触发器或为旁路实现组合逻辑。寄存器的时钟、清0、置位可由全局信号、通用I/O引脚或任何内部逻辑驱动11。进位链
42、输出级联链输出LAB局部互连LAB控制信号4LE1LE2LE3LE4LE5LE6LE7LE8进位链输入级联链输入2444444444261688816LAB连接到行互连及列互连244列到行互连列互连专用输入全局信号行互连图2.2 FLEX10K LAB的结构17 Fig. 2.2 The structure of FLEX10K LAB进位链和级联链是专用高速数据通道,用于不通过局部互连通路连接相连的LE。进位链用来支持高速计数器和加法器,提供LE之间快速向前进位功能,可使FPGA适用于高速计数器、加法器等;级联链主要实现多输入逻辑函数。查找表 进位链(LUT)数据数据数据数据清零和预置逻辑L
43、ab控制1Lab控制2Lab控制3Lab控制4进位输入级联链DQCLRN进位输出级联输出 LE输出图2.3 FLEX10K LE的结构Fig. 2.3 The structure of FLEX10K LELE的两个输出分别驱动局部互连和快速通道互连。这两个输出可以独立控制,如LUT驱动一个,寄存器驱动另外一个。内部结构图如图2.3所示:LAB局部互连实现LAB的LE与行互连之间的连接及LE输出的反馈等。3. 快速通道互连FT快速通道互连FT作用是将LE和器件I/O引脚连接起来,快速通道互连与CPLD的PIA相似,是一系列水平(行互连)和垂直(列互连)走向的连续式布线通道。行互连可以驱动I/O
44、引脚,或馈送到其他LAB;列互连连接各行,也能驱动I/O引脚。4. I/O单元IOE和专用输入引脚FPGA的I/O引脚由I/O单元驱动,I/O单元位于快速通道的行或列的末端,由一个双向三态缓冲器和一个寄存器组成,可编程配置成输入、输出或输入输出双向口组成。I/O单元的清0、时钟、时钟使能和输出使能控制均由I/O控制信号网络采用高速驱动。FPGA的I/O单元支持JTAG编程、摆率控制、三态缓冲和漏极开路输出。专用输入引脚用于驱动I/O单元寄存器的控制端,其中4个还可用于驱动全局信号(内部逻辑也可驱动),为了高速驱动,使用了专用布线通道15。2-3 FPGA器件的配置FPGA是基于门阵列方式为用户
45、提供可编程资源的,其内部逻辑结构的形成是由配置数据决定的。这些配置数据通过外部控制电路或微处理器加载到FPGA内部的SRAM中,由于SRAM的易失性,每次上电时,都必须对FPGA进行重新配置,在不掉电的情况下,这些逻辑结构将会始终被保持,从而完成用户编程所要实现的功能18。FPGA器件的配置模式以Xilinx公司的器件为例,Xilinx FPGA的配置有3种模式,分别为并行(Select Map)、串行(Serial)和边界扫描(Boundary Scan)模式。当然Virtex-5和Spartan-3E3A的器件有更多的配置模式,如SPI Flash配置和BPI Flash配置。根据配置时钟
46、的来源,串行模式又分成主串(Master Serial)和从串(Slave Serial)模式,模式选择由器件的3个控制引脚MO、M1和M2来完成。为了保证数据的正确配置,必须设置正确的配置模式。用来存放配置数据的器件有XC17系列(OTP)、XC18系列(Flash)和新一代的Platform Flash系列配置器件,以及通用的SPI和BPI Flash。(1)并行配置为了实现数据的快速加载,Xilinx在FPGA器件中增加了并行模式配置。该模式为8位配置数据宽度,需要8位数据线D7D0、低电平有效的芯片选择信号(CS_B)、电平有效的写信号(RD WR_B)及高电平有效的忙信号(BUSY)
47、。当BUSY信号为高时,表示器件忙,即器件不能执行下一步的写操作,需要等待,直到该信号引脚为低时执行下一步。对于50 MHz以下的配置时钟,可以不用该控制信号。当配置完成后,这些多功能引脚可作为普通输入输出线使用,该模式需要辅助控制逻辑和配置时钟。并行模式又可以细分成主并行模式和从(Slave)并行模式,当需要对多个器件进行并行配置时,需选择从并行模式。(2)串行配置串行配置可分为主串和从串两种模式。该配置方式每个时钟仅接收一位配置数据,如果配置的时钟信号来自所需配置的FPGA器件,则为主串模式;如果时钟由外部器件提供配置,这种配置模式为从串模式。对于多个采用串行配置方案的器件,可以组成菊花链(dai