新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 詳細解析微處理器和JTAG總線橋接接口

詳細解析微處理器和JTAG總線橋接接口

作者: 時間:2018-08-02 來源:網(wǎng)絡 收藏

引言

本文引用地址:http://2s4d.com/article/201808/384963.htm

隨著科學技術水平的提高,智能儀器儀表或微機裝置等智能電子設備(IED)已廣泛應用于工業(yè)現(xiàn)場。

網(wǎng)絡打印(network print server)可為智能電子設備提供可靠的共享打印服務,節(jié)約系統(tǒng)成本。CAN總線是一種支持分布或實時控制的現(xiàn)場總線,具有高可靠性、實時性和靈活性,廣泛應用于汽車控制、工業(yè)控制、機器人、家用電器等領域。CAN總線已成為工業(yè)現(xiàn)場首選現(xiàn)場總線之一。設計的網(wǎng)絡打印采用CAN總線作為數(shù)據(jù)通訊網(wǎng)絡,每個網(wǎng)絡打印可與幾十甚至上百個智能電子設備構成總線型網(wǎng)絡,采用屏蔽雙絞線作為通訊介質減少節(jié)點干擾。通訊速率在10 Kb/s~1 Mb/s范圍內可選。

2 系統(tǒng)硬件設計

網(wǎng)絡打印服務器的核心處理器采用PHILIPS公司的LPC2129。LPC2129是一款支持實時仿真和跟蹤的16/32位7TDMI-S CPU“微控制器”,帶有256 KB的嵌入式高速Flash存儲器,16 KB支持8/16/32位訪問的靜態(tài)RAM,128位寬度的存儲器接口和獨特的加速結構,可使32位代碼在最大時鐘速率下運行。而對代碼有嚴格控制要求的應用則可使用16位Thumb模式。LPC2129采用64引腳封裝,低功耗,內帶有46個GPIO,2個32位定時器,2路CAN控制器,多路串行接口,9路外部中斷。選取該處理器主要考慮其內部資源豐富,無需擴展存儲器、CAN控制器,且性能優(yōu)異,抗干擾能力強;價格低廉,具有極高的性價比。

系統(tǒng)硬件電路設計框圖如圖2所示。調試接口直接與LPC2129連接,用于調試開發(fā);由MAX232-EPE等器件構成的串口電路用于程序下載;看門狗負責監(jiān)控程序是否出現(xiàn)異?;蚺茱w,若出現(xiàn)故障時,看門狗使整個系統(tǒng)復位;而電源電路由SP220-15D5D和DUP75-05S05等器件構成,為網(wǎng)絡打印服務器提供工作電源。

網(wǎng)絡打印機服務器的核心電路是CAN及打印機接口電路,如圖3所示。打印機接口電路部分由光耦PS2701和電容電阻等元件構成,LPC2129的P0和P1端口引腳經(jīng)該接口電路與針式打印機連接,實現(xiàn)打印功能;CAN總線接口電路由6N137和PCA82-C250等器件構成,LPC2129內部CAN控制器完成CAN協(xié)議處理,PCA82-C250可提高節(jié)點的驅動能力。為了增強CAN總線節(jié)點的抗干擾能力,LPC2129的CNTX和CNRX不能直接與PCA82C250的TXD和RXD相連,應經(jīng)高速光耦6N137后再與PCA82C250相連,從而實現(xiàn)總線上各CAN節(jié)點間的電氣隔離。高速光耦電路中的電源VCC和VDD必須完全隔離,采用隔離型電源模塊DUP75-05S05實現(xiàn)隔離。PCA82C250與CAN總線的接口部分也采取了抗干擾措施,CANH和CANL與地之間分別并聯(lián)一只1 000 pF/2 kV的電容,用于濾除總線上的高頻干擾,并具有一定的抗電磁輻射性能。另外,在CAN總線接人端與地之間連接一個瞬態(tài)電壓抑制二極管(TVS),保護PCA82C250免受ESD和EMI浪涌脈沖。通訊信號傳輸?shù)綄Ь€的端點時產生反射,并干擾正常信號傳輸,在PCA82C250的兩根輸出數(shù)據(jù)線之間接一120 Ω的終端電阻可抑制反射信號。若忽略該終端電阻,則大大降低通訊的抗干擾性和可靠性,甚至導致無法通訊。

3 系統(tǒng)軟件設計

網(wǎng)絡打印服務器與各個智能電子設備之間采用主從方式,通過查詢完成工作。軟件主要由網(wǎng)絡打印服務主程序、CAN驅動程序、打印接口驅動程序、定時器中斷程序以及LPC2129啟動程序組成。

LPC2129啟動程序采用匯編語言編寫,主要包括異常中斷向量表、堆棧初始化、目標板初始化、存儲系統(tǒng)初始化等。定時器中斷程序是定時器0的中斷處理程序,用于完成各種定時或延時功能,為打印和CAN通訊提供必要支持。打印接口驅動程序包括打印初始化和發(fā)送打印數(shù)據(jù)。打印初始化程序用于設置的P0和P1端口部分引腳的工作方式,初始化打印機。發(fā)送打印數(shù)據(jù)程序首先檢測打印機是否忙,若打印機忙則等待,若空閑則發(fā)送要打印的數(shù)據(jù)。然后選通打印機,最后回收打印機,即不選通并將數(shù)據(jù)寄存器置位。

CAN驅動程序主要包括初始化CAN控制器、發(fā)送報文和接收報文。初始化CAN控制器主要包括設置相應引腳功能、工作方式、波特率參數(shù)以及出錯警告界限等。

LPC2129中有全局驗收濾波器,該模塊可為CAN控制器提供接收標識符的查詢功能(驗收濾波)。另外,驗收濾波器為選擇的標準標識符提供了FulICAN-style自動接收功能。在初始化CAN控制器中將驗收濾波器設置為旁路,也可以根據(jù)實際需要進行設置,讓其參與接收濾波的工作,有助于改善節(jié)點接收信息的選擇性。完成初始化CAN控制器后,即可發(fā)送和接收報文信息。

發(fā)送報文驅動程序主要實現(xiàn)報文發(fā)送,發(fā)送報文流程如圖4所示。發(fā)送報文時。將待發(fā)送的數(shù)據(jù)打包成符合CAN發(fā)送幀格式的數(shù)據(jù)送人CAN控制器的發(fā)送緩存區(qū)。在向發(fā)送緩沖區(qū)送報文之前,必須判斷發(fā)送緩沖區(qū)是否空閑。若發(fā)送緩沖區(qū)繁忙則返回失敗;若空閑則將數(shù)據(jù)寫人發(fā)送緩沖區(qū),寫入完成后再判斷寫入是否成功,寫入成功后啟動發(fā)送命令,發(fā)送緩沖區(qū)中的數(shù)據(jù),然后返回狀態(tài)標志。

接收驅動程序主要完成報文接收以及其CAN異常情況處理。CAN發(fā)送報文流程如圖5所示。接收報文驅動程序相對復雜些,因為在處理接收報文的過程中,同時也要處理總線關閉、錯誤報警、接收溢出等情況。該系統(tǒng)設計采片j中斷接收方式獲得較高的實時性,從而提高網(wǎng)絡打印服務器性能。初始化CAN控制器必須使能接收中斷。中斷服務子程序讀取CANICR控制器,判斷是否為接收中斷標志,若是則讀取接收緩沖區(qū)數(shù)據(jù);若是CAN異常情況,則進行相應處理。

在LPC2129啟動程序后執(zhí)行網(wǎng)絡打印服務主程序。首先初始化,包括初始化看門狗、打印機、CAN控制器、定時器0及使能中斷等;再與智能電子設備握手連接,然后打印首次握手成功的IED基本信息;最后執(zhí)行無限循環(huán)程序代碼。在這段程序中判斷是否有定時器超時。若查詢IED定時超時,則查詢各個IED是否要打印,若無打印需求則進入下一循環(huán)狀態(tài);若有打印需求則申請數(shù)據(jù)信息完成打印。如果重新握手定時超時,則與IED設備重新握手連接,檢測中途接人的智能電子設備可以滿足系統(tǒng)需求,重新握手完成后執(zhí)行無限循環(huán)程序。

在ADS1.2環(huán)境及EasyJTAG仿真器中進行軟件調試。程序代碼在ADS1.2環(huán)境下編譯、連接后生成可執(zhí)行文件,通過EasyJTAG仿真器仿真調試,最后寫入Flash存儲器中。經(jīng)過現(xiàn)場調試使用,基于CAN總線的網(wǎng)絡打印服務器能夠可靠地完成網(wǎng)絡打印功能。


上一頁 1 2 下一頁

評論


相關推薦

技術專區(qū)

關閉