<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 以DSP為核心的無(wú)線(xiàn)定位系統的方案設計

以DSP為核心的無(wú)線(xiàn)定位系統的方案設計

——
作者:吉林大學(xué) 通信工程學(xué)院 盧海軍哈爾濱理工大學(xué)電氣與電子工程學(xué)院 孫賀欣 時(shí)間:2005-11-30 來(lái)源:世界電子元器件 收藏
引言

無(wú)線(xiàn)定位技術(shù)是利用無(wú)線(xiàn)信號來(lái)判定某一半徑范圍內無(wú)線(xiàn)信號發(fā)射終端物理位置的一種方法。移動(dòng)通信網(wǎng)絡(luò )中移動(dòng)終端的定位方法可分為兩大類(lèi):一類(lèi)是基于手機的定位方法,通過(guò)在每個(gè)移動(dòng)終端(如手機)內部安裝微型GPS接收器進(jìn)行定位。另一類(lèi)是基于網(wǎng)絡(luò )的定位方法。這種方法與基于移動(dòng)終端的定位方法正相反,該方法根據移動(dòng)終端發(fā)出的信號到達基站的參數,如到達時(shí)間(TOA)參數、到達角度(DOA)參數等進(jìn)行定位?;诰W(wǎng)絡(luò )定位的方法需要用到陣列天線(xiàn),陣列天線(xiàn)傳感器接收到的無(wú)線(xiàn)信號經(jīng)過(guò)前端預處理進(jìn)行放大、取噪,然后進(jìn)行模數轉換,最后DSP對接收數據進(jìn)行處理得到方向估計。

因為T(mén)MS320VC5402(以下簡(jiǎn)稱(chēng)C5402)內部沒(méi)有集成A/D,因此在數據采集時(shí)需要使用A/D轉換芯片,A/D芯片與C5402的接口設計成為一個(gè)重要的問(wèn)題。為了充分利用C5402所提供的多通道緩沖串口資源,簡(jiǎn)化系統設計,本系統利用兩片C5402來(lái)完成四路數據采集,大大提高了串口工作效率。TMS320C54x系列DSP芯片只有同步串口,通常只能用于與具有同步通信接口的外設進(jìn)行通信。本系統中采用TI公司的的異步通信芯片TL16C550C完成數據的串/并、并/串變換,實(shí)現DSP與PC機的高速串行通信。本文在實(shí)際經(jīng)驗的基礎上,給出了兩片DSP組成的無(wú)線(xiàn)定位模擬系統,分別介紹了系統中串行A/D TLV1572、異步串行通信芯片TL16C550C的工作原理,同時(shí)分析了系統獨立工作的程序裝載原理和可行性。


系統主要器件和原理介紹

串行A/D芯片TLV1572

TLV1572是TI公司生產(chǎn)的高速十位串行A/D轉換芯片。TLV1572采用的是8腳的SOIC封裝,如圖1所示。TLV1572所要求提供的供電電壓在3V-5V之間,TLV1572的最小參考電壓為2.7V。在5V供電時(shí),最高轉換速度為1.25MSPS,在3V供電時(shí)最高轉換速度為625KSPS。為了使其達到最大的轉換速率,所提供的時(shí)鐘分別為20MHz和10MHz。TLV1572可以通過(guò)3或4個(gè)串行口線(xiàn)直接與DSP或其它數字微處理器串口相連,不需要外加邏輯,但是轉換速度受SCLK供給時(shí)鐘的限制。TLV1572與DSP的多通道緩沖串口通過(guò)/CS、SCLK、DO和FS四條線(xiàn)相連,此時(shí)DSP的CLKR產(chǎn)生移位脈沖,FSR產(chǎn)生幀同步信號,并分別提供給TLV1572。當TLV1572與其它串口微處理器相連接時(shí)FS必須提供高電平,通過(guò)/CS、SCLK、DO三條線(xiàn)來(lái)完成數據傳輸。當/CS為高時(shí),A/D芯片各管腳處于三態(tài)狀態(tài)。在/CS由高變低時(shí),TLV1572檢測FS引腳的狀態(tài)來(lái)確定工作模式,若FS為低則為DSP模式,若FS為高則為其它微處理器模式。

當TLV1572工作在DSP模式時(shí),必須保證在/CS變低時(shí),FS為低電平,并且要鎖存一定時(shí)間。/CS為低時(shí),DO跳出三態(tài)狀態(tài),但是直到FS為高時(shí)芯片才脫離休眠狀態(tài)。TLV1572在每個(gè)時(shí)鐘SCLK的下降沿檢測FS的狀態(tài),一旦檢測到FS為高,TLV1572開(kāi)始采樣。在FS的下降沿,A/D芯片通過(guò)移位時(shí)鐘將數據移到DO上。在6個(gè)前導0傳送之后,DSP可以在時(shí)鐘的下降沿得到A/D轉換的數據,如圖2所示。在最低位移出之后,A/D芯片自動(dòng)進(jìn)入休眠狀態(tài),直到FS下一次有效。如果FS在16位傳輸完成后立即有效,則A/D開(kāi)始新的數據轉換,此時(shí)A/D為連續轉換。若FS在TLV1572轉換數據的過(guò)程中變高,則A/D芯片被復位,開(kāi)始新的數據轉換周期。因此可以通過(guò)設置FS改變數據傳輸的位數。

異步通信芯片TL16C550C

TL16C550C是TI公司的異步通信芯片,具有與DSP的連接硬件簡(jiǎn)單,使用經(jīng)濟、可靠的優(yōu)點(diǎn)。其主要特點(diǎn)如下:管腳與TL16C450兼容;可由軟件設定16字節的FIFO以減少CPU中斷;波特率發(fā)生器可編程;具有可編程的串行數據發(fā)送格式;數據位長(cháng)度為5、6、7、8;具有偶校驗、奇校驗或無(wú)校驗模式;停止位長(cháng)度為1、1.5、2;采用44引腳PLCC封裝。

TL16C550C內部共有11個(gè)寄存器,這些寄存器分別用于實(shí)現通信參數的設置,對線(xiàn)路及MODEM的狀態(tài)訪(fǎng)問(wèn),數據的發(fā)送和接收以及中斷管理等功能。在編程過(guò)程中,可由A0、A1、A2 三條片內寄存器選擇線(xiàn)和線(xiàn)路控制寄存器(LCR)的D7位(DLAB)一起訪(fǎng)問(wèn)或控制TL16C550C的任何一個(gè)寄存器。表1給出了訪(fǎng)問(wèn)這些寄存器時(shí)DLAB和A0、A1、A2的狀態(tài)。因為接收和發(fā)送緩沖寄存器的DLAB、A0、A1、A2各位都相同,因此還必須通過(guò)讀寫(xiě)信號來(lái)加以區分。

因為接收/發(fā)送緩沖寄存器和中斷使能寄存器分別與波特率因子寄存器的低位和高位相同,要通過(guò)DLAB加以區分,可以任意選擇寫(xiě)入波特率因子的高字節和低字節的順序,寫(xiě)入前必須置LCR的DLAB位為1。寫(xiě)入波特率因子后應將D7置為0,以便訪(fǎng)問(wèn)其他寄存器。在外接晶振為3.072MHz時(shí),幾種常用的波特率所對應的波特率因子寄存器的值如表1所列。

C5402的Bootloader原理

C5402上電后,首先檢查MP/MC引腳的狀態(tài):如果為高電平,說(shuō)明DSP處于微處理器工作模式,從外部程序存儲器0FF80h地址開(kāi)始執行用戶(hù)程序;若為低電平,DSP被設置為微計算機模式,從片內ROM的0FF80h地址開(kāi)始執行程序。在C5402的0FF80h地址處存放著(zhù)一條跳轉至0F800h處執行DSP自行引導裝載(Bootloader)程序的指令。當C5402執行Bootloader程序時(shí),將會(huì )按HPI裝載模式→串行EEPROM裝載模式→并行裝載模式→標準串行口裝載模式 →I/O口引導裝載模式的順序循環(huán)檢測,以決定執行哪種啟動(dòng)模式。

對于以C5402為核心的數字信號處理系統來(lái)說(shuō),并行引導裝載模式被認為是最適用的。因為HPI引導裝載模式、標準串行口引導裝載模式和I/O口引導裝載模式只適用于由其它處理器為C5402提供運行代碼的多處理器系統中,串行EEPROM引導裝載模式只支持價(jià)格偏高的SPI端口EEPROM,而并行引導裝載模式可采用的并行EEPROM和Flash種類(lèi)很多,有的價(jià)格比較低,操作起來(lái)比較簡(jiǎn)單。在不自己編寫(xiě)Bootloader程序的情況下,并行引導裝載模式最大只能裝載32K字的程序或數據。若程序數據大于32K,此時(shí)需要自己編寫(xiě)一個(gè)并行裝載的內核程序,通過(guò)片內的裝載程序將編寫(xiě)的內核程序傳送到片內DRAM中,然后再運行裝載內核程序,將大于32K的程序數據送到片外的SRAM中。在有兩個(gè)或兩個(gè)以上的C5402或具有標準串口功能的多微處理器的系統中,若為每一個(gè)微處理器都配置一個(gè)并行的Flash來(lái)存儲程序,會(huì )很浪費資源,占用總線(xiàn)。而利用一片Flash,主機利用并行裝載,然后主機通過(guò)HPI裝載模式對其它C5402進(jìn)行裝載,這樣就可以節省大量資源。


系統硬件結構及原理分析

系統硬件原理圖

本系統主要完成無(wú)線(xiàn)信號的采集、采樣信號的處理得到方向估計及與PC機通信,系統的硬件原理如圖2所示。

數據采集與通信

為了達到與C5402很好的匹配,A/D電源和參考電壓都接了3.3V。A/D的FS接DSP的FSX和FSR,使數據輸入的幀同步信號由DSP產(chǎn)生。SCLK接DSP的CLKX和CLKR,這樣數據的輸入和輸出時(shí)鐘均來(lái)自DSP。C5402與各自?xún)善珹/D進(jìn)行數據傳輸時(shí),設置串口中斷工作在00模式,即串口數據到達觸發(fā)中斷,這樣CPU可以根據A/D傳輸數據產(chǎn)生相應的串口中斷RINT0或RINT1。當兩個(gè)串口的數據同時(shí)到達,即同時(shí)申請中斷時(shí),C5402的CPU會(huì )根據中斷優(yōu)先級響應RINT0中斷,然后再響應中斷RINT1。為了保證數據通信的可靠性,避免數據沖突,在響應RINT1中斷的過(guò)程中,串口0無(wú)中斷請求。 兩片C5402(A,B)是通過(guò)HPI口進(jìn)行數據交流的,其中C5402(A)作為主機,C5402(B)工作在HPI 模式。兩片DSP分別計算自己的數據的自相關(guān)函數Rxx,由C5402(A)將數據送到C5402(B)中,進(jìn)行互相關(guān)函數Rxy計算,然后通過(guò)ESPRIT方法計算出方向。估計完方向后,C5402(B)通過(guò)TI公司的異步串行芯片TL16C550C將估計結果傳給PC機進(jìn)行網(wǎng)絡(luò )定位,或下一步處理。

TL16C550C能以16MHz的速度讀寫(xiě)數據,讀寫(xiě)信號的脈寬很窄,使用一般的串口微處理器誤碼率較高,而TL16C550C能夠很好的與DSP匹配。這里VC5402以19200的波特率與PC機通信, 當XIN、XOUT端外接3.072MHz晶振時(shí),波特率因子寄存器的低位的值應為0AH,高位值為00H。C5402與TL16C550C之間的邏輯控制通過(guò)CPLD來(lái)完成,其內部邏輯如圖3所示。

由于RS-232-C電路電平與CMOS電平不同,因此RS232驅動(dòng)器與CMOS電平連接時(shí)必須經(jīng)過(guò)電平轉換,本系統采用MAXIM公司的MAX232來(lái)完成這一功能。


系統獨立工作的程序裝載過(guò)程

本系統的程序裝載分為兩部分:C5402(A)自身的并行裝載和C5402(B)的HPI裝載。

C5402(A)與Flash AT29LV1024和SRAM IS61LV6164之間的邏輯如圖4所示。C5402(A)上電復位裝載時(shí),由于Bootloader程序在初始化時(shí)設置XF為高電平,在系統進(jìn)入并行引導裝載模式后,C5402(A)從數據尋址為0FFFFh單元(A15=1,選中Flash)中讀取將要載入的程序存儲區首地址和并行裝載數據流。此時(shí),C5402可以將 Flash地址08000h-0FFFFh單元中的數據讀到C5402對應于0000h-7FFFh尋址區的片內DARAM和片外SRAM中。Bootloader程序結束后用戶(hù)程序的第一條語(yǔ)句為RSBX XF,置XF引腳為低電平, Flash始終不選通。這樣,SRAM的高32K區域(08000h-0FFFFh)被釋放出來(lái),可以作為C5402(A)運行時(shí)的數據區或程序區使用。C5402(A)裝載進(jìn)來(lái)的程序數據主要分三部分:給C5402(B)的裝載程序,自身的運行程序及C5402(B)的運行程序。

在C5402(A)進(jìn)行并行裝載的過(guò)程中,C5402(B)在判斷是哪種裝載模式。因為C5402(B)的HINT和INT2連在一起,在DSP上電初始化時(shí)將07FH單元清0,同時(shí)HINT置0,這樣導致了INT2的IFR的相應標志位有效,C5402(B)查詢(xún)到INT2的標志位有效后,判斷是HPI裝載模式。C5402(A)在進(jìn)行完并行裝載后,首先運行裝載程序,將C5402(B)運行程序數據傳送C5402(B)中,最后將C5402(B)的程序入口地址寫(xiě)到07FH單元,表明HPI裝載結束。

系統軟件設計

系統的軟件設計主要包括,多通道緩沖串口的初始化,串口中斷服務(wù)程序,并行裝載程序設計,TL16C550C的初始化及HPI設計等。


程序設計應注意的問(wèn)題

(1)McBSP工作在數據接收中斷方式,因此全局中斷和串口中斷的相應位應該合理設置。同時(shí),在設置中斷向量表時(shí),使中斷向量表的位置與處理器模式狀態(tài)寄存器PMST中的中斷向量指針I(yè)PTR相對應,使IPTR的9位地址指向128字的中斷向量所在的程序頁(yè),同時(shí),中斷向量表要嚴格按照C5402規定的格式編寫(xiě),否則不能正確地產(chǎn)生需要的中斷結果。

(2)要實(shí)現DSP數據采集系統的脫機獨立運行,程序裝載十分關(guān)鍵。C5402(A)進(jìn)行并行裝載,要求AT29LV1024中的程序數據流嚴格按照并行裝載的格式,依次給C5402(B)裝載程序、C5402(A)自身執行程序,C5402(B)的程序裝載到片內DRAM和片外SRAM中。

(3)注意到系統設計中,C5402(B)的HPI口既用來(lái)進(jìn)行程序裝載,又作為兩片DSP通信接口,為了避免混亂,在C5402(B)的程序中應將IFR中INT2的相應位清零,最好在IMR中屏蔽INT2。

(4)為了實(shí)現兩路A/D和C5402之間的時(shí)序匹配,避免數據沖突,需要注意C5402采樣率發(fā)生寄存器SRGR1中CLKGDV位的設置,使C5402工作時(shí)鐘周期大于兩個(gè)串口中斷的響應時(shí)間。

TL16C550C的軟件流程

TL16C550C 初始化程序主要完成波特率及其它工作寄存器的設置。這里設置TL16C550C工作模式為8位數據位,2位停止位,奇校驗狀態(tài)。TL16C550C的軟件設置流程如圖5所示。

圖5 TL16C55C工作的軟件流程(略)


串口接收的部分初始化程序

下面根據多通道緩沖串口的特性和兩路串行A/D工作的要求,主要介紹一下串口接收的軟件設計和串口部分關(guān)鍵設置。

;=====初始化串口0========
stm #0, SPSA0 
stm #0000h, SPSD0 ; #0000H SPCR10
stm #1, SPSA0
stm #0000h, SPSD0 ; #0000H SPCR20
stm #2, SPSA0
stm #0040h, SPSD0 ; #0040H RCRC10 每字16位
stm #3, SPSA0
stm #0040h, SPSD0 ; #0040H RCR20 每幀一段,每段一字
stm #6, SPSA0
stm #000fh,SPSD0 ; #0009H SRGR1 時(shí)鐘周期 CLKG=6.4MHz
stm #7, SPSA0
stm #300fh, SPSD0 ; #3010H SRGR20 幀周期為16個(gè)CLKG
stm #0eh,SPSA0
stm #0a04h, SPSD0 ; #0A04H PCR0 FSX, CLKX輸出,FSR,
CLKR輸入
;=====初始化串口1======
串口1的初始化程序參見(jiàn)串口0
;=====啟動(dòng)接收========
stm #0,SPSA0
stm #0001h, SPSD0 ;啟動(dòng)串口0接收
stm #1,SPSA0
stm #00c0h, SPSD0 ;內部產(chǎn)生時(shí)鐘產(chǎn)生FSG
stm #0,SPSA1
stm #0001h, SPSD1 ;啟動(dòng)串口1接收
stm #1,SPSA1
stm #00c0h, SPSD1 ;內部產(chǎn)生時(shí)鐘產(chǎn)生FSG
;==串口0接收中斷子程序===
.sect "brint0"
host_brint0: 
rsbx intm ;關(guān)中斷
ldm drr0,A
stl A,*ar4+ ; 接收
:::
其它處理程序
rete


結束語(yǔ)

本文利用兩片DSP,根據TM320C5402多通道緩沖串口的特點(diǎn),提出了由四個(gè)陣列天線(xiàn)傳感器陣元組成的DOA估計硬件設計方案,并給出了系統獨立工作的硬件原理圖和軟件設計的部分關(guān)鍵程序。并行裝載模式和HPI裝載模式同時(shí)使用,有效利用了系統資源,減小成本,同時(shí)TL16C550C的使用實(shí)現了DSP與PC機的高速串行通信。



關(guān)鍵詞:

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>