當(dāng)前位置:首頁 > 電源 > 數(shù)字電源
[導(dǎo)讀]隨著數(shù)字信號處理技術(shù)的快速發(fā)展,數(shù)字信號處理器(DSP)越來越廣泛地應(yīng)用于各種實時嵌入式系統(tǒng)中。當(dāng)系統(tǒng)調(diào)試完畢,想脫離仿真環(huán)境并在上電復(fù)位后自動啟動程序代碼運行時,必須將程序代碼存儲在非易失性存儲器中。Fla

隨著數(shù)字信號處理技術(shù)的快速發(fā)展,數(shù)字信號處理器(DSP)越來越廣泛地應(yīng)用于各種實時嵌入式系統(tǒng)中。當(dāng)系統(tǒng)調(diào)試完畢,想脫離仿真環(huán)境并在上電復(fù)位后自動啟動程序代碼運行時,必須將程序代碼存儲在非易失性存儲器中。Flash存儲器以其大容量和可在線編程等特點已成為DSP系統(tǒng)的一個基本配置。在系統(tǒng)上電復(fù)位后,DSP芯片內(nèi)部固化的引導(dǎo)裝載器(Bootloader)把應(yīng)用程序從Flash引導(dǎo)到DSP芯片內(nèi)高速 RAM中執(zhí)行。這樣既利用了外部存儲器擴展DSP有限的ROM資源,又可以充分保證用戶程序的全速運行[1-2]。
  本文采用德州儀器公司的16位定點DSP芯片TMS320VC5509A(以下簡稱5509A),其PGE封裝形式只有14根地址總線(A0~A13),最大只能尋址16KB的Flash存儲器[3]。若要尋址更大地址空間,就需要控制Flash存儲器的高位地址線。常見的解決方案是采用DSP的通用輸入輸出GPIO(General Purpose Input/Output)引腳來控制Flash的高位地址線,從而實現(xiàn)Flash存儲器的分頁訪問[5-6]。然而,對于較大容量的Flash存儲器,如本文采用的Am29LV800的容量為512K×16bit,有19根地址線[4],如果采用上述方法,硬件連接雖然簡單,但會占用較多的GPIO引腳,而且以后的系統(tǒng)擴展也不方便。本文介紹了一種基于CPLD快速譯碼的DSP二次引導(dǎo)方法,利用CPLD的時序嚴(yán)格、譯碼速度快、可在線編程等特點,在 DSP的外部存儲器接口EMIF(Exteral Memory Interface)的CE2空間模擬了一個Flash換頁寄存器FPR(Flash Page Register),在上電復(fù)位后控制Flash的高位地址線,從而實現(xiàn)Flash的分頁訪問。因此,可通過二次bootloader程序修改FPR的值,控制Flash的高位地址線,將最終的應(yīng)用程序加載到RAM中運行。
1 TMS320VC5509A的并行引導(dǎo)模式
1.1 5509A的引導(dǎo)模式
  5509A的引導(dǎo)模式選擇是通過4個模式選擇引腳BOOTM[3:0]來配置的,BOOTM3~0引腳分別與GPIO0、3、2、1相連。5509A提供了六種引導(dǎo)模式,即EHPI引導(dǎo)模式、8位/16位并行EMIF引導(dǎo)模式、8位/16位標(biāo)準(zhǔn)串行口引導(dǎo)模式、SPI EEPROM引導(dǎo)模式、USB引導(dǎo)模式以及I2C E2PROM引導(dǎo)模式。本文采用16位并行EMIF引導(dǎo)模式,將BOOTM[3:0]設(shè)置為1011即可。
  在16位并行EMIF引導(dǎo)模式下,DSP芯片內(nèi)部固化的Bootloader程序上電復(fù)位后,首先從CE1空間首地址0x200000h處開始讀取程序代碼,并加載到RAM中運行。
1.2 5509A的引導(dǎo)表格式
  程序代碼以引導(dǎo)表的格式存儲在Flash存儲器中。引導(dǎo)表是獨立于所選引導(dǎo)模式的一種特定的格式,包含了用戶程序的代碼段、數(shù)據(jù)段、段在RAM中的目標(biāo)地址以及程序入口地址等其他相關(guān)信息。5509A引導(dǎo)表結(jié)構(gòu)如表1所示。

 
  DSP芯片內(nèi)部固化的Bootloader的主要功能是將Flash中存儲的引導(dǎo)表按一定順序加載到 RAM中,然后跳轉(zhuǎn)到32位程序入口地址開始執(zhí)行。引導(dǎo)表文件可以通過TI公司提供的16進制轉(zhuǎn)換工具生成,一般是hex格式,然后將此hex文件燒寫到 Flash存儲器中供Bootloader加載。
2 DSP二次Bootloader的原理及實現(xiàn)
  由上述分析可知,DSP用戶程序的并行加載過程是由DSP內(nèi)固化的Bootloader實現(xiàn)的。由于5509A的PGE封裝只有14根地址線,最多只能訪問到16K×16bit地址空間。對于超過16KB的用戶代碼,Bootloader將不能加載全部的引導(dǎo)表文件。因此若要加載超過16K的用戶代碼,必須進行二次Bootloader。[!--empirenews.page--]
  二次Bootloader的原理是由用戶自行編寫一個代碼長度小于16KB的引導(dǎo)程序(以下簡稱 uboot),其功能與DSP內(nèi)固化的Bootloader相同,用于加載最終的用戶代碼。在uboot程序中控制Flash存儲器的高位地址線來訪問 Flash的其他存儲內(nèi)容。這樣,DSP上電復(fù)位后,Bootloader首先加載uboot并運行,然后uboot又加載最終用戶代碼,實現(xiàn)了大于 16K代碼的二次引導(dǎo)。
2.1 DSP與Flash及CPLD的硬件接口
  本文采用AMD的 Am29LV800作為DSP的外部存儲器擴展。Am29LV800按8位方式訪問,容量為1M字;按16位方式訪問,容量為512K字。DSP外圍電路邏輯譯碼及Flash高位地址線模擬由CPLD實現(xiàn)。Xilinx公司的XC9572XL是一款高性能的CPLD芯片,最高主頻可達178MHz,包含了 72個宏單元,1 600個可用門電路,其TQFP封裝有72個可用I/O引腳[7]。圖1是5509A與CPLD及Flash之間的硬件接口設(shè)計原理圖。

  如圖1所示,5509A的地址線A[13:1]與Flash的地址線A[12:0],A0未用。Flash存儲器被映射到DSP的CE1空間,由片選線CE1經(jīng)CPLD譯碼后選通。其中DSP的地址線A13和A[3:1]與CPLD接口,用于換頁寄存器FPR的模擬。Flash存儲器的BYTE引腳經(jīng)上拉后接高電平,即按16位方式訪問。
2.2 CPLD譯碼VHDL程序設(shè)計
  目前DSP系統(tǒng)主頻越來越高,運算速度越來越快,利用小規(guī)模邏輯器件譯碼的方式已不能滿足DSP系統(tǒng)性能的需求。CPLD器件以其嚴(yán)格的時序、快速的譯碼、良好的可編程性成為DSP系統(tǒng)必不可少的部件之一。
  本文利用CPLD的快速邏輯譯碼功能,模擬了一個FPR寄存器來控制Flash的高位地址線。VHDL語言源程序如下(篇幅有限,這里省略實體端口聲明及中間信號定義):
begin
  fce  <=ce1;
  foe  <=aoe;
  fwe  <=awe;
  h_addr <=a13;
  l_addr <=a3&a2&a1;
  datain <=d5&d4&d3&d2&d1&d0;
  facs  <=′1′ when h_addr=′1′
      and ce2=′0′ and l_addr='000'
     else ′0′;  --CE2 0x400000
  FPR:process(facs,awe,reset)
  begin
   if reset=′0′ then
      fa<=″000000″;
    else if reset=′1′ then
      if awe′event and awe=′1′ then
          if facs=′1′ then
                  fa<=datain(5 downto 0);
                  end if;
         end if;
  end if;
end process;
dataout<=fa  when aoe=′0′ and facs=′1′
         else ″ZZZZZZ″;
  d5   <=dataout(5);
  d4   <=dataout(4);
  d3   <=dataout(3);
  d2   <=dataout(2);
  d1   <=dataout(1);
  d0   <=dataout(0);
  fa18   <=fa(18);
  fa17   <=fa(17);
  fa16   <=fa(16);
  fa15   <=fa(15);
  fa14   <=fa(14);
  fa13   <=fa(13);
end  behaviour;
  由上述VHDL程序可知,F(xiàn)PR寄存器被映射到了CE2空間的0x401000地址。其中引入A13及A[3:1]地址線的目的是為了便于以后的功能擴展,映射出更多的寄存器,如LCD控制寄存器、UART控制寄存器等。[!--empirenews.page--]
  FPR寄存器定義如表2所示。


  FPR寄存器的第5~0位分別控制Flash的高位地址線A18~A13,第7~6位無效。當(dāng)DSP 上電復(fù)位時,F(xiàn)PR寄存器的值被設(shè)置為全0,此時Flash的所有高位地址線均處于低電平狀態(tài),DSP開始訪問Flash的最低8KB地址單元。復(fù)位結(jié)束,就可以對FPR寄存器寫入值,改變Flash的高位地址,從而實現(xiàn)Flash的分頁訪問。這樣Am29LV800 Flash的512K字存儲空間相當(dāng)于被劃分為64頁(0~63),每頁8K字,當(dāng)程序大于一頁時,修改FPR,進行軟件翻頁,讀入下一頁Flash數(shù)據(jù)。也可以通過讀FPR寄存器,了解當(dāng)前高位地址線的狀態(tài),此時FPR寄存器與Flash的地址映射關(guān)系為:
  Flash地址單元=(FPR<<13)+DSP地址線A[13:1]
2.3 二次Bootloader的實現(xiàn)
  基于上述的設(shè)計和分析,要實現(xiàn)大程序的自動引導(dǎo),可以采用二次Bootloader的方法。首先要設(shè)計一個uboot程序,大小不能超過一頁。將 uboot程序燒寫到Flash存儲器的第0頁,也就是DSP上電復(fù)位后被固化的Bootloader自行引導(dǎo)的那一頁。uboot的主要功能是通過修改 FPR寄存器值,并按照引導(dǎo)表的格式讀取Flash存儲器的其他頁程序到RAM中,最后跳轉(zhuǎn)到用戶程序的32位入口地址開始執(zhí)行。uboot程序中,可以定義一個16位無符號整型指針變量,指向CE2空間的0x401000地址,即:
  unsigned int*FPR=(unsigned int*) 0x401000;
  若*FPR=1,即可以訪問Flash的第1頁。
    在編寫uboot程序和用戶程序時,要對存儲器空間重新分配,即在定義CMD文件時,要注意用戶程序所占用的存儲空間不能與uboot程序占用的存儲空間重疊。因為uboot首先被加載運行,在運行時加載用戶程序,也需要占用RAM地址空間。而且uboot程序代碼長度不能超過一頁。當(dāng)燒寫Flash時,必須將uboot程序燒寫到Flash的第0頁,然后將用戶程序燒寫到第一頁或以后的存儲空間中。
3 實驗結(jié)果
    以煤礦井下煤矸分界傳感器為例,測試本文介紹的基于CPLD譯碼的DSP二次Bootloader方法。該傳感器采集放煤時煤矸石振動信號,經(jīng)AD轉(zhuǎn)換后送入DSP經(jīng)數(shù)字信號處理,分析得出煤矸石放落比例[8]。用戶程序代碼大小為23K字左右,顯然不能夠被固化的Bootloader正常加載,因此必須經(jīng)過二次Bootloader。
  將大小約2K字的uboot程序燒寫到Flash第0頁,用戶燒寫到第1~3頁。經(jīng)多次測試,該系統(tǒng)從上電復(fù)位到開始運行用戶程序,耗時大約0.3s,而且系統(tǒng)運行穩(wěn)定可靠。
  本文介紹的基于CPLD快速譯碼的DSP二次Bootloader方法,利用CPLD器件的快速譯碼功能,模擬了一個換頁寄存器,實現(xiàn)了大程序的上電后二次引導(dǎo)。與常見的利用GPIO換頁的方法相比,本方法更有效,通用性更好,不會占用寶貴的GPIO資源,而且系統(tǒng)擴展方便,接口簡單。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉