《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于CAN總線的DSP芯片程序受控加載設計實現
基于CAN總線的DSP芯片程序受控加載設計實現
摘要: 本文研究的這項技術提供了一種簡單易行?成本低廉的DSP程序加載方法?這項技術具有高度的可靠性?靈活性和實用性?此項技術用于磁懸浮列車這樣一個復雜的DCS系統(tǒng)后,能夠很好地控制列車上眾多基于DSP芯片的系統(tǒng)的程序加載,并方便地對它們進行調試,使這些系統(tǒng)能根據不同的需要執(zhí)行不同的程序,取得了很好的效果?目前上海引進的磁懸浮列車也采用了此項在線調試技術?
關鍵詞: DSP CAN總線
Abstract:
Key words :

  CAN總線概念

  CAN 是Controller Area Network 的縮寫(以下稱為CAN),是ISO國際標準化的串行通信協議。在當前的汽車產業(yè)中,出于對安全性、舒適性、方便性、低公害、低成本的要求,各種各樣的電子控制系統(tǒng)被開發(fā)了出來。由于這些系統(tǒng)之間通信所用的數據類型及對可靠性的要求不盡相同,由多條總線構成的情況很多,線束的數量也隨之增加。為適應“減少線束的數量”、“通過多個LAN,進行大量數據的高速通信”的需要,1986 年德國電氣商博世公司開發(fā)出面向汽車的CAN 通信協議。此后,CAN 通過ISO11898 及ISO11519 進行了標準化,現在在歐洲已是汽車網絡的標準協議。   現在,CAN 的高性能和可靠性已被認同,并被廣泛地應用于工業(yè)自動化、船舶、醫(yī)療設備、工業(yè)設備等方面。現場總線是當今自動化領域技術發(fā)展的熱點之一,被譽為自動化領域的計算機局域網。它的出現為分布式控制系統(tǒng)實現各節(jié)點之間實時、可靠的數據通信提供了強有力的技術支持。

  該技術使對DSP芯片程序的加載可以脫離仿真器而直接受控于列車的主控機。該技術可靠性高,使用靈活方便,具有很強的實用性。

  磁懸浮列車上有很多基于DSP芯片的模塊和系統(tǒng)。目前, DSP芯片程序的加載與運行都主要依賴于仿真器,而DSP仿真器價格高、體積大,這使得磁懸浮列車系統(tǒng)的調試很不靈活方便;且這些基于DSP芯片的系統(tǒng)一旦脫離仿真器就只能運行事前載入的單一的程序,也使系統(tǒng)的靈活性受到了很大的限制。 本文研究了DSP芯片程序加載的基本原理,并根據這些原理,基于CAN總線,實現了DSP芯片程序的受控加載,使得DSP芯片程序的加載與啟動可直接受控于上位主控機。由于主控機的靈活性很大,磁懸浮列車系統(tǒng)在調試時就可根據需要對其上各個控制模塊的主控DSP芯片加載不同的程序,控制它的啟動運行,非常方便靈活。

CAN總線結構圖 www.elecfans.com

  2 CAN總線的特點及工作原理

  CAN Control Area Network,即控制器局域網 總線是一種有效支持分布式控制或定時控制的串行通訊網絡它以半雙工的方式工作一個節(jié)點發(fā)送信息 多個節(jié)點接收信息 實現了全分布式多機系統(tǒng)提高了數據在網絡中傳輸的可靠性?其結構形式如圖1所示?CAN總線的信息存取利用了廣播式的存取工作方式 信息可以在任何時候由任何節(jié)點發(fā)送到空閑的總線上每個節(jié)點的CAN總線接口必須接收總線上出現的所有信息因此各節(jié)點都設置有一個接收寄存器 該寄存器接收信息 然后根據信息標文符決定是否讀取信息包中的數據以判斷是否使用這一信息? CAN總線的特點是以通信數據塊編碼代替?zhèn)鹘y(tǒng)的地址編碼 CAN總線面向的是數據而不是節(jié)點這種方式的優(yōu)點是可使網絡內的節(jié)點個數在理論上不受限制 加入或減少設備不影響整個系統(tǒng)的工作?基于CAN總線的各種系統(tǒng)可以根據用戶需要任意改變節(jié)點數量?CAN總線收發(fā)數據的長度最多為8個字節(jié)因而不存在占線時間問題 可以保證通信的實時性通信速率最高可達1Mb/s距離為40m 最遠可達10km速率為5kb/s ?對通信介質的要求較低可以是光纖或同軸電纜甚至雙絞線?  

  3 CAN總線優(yōu)勢
 
  CAN屬于現場總線的范疇,它是一種有效支持分布式控制或實時控制的串行通信網絡。較之目前許多RS-485基于R線構建的分布式控制系統(tǒng)而言, 基于CAN總線的分布式控制系統(tǒng)在以下方面具有明顯的優(yōu)越性:
 
  3.1 網絡各節(jié)點之間的數據通信實時性強
 
  首先,CAN控制器工作于多主方式,網絡中的各節(jié)點都可根據總線訪問優(yōu)先權(取決于報文標識符)采用無損結構的逐位仲裁的方式競爭向總線發(fā)送數據,且CAN協議廢除了站地址編碼,而代之以對通信數據進行編碼,這可使不同的節(jié)點同時接收到相同的數據,這些特點使得CAN總線構成的網絡各節(jié)點之間的數據通信實時性強,并且容易構成冗余結構,提高系統(tǒng)的可靠性和系統(tǒng)的靈活性。而利用RS-485只能構成主從式結構系統(tǒng),通信方式也只能以主站輪詢的方式進行,系統(tǒng)的實時性、可靠性較差;
 
  3.2 縮短了開發(fā)周期
 
  CAN總線通過CAN收發(fā)器接口芯片82C250的兩個輸出端CANH和CANL與物理總線相連,而CANH端的狀態(tài)只能是高電平或懸浮狀態(tài),CANL端只能是低電平或懸浮狀態(tài)。這就保證不會在出現在RS-485網絡中的現象,即當系統(tǒng)有錯誤,出現多節(jié)點同時向總線發(fā)送數據時,導致總線呈現短路,從而損壞某些節(jié)點的現象。而且CAN節(jié)點在錯誤嚴重的情況下具有自動關閉輸出功能,以使總線上其他節(jié)點的操作不受影響,從而保證不會出現象在網絡中,因個別節(jié)點出現問題,使得總線處于“死鎖”狀態(tài)。而且,CAN具有的完善的通信協議可由CAN控制器芯片及其接口芯片來實現,從而大大降低系統(tǒng)開發(fā)難度,縮短了開發(fā)周期,這些是僅有電氣協議的RS-485所無法比擬的。
 
  3.3 已形成國際標準的現場總線
 
  另外,與其它現場總線比較而言,CAN總線是具有通信速率高、容易實現、且性價比高等諸多特點的一種已形成國際標準的現場總線。這些也是目前 CAN總線應用于眾多領域,具有強勁的市場競爭力的重要原因。

  4 DSP芯片的程序加載與運行原理

  在本項技術中,DSP的程序加載與啟動運行是通過對其HPI 8位并行口的操作實現的?下面先簡單介紹一下DSP的HPI 8位并行口以及如何對它進行讀寫操作,然后介紹本文研究的這種DSP程序加載技術?

  4.1 DSP芯片的并口(HPI)簡介

  HPI并行口的讀寫操作主要由DSP的三個16位寄存器控制,它們分別是:HPIC HPI Control Register,控制寄存器 ?HPID HPI Data Register,數據寄存器 ?HPIA HPI Adress Register,地址寄存器 ?寫HPIC寄存器控制HPI并口的讀寫方式以及數據高低字節(jié)的讀寫順序等;寫HPIA寄存器控制寫入或讀出數據的具體地址(自增模式下2 為數據寫入/讀出時的初始地址);從HPID直接寫入/讀出數據?

  HPI有兩種讀寫方式:普通模式下的讀寫按照HPIA的地址將HPID的數據寫入內存或將該地址的數據讀入HPID;自增模式下HPIA則是首地址,每次讀或寫操作后它都會自動指向下一個待讀寫的地址?

  4.2 DSP芯片的程序加載與啟動

  由CCS編譯器生成的DSP可執(zhí)行文件是一種.out文件?本方法中首先調用TI公司提供的hex500.exe程序,將其轉換為.hex文件3,這種.hex文件的組織結構具體如下: 它由一個一個的塊(block)組成,每一個塊的第一個字節(jié)表示當前塊包含的待加載的有效數據的長度,第二?第三個字節(jié)表示這些有效數據寫入DSP內存時的首地址,從第五個字節(jié)開始是待寫入DSP內存的有效數據(第四個字節(jié)通常為0x00,是無效數據),超出當前有效數據長度的數據不需要處理?需要注意的是,文件的結尾(也就是最后一個塊)的第一個字節(jié)的數據是0,表示當前塊為文件的結尾,其后的任何數據都是無效數據? 知道這種.hex文件的組織結構后,就可以分離出其中的有效數據,然后就可將這些有效數據寫入DSP的內存?本技術是通過DSP的HPI口來完成寫操作的?具體如下: 首先對DSP復位,清除原來的數據;然后在單片機的控制下從.hex文件讀出每次寫入的初始地址,從這些初始地址開始不斷地將有效數據寫入DSP的內存;寫操作完成后,向DSP的內存地址0x007f寫數據0x8000,程序即啟動,開始執(zhí)行?  

  5 系統(tǒng)的組成

  系統(tǒng)組成框圖如圖2所示? ISA插卡通過ISA插槽與PC機(即相當于磁懸浮系統(tǒng)上的主控機)連接,受PC機的控制,接收來自PC機的數據,向PC機轉發(fā)收到的數據?插卡上有SJA1000芯片,通過它與PCB板上的SJA1000實現數據交換?

  CB板上的SJA1000的數據/地址信號線與單片機的P0并口相連,同時P0并口也與DSP的HPI并口數據線HD0~7相連?在單片機的控制下,SJA1000接收來自PC機的數據,并將其通過P0并口發(fā)送給單片機,然后單片機再將這些數據通過HPI發(fā)送給DSP?

  

  6 系統(tǒng)的實現
 
  6.1 硬件實現
 
  根據系統(tǒng)組成框圖,各個具體模塊的硬件實現如圖3?圖4?圖5所示? 圖3為單片機的接口電路,并口P0與SJA1000的并行數據口D0~D7(如圖4所示)及DSP的HPI口(如圖5所示)相連,實現數據交換:SJA1000接收來自CAN總線的數據,通過并行數據口D0~D7及P0口發(fā)送給單片機,單片機接收到數據并經過處理后又通過P0口和HPI口轉發(fā)給DSP? HBIL?HCT0?CHT1?HR/W為HPI口的控制信號2,故HPI的讀寫等操作都受控于單片機? CSCAN為SJA1000的選通信號,/RST為SJA1000與DSP的復位信號;RD?WR分別為讀寫控制信號?
 
  6.2 軟件實現
 
  PC機程序負責對。hex文件的分析,并根據分析結果,通過SJA1000,將每一個塊的“頭部”和有效數據有區(qū)別地向CAN總線上發(fā)送,直到遇到文件結束符為止? 單片機控制程序負責接收從SJA1000上傳的CAN總線上的數據,分析數據的性質(即該幀數據是“頭部”還是有效數據),然后通過DSP芯片的HPI并行口將有效數據正確地寫入相應的內存地址?
  本文研究的這項技術提供了一種簡單易行?成本低廉的DSP程序加載方法?這項技術具有高度的可靠性?靈活性和實用性?此項技術用于磁懸浮列車這樣一個復雜的DCS系統(tǒng)后,能夠很好地控制列車上眾多基于DSP芯片的系統(tǒng)的程序加載,并方便地對它們進行調試,使這些系統(tǒng)能根據不同的需要執(zhí)行不同的程序,取得了很好的效果?目前上海引進的磁懸浮列車也采用了此項在線調試技術?
此內容為AET網站原創(chuàng),未經授權禁止轉載。