《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于CPLD譯碼的DSP二次Bootloader方法
基于CPLD譯碼的DSP二次Bootloader方法
劉 偉1,閆玉華2
摘要: 以實際項目開發為背景,介紹了一種基于CPLD譯碼的TI TMS320VC55x系列DSP大程序的二次引導方法。闡述了DSP與CPLD以及Flash存儲器之間的硬件接口電路設計及二次Bootloader方法的實現,給出了CPLD譯碼的VHDL代碼。實驗證明,利用CPLD的快速譯碼實現的DSP二次Bootloader方法,接口簡單、編程方便、有較強的通用性和可靠性。
關鍵詞: PSoC DSP CPLD TMS320VC55x
Abstract:
Key words :

  摘 要: 以實際項目開發為背景,介紹了一種基于CPLD譯碼的TI TMS320VC55x系列DSP大程序的二次引導方法。闡述了DSP與CPLD以及Flash存儲器之間的硬件接口電路設計及二次Bootloader方法的實現,給出了CPLD譯碼的VHDL代碼。實驗證明,利用CPLD的快速譯碼實現的DSP二次Bootloader方法,接口簡單、編程方便、有較強的通用性和可靠性。


  關鍵詞: CPLD譯碼;DSP;二次Bootloader;Flash存儲器

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

 


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

  如圖1所示,5509A的地址線A[13:1]與Flash的地址線A[12:0],A0未用。Flash存儲器被映射到DSP的CE1空間,由片選線CE1經CPLD譯碼后選通。其中DSP的地址線A13和A[3:1]與CPLD接口,用于換頁寄存器FPR的模擬。Flash存儲器的BYTE引腳經上拉后接高電平,即按16位方式訪問。
2.2 CPLD譯碼VHDL程序設計
  目前DSP系統主頻越來越高,運算速度越來越快,利用小規模邏輯器件譯碼的方式已不能滿足DSP系統性能的需求。CPLD器件以其嚴格的時序、快速的譯碼、良好的可編程性成為DSP系統必不可少的部件之一。
  本文利用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程序可知,FPR寄存器被映射到了CE2空間的0x401000地址。其中引入A13及A[3:1]地址線的目的是為了便于以后的功能擴展,映射出更多的寄存器,如LCD控制寄存器、UART控制寄存器等。
  FPR寄存器定義如表2所示。


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

參考文獻
[1] 張小波,廖新征.基于DSP的低功耗高速采集系統.電子技術應用[J],2004(12).
[2] TI Datasheet:Using the TMS320VC5509/C5509A Bootloader. 2003(9).
[3] TI Datasheet:TMS320VC5509A Fixed-Point Digital Signal Processor.2004(1).
[4] AMD Datasheet:AM29LV800T/800B.1997(11).

[5] 呂曉明.TMS320VC55x系列DSP的Flash引導方法研究[J].國外電子元器件[J],2007,19(6):23-26.
[6] 鄧罡,文聰.TI C5500系列DSP EMIF的二次引導方法[J].單片機與嵌入式系統應用[J],2006,21(4):64-66.
[7] Xilinx Datasheet:XC9572XL High Performance CPLD.2000(8).
[8] 張守祥,劉偉.綜采工作面煤矸頻譜特征[J].煤炭學報,2007,32(9).
 

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          洋洋av久久久久久久一区| 国产一区二区三区四区| 欧美日韩午夜在线| 国产欧美日韩精品a在线观看| 91久久在线播放| 欧美不卡激情三级在线观看| 欧美日本三区| 欧美国产精品专区| 欧美日韩美女一区二区| 午夜日韩在线观看| 一区二区三区视频观看| 欧美日韩1区2区| 在线观看成人网| 国产欧美日韩三级| 国产精品一区二区视频| 欧美国产激情| 久久久噜噜噜久久狠狠50岁| 久久久噜久噜久久综合| 亚洲第一黄网| 欧美午夜国产| 久久国内精品自在自线400部| 久久久精品国产一区二区三区| 欧美丝袜一区二区三区| 欧美一区二区网站| 在线视频欧美一区| 亚洲人成人77777线观看| 亚洲一区二区三区在线播放| 欧美日韩中文在线| 亚洲精品国久久99热| 久久久精品国产一区二区三区| 久久性色av| 亚洲精品在线视频| 国产日韩欧美一区在线| 99国内精品久久久久久久软件| 久久嫩草精品久久久久| 久久久久久伊人| 欧美精品久久一区二区| 免费观看国产成人| 在线中文字幕不卡| 一本色道久久综合精品竹菊| 在线播放亚洲| 欧美日韩精品一区二区三区| 亚洲午夜久久久| 亚洲美女一区| 欧美成人中文字幕在线| 一区二区三区产品免费精品久久75| 一区二区三区欧美在线观看| 亚洲乱码日产精品bd| 久久婷婷麻豆| 欧美亚洲一区在线| 欧美午夜片在线免费观看| 国产啪精品视频| 亚洲影院在线| 欧美有码视频| 一本色道久久综合狠狠躁的推荐| 国产精品一区二区三区成人| 亚洲美女免费视频| 亚洲美女诱惑| 国模 一区 二区 三区| 裸体歌舞表演一区二区| 久久爱www| 国产精品免费一区二区三区在线观看| 欧美在线首页| 久久漫画官网| 国产精品久久久久毛片大屁完整版| 一区二区高清在线观看| 亚洲国产一区二区三区青草影视| 久久久亚洲成人| 欧美日韩久久精品| 国产精品久久久久7777婷婷| 黑人巨大精品欧美一区二区| 亚洲视频在线一区观看| 精品粉嫩aⅴ一区二区三区四区| 欧美日韩一区二区三区| 欧美日韩在线视频一区二区| 国产精品香蕉在线观看| 亚洲毛片在线免费观看| 久久天天躁狠狠躁夜夜爽蜜月| 国产免费观看久久| 一色屋精品视频在线观看网站| 一本色道久久88综合亚洲精品ⅰ| 99re6这里只有精品视频在线观看| 亚洲精品一区二区三区婷婷月| 在线免费观看一区二区三区| 女生裸体视频一区二区三区| 亚洲人久久久| 免费欧美电影| 亚洲一区三区在线观看| 尤妮丝一区二区裸体视频| 欧美国产一区二区三区激情无套| 日韩亚洲视频| 亚洲欧美成人一区二区三区| 亚洲激情综合| 日韩一区二区福利| 国产伦精品一区二区三区视频黑人| 欧美日韩精品免费观看视一区二区| 一区二区三区我不卡| 国产在线拍揄自揄视频不卡99| 亚洲精品一区二区在线观看| 免播放器亚洲一区| 亚洲一区在线观看免费观看电影高清| 韩国免费一区| 国产欧美一区二区三区在线老狼| 欧美亚洲免费| 一区二区激情视频| 亚洲精品乱码久久久久久黑人| 韩国三级电影久久久久久| 国产精品嫩草影院一区二区| 欧美日韩精品二区第二页| 欧美成人午夜免费视在线看片| 亚洲国产裸拍裸体视频在线观看乱了| 久久国产色av| 久久精彩视频| 国产日产欧美a一级在线| 国产精品久久久久久亚洲毛片| 欧美日韩精品一本二本三本| 国产啪精品视频| 国产精品亚洲综合色区韩国| 久久精品一区二区三区不卡| 日韩午夜视频在线观看| 欧美精品一区二区三区蜜桃| 亚洲电影免费观看高清完整版在线观看| 国外精品视频| 国产欧美精品日韩精品| 免费欧美在线| 这里是久久伊人| 最新日韩在线| 久久免费一区| 99视频一区二区| 久久婷婷国产综合尤物精品| 欧美特黄一级| 国产一区在线视频| 久久亚洲精品中文字幕冲田杏梨| 在线视频亚洲一区| 国产综合欧美在线看| 亚洲高清一二三区| 99视频国产精品免费观看| 国产日韩在线看| 久久手机免费观看| 伊大人香蕉综合8在线视| 亚洲六月丁香色婷婷综合久久| 欧美.com| 亚洲欧美日韩精品| 欧美精品一卡二卡| 国产区在线观看成人精品| 欧美激情一区二区三级高清视频| 欧美日韩在线播放一区二区| 鲁大师成人一区二区三区| 国产精品久久久久久五月尺| 欧美婷婷六月丁香综合色| 国产亚洲精久久久久久| 国产精品国产三级国产普通话蜜臀| 欧美在线视频一区二区| 国产精品视频99| 国产女主播一区二区| 欧美激情视频一区二区三区不卡| 一区二区三区高清视频在线观看| 欧美日韩亚洲视频一区| 欧美日韩一级视频| 一本大道久久a久久综合婷婷| 国产精品男女猛烈高潮激情| 含羞草久久爱69一区| 国产区精品视频| 亚洲欧美激情一区二区| 国产精品久久久一区麻豆最新章节| 亚洲综合成人婷婷小说| 亚洲人成网站精品片在线观看| 欧美黄免费看| 欧美激情2020午夜免费观看| 国产综合18久久久久久| 亚洲欧洲精品一区二区三区不卡| 欧美日韩在线精品一区二区三区| 母乳一区在线观看| 免费久久久一本精品久久区| 欧美激情中文不卡| 国产精品黄色在线观看| 国内精品一区二区| 欧美日韩激情小视频| 久久亚洲国产成人| 国产精品igao视频网网址不卡日韩| 国产精品入口福利| 国产亚洲一级| 老司机亚洲精品| 久久亚洲春色中文字幕久久久| 国产日韩亚洲欧美综合| 亚洲欧洲一区二区在线观看| 一本色道久久综合亚洲精品婷婷| 模特精品在线| 国产日韩欧美另类| 欧美黄色一区二区| 欧美色精品天天在线观看视频| 国产一区二区三区久久| 激情文学综合丁香| 亚洲欧美国产va在线影院| 黄色精品在线看| 国产精品国产三级国产专区53| 新片速递亚洲合集欧美合集| 国产精品毛片a∨一区二区三区|国| 欧美怡红院视频一区二区三区| 久久青草福利网站| 亚洲区一区二| 中文亚洲欧美| 国产日韩在线亚洲字幕中文| 亚洲欧美日韩一区在线观看| 国产精品xnxxcom| 国产欧美日韩在线观看| 亚洲图中文字幕| 亚洲制服少妇| 亚洲欧美色一区| 欧美chengren| 欧美伊久线香蕉线新在线| 在线视频欧美精品| 国产精品久久久久99| 国产欧美日韩精品在线| 亚洲欧美日韩电影| 欧美日韩dvd在线观看| 欧美精品99| 欧美日本一区| 国产精品成人免费视频| 一区二区视频免费完整版观看| 亚洲国产一区二区在线| 亚洲欧美影音先锋| 红桃视频国产精品| 国产伦精品一区二区三区| 91久久精品www人人做人人爽| 91久久久在线| 欧美日韩视频专区在线播放| 亚洲在线观看免费视频| 国产伦精品一区二区三区高清| 国产精品午夜在线| 久久综合国产精品台湾中文娱乐网| 欧美激情按摩在线| 黄色成人av网站| 激情欧美一区二区三区在线观看| 久久久在线视频| 亚洲一区二区免费| 亚洲欧美制服中文字幕| 噜噜噜91成人网| 国产欧美日韩在线视频| 国产精品久久久久99| 欧美日韩一区二区三区| 亚洲精品免费一二三区| 欧美另类在线观看| 一区精品久久| 久久综合色综合88| 国产精品久久精品日日| 国产精品视频观看| 老色鬼精品视频在线观看播放| 国产精品亚洲不卡a| 久久精品理论片| 1000精品久久久久久久久| 在线观看视频一区| 国产精品福利在线| 久久精品一区二区| 亚洲视频第一页| 国产精品色在线| 久久激情五月婷婷| 性xx色xx综合久久久xx| 欧美欧美天天天天操| 欧美在线黄色| 在线播放国产一区中文字幕剧情欧美| 在线 亚洲欧美在线综合一区| 午夜在线不卡| 最新国产の精品合集bt伙计| 一区二区三区日韩精品视频| 欧美成人国产va精品日本一级| 欧美日韩在线视频首页| 久久国产精品久久久久久| 亚洲国产婷婷香蕉久久久久久| 亚洲免费av电影| 亚洲一二三区视频在线观看| 亚洲综合电影一区二区三区| 99re6热在线精品视频播放速度| 久久久久一区二区| 国产精品日韩精品欧美精品| 免费中文字幕日韩欧美| 久久九九全国免费精品观看| 狠狠久久婷婷| 一区二区三区你懂的| 日韩亚洲欧美成人一区| 精品999在线播放| 国产精品夜夜嗨| 一本色道久久综合狠狠躁篇的优点| 亚洲欧美久久| 136国产福利精品导航网址应用| 午夜精彩视频在线观看不卡| 亚洲综合999| 欧美aaaaaaaa牛牛影院| 91久久久久久久久久久久久| 欧美激情乱人伦| 国产精品成人观看视频免费| 国产精品亚洲а∨天堂免在线| 99精品热视频只有精品10| 亚洲网站在线| 在线观看91久久久久久| 亚洲国产欧美不卡在线观看| 国产亚洲成年网址在线观看| 亚洲国产mv| 国产欧美日韩亚洲精品| 国产精品天天摸av网| 久久久免费观看视频| 亚洲女与黑人做爰| 国产精品综合视频| 91久久久久久久久久久久久| 亚洲精品一品区二品区三品区| 久久亚洲影音av资源网| 亚洲精品中文字幕有码专区| 99精品国产在热久久婷婷| 欧美一区二区在线| 欧美承认网站| 久久影视三级福利片| 国产精品狼人久久影院观看方式| 91久久精品www人人做人人爽| 国产主播精品| 欧美日韩国产三区| 国产麻豆日韩| 西瓜成人精品人成网站| 亚洲欧洲日本mm| 欧美色网在线| 日韩一区二区精品在线观看| 欧美日韩激情小视频| 国产精品丝袜久久久久久app| 欧美怡红院视频| 亚洲精品视频一区二区三区| 欧美高清在线一区二区| 亚洲天堂网站在线观看视频| 在线天堂一区av电影| 国产午夜精品久久久|