CN201514768U - Fpga控制设备的在线flash烧写器 - Google Patents
Fpga控制设备的在线flash烧写器 Download PDFInfo
- Publication number
- CN201514768U CN201514768U CN2009200351178U CN200920035117U CN201514768U CN 201514768 U CN201514768 U CN 201514768U CN 2009200351178 U CN2009200351178 U CN 2009200351178U CN 200920035117 U CN200920035117 U CN 200920035117U CN 201514768 U CN201514768 U CN 201514768U
- Authority
- CN
- China
- Prior art keywords
- usb
- fpga
- data
- module
- flash
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
Images
Landscapes
- Stored Programmes (AREA)
Abstract
本实用新型公开了一种FPGA控制设备的在线FLASH烧写器,包括计算机、USB数据控制板及FPGA用户端,所述的计算机通过USB接口与USB数据控制板连接,USB数据控制板通过数据总线与FPGA用户端连接,所述的计算机中置入FLASH烧写控制软件、EZ-USB通用驱动程序和固件驱动程序以及上位机控制软件,实现硬件状态检测及硬件控制功能;所述的USB数据控制板中包括由USB控制器、数据接口、FPGA模块、LVDS-A模块依次连接组成的数据处理通道,和用于固件程序处理的GPIF模块;所述的FPGA用户端包括FLASH烧写硬核组件、数据收发硬核组件和LVDS-B模块,并预装用户自己的FPGA程序。本实用新型的在线FLASH烧写器降低了硬件设计的难度,减少了控制器的体积。
Description
技术领域
本实用新型属于电子控制技术领域,涉及一种FPGA控制设备的在线FLASH烧写器。
背景技术
在FPGA正常工作时,配置数据存储在SRAM单元中,这个SRAM单元也被称为配置存储器(Configuration RAM)。由于SRAM是易失性的存储器,因此FPGA在上电之后,外部电路需要将配置数据重新载入到片内的配置RAM中。在芯片配置完成后,内部的寄存器以及I/O管脚必须进行初始化。等初始化完成以后,芯片才会按照用户设计的功能正常工作,因此通常都会给FPGA配置一个FLASH配置芯片,存放配置数据。
在实际应用中,FPGA的控制设备常需要对控制器的FPGA软件进行重新的刷新、诊断和更新。在以往的FPGA的控制设备需要借助于BDM进行FLASH的烧写,因此在布置的时候需要给控制器BDM接口预留较大的空间,对于布置十分紧凑的控制设备来说,这无疑增加了布置的难度;而且一旦控制器布置不当,将控制器从设备中拆卸下来进行重新的烧写,烧写完成之后,再将控制器安装上去,这样对控制器软件的更新非常的困难,对于一些设备来说,很难把焊接好的FLASH拔出来进行烧写。因此经常为更新设备程序,要更新整个电路板。因此设计一个能在线烧写FLASH的控制设备是至关重要的。
发明内容
本实用新型的目的是提供一种FPGA控制设备的在线FLASH烧写器,解决了现有技术对控制器进行重新烧写非常困难的问题。
本实用新型所采用的技术方案是,一种FPGA控制设备的在线FLASH烧写器,包括计算机、USB数据控制板及FPGA用户端,所述的计算机通过USB接口与USB数据控制板连接,USB数据控制板通过数据总线与FPGA用户端连接,所述的计算机中置入FLASH烧写控制软件、EZ-USB通用驱动程序和固件驱动程序以及上位机控制软件,实现硬件状态检测及硬件控制功能;所述的USB数据控制板中包括由USB控制器、数据接口、FPGA模块、LVDS-A模块依次连接组成的数据处理通道,和用于固件程序处理的GPIF模块;所述的FPGA用户端包括FLASH烧写硬核组件、数据收发硬核组件和LVDS-B模块,并预装用户自己的FPGA程序。
本实用新型的在线FLASH烧写器,其特征还在于:
所述的USB接口选用USB2.0设备。
所述的数据总线选用96M的SPI总线。
所述的LVDS-A模块和LVDS-B模块均选用96Mbps速度的LVDS接口。
本实用新型的在线FLASH烧写器利用SPI总线,借助于USB2.0通信接口实现了对FPGA控制设备的FLASH在线烧写,解决了对控制器进行重新烧写的难题,明显降低了硬件设计的难度,减少了控制器的体积。
附图说明
图1是本实用新型装置的连接框图。
图中,1.计算机,2.USB接口,3.USB控制器,4.数据接口,5.FPGA模块,6.LVDS-A模块,7.GPIF模块,8.FLASH烧写硬核组件,9.数据收发硬核组件,10.FPGA用户端,11.数据总线,12.LVDS-B模块,13.USB数据控制板。
具体实施方式
下面结合附图和具体实施方式对本实用新型进行详细说明。
如图1,本实用新型装置的结构是,包括计算机1、USB数据控制板13、FPGA用户端10连接组成,计算机1通过USB接口2与USB数据控制板13连接,USB接口2选用USB2.0设备,USB数据控制板13通过数据总线11与FPGA用户端10连接,数据总线11选用96M的SPI总线,在计算机1中置入FLASH烧写控制软件、EZ-USB通用驱动程序和固件驱动程序以及上位机控制软件,完成硬件状态检测及硬件控制功能;USB数据控制板13中包括由USB控制器3、数据接口4、FPGA模块5、LVDS-A模块6依次连接组成的数据处理通道和用于固件程序处理的GPIF模块7;FPGA用户端10包括FLASH烧写硬核组件8、数据收发硬核组件9和LVDS-B模块12,并预装用户自己的FPGA程序。LVDS-A模块6和LVDS-B模块12均选用96Mbps速度的LVDS接口。
USB数据控制板13采用USB2.0和GPIF进行数据传输,并结合了96Mbps速度的LVDS接口,可以实现高速数据采集和控制及FLASH烧写。USB数据控制板13的硬件采用USB接口供电,小巧灵活,便于携带。
参照图1,本实用新型整个装置的硬件结构分成3个层次:计算机1所在的计算机管理层,USB数据控制板13所在的数据控制层,以及FPGA用户端10所在的用户FPGA层。
计算机管理层主要负责界面管理,固件程序下载、USB通信过程等构成。其中,界面管理模块功能包括打开文件、擦除芯片、烧写文件、校验、数据状态检测等,给FLASH烧写器提供一个很好的交互平台。固件下载主要功能是:通常USB控制芯片的固件程序,被烧写在ROM中,这种方式一旦想升级固件程序,扩展系统功能,就很难实现,USB数据控制板13的固件运行程序通过USB接口2从主机下载到内部RAM,这样就明显的方便了修改、调试和更新。之所以能下载代码是因为芯片一上电完全在硬件上自动完成枚举过程,不需要Firmware。完成枚举后便可作为一个USB设备(叫做缺省USB设备)与计算机通讯,此时即可进行Firmware下载。下载完后,控制芯片内核脱离RESET状态开始执行代码。可以通过Firmware对USB设备重新配置,这个重新配置过程叫做再枚举。USB通信过程主要完成当USB设备插入计算机时,计算机和USB设备之间产生一个枚举过程。计算机检测到有设备插入,自动发出查询请求;USB设备回应这个请求,送出设备的Verdor ID和Product ID;计算机根据这两个ID装载相应的设备驱动程序,完成枚举过程。计算机与USB设备的数据通信全部靠端点进行通信的,端点0,是系统端点,主要进行系统枚举,以及控制系统的下发,端点2和4是数据输出端点,端点6和8作为数据输入端点,根据本控制装置的通信特点,主要包括三个方面:一是读取数据;二是发生数据;三是发生控制指令。直接使用缺省配置中的3个Endpoint。端点0:主要完成控制指令的下发和系统状态读取,包括输入和输出切换,系统复位,缓冲区复位,以及读取各个数据缓冲区的状态。端点2:主要负责数据的输出,端点6:读取外面采集的数据,目前端点4和8系统没有使用,为以后的高速数据采集,留有专门的数据收发通道。
USB数据控制板13是整个装置数据转发的核心,它主要作用是负责协议传输,通过USB与计算机管理层进行数据交换,通过SPI与用户FPGA层进行数据传输。USB数据控制板13和计算机管理层进行数据交互的通信方式:异步,全双工,主从应答式;包大小:固定包长512字节;传输速率:480Mbps;USB字段长度:4个字节;每次传输包含字段数:128个。在FLASH模式下,如果处于设置地址低位地址命令下的时候,USB字段数据结构中的高位和低位数据,组合为1个16位地址,送给FLASH的A0-A15,如果处于高位地址模式下的时候,USB字段数据结构中的高位和低位数据,组合为1个16位数值,送给高位地址的中,A16-A24,以及FLASH的控制总线Vopen,nCE0,nCE1,nCE2,nCE3,nByte,nRP。这样就为了FLASH所有控制总线对于计算机来说,都是开放的,便于兼容不同种类的FLASH。在数据收发模式下,通过命令字D4和D5组合,以及16位数据,实现32位的数据收发。
用户FPGA层主要是嫁接用户FPGA用户端10内部的一个程序,主要负责和USB数据控制通过LVDS进行数据交互。交互协议包大小:8位、16位、24位、32位;传输速率:96Mbps;常用包大小:24位。
下面结合表1,说明具体协议通过LVDS实现方式,整个数据传输最小字段是4个字节,USB每个数据包固定长度是512个字节,这样每个数据分为128个数据字段,提高通信效率,LVDS字段表示第一个字节是指令包,具体描述如表2,当对FLASH操作的时候,通常过程需要设置地址,然后送数据,因此对表2指令包分析可以看出,写FLASH和读FLASH,以及LVDS数据长度,可以通过这个指令包进行完成。字段第2和第3个字节是个数据自己,表示根据命令包,所产生命令不同,功能也不一样,当设置地址的时候,它表示的是高位和低位地址,当是读写数据的时候,它表示的是16位数据。表3为FLASH模式下地址定义,通过以上的的过程,可以完成对FLASH进行烧写和读取。
表1通过LVDS的字段格式
表2数据通过LVDS传输过程
表3FLASH模式下地址定义
本实用新型的FPGA控制设备的在线FLASH烧写器,利用96M的SPI总线,借助于USB2.0通信接口实现对FPGA控制设备的FLASH进行在线烧写,由于使用SPI总线进行通讯的控制设备很多,这样使用SPI接口进行FLASH的烧写在控制器的硬件设计上不需要增加什么新的功能接口,这样在硬件初期设计的时候,就省掉BDM接口,降低了硬件设计的难度,减少了控制器的体积。
综上所述,本实用新型的FPGA控制设备的在线FLASH烧写器,用于对安装在现有的硬件系统中的FLASH进行在线烧写,并且能对32路的硬件状态进行在线监测,提供了32路的硬件系统的开关量输出控制、监测和控制点数量,可以随着硬件的系统需求,灵活变更。
Claims (4)
1.一种FPGA控制设备的在线FLASH烧写器,其特征在于:包括计算机(1)、USB数据控制板(13)及FPGA用户端(10),所述的计算机(1)通过USB接口(2)与USB数据控制板(13)连接,USB数据控制板(13)通过数据总线(11)与FPGA用户端(10)连接,
所述的计算机(1)中置入FLASH烧写控制软件、EZ-USB通用驱动程序和固件驱动程序以及上位机控制软件,实现硬件状态检测及硬件控制功能;
所述的USB数据控制板(13)中包括由USB控制器(3)、数据接口(4)、FPGA模块(5)、LVDS-A模块(6)依次连接组成的数据处理通道,和用于固件程序处理的GPIF模块(7);
所述的FPGA用户端(10)包括FLASH烧写硬核组件(8)、数据收发硬核组件(9)和LVDS-B模块(12),并预装用户自己的FPGA程序。
2.根据权利要求1所述的在线FLASH烧写器,其特征在于:所述的USB接口(2)选用USB2.0设备。
3.根据权利要求1所述的在线FLASH烧写器,其特征在于:所述的数据总线(11)选用96M的SPI总线。
4.根据权利要求1所述的在线FLASH烧写器,其特征在于:所述的LVDS-A模块(6)和LVDS-B模块(12)均选用96Mbps速度的LVDS接口。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN2009200351178U CN201514768U (zh) | 2009-10-20 | 2009-10-20 | Fpga控制设备的在线flash烧写器 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN2009200351178U CN201514768U (zh) | 2009-10-20 | 2009-10-20 | Fpga控制设备的在线flash烧写器 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN201514768U true CN201514768U (zh) | 2010-06-23 |
Family
ID=42486179
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN2009200351178U Expired - Fee Related CN201514768U (zh) | 2009-10-20 | 2009-10-20 | Fpga控制设备的在线flash烧写器 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN201514768U (zh) |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104536774A (zh) * | 2014-11-20 | 2015-04-22 | 成都九洲迪飞科技有限责任公司 | 芯片软件烧录方法 |
CN104778062A (zh) * | 2015-04-16 | 2015-07-15 | 中国科学院长春光学精密机械与物理研究所 | 星上可擦写芯片地面烧写的硬件结构及其应用方法 |
CN105242939A (zh) * | 2015-09-11 | 2016-01-13 | 三星半导体(中国)研究开发有限公司 | 将固件烧写到主板的连接器和利用连接器烧写固件的方法 |
CN103856210B (zh) * | 2012-11-28 | 2017-09-12 | 艺伦半导体技术股份有限公司 | 一种控制fpga编程新地址的方法、装置及编程电路 |
CN111045734A (zh) * | 2019-11-19 | 2020-04-21 | 中国航空工业集团公司西安航空计算技术研究所 | 一种基于ima平台的软硬件程序一键固化系统及方法 |
CN111124433A (zh) * | 2018-10-31 | 2020-05-08 | 华北电力大学扬中智能电气研究中心 | 程序烧写设备、系统及方法 |
CN111857769A (zh) * | 2020-06-24 | 2020-10-30 | 苏州浪潮智能科技有限公司 | 一种基于usb转spi的fpga升级系统及方法 |
CN112765068A (zh) * | 2021-01-06 | 2021-05-07 | 天津飞腾信息技术有限公司 | 用于fpga原型系统的sd卡无插拔烧写控制装置及方法 |
-
2009
- 2009-10-20 CN CN2009200351178U patent/CN201514768U/zh not_active Expired - Fee Related
Cited By (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103856210B (zh) * | 2012-11-28 | 2017-09-12 | 艺伦半导体技术股份有限公司 | 一种控制fpga编程新地址的方法、装置及编程电路 |
CN104536774B (zh) * | 2014-11-20 | 2018-02-02 | 成都九洲迪飞科技有限责任公司 | 芯片软件烧录方法 |
CN104536774A (zh) * | 2014-11-20 | 2015-04-22 | 成都九洲迪飞科技有限责任公司 | 芯片软件烧录方法 |
CN104778062A (zh) * | 2015-04-16 | 2015-07-15 | 中国科学院长春光学精密机械与物理研究所 | 星上可擦写芯片地面烧写的硬件结构及其应用方法 |
CN104778062B (zh) * | 2015-04-16 | 2018-04-27 | 中国科学院长春光学精密机械与物理研究所 | 星上可擦写芯片地面烧写的硬件结构及其应用方法 |
CN105242939A (zh) * | 2015-09-11 | 2016-01-13 | 三星半导体(中国)研究开发有限公司 | 将固件烧写到主板的连接器和利用连接器烧写固件的方法 |
CN111124433B (zh) * | 2018-10-31 | 2024-04-02 | 华北电力大学扬中智能电气研究中心 | 程序烧写设备、系统及方法 |
CN111124433A (zh) * | 2018-10-31 | 2020-05-08 | 华北电力大学扬中智能电气研究中心 | 程序烧写设备、系统及方法 |
CN111045734A (zh) * | 2019-11-19 | 2020-04-21 | 中国航空工业集团公司西安航空计算技术研究所 | 一种基于ima平台的软硬件程序一键固化系统及方法 |
CN111045734B (zh) * | 2019-11-19 | 2023-09-01 | 中国航空工业集团公司西安航空计算技术研究所 | 一种基于ima平台的软硬件程序一键固化系统及方法 |
CN111857769A (zh) * | 2020-06-24 | 2020-10-30 | 苏州浪潮智能科技有限公司 | 一种基于usb转spi的fpga升级系统及方法 |
CN112765068A (zh) * | 2021-01-06 | 2021-05-07 | 天津飞腾信息技术有限公司 | 用于fpga原型系统的sd卡无插拔烧写控制装置及方法 |
CN112765068B (zh) * | 2021-01-06 | 2022-03-29 | 飞腾信息技术有限公司 | 用于fpga原型系统的sd卡无插拔烧写控制装置及方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN201514768U (zh) | Fpga控制设备的在线flash烧写器 | |
CN103034515B (zh) | 一种卫星导航接收机fpga快速加载方法 | |
CN103064805B (zh) | Spi控制器及通信方法 | |
CN102243619A (zh) | 一种基于fpga实现多路i2c总线端口扩展的方法 | |
CN103870429B (zh) | 基于嵌入式gpu的高速信号处理板 | |
CN109525474A (zh) | 一种基于Linux平台的多接口协议智能转换器及转换方法 | |
CN104375855A (zh) | 一种基于车载多mcu通过存储设备升级固件的装置及方法 | |
CN101359303B (zh) | 一种在线调试微控制器及其外设器件的装置及调试方法 | |
CN104731746A (zh) | 设备控制器装置 | |
CN108664440A (zh) | 接口服务器和机箱 | |
CN104615386A (zh) | 一种核外高速缓存装置 | |
CN104298474A (zh) | 一种基于服务端与外部缓存系统的外接式计算设备加速方法与实现该方法的设备 | |
CN102693203A (zh) | 嵌入式usb主机 | |
CN209105202U (zh) | 一种基于Linux平台的多接口协议智能转换器 | |
CN107329863B (zh) | 一种基于COMe的测量仪器通用硬件平台 | |
CN111679995B (zh) | 一种基于1553b总线的空间计算机嵌入式管理执行单元 | |
CN104698909A (zh) | 水下航行器控制系统传感器的数据采集接口及其配置方法 | |
CN211375594U (zh) | 一种基于sw421处理器的接口扩展机构 | |
CN103218334A (zh) | 基于usb总线和rs485总线的计算机外设级联装置 | |
CN201435078Y (zh) | 一种接口扩展装置 | |
CN102855217A (zh) | 一种前端机的通用核心板及其前端机 | |
CN201220551Y (zh) | 蓝牙绘图仪 | |
CN104732849A (zh) | 基于动态部分可重构fpga的计算机系列课程实验平台装置 | |
CN201628975U (zh) | 一种带spi接口的iic存储卡读写装置 | |
CN214846341U (zh) | 一种基于嵌入式的采煤机显示设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C14 | Grant of patent or utility model | ||
GR01 | Patent grant | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20100623 Termination date: 20151020 |
|
EXPY | Termination of patent right or utility model |