www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式教程
[導(dǎo)讀]基于CPLD譯碼的DSP二次Bootloader方法

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

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

  如圖1所示,5509A的地址線(xiàn)A[13:1]與Flash的地址線(xiàn)A[12:0],A0未用。Flash存儲(chǔ)器被映射到DSP的CE1空間,由片選線(xiàn)CE1經(jīng)CPLD譯碼后選通。其中DSP的地址線(xiàn)A13和A[3:1]與CPLD接口,用于換頁(yè)寄存器FPR的模擬。Flash存儲(chǔ)器的BYTE引腳經(jīng)上拉后接高電平,即按16位方式訪(fǎng)問(wèn)。
2.2 CPLD譯碼VHDL程序設(shè)計(jì)
  目前DSP系統(tǒng)主頻越來(lái)越高,運(yùn)算速度越來(lái)越快,利用小規(guī)模邏輯器件譯碼的方式已不能滿(mǎn)足DSP系統(tǒng)性能的需求。CPLD器件以其嚴(yán)格的時(shí)序、快速的譯碼、良好的可編程性成為DSP系統(tǒng)必不可少的部件之一。
  本文利用CPLD的快速邏輯譯碼功能,模擬了一個(gè)FPR寄存器來(lái)控制Flash的高位地址線(xiàn)。VHDL語(yǔ)言源程序如下(篇幅有限,這里省略實(shí)體端口聲明及中間信號(hào)定義):
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]地址線(xiàn)的目的是為了便于以后的功能擴(kuò)展,映射出更多的寄存器,如LCD控制寄存器、UART控制寄存器等。[!--empirenews.page--]
  FPR寄存器定義如表2所示。


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

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

摘要:主要介紹了應(yīng)用DSP的電能質(zhì)量檢測(cè)系統(tǒng)的硬件電路及軟件開(kāi)發(fā)工具,對(duì)采集來(lái)的某電鐵電流信號(hào)進(jìn)行了電能質(zhì)量檢測(cè),并開(kāi)展了實(shí)際實(shí)驗(yàn)嘗試。實(shí)驗(yàn)結(jié)果顯示,實(shí)際信號(hào)含有大量諧波,但通過(guò)應(yīng)用DSP的電能質(zhì)量檢測(cè)系統(tǒng)成功檢測(cè)到了它...

關(guān)鍵字: 電能質(zhì)量檢測(cè) Matlab仿真 DSP

隨著生活水平的提高,大家都想從生活壓力中釋放出來(lái),越來(lái)越多的人向往戶(hù)外運(yùn)動(dòng)、露營(yíng)等,在大自然的擁抱中釋放壓力,解放自我,從而成為戶(hù)外旅行火熱的原因之一。因此,很多音箱廠商都開(kāi)始推出針對(duì)戶(hù)外的戶(hù)外藍(lán)牙音箱。但是市面上的藍(lán)牙...

關(guān)鍵字: PD快充 I2S DSP IC

摘要:基于DSP和CPLD設(shè)計(jì)了CAN一1553B網(wǎng)關(guān),選擇了1553B總線(xiàn)作為電機(jī)控制系統(tǒng)的主總線(xiàn),其主要用于操作系統(tǒng)與子控制系統(tǒng)之間的通信。為了更好地完成各節(jié)點(diǎn)之間的通信,采用CAN總線(xiàn)作為子系統(tǒng)總線(xiàn),構(gòu)建基于CAN...

關(guān)鍵字: 電機(jī)控制網(wǎng)絡(luò) 1553B總線(xiàn) CPLD

摘要:數(shù)字信號(hào)處理器(DSP,digitalSignalproceSSor)是專(zhuān)門(mén)用于某些數(shù)字信號(hào)處理任務(wù)的微處理器,一般由集成電路芯片構(gòu)成。當(dāng)前,水聲領(lǐng)域中聲吶探測(cè)設(shè)備正逐漸向大運(yùn)算量、強(qiáng)實(shí)時(shí)性及小型化等方向發(fā)展,對(duì)高...

關(guān)鍵字: 水聲信號(hào)處理 DSP 聲吶

DSP開(kāi)發(fā)板,就是圍繞DSP的功能進(jìn)行研發(fā),推出用于DSP芯片開(kāi)發(fā)的線(xiàn)路板,并提供原理圖和源代碼給客戶(hù)。DSP尤以TI公司的DSP市場(chǎng)占有率最大。

關(guān)鍵字: DSP 開(kāi)發(fā)板

在這篇文章中,小編將為大家?guī)?lái)無(wú)線(xiàn)模塊的相關(guān)報(bào)道。如果你對(duì)本文即將要講解的內(nèi)容存在一定興趣,不妨繼續(xù)往下閱讀哦。

關(guān)鍵字: 無(wú)線(xiàn)模塊 自動(dòng)化 DSP

當(dāng)你在大疆無(wú)人機(jī)上拍照,跟蹤或者自主飛行時(shí),背后有一堆高性能處理器在為這些應(yīng)用加速,其中就有DSP(Digital Signal Processor)。DSP的軟硬件解決方案為圖像,機(jī)器學(xué)習(xí)和飛行控制業(yè)務(wù)提供高性能計(jì)算平...

關(guān)鍵字: 嵌入式 DSP 大疆

(全球TMT2022年5月26日訊)Yahoo和全球領(lǐng)先的獨(dú)立程序化戶(hù)外 (DOOH) 廣告技術(shù)公司Hivestack巢仕達(dá)宣布建立全球戰(zhàn)略合作伙伴關(guān)系,致力于連接雙方行業(yè)領(lǐng)先的技術(shù),并為全球范圍內(nèi)的優(yōu)質(zhì)程序...

關(guān)鍵字: STACK BSP DSP MT

華為開(kāi)源云原生AI衛(wèi)星應(yīng)用方案亮相KubeCon EU 2022 瓦倫西亞2022年5月20日 /美通社/ -- 5月18日,在云原生領(lǐng)域備受矚目的會(huì)議——KubeCon和CloudNativeCon歐洲峰會(huì)主論壇中,...

關(guān)鍵字: DSP 華為 衛(wèi)星 開(kāi)源

(全球TMT2022年5月16日訊)日前,國(guó)際權(quán)威研究機(jī)構(gòu)Gartner發(fā)布《市場(chǎng)份額分析:2021年全球軟件行業(yè)市場(chǎng)規(guī)模報(bào)告》,報(bào)告顯示浪潮云海服務(wù)器虛擬化軟件InCloud Sphere(以下簡(jiǎn)稱(chēng)InCloud S...

關(guān)鍵字: DSP 虛擬化 軟件 AI

嵌入式教程

6897 篇文章

關(guān)注

發(fā)布文章

編輯精選

技術(shù)子站

關(guān)閉