cpld技术在pci总线开发中的应用

cpld技术在pci总线开发中的应用

ID:22309923

大小:50.00 KB

页数:5页

时间:2018-10-28

cpld技术在pci总线开发中的应用_第1页
cpld技术在pci总线开发中的应用_第2页
cpld技术在pci总线开发中的应用_第3页
cpld技术在pci总线开发中的应用_第4页
cpld技术在pci总线开发中的应用_第5页
资源描述:

《cpld技术在pci总线开发中的应用》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、CPLD技术在PCI总线开发中的应用

2、第1内容显示中摘要:根据CPLD可编程技术具有功能集成度高、设计灵活,开发周期短、成本低的特点,本文给出了一种使用Altera公司的芯片以及开发软件,设计开发PCI总线上的各种即插即用板卡的具体设计方法。PLD与PCI简介PLD(可编程逻辑器件)以其操作灵活、使用方便、开发迅速、投资风险低的特点,很快发展起来,并越来越受人们的瞩目。PLD是可以由用户在工作现场编程的逻辑器件,它从简单的PAL、GAL,已发展到CPLD、EPLD、FPGA和FLEX系列。他们都具有体系结构和逻辑单元灵

3、活、集成度高以及适用范围广等特点。同以往的PAL、GAL等相比较,FPGA/CPLD的规模比较大,适合于时序、组合等逻辑电路等场合应用。可编程逻辑器件易学、易用,简化了系统设计,缩小了系统规模,提高了系统的可靠性。一个器件的可用门已达数万门,引脚间延时仅几ns,而且仍在朝着高密度、高速度的方向迅速发展。计算机总线是计算机各部件之间进行信息传输的公共通道。在当今的微型机中主要采用的是PCI总线,ISA、EISA总线正逐步被淘汰。所以对硬件设计人员来说,掌握PCI总线板卡的开发技术是非常重要的。板卡的设计方法通常有这么几种

4、:一是做ASIC,开发周期长;另一种是在专用接口芯片下开发,使使用不是很灵活,系统规模大;目前最新的方法是用PLD来开发设计。设计实例在进行CPLD设计时,笔者使用的软件是Altera的MAX+PLUSⅡ开发系统是一个完全集成化、易学易用的、与结构无关的可编程逻辑设计环境,它使通用系统设计和者能方便的进行设计输入、快速处理和器件编程,使用此软件的设计方法是很灵活的,可以采用硬件描述语言(PLD)、电路图,甚至是时序图。根据不同的情况可以采用不同的方法,在一个设计中也可以采用多种方法。下面以一个简单的PCI从设备设计为例

5、,说明设计思想与过程。在本例中,设计的PCI卡作为从设备使用,可以实现即插即用功能,卡上有1MB的存储器可供使用。在PCI即插即用板卡的设计中,核心设计有两部分:时序控制和配置空间。时序控制保证了板卡能按正常的PCC时序工作,配置空间部分保证了板卡的即插即用功能。在本例中,这两部分都由AHDL语言来实现的(AHDL语言是Altera公司专门为其芯片设计开发的一种硬件描述语言)。在时序控制程序中采用状态机模型来实现不同时序的转换,采用这种方式既节省资源,程序也简单易懂。本例中的状态机共使用了七种状态,分别对应空闲、存储器

6、读写的判断、配置读写的判断、读、写、过渡周期、总线忙周期的时序。板卡接到复位信号后,对系统进行复位,然后转入空闲状态。在空闲状态中采用总线,并根据总线的变化来决定下一个时钟上升沿后,状态机转入何种状态。这些时序和程序中用到的信号都是基本且必须的。在进行开发时可以根据需要增添必要的状态和信号。程序描述如下:subdesignstatesmachine(clk,rst,frame,ad[31..0],cbe[3..0],idsel,irdy,mem_bar[12..0]:input;devsel,trdy,cfg_rd,c

7、fg_em_rd,mem_em_addr[16..0]:output;)//以上定义了状态机模块的输入输出引脚VARIABLEpxgci_state:MACHINEp_cfg,cmp_addr,read,p_cfg,比较地址cmp_addr,读状态read,写状态e和idsel信号的变化,一旦发现frame被置为有效,就根据idsel信号判断下一状态转入对配置空间操作的cmp_cfg或是比较地址对存储器操作的cmp_addrp_cfg=>//对配置空间操作的状态。在此状态中根据地址线的低两位判断是否是对配置空间的

8、操作,若不是转入总线忙状态bus_busy;若是则根据cbe的信号是A或B来判断是读还是写,转入相应的状态read,p_addr=>//地址比较状态在此状态中判断要读写地址的高位与配置空间中分配的地址是否相同,若不同转入总线忙状态bus_busy;若相同则根据cbe的信号是6或7来判断是读还是写,转入相应的状态read,em_rd,cfg_rd,trdy,devsel产生相应的读时序,同时在此周期中判断frame,irdy信号,若irde变低并且frame变高,则读状态结束,转入turn_ar状态。_e,irdy

9、信号,若irdy变低并且frame变高,则写状态结束,转入turn_ar状态。e信号的判断,本决定何时脱离本状态。WHENOTHERS=>若进入此状态,则应根据需要,马上转入bus_busy或idleEND,CASE;ENDIF;END;配置空间部分也采用AHDL语言来描述实现,在配置空间中定义PCI卡的功能、内存空间的分配

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。