RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

遠(yuǎn)程升級(jí)之后程序加載的過程解析

FPGA之家 ? 來源:CSDN博客 ? 作者:CSDN博客 ? 2020-10-23 10:24 ? 次閱讀

在做在線遠(yuǎn)程升級(jí)的時(shí)候,一般需要兩步:1、將數(shù)據(jù)寫到外掛的flash中。2重新啟動(dòng)FPGA配置。 不過要做到遠(yuǎn)程升級(jí),一般需要在原始程序中就考慮到加入遠(yuǎn)程升級(jí)模塊,remote updata IP, 在升級(jí)的時(shí)候才可以啟動(dòng)遠(yuǎn)程升級(jí)功能。

遠(yuǎn)程升級(jí)之后程序加載的過程:在進(jìn)行遠(yuǎn)程升級(jí)成功以后,flash中應(yīng)該會(huì)至少存儲(chǔ)兩個(gè)程序,出廠程序和升級(jí)程序。兩個(gè)程序在不同的地址空間中(出廠程序從0X0000開始存儲(chǔ))。在FPGA上電之后,F(xiàn)PGA會(huì)加載出廠程序,出廠程序在運(yùn)行之后,檢測(cè)到remote updata IP中的一些參數(shù)(如配置鏡像參數(shù)等,remote updata IP部分會(huì)介紹到)后,將讀取flash中升級(jí)程序內(nèi)容的開始地址指向讀取地址,然后觸發(fā)重新配置(如reconfig信號(hào)有效),開始加載重新配置程序。直到無錯(cuò)誤的加載完成。也就是整個(gè)過程會(huì)加載兩次程序。

一、如何將程序?qū)懙絝lash中。

在程序運(yùn)行過程中,可以通過控制一些IP來將程序?qū)懙絝lash中,這里有兩個(gè)IP可以使用:EPCS controller, ASMI 。

1、EPCS Controller:

該IP在Qsy系統(tǒng)中,一般需要配合NIOS II來使用,需要使用者對(duì)ARM編程有一定的基礎(chǔ)。不過Altera 也提供了一些有關(guān)epcs操作的API,如讀寫,擦除等。不過在操作前會(huì)讀取一下FLASH的ID來確定是EPCS還是EPCQ,或者EPCQL,還有容量是多大的。確定好Flash的類型之后就可以調(diào)用API函數(shù)對(duì)Flash操作了。網(wǎng)上也有例程,如鋯石科技的參考例程。不過如果使用的是第三方的flash,而讀取的ID不在官方flash的ID列表之后,則就會(huì)認(rèn)為沒有flash,也就無法讀寫操作了(不敢百分百確定的,但是肯定要改程序)。所以需要操作者對(duì)ARM的操作有一定的知識(shí)。

EPCS Controller IP在cyclone IV上使用的時(shí)候是需要手動(dòng)綁定那四個(gè)pin的,在cyclone V上是不需要綁定的。

2、ASMI IP

該IP在IP庫中,Qsys中也有,可以直接用verilog進(jìn)行編程控制,網(wǎng)上也有中文文檔:ug_altasmi_parallel_CH.pdf 。該文檔會(huì)介紹如何擦除,讀寫flash等,只要時(shí)序控制好,EPCS/EPCQ/EPCQL的空間地址控制號(hào)就可以了。網(wǎng)上或官方都有參考例程,可以參考一下。

二、如何打開下載程序文件

遠(yuǎn)程燒錄,需要PC等通過串口或網(wǎng)絡(luò)將程序傳給FPGA,程序文件一般是jic/sof/rbf等格式的文件,那么一般軟件不能打開也看不到里面的內(nèi)容,可以使用UltraEdit軟件來打開這些文件,而且里面還會(huì)有一部分提示。

但是這個(gè)文件會(huì)很大,比如16MB,并不是所有的都是有效的信息,我現(xiàn)在也不知道該寫哪一些數(shù)據(jù)到flash中,以后知道了再補(bǔ)充吧。 三、remote updata IP 該IP在IP庫和Qsys中都有,可以用verilog來控制,建議使用前也要先看下他的說明書,ug_altremote.pdf,里面對(duì)寄存器有詳細(xì)的說明。

在使用過程其實(shí)是讀取寄存器或者寫寄存器的過程,最后一步reconfig信號(hào)就可以了。 網(wǎng)友給出了一個(gè)思路:read 3‘b000 (讀取reconfig的條件) --》 write 3’b101(Anf配置模式選擇:出廠or鏡像) --》 read Anf 3‘b101(確定一下) --》write 3’b011 (寫看門狗使能) --》write 3‘b010(寫看門狗溢出值) --》 write 3’b100 (寫看門狗溢出值) --》 reconfig 使能。然后就操作完成了,等待重新啟動(dòng)。
責(zé)任編輯人:CC

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴

原文標(biāo)題:?Altera FPGA 遠(yuǎn)程升級(jí)有關(guān)的幾個(gè)IP的使用

文章出處:【微信號(hào):zhuyandz,微信公眾號(hào):FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    MSP430?閃存器件引導(dǎo)加載程序(BSL)

    電子發(fā)燒友網(wǎng)站提供《MSP430?閃存器件引導(dǎo)加載程序(BSL).pdf》資料免費(fèi)下載
    發(fā)表于 11-18 14:40 ?2次下載
    MSP430?閃存器件引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>(BSL)

    MSPM0引導(dǎo)加載程序

    電子發(fā)燒友網(wǎng)站提供《MSPM0引導(dǎo)加載程序.pdf》資料免費(fèi)下載
    發(fā)表于 11-14 16:08 ?1次下載
    MSPM0引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>

    MSP430? FRAM器件引導(dǎo)加載程序(BSL)

    電子發(fā)燒友網(wǎng)站提供《MSP430? FRAM器件引導(dǎo)加載程序(BSL).pdf》資料免費(fèi)下載
    發(fā)表于 11-07 09:28 ?0次下載
    MSP430? FRAM器件引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>(BSL)

    TMS320C54CST引導(dǎo)加載程序技術(shù)參考

    電子發(fā)燒友網(wǎng)站提供《TMS320C54CST引導(dǎo)加載程序技術(shù)參考.pdf》資料免費(fèi)下載
    發(fā)表于 10-18 11:14 ?0次下載
    TMS320C54CST引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>技術(shù)參考

    使用TMS320DM643x引導(dǎo)加載程序

    電子發(fā)燒友網(wǎng)站提供《使用TMS320DM643x引導(dǎo)加載程序.pdf》資料免費(fèi)下載
    發(fā)表于 10-16 10:18 ?0次下載
    使用TMS320DM643x引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>

    使用TMS320C672x引導(dǎo)加載程序

    電子發(fā)燒友網(wǎng)站提供《使用TMS320C672x引導(dǎo)加載程序.pdf》資料免費(fèi)下載
    發(fā)表于 10-16 10:09 ?0次下載
    使用TMS320C672x引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>

    使用TMS320C6452引導(dǎo)加載程序

    電子發(fā)燒友網(wǎng)站提供《使用TMS320C6452引導(dǎo)加載程序.pdf》資料免費(fèi)下載
    發(fā)表于 10-15 13:53 ?0次下載
    使用TMS320C6452引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>

    使用AM17xx引導(dǎo)加載程序

    電子發(fā)燒友網(wǎng)站提供《使用AM17xx引導(dǎo)加載程序.pdf》資料免費(fèi)下載
    發(fā)表于 10-14 11:31 ?0次下載
    使用AM17xx引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>

    在Keystone II器件上使用Arm ROM引導(dǎo)加載程序

    電子發(fā)燒友網(wǎng)站提供《在Keystone II器件上使用Arm ROM引導(dǎo)加載程序.pdf》資料免費(fèi)下載
    發(fā)表于 09-19 12:33 ?0次下載
    在Keystone II器件上使用Arm ROM引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>

    使用AM18xx引導(dǎo)加載程序

    電子發(fā)燒友網(wǎng)站提供《使用AM18xx引導(dǎo)加載程序.pdf》資料免費(fèi)下載
    發(fā)表于 09-19 11:01 ?0次下載
    使用AM18xx引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>

    AWR294x主引導(dǎo)加載程序和輔助引導(dǎo)加載程序

    電子發(fā)燒友網(wǎng)站提供《AWR294x主引導(dǎo)加載程序和輔助引導(dǎo)加載程序.pdf》資料免費(fèi)下載
    發(fā)表于 09-06 09:47 ?0次下載
    AWR294x主引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>和輔助引導(dǎo)<b class='flag-5'>加載</b><b class='flag-5'>程序</b>

    linux驅(qū)動(dòng)程序如何加載進(jìn)內(nèi)核

    ,需要了解Linux內(nèi)核的基本概念和API。以下是一些關(guān)鍵概念: 1.1 內(nèi)核模塊:Linux內(nèi)核模塊是一種動(dòng)態(tài)加載和卸載的代碼,可以在不重新啟動(dòng)系統(tǒng)的情況下加載和卸載。驅(qū)動(dòng)程序通常以內(nèi)核模塊的形式實(shí)現(xiàn)。 1.2 設(shè)備模型:Li
    的頭像 發(fā)表于 08-30 15:02 ?439次閱讀

    labview CAN DBC加載解析程序

    labview CAN DBC加載解析程序
    發(fā)表于 08-18 11:42

    在增強(qiáng)模式下引導(dǎo)加載程序時(shí),OTA升級(jí)失敗了,為什么?

    userbin number!n\"); return; } ...然后獲取文件并執(zhí)行升級(jí)... 此外,我沒有找到一種方法來退出增強(qiáng)模式以正常運(yùn)行引導(dǎo)加載程序,即使在再次刷新固件和引導(dǎo)
    發(fā)表于 07-18 07:12

    通過物通博聯(lián)PLC遠(yuǎn)程調(diào)試網(wǎng)關(guān)實(shí)現(xiàn)PLC遠(yuǎn)程升級(jí)程序

    遠(yuǎn)程調(diào)試網(wǎng)關(guān),實(shí)現(xiàn)了PLC遠(yuǎn)程升級(jí)程序的功能,提高了生產(chǎn)效率,降低了運(yùn)營(yíng)成本,并使PLC的升級(jí)和維護(hù)更加便捷。 物通博聯(lián)PLC
    的頭像 發(fā)表于 03-09 17:19 ?533次閱讀
    通過物通博聯(lián)PLC<b class='flag-5'>遠(yuǎn)程</b>調(diào)試網(wǎng)關(guān)實(shí)現(xiàn)PLC<b class='flag-5'>遠(yuǎn)程</b><b class='flag-5'>升級(jí)</b><b class='flag-5'>程序</b>
    RM新时代网站-首页