DSP與PC機串行通信在減搖水艙試驗臺架控制系統(tǒng)中的
摘 要:針對TI公司的TMS320LF2407,在詳細描述其串行通信接口和模塊的基礎(chǔ)上,結(jié)合減搖水艙試驗臺架控制系統(tǒng),介紹了實現(xiàn)DSP與PC機串行通信的設(shè)計方法,并給出了相關(guān)的框圖和程序。
1 引言
TMS320LF2407是美國TI(Texas Instruments)公司專為數(shù)字伺服控制和嵌入式控制系統(tǒng)而推出的一種低功耗、高性能16位定點DSP芯片。通過把高速的數(shù)字信號處理器內(nèi)核和功能強大的片內(nèi)外設(shè)集成在一起, DSP成為傳統(tǒng)的微控制單元和多片設(shè)計系統(tǒng)的一種理想替代品。
在減搖水艙試驗臺架控制系統(tǒng)工作過程中,需要實時修改DSP中控制器參數(shù)等變量,因此如何實現(xiàn)PC機與DSP的可靠通信成為一個重要問題。串行通信具有連接簡單、使用靈活方便、數(shù)據(jù)傳遞可靠等優(yōu)點,在工業(yè)監(jiān)控、數(shù)據(jù)采集和實時控制系統(tǒng)中得到了廣泛應(yīng)用。因而,本系統(tǒng)中采用了串行通信進行參數(shù)傳送。
本文基于減搖水艙試驗臺架控制系統(tǒng),設(shè)計了一種實現(xiàn)DSP與PC機串行通信的方案。
2 減搖水艙試驗臺架控制系統(tǒng)
減搖水艙是減小船舶橫向搖擺的重要減搖裝置之一,對減搖水艙除了進行理論研究外,建立減搖水艙的試驗裝置是對減搖水艙進行研究的重要手段。減搖水艙試驗臺架是研究和設(shè)計減搖水艙的重要試驗設(shè)備,它可以模擬實際艦船在海浪中的運動,研究水艙的運動、控制規(guī)律,并可測得其減搖效果。
為了使水艙試驗臺架能夠模擬實船在海浪中的運動并研究水艙的實際作用效果,必須有一套能夠模擬海浪橫搖力矩的力矩伺服系統(tǒng)。由于海浪橫搖力矩幅值和頻率變化很快,對力矩伺服系統(tǒng)的要求較高,所以試驗臺架采用電液力矩伺服系統(tǒng)。減搖水艙試驗臺架系統(tǒng)如圖1所示。
圖1 減搖水艙試驗臺架系統(tǒng)框圖
在減搖水艙試驗臺架控制系統(tǒng)中,采用PC機和DSP的主從式結(jié)構(gòu)。PC機作為上位機,提供海浪橫搖力矩信號、對一些傳感器采集得到的數(shù)據(jù)進行顯示,而DSP作為下位機,完成對減搖水艙試驗臺架電液伺服系統(tǒng)的實時控制。其輸出電壓信號經(jīng)伺服放大器控制流量電液伺服閥,由伺服閥控制擺動油缸,由液壓油缸驅(qū)動試驗臺架系統(tǒng),擺動油缸輸出的海浪橫搖力矩由傳感器檢測送至DSP構(gòu)成閉環(huán)控制回路。
3 TMS320LF2407及串行通信接口(SCI)
3.1 TMS320LF2407簡介
TMS320LF2407除了具有TMS320系列DSP的基本功能,還具有一些適合應(yīng)用于數(shù)字伺服控制的特點。采用高性能靜態(tài)CMOS技術(shù),使得供電電壓為3.3V,降低了控制器的功耗,而且高達40MIPS的執(zhí)行速度使指令周期縮短到25ns,提高了控制器的實時控制能力。TMS320LF2407片內(nèi)有高達32K 16位的Flash程序存儲器,544字的雙端口RAM(DARAM)和2K字的單口RAM(SARAM)。TMS320LF2407的片內(nèi)外設(shè)非常豐富,包括兩個事件管理器模塊、10位A/D轉(zhuǎn)換模塊、看門狗定時器、CAN現(xiàn)場總線接口、基于鎖相環(huán)(PLL)的時鐘發(fā)生器、PWM信號通道、串行外設(shè)接口(SPI)、串行通信接口(SCI)。TMS320LF2407提供的片內(nèi)外設(shè)資源使得數(shù)字伺服控制應(yīng)用中所需使用的外圍芯片大大減少了,為應(yīng)用系統(tǒng)的設(shè)計提供了方便
3.2 串行通信接口(SCI)
串行通信模塊的寄存器是8位的,并且可編程。串行通信接口(SCI)支持DSP和其他使用標準NRZ(非歸零)格式的異步外設(shè)之間的異步串行數(shù)字通信。SCI模塊會對接收到的數(shù)據(jù)進行測試,如間斷測試、奇偶性、超時以及幀錯誤測試等,以確保數(shù)據(jù)的完整性。可編程1—8位數(shù)據(jù)長度和1—2位停止位。SCI模塊有雙緩沖的發(fā)送器和接收器,每個都有獨立的使能位和中斷位,兩者可獨立工作,也可同時在全雙工模式下工作,并且發(fā)送和接收操作均可通過中斷和查詢兩種方式來進行。在該模塊中,通過對一個16位波特率選擇寄存器編程,可獲得超過65000種不同的波特率。
在TMS320LF2407與其他異步外設(shè)的串行通信中,對SCI模塊的控制、波特率和字符格式的選擇、操作方式和通信協(xié)議的選擇、中斷優(yōu)先級的選擇和使能等都是通過對相關(guān)寄存器編程來實現(xiàn)的。
4 本系統(tǒng)中串行通信設(shè)計方法及協(xié)議
SCI有兩種多處理器協(xié)議,即空閑線多處理器模式和地址線多處理器模式。這些協(xié)議允許在多個處理器之間進行有效的數(shù)據(jù)傳輸。在本系統(tǒng)中,采用空閑線模式。在此模式下,當接收到數(shù)據(jù)塊起始信號后,串行通信接口被喚醒。處理器識別下一個串行通信接口中斷。中斷服務(wù)程序?qū)⒔邮盏降牡刂放c自己的地址進行比較。如果該CPU正在被尋址,則中斷服務(wù)程序清除SLEEP位,并接收數(shù)據(jù)塊中剩余的數(shù)據(jù)。如果該CPU不被尋址,則SLEEP位仍保持置位。這樣就允許CPU繼續(xù)執(zhí)行它的主程序而不被SCI所中斷,直到檢測到下一個塊的起始信號。
DSP接收和發(fā)送數(shù)據(jù)可以采用查詢或中斷兩種模式來實現(xiàn)。本系統(tǒng)中采用中斷方式來接收PC機所傳來的參數(shù),這里主要介紹該模式下數(shù)據(jù)接收和發(fā)送的具體方法。TMS320LF2407串行通信接口模塊的數(shù)據(jù)接收和發(fā)送均有其獨立的外設(shè)中斷向量,并可使用高優(yōu)先級或低優(yōu)先級,中斷服務(wù)程序可通過檢查外設(shè)中斷向量寄存器的值來轉(zhuǎn)入相應(yīng)的接收或發(fā)送中斷處理程序。
在串行通信中,雙方必須使用相同的波特率。SCI使用一個16位波特率選擇寄存器可獲得65000種不同的可編程波特率,波特率由系統(tǒng)時鐘SYSCLK頻率和波特率選擇寄存器決定,不同通信模式下的串行通信接口波特率計算方法如下:
BRR=1到65535時
SCI異步波特率=
BRR=0時
SCI異步波特率=
(BRR為波特率選擇寄存器的十六位值)
在本系統(tǒng)的串行通信過程中,波特率設(shè)為9600bit/s,八位數(shù)據(jù)位,一個停止位,奇校驗。為了實現(xiàn)通訊,PC機與TMS320LF2407之間必須采用相同的通信協(xié)議。
5 串行通信硬件接口電路及軟件編程
5.1 硬件接口電路
PC機串行口使用的是標準RS-232-C電平,低電平“0”在+5V~+15V之間,高電平“1”在-5V~-15V之間。而TMS320LF2407的電源為3.3V,低電平“0”在+0.4V~+0.8V之間,高電平“1”在+2.4V~+2.8V之間。為了使二者電平匹配,在DSP與PC機之間必須進行電平邏輯轉(zhuǎn)換,本系統(tǒng)中采用的是MAXIM公司的MAX232集成芯片。具體硬件接口電路如圖所示。
圖2 DSP與PC機串行通信硬件接口圖
評論