引言
DSP具有高速的計算能力與豐富的外設接口,被廣泛應用于嵌入式系統中。很多基于DSP的嵌入式系統被配置于苛刻的環境或偏遠地區,當需要軟件升級或程序更新時,人員無法進入或很難到達相應環境中,必須采用遠程加載技術來完成升級和更新。以太網具有傳輸距離遠、傳輸速率高的優點,是遠程數據傳輸的良好載體,目前主流的DSP芯片均可擴展以太網接口。本文結合以太網技術,以TI公司的DSP芯片為例對DSP遠程加載技術進行了研究。
DSP遠程加載的核心思想包括3個方面:
① DSP能夠收發遠程控制端數據;
② DSP能夠更新存放用戶程序的Flash區域;
③ DSP能夠獲取用戶配置選擇是否需要遠程加載。
基于上述3點,本文對DSP網絡接口技術、DSP與Flash接口及驅動技術、遠程加載配置技術進行了研究。
1 遠程加載的硬件基礎
1.1 DSP以太網接口技術
(1) 通過專用接口芯片擴展以太網接口
在TI公司早期的DSP中,如C5000、C6201、C6701等系列,芯片內部沒有集成專用的以太網控制器,無法直接與以太網進行通信,必須通過DSP的EMIF(外部存儲接口)與專用接口芯片連接來擴展以太網。這些專用芯片有CP2200、MC9S12NE6等。圖1給出了TMS320C5410與CP2200的接口示意圖[1]。
圖1 TMS320C5410與CP2200的接口示意圖
(2) 通過片內專用接口擴展以太網接口
隨著DSP制造工藝的提高,很多DSP芯片內部已經集成了以太網控制器,如DM642、C6455、C6416等,只需要外接物理層芯片(如RTL8019AS、82540EM等)即可擴展以太網接口。圖2給出了DSP通過片內專用接口直接擴展以太網示意圖。
圖2 DSP通過片內專用接口直接擴展以太網示意圖
1.2 可編程Flash芯片
TI公司的高速DSP(C5000、C6000系列)均沒有片上非易失性存儲器,必須將程序保存在外部非易失性存儲器中。通常采用可編程Flash存儲器對DSP程序進行存儲和加載,常用的Flash芯片有Intel公司的E28Fxx系列和AMD公司的AM29xx系列。圖3給出了DSP與Flash的典型接口電路[2]。
圖3 DSP與Flash的典型接口電路
1.3 遠程運行模式配置
DSP在上電后,需要明確知道當前是處于程序更新模式還是處于程序正常運行模式,這就需要采用外部硬件控制電路,對DSP的加載進行配置,
圖4 遠程DSP配置加載模式電路示例
圖4給出了一種遠程DSP配置加載模式電路的示例。
用戶通過遠程配置DSP的GPIO接口為高電平或低電平來告知加載程序是否執行遠程加載,在實際應用中具體實現可由用戶自己定義。
2 遠程加載的軟件基礎
2.1 NDK簡介
在DSP上直接編寫網絡接口程序非常復雜,為了屏蔽底層細節,使用戶可以將資源重點投入到應用程序的開發中,TI公司提供了網絡開發套件NDK( Network Developer’s Kit)。NDK提供了從DSP底層驅動到TCP/IP" target="_blank">IP協議的整體解決方案,支持常規的TCP/IP服務,是實現DSP以太網擴展的重要支撐工具。圖5給出了NDK的系統結構圖[3]。
圖5 NDK系統結構圖
2.2 Flash驅動程序
Flash芯片需要專用的指令對其進行操作,主要指令包括擦除、讀、寫、復位等,根據這些操作指令就可以設計Flash驅動程序,圖6給出了C6000系列的DSP對AM29F040進行編程的流程[4]。其中EMIF_Base_Addr為DSP外部存儲接口地址;Prog_addr為目標Flash編程地址;Prog_data為目標Flash編程數據。
圖6 Flash編程流程
3 基于網絡的遠程加載方法
3.1 遠程加載流程
圖7給出了典型的DSP加載方式以及程序在Flash中的存儲方式,二次加載程序直接將用戶程序加載到DSP中,無需額外處理[5]。
圖7 典型的DSP加載方式
采用圖7中所示方式無法實現遠程加載,可以對典型加載方式進行擴展,增加網絡接口功能,更改Flash存儲方式,從而實現遠程加載。DSP遠程加載方式如圖8所示。
圖8 DSP遠程加載方式
圖8所示的遠程加載步驟如下:
① 上電后DSP運行二次加載程序;
② DSP讀取外部控制電路狀態,判斷是否處于程序更新模式;
③ 如果是更新模式,跳轉到第4步,否則跳轉到第5步;
④ DSP從Flash中加載網絡接口程序到DSP片內并運行,通過網絡接口接收遠程數據,將接收到的數據燒寫到用戶程序區域完成軟件的更新。
⑤ DSP加載Flash中用戶程序到DSP片內,正常運行程序。
為了配合遠程加載流程,需要對圖7所示的Flash存儲結構進行擴展,在圖8中同時給出了用于遠程加載的Flash存儲結構。與圖7中的典型Flash存儲結構相比,遠程加載的Flash存儲結構在二次加載程序和用戶程序之間增加了網絡加載程序,該區域僅對二次加載程序可見,用于存放遠程加載程序。當需要遠程加載時,二次加載程序就調用網絡加載程序,采用DSP遠程加載方式;當無需遠程加載時,二次加載程序直接調用用戶程序,采用典型的DSP加載方式。
在設計存儲結構時需要注意兩點:網絡加載程序是不能被改變的,必須使用固定大小的存儲區域;網絡加載程序區域應放在用戶程序區域前,便于用戶程序的擴展。
3.2 網絡加載程序設計
網絡加載程序運行流程是遠程加載的核心部分,如圖9所示。
圖9 網絡加載程序運行流程
網絡加載程序運行流程主要包括:
① 加載NDK網絡硬件驅動,配置DSP片上硬件以太網控制器,包括網絡速率、單雙工傳輸方式以及MAC地址配置等。
② 啟動TCP/IP服務。實現配置DSP的網絡IP地址、綁定TCP通信端口、開始接收遠程數據等功能。
③ 接收遠程數據。從以太網接收遠程數據并進行數據正確性和完整性校驗,將遠程數據存入到數據緩存區中,當緩存區滿后啟動Flash更新程序。
④ Flash程序更新。Flash首先擦除當前用戶區域,然后將數據緩存區中的數據燒寫到用戶區域中。
⑤ 判斷遠程數據是否接收完成,如果未完成,跳轉到步驟③;如果完成,進行步驟⑥。
⑥ 完成數據更新后,跳轉到二次加載程序,重新加載用戶程序。
需要注意的是,當網絡加載程序完成用戶程序更新后,遠程控制端必須及時將DSP加載模式切換到直接加載用戶程序模式。
結語
本文研究了基于網絡的DSP遠程加載技術,介紹了遠程加載需要的硬件基礎和軟件基礎,并給出了典型設計;然后從遠程加載流程、Flash存儲模型設計以及網絡接口流程設計三個方面研究了具體的遠程加載方法。本文提出的方法不僅能夠解決基于DSP的遠程嵌入式系統的加載問題,同時為基于其他處理器的遠程加載提供了思路,具有較好的工程價值和廣闊的應用前景。
參考文獻
[1] 左顥睿. TMS320C54x與CP2200的接口設計[J].單片機與嵌入式系統應用,2007(9).
[2] TI .TMS320C6000 EMIF to External Flash Memory[EB/OL].[201112].http://www.ti.com/lit/an/spra568a/ spra568a.pdf.
[3] TI.TMS320C6000 TCP/IP Network Developers KitUsers Guide[EB/OL].[201112].http:// www.ti.com/ lit/ug/spru523g/spru523g.pdf.
[4] AMD. Am29F040 Datasheet[EB/OL].[201112].http://www.spansion.com/Support/Datasheets/AM29F040B_EOL_21445e8.pdf.
[5] 左顥睿. C6000系列DSP Flash二次加載技術研究[J].單片機與嵌入式系統應用,2011(7).
左顥睿(工程師),主要研究領域為并行計算和嵌入式系統設計。