软核更新方法和系统与流程

文档序号:17048359发布日期:2019-03-05 19:47阅读:473来源:国知局
软核更新方法和系统与流程

本发明涉及软件更新技术领域,尤其涉及一种软核更新方法以及一种软核更新系统。



背景技术:

led显示屏控制卡一般采用fpga进行图像和通讯处理。在与外围通讯处理器例如arm通讯中为了解析协议一般采用软核进行处理。软核更新方式一般采用jtag口和as(activeserial,主动串行)方式,jtag只适合调试阶段,不适合产品阶段。as方式适合产品阶段,但要增加一片eeprom存储器挂接至fpga来专门存放fpga的配置程序和软核程序,这也就增加了成本。而且当软核应用程序在外部存储器例如ddr3中运行的应用场合,利用软核程序中的boot程序将eeprom存储器中的软核应用程序文件转写到外部存储器,这样就增加了内部ram的使用个数,当内部ram非常紧张时这种方式是不可取的。



技术实现要素:

因此,本发明的实施例提供一种软核更新方法以及一种软核更新系统,以实现降低成本和/或节省内部ram资源的技术效果。

一方面,提供了一种软核更新方法,包括:将第一程序文件从第一存储器读出并加载至可编程逻辑器件;在将所述第一程序文件从所述第一存储器读出并加载至可编程逻辑器件后,与所述可编程逻辑器件进行握手通信,并在握手通信成功后将第二程序文件从所述第一存储器读出并发送给所述可编程逻辑器件;所述可编程逻辑器件的寄存器传输级代码将所述第二程序文件存储至第二存储器;以及在所述可编程逻辑器件的寄存器传输级(rtl)代码将所述第二程序文件存储至第二存储器后,所述可编程逻辑器件将程序运行的入口地址跳转到所述第二存储器中的目标地址,运行所述第二程序文件对应的软核代码。

在本发明的一个实施例中,所述第一程序文件包含所述可编程逻辑器件的配置程序和软核引导程序,所述第二程序文件包含所述可编程逻辑器件的软核应用程序。

在本发明的一个实施例中,在将所述第一程序文件从所述第一存储器读出并加载至所述可编程逻辑器件后,所述可编程逻辑器件根据所述配置程序进行配置、并在配置完成后运行所述软核引导程序。

在本发明的一个实施例中,所述方法还包括:获取初始配置程序和软核程序,其中所述软核程序包含elf格式的软核引导程序和elf格式的软核应用程序;根据所述初始配置程序和所述elf格式的软核引导程序生成bit格式的所述第一程序文件;根据所述elf格式的软核应用程序生成bin格式的所述第二程序文件;以及将bit格式的所述第一程序文件和bin格式的所述第二程序文件从上位机发送至微处理器,以供所述微处理器接收所述第一程序文件和所述第二程序文件并存储至所述第一存储器,其中所述微处理器连接所述第一存储器和所述可编程逻辑器件。

在本发明的一个实施例中,所述根据所述elf格式的软核应用程序生成bin格式的所述第二程序文件包括:将所述elf格式的软核应用程序转换成srec格式文件;对所述srec文件进行局部内容修改,以设置软核应用程序在所述第二存储器中的基地址,得到修改后srec格式文件;以及将所述修改后srec格式文件转换成bin格式文件,得到转换后bin格式文件。

在本发明的一个实施例中,所述根据所述elf格式的软核应用程序生成bin格式的所述第二程序文件还包括:对所述转换后bin格式文件进行局部内容修改,以设置复位和中断执行代码,得到bin格式的所述第二程序文件。

在本发明的一个实施例中,所述第一程序文件为bit格式文件且所述配置程序和所述软核引导程序位于同一个bit格式文件中,所述第二程序文件为bin格式文件。

再一方面,提供了一种软核更新系统,包括:微处理器、第一存储器、可编程逻辑器件和第二存储器,所述微处理器连接所述第一存储器和所述可编程逻辑器件,所述第二存储器连接所述可编程逻辑器件;所述微处理器用于将第一程序文件从所述第一存储器读出并加载至所述可编程逻辑器件,在将所述第一程序文件从所述第一存储器读出并加载至所述可编程逻辑器件后与所述可编程逻辑器件进行握手通信,并在握手通信成功后将第二程序文件从所述第一存储器读出并发送给所述可编程逻辑器件;所述可编程逻辑器件用于利用寄存器传输级代码将所述第二程序文件存储至第二存储器,以及在将所述第二程序文件存储至第二存储器后将程序运行的入口地址跳转到所述第二存储器中的目标地址,运行所述第二程序文件对应的软核代码。

在本发明的一个实施例中,所述第一程序文件包含所述可编程逻辑器件的配置程序和软核引导程序,所述第二程序文件包含所述可编程逻辑器件的软核应用程序。

在本发明的一个实施例中,所述可编程逻辑器件还用于根据所述配置程序进行配置、并在配置完成后运行所述软核引导程序。

在本发明的一个实施例中,所述系统还包括:上位机,所述上位机通过通信接口连接所述微处理器;所述上位机用于:获取初始配置程序和软核程序,其中所述软核程序包含elf格式的软核引导程序和elf格式的软核应用程序;根据所述初始配置程序和所述elf格式的软核引导程序生成bit格式的所述第一程序文件;以及根据所述elf格式的软核应用程序生成bin格式的所述第二程序文件。

在本发明的一个实施例中,所述上位机根据所述elf格式的软核应用程序生成bin格式的所述第二程序文件包括:将所述elf格式的软核应用程序转换成srec格式文件;对所述srec文件进行局部内容修改,以设置软核应用程序在所述第二存储器中的基地址,得到修改后srec格式文件;以及将所述修改后srec格式文件转换成bin格式文件,得到转换后bin格式文件。

在本发明的一个实施例中,所述上位机根据所述elf格式的软核应用程序生成bin格式的所述第二程序文件还包括:对所述转换后bin格式文件进行局部内容修改,以设置复位和中断执行代码,得到bin格式的所述第二程序文件。

在本发明的一个实施例中,所述第一程序文件为bit格式文件且所述配置程序和所述软核引导程序位于同一个bit格式文件中,所述第二程序文件为bin格式文件。

上述技术方案的一个技术方案具有如下优点或有益效果:通过连接至微处理器的第一存储器来存储程序文件,其可以节省一片挂接至fpga的存储器,以节省成本;此外利用rtl代码进行程序文件写入至可编程逻辑器件的外部存储器(第二存储器),可以节省内部ram的使用。

附图说明

为了更清楚地说明本发明实施例的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。

图1为本发明实施例中提出的一种软核更新方法的流程示意图;

图2为本发明实施例中提出的一种软核更新系统的架构示意图;

图3为本发明实施例中elf格式文件转srec格式文件的界面图片;

图4a和图4b为本发明实施例中将srec格式文件转换为bin格式文件前对srec格式文件进行局部内容修改的界面图片;

图5a为本发明实施例中srec格式文件中的复位及中断执行代码的界面图片;

图5b为本发明实施例中已设置好复位及中断程序代码的bin格式文件的局部内容界面图片。

具体实施方式

下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。

请参见图1,其为本发明实施例提供的一种软核更新方法的流程示意图。本实施例的软核更新方法主要包括以下步骤:

s11:将第一程序文件从第一存储器读出并加载至可编程逻辑器件;

s12:与可编程逻辑器件进行握手通信,并在握手通信成功后将第二程序文件从第一存储器读出并发送给可编程逻辑器件;

s13:可编程逻辑器件的寄存器传输级代码将第二程序文件存储至第二存储器;以及

s14:可编程逻辑器件将程序运行的入口地址跳转到第二存储器中的目标地址,运行第二程序文件对应的软核代码。

更具体地,在前述软核更新方法中,第一程序文件优选为包含可编程逻辑器件的配置程序和软核引导程序(或称软核boot程序),第二程序文件优选为包含可编程逻辑器件的软核应用程序;可编程逻辑器件被加载第一程序文件后,根据所述配置程序进行配置、并在配置完成后运行软核引导程序。更进一步地,第一程序文件优选为bit格式文件且所述配置程序和所述软核引导程序位于同一个bit格式文件中;第二程序文件优选为bin格式文件,以便于发送至可编程逻辑器件中。

另外,在其他实施例中,本发明的软核更新方法在步骤s11之前还可以包括以下步骤:(a)获取初始配置程序和软核程序,其中所述软核程序包含elf格式的软核引导程序和elf格式的软核应用程序;(b)根据所述初始配置程序和所述elf格式的软核引导程序生成bit格式的第一程序文件;(c)根据所述elf格式的软核应用程序生成bin格式的第二程序文件;以及(d)将bit格式的第一程序文件和bin格式的第二程序文件从上位机发送出去。甚至,步骤(d)还可以细化为包括子步骤:(d1)将所述elf格式的软核应用程序转换成srec格式文件;(d2)对所述srec文件进行局部内容修改,以设置软核应用程序在第二存储器中的基地址,得到修改后srec格式文件;(d3)将所述修改后srec格式文件转换成bin格式文件,得到转换后bin格式文件。子步骤(d3)得到的bin格式文件可以直接作为前述第二程序文件,如果需要将reset(复位)及interrupt(中断)程序也写入第二存储器,则应进一步设置子步骤(d4):对所述转换后bin格式文件进行局部内容修改,以设置复位和中断执行代码,得到bin格式的第二程序文件作为前述第二程序文件。

为便于更清楚的理解本发明前述实施例的软核更新方法,下面列举出具体例子并结合图2所示的软核更新系统对各个前述步骤进行详细说明。

如图2所示,上位机例如pc机通过通信接口将bit格式的第一程序文件和bin格式的第二程序文件发送给微处理器,由微处理器将接收到的第一程序文件和第二程序文件存储到第一存储器中。此处的通信接口例如是网口、usb口或uart口,通信接口的使用可以实现软核的在线更新;再者,微处理器例如是mcu、arm或其他cpu,第一存储器典型地为非易失性存储器例如eeprom,第一程序文件例如包含可编程逻辑器件例如fpga的配置程序和软核引导程序且配置程序和软核引导程序优选为位于同一个bit格式文件中,第二程序文件例如包含可编程逻辑器件例如fpga的软核应用程序。本实施例是利用连接微处理器的第一存储器来存储第一及第二程序文件,因而无需像现有技术为fpga专门挂接一片eeprom存储器,从而可以节省一片存储器以降低成本。

第一程序文件和第二程序文件接收完毕之后,微处理器首先将bit格式的第一程序文件从第一存储器中读出来,通过可编程逻辑器件例如fpga加载线将第一程序文件加载至fpga中,由fpga根据第一程序文件中的配置程序进行自身配置并在配置完成后在内部ram中运行第一程序文件中的软核引导程序,此处软核引导程序的功能是等待fpga的rtl(registertransferlevel,寄存器传输级)代码将bin格式的第二程序文件写入第二存储器,而第二存储器例如是sdram、ddr2或ddr3等易失性存储器。本实施例中,由于是利用rtl代码来实现第二程序文件写入第二存储器,其相对于现有技术as更新方式下利用boot程序将eeprom中的软核应用程序文件转写至ddr3需要消耗内部ram的情形而言,可以节省内部ram的使用。

之后,微处理器与fpga进行握手通信例如通过串口与fpga进行握手通信,握手通信成功之后再将bin格式的第二程序文件从第一存储器中读出来发送给fpga,再由fpga的rtl代码将bin格式的第二程序文件存储至第二存储器中,在第二程序文件写入第二存储器之后,fpga从软核引导程序跳转到第二存储器运行第二程序文件对应的软核代码,也即将程序运行的入口地址跳转到第二存储器中的目标地址(对应第二程序文件在第二存储器中的基地址),以运行所述第二程序文件对应的软核代码,达成软核在线更新之目的。

承上述,可编程逻辑器件例如fpga的软核程序包括两个程序:软核应用程序(或称软核应用区程序)及软核boot程序。软核应用区程序是正常运行的程序,在第二存储器例如ddr3中运行;软核boot程序在内部ram中运行,功能是等待可编程逻辑器件例如fpga的rtl代码将bin格式文件写入ddr3之后,跳转到ddr3运行。再者,软核应用区程序分为reset及interrupt程序和实际运行程序,这两段程序在ddr3中不同位置。首先软核boot程序先将reset及interrupt程序入口地址向量从ddr3中读出来写入内部地址0,再将程序运行的入口地址跳转到ddr3地址中。

软核程序(包括软核boot程序和软核应用程序)在内部ram还是外部存储器运行,可以通过软件进行设置,以xilinxfpga为例,设置方法可以为打开sdk(softwaredevelopmentkit,软件开发工具包),选择软核程序所在目录,打开工程,右击工程,选择generatelinkerscript,出现对话框,再选择在内部ram还是外部运行。

此外,软核程序生成的可执行文件为elf格式文件,本实施例中的软核程序包含两个elf文件,分别是dprx.elf和boot.elf。boot.elf文件嵌入到硬件工程中,和硬件工程一起生成一个.bit文件,以得到前述包含配置程序和软核引导程序的第一程序文件;dprx.elf要想下载到可编程逻辑器件例如fpga中,要转换成.bin文件才可以。仍以xilinxfpga为例,转换步骤如下:

(1)打开由xilinxtools工具下launchshell,找到dprx.elf文件所在的目录,之后输入命令“mb-objcopy-osrecdprx.elfdprx.srec”并回车,此时已成功转换为dprx.srec文件,如图3所示;

(2)把dprx.srec复制一份,用编辑工具ultraedit把dprx.srec打开,把第2/3/4/5行(如图4a所示)删除,并把最后一行s70500000000fa(如图4b所示)改为s70590000000fa,其中90000000是软核应用程序运行的基地址,如果软核应用程序运行的基地址是80000000,那么s70500000000fa需改为s70580000000fa。之后用srectobin.exe把修改后srec格式文件dprx.srec转换为bin格式文件dprx.bin;

(3)用编辑工具ultraedit将复制的dprx.srec和转换后的bin格式文件dprx.bin打开,把srec格式dprx.srec文件中对应复位(reset)和中断(interrupt)执行代码的第1/2/3/4行拷贝出来并将这些行中的内容“s30d”及每行最后1个字节“f2”、“24”、“3b”及“3f”(如图5a所示)删除;其中00000000后的数据“009000b0000008b8”插入bin格式文件dprx.bin的00000000h位置,00000008后的数据“049000b06c5608b8”插入dprx.bin文件的00000008h位置,00000010后的数据“029000b0a00508b8”插入dprx.bin文件的00000010h位置,00000020后的数据“029000b08c0508b8”插入dprx.bin文件的00000020h位置,无效数据的位置填写00,00000030h插入00,写完之后如图5b所示,此时dprx.bin文件就是要写入第二存储器例如ddr3的第二程序文件。

值得一提的是,软核应用程序没有用到interrupt程序时,则不需要将reset及interrupt程序写入第二存储器例如ddr3中,相应地只需要将实际运行程序写入ddr3中即可,而无需进行前述步骤(3)来设置dprx.bin文件中的复位及中断程序代码,那么软核boot程序在第二程序文件写入第二存储器例如ddr3之后直接跳转到ddr3运行即可。

综上所述,本发明前述实施例提出的可编程逻辑器件例如fpga的软核更新方法及系统,通过连接至微处理器的第一存储器来存储程序文件,其可以节省一片挂接至fpga的存储器,以节省成本;此外利用rtl代码进行程序文件写入至可编程逻辑器件的外部存储器,可以节省内部ram的使用;另外,使用usb、uart或者网口等通信接口可以实现软核程序的在线更新。

在本申请所提供的几个实施例中,应该理解到,所揭露的系统,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多路单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。

作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多路网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。

另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。

上述以软件功能单元的形式实现的集成的单元,可以存储在一个计算机可读取存储介质中。上述软件功能单元存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例方法的部分步骤。而前述的存储介质包括:u盘、移动硬盘、只读存储器(read-onlymemory,简称rom)、随机存取存储器(randomaccessmemory,简称ram)、磁碟或者光盘等各种可以存储程序代码的介质。

最后应说明的是:以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1