当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]FPGA的在应用编程技术研究

引 言
   
在FPG人中实现在应用编程(In Application Pro—gramming,IAP)有两种方法:一种是,在电路板上加外电路。例如用MCU或CPLD来接收配置数据,在被动串行(PS)模式下由外电路编程FPGA或是编程Flash器件(包括EPCS和Flash),然后控制FPGA的配置复位引脚来复位整个FPGA,最后FPGA采用主串方式进行自我配置。另一种是,通过FPGA中的Nios CPU或是专用IP来接收编程数据,并编程Flash芯片,然后通过外部简单电路将FPGA复位启动,以主动串行(AS)模式进行配置。
    为了减小电路板面积,节约成本,提高可靠性,本设计采用第二种方法。本设计的要求是:硬件电路须配置为主动串行模式,即选择MSEL[1:O]为l:O;具备EPCS,或同时具备EPCS和Flash;具有与PC机通信的功能。FPGA接收更新数据,并将其存入Flash器件,然后复位Nios或FPGA对软硬件进行更新。 

1 系统的硬件设计
    系统主要由Cyclone FPGA、EPCS、Flash和串行通信等组成,硬件结构如图1所示。

    EPCS采用Altera公司的EPCS4,容量达到4 Mb,引脚较少,成本低,支持3.3 V低电压操作。Flash芯片采用AMD公司的Am29LV640MH/L,支持3.O V低电压操作,具有低功耗特性,芯片容量为64 Mb,满足大容量数据的存储;并口操作,与Cyclone FPGA完全兼容,而且在SOPC中有与之对应的CFI_FLASH核,便于硬件电路的设计。

2 工作原理
2.1 几个概念

    FPGA配置数据:是sof文件,将sof文件编程到Flash中,上电后FPGA可以从Flash中配置。sof文件是其他配置文件的基础,其他文件均可由sof文件转换得到。
    软件数据:通过NiosII IDE创建elf文件,将用户程序编程到Flash中,允许复位后从F1ash中加载软件程序,从而启动NiosII CPU。
2.2 编程文件
    编程文件为Flash格式的文件,即S—reeorld(简称“SREC”)格式。SREC格式是Motorola公司制定的一种烧写格式标准。SREC格式文件是由一组ASCII码组成,所有的十六进制数据均为大写形式,结构说明如下:
    ①起始代码。以S作为一个数据行的开始。
    ②记录类型。1个十进制数字(O~9),定义数据域的类型。
    ③字节数。1个字节,定义字节数之后除地址字节、校验字节之外其他字节的个数。
    ④地址。由4(或6、8)个字节组成,定义了第一个数据字节存储的位置。
    ⑤数据字节。由n个字节组成,数据字节为实际有效的编程信息。
    ⑥校验字节。1个字节,作校验使用,所有十六进制字节相加后取8位,为0xFF。
2.3 AS配置模式
   
FPGA的配置数据存储在内部SRAM单元中。由于SRAM掉电后数据会丢失,因此每次上电时必须重新将配置数据写入SRAM中。这个过程称为“FPGA的配置”。由此可见,FPGA的配置信息是存储在FPGA内部RAM当中的。可知在主动串行模式下,FPGA将配置数据从EPGS中读取,然后存入内部RAM中。
    AS配置模式支持StratixII和Cyclone系列的FPGA,通过配置MSEL[1:O]为1:0,选择主动配置模式(除JTAG模式不受MSEL控制外,其他配置方式均由MSEL决定)。AS配置模式使用串行配置器件(EPCS1/EPCS4/EPCSl6/EPCS64)。在AS配置过程中,StratixlI和Cy—clone系列的FPGA是主设备,串行配置器件为从设备。如图2所示,在AS配置模式下,FPGA通过DATA0接收配置数据,配置数据和DCLK是同步的。每个时钟周期传输1位配置数据。通过控制nCONFIG、nSTATUS、CONF_DONE来表示配置过程。串行配置芯片在DCLK上升沿时锁存输入信号和控制信号,在下降沿时输出配置数据。Cyclone芯片在DCLK下降沿时输出控制信号,并锁存配置数据。

3 工作流程
3.1 硬件配置的更新

    如图3所示,FPGA的配置过程分为:复位、配置和初始化。

[!--empirenews.page--]

    (1)复位FPGA

    上电复位:在用户模式下,当nCONFIG引脚持续低电平40μs时,FPGA将进入复位状态。复位时,FP—GA采样MSEL引脚的电平值,以确定采用的配置方式;同时,nSTATUS和CONF_DONE引脚由FPGA置为低电平,所有I/0引脚为三态且FPGA内部配置寄存器被清空。
    FPGA复位的2种方法:
    ①外加RC复位电路或者复位芯片,自动产生上电复位脉冲。
    ②参考芯片手册。如果芯片提供了上电复位脉冲(一般是全局复位信号),则使用它作为复位信号;若没有提供,则查找芯片是否给出了寄存单元上电默认值(一般是O),利用该特性复位或者产生复位脉冲。
    (2)配置FPGA
    复位后,nCONFIG被外部上拉电阻拉高,进入配置阶段。此时,nSTATUS被FPGA释放并由外部上拉电阻拉为高电平后进入配置状态。Cyclone芯片通过将nCSO输出的信号置低来使能串行配置芯片,nCS0引脚连接配置芯片的片选段(nCS),用串行时钟(DCLK)和串行数据输出(ASDO)引脚来发送操作指令,及/或将地址信号读到串行配置芯片中。接着配置芯片将数据送到串行数据输出(DATA)引脚,DATA引脚连接Cyclone芯片的DATA0输入脚。配置数据在DCLK时钟的上升沿载入FPGA。当接收完所有的配置位后(CRC校验无误),Cyclone芯片悬空CONF_DONE引脚,该引脚由外部10 kΩ电阻拉高;同时,停止驱动DCLK信号。只有当CONF_DONE到达一定的逻辑高电平后,初始化才开始。
    (3)初始化阶段
    在Cyclone芯片中,初始时钟源是Cyclone芯片的lOMHz(典型的)内部晶振,或者是可供选择的CLKUSR引脚。内部晶振是默认的初始化时钟源。如果用了内部时钟,则Cyclone芯片为正确的初始化提供足够的时钟。使用内部时钟的好处在于,初始化时不需要从外部发送其他的时钟到CLKUSR引脚,而且可以把CLKUSR引脚当作I/O引脚。
    (4)用户模式
    初始化结束后,FPGA进入用户模式。在用户模式下,用户I/O引脚不再有弱上拉电阻,而是执行设计中分配的功能。Cyclone芯片可以通过将nCONFIG拉低而开始重新配置。nCONFIG低信号应该至少持续40μs。当nCONFIG被拉低时,Cyclone芯片被复位并进入复位阶段。Cyclone芯片也会把nSTATUS和CONF_DONE拉低,所有的I/O引脚处于三态。一旦nCONFIG回到逻辑高电平,Cyclone芯片将释放nSTATUS,重新开始配置。
    (5)配置时出现的错误
    如果在配置时出现错误,则Cyclone芯片将nSTA—TUS信号置低来表明一个数据帧错误,CONF_DONE信号为低。如果在Quartus软件的Device&Pin Options窗口的General项中,选中Auto—restart configuration aftererror选项,则Cyclone芯片通过激活nCSO来实现复位,在复位失效时间(40μs)后释放nSTATUS,并再次尝试配置。如果该选项未被选中,则外部系统必须监视nSTA—TUS信号以防出错,然后将nCONFIG信号拉低并持续至少40μs来重新配置。
    计算机与目标板上的Nios程序建立连接,通过通信接口将Flash文件传输给FPGA;Nios程序判断出传输文件的针对目标后,将编程数据存放在EPCS或Flash中。接收到的数据首先暂存入SDRAM,而不是直接对EPCS和Flash进行操作。这样做的好处是,一旦传输失败或中止,不会破坏原有EPCS和Flash中的数据。
    通过sof2Flash命令来生成Flash文件时,可以通过SOPC Builder打开NioslI command shell,使用“sof2 Flash—epcs-input=<输入文件名.sof>一output=<输出文件名.Flash>”命令,生成的Flash文件存在于工程目录下。也可以将sof文件复制到“〈quartus安装目录〉\kits\nios2_60\examples”下,直接打开NiosII command shell,使用“sof2Flash-epcs—input=<输入文件名.sof>一output=<输出文件名.Flash>”,生成的Flash文件存在于“〈quartus安装目录〉\kits\nios2_60\examples”下。
3.2 软件程序的更新
   
如前所述,软件程序既可以存放在Flash中,也可以存放在EPCS中。生成软件Flash文件的最简单的方式是,在NiosII IDE环境下对系统进行编译,生成的Flash文件存在于“<目标工程>\software\debug\<软件工程>\Debug\obj\”目录下。
    Nios程序可以存放在Flash中,在SDRAM或On—chip RAM(以下统称“RAM”)中运行。这种情况需要有一个专门的Bootloader,该文件存在于“ quartus安装目录>\kits\nios2_60\components\altera_nios2”目录下,名称为“boot_loader_cfi.srec”。它把存放在Flash中的各个程序段搬到程序执行时各个段真正的位置。
    如图4所示,Bootloader代码位于Flash的低地址处,NiosII就被逻辑中的复位电路复位,从reset地址处开始执行代码。如果reset地址设置在Flash中,那么复位后首先运行Flash前面的Bootloader代码,由Bootloader代码将后面的用户程序引导到指定位置。执行elf2Flash应用程序在elf文件前会插入一个引导复制(Boot—copier)程序,前提是,elf将被链接到RAM中运行。

[!--empirenews.page--]

    Bootloader的工作流程如图5所示。

    NiosII C程序在运行之前需要做一些初始化工作。如果程序直接从Flash中运行,则Crt0.S是最先执行的代码;如果程序不是直接从Flash中运行,则Crt0.S是执行完Bootloader后最开始执行的代码。
    运行完Bootloader后仍然要执行CrtO.s,但此时Crt0.s的流程和程序在Flash中直接运行的情况有一些区别:它没有初始化指令Cache,也不会企图去装载别的段,这些步骤已经在Boot—loader中完成。程序映像已经包含这些段,在搬移程序映像的同时也装载了相应的段(.rodata段,.rwdata段和.exceptions段)。程序映像中不包含.bss段和栈,所以仍然需要清.bss段,以及设置栈指针sp和全局指针gp。Bootloader没有读写存储器数据,因此没有初始化数据Cache,所以Crt0.S仍然要初始化数据Cache。如图6所示,当Bootloader读取到L时,L=0表示前面所有的程序记录已经处理完毕,这是最后的程序记录,所以就直接跳到地址A的地方执行。显然A必须是程序的入口地址。如果L=Oxffffffff(即一1),那么就忽略A并停机,这样,即使是一个只有FPGA配置数据而没有程序的EPCS也是安全的。当一个EPCS只有配置数据而没有程序时,sof2Flash会在配置数据的末尾增加4个字节的Oxff,使Bootloader不会有误动作。Bootloader的工作流程与Flash中相同,如图5所示。

4 软件编程
    Altera公司提供给客户两种类型的函数:SimpleFlash Access(简单的Flash访问),以及Fine—GrainedFlash Access(细粒度Flash访问)。本文使用Fine—Grained Flash Access函数,虽然比Simple Flash Access复杂一些,但可以避免通常的跨块擦除问题。因为Flash是按照块(Block)组织起来的,通常一次擦除一整个块。如果写Flash的地址与Flash块的组织结构不吻合,比如跨越了Flash块的边缘,那么可能会擦除掉其余的数据。在使用Flash的读写函数时,头文件中要包含“sys/alt_Flash.h”和“sys/alt_Flash_dev.h”,这两个头文件提供了访问Flash器件的驱动接口。
    使用之前要打开Flash。打开Flash,就像C程序打开硬盘中的数据文件一样。这里使用alt_Flash_open_dev()打开Flash,它返回一个句柄。例如:


其中,fd是alt_Flash_open_dev()返回的句柄;offset是相对Flash基地址的偏移量,是读操作中要读出数据第一个字节的地址;length是本次操作的数据长度,单位是字节。当返回值为时,表示读操作成功。

其中,fd是a1t_Flash_open_dev()返回的句柄;offset是相对Flash基地址的偏移量,是写操作中要写入的数据第一个字节的地址;length是本次操作的数据长度,单位是字节。当返回值为O时,表示写操作成功。
    使用完后别忘记关闭该Flash,就像读写完硬盘中的数据文件后要关闭一样。其原型如下:
void alt_Flash_close_dev(alt_Flash_fd*fd);
其中,fd是alt_Flash_open_dev()返回的句柄。
    编者注:Flash器件读写程序略。


结 语
    目前,在FPGA的开发过程中,每次进行程序的调试和更新时都需要将产品与计算机直连,进行在线操作,这样就限制了程序调试和更新的空间范围。而基于FPGA的在应用编程技术就是为了打破这种限制而设计的。在应用编程技术对硬件要求极低,只要满足FPGA是Cy—clone系列,具有Flash器件,具有上下位机的通信能力,无需增加太多的硬件资源,都可以实现在应用编程。如果产品具有网络功能或无线功能,那么在恶劣的工业现场和野外可以免除到现场反复拆卸、调试的麻烦。对于保密产品,该项技术可以保护知识产权,通过网络更新产品的软硬件,增加了更新过程中被破解的难度。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

助力科研与检测新突破 上海2024年5月15日 /美通社/ -- 全球知名的科学仪器和服务提供商珀金埃尔默公司今日在上海举办了主题为"创新不止,探索无界"的新品发布会,集中展示了其在分析仪器领域的最...

关键字: 质谱仪 BSP DSC 气相色谱

上海2024年5月16日 /美通社/ -- 2024年5月10日至5月13日,富士胶片(中国)投资有限公司携旗下影像产品创新力作亮相北京P&E 2024。在数码相机展览区域,全新制定的集团使命"为世界绽...

关键字: 富士 数码相机 影像 BSP

Bourns® TLVR1005T 和 TLVR1105T 系列采用双绕组结构和低感值设计,可提供快速瞬态响应,并可依据 CPU、FPGA 和 ASIC 负载要求进行延展

关键字: 数据驱动 电感器 FPGA

贝克曼库尔特目前已成为MeMed Key免疫分析平台和MeMed BV检测技术的授权经销商 在原有合作的基础上,继续开发适用于贝克曼库尔特免疫分析仪的MeMed BV检测 加州布瑞亚和以色列海法2024年5月16日...

关键字: BSP IO 检测技术 免疫分析仪

英国英泰力能的燃料电池是可产业化的产品解决方案 英国首个专为乘用车市场开发的燃料电池系统 在 157kW 功率下,此燃料电池比乘用车的其他发动机更为强大 &...

关键字: ENERGY INTELLIGENT 氢燃料电池 BSP

深爱人才,共赴"芯"程 深圳2024年5月15日 /美通社/ -- 5月11日,深圳国资国企"博士人才荟"半导体与集成电路产业专场活动在深圳市重投天科半导体有限公司(简...

关键字: 半导体 集成电路产业 BSP 人工智能

武汉2024年5月15日 /美通社/ -- 北京时间4月26日-5月4日,2024 VEX 机器人世界锦标赛于美国得克萨斯州达拉斯市举办。本届 VEX 世锦赛为期九天,设有 VIQRC 小学组/初中组、V5RC 初中组/...

关键字: 机器人 BSP RC POWERED

上海2024年5月15日 /美通社/ -- 由生成式人工智能(AI)驱动的临床阶段生物医药科技公司英矽智能宣布,与复星医药(600196.SH;02196.HK)合作开发的潜在"全球首创"候选药物IS...

关键字: ISM BSP PC 人工智能

上海2024年5月13日 /美通社/ -- 5月8日,浦东新区国资委组织陆家嘴集团等9家区属企业与立邦中国召开合作交流会,旨在贯彻落实浦东新区区委、区政府工作要求,进一步放大进博会溢出带动效应,持续扩大区属企业与进博会重...

关键字: BSP 数字化 自动化立体仓库 智慧园区
关闭
关闭