當前位置:首頁 > 電源 > 數字電源
[導讀]無線定位技術是利用無線信號來判定某一半徑范圍內無線信號發(fā)射終端物理位置的一種方法。移動通信網絡中移動終端的定位方法可分為兩大類:一類是基于手機的定位方法,通過在每個移動終端(如手機)內部安裝微型GPS接收器進行定位。

引言 

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

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


系統主要器件和原理介紹 

串行A/D芯片TLV1572 

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

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

異步通信芯片TL16C550C 

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

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

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

C5402的Bootloader原理 

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

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


系統硬件結構及原理分析 

系統硬件原理圖 

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

數據采集與通信 

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

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

由于RS-232-C電路電平與CMOS電平不同,因此RS232驅動器與CMOS電平連接時必須經過電平轉換,本系統采用MAXIM公司的MAX232來完成這一功能。 


系統獨立工作的程序裝載過程 

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

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

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

系統軟件設計 

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


程序設計應注意的問題 

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

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

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

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

TL16C550C的軟件流程 

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

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


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

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

;=====初始化串口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 時鐘周期 CLKG=6.4MHz 
stm #7, SPSA0 
stm #300fh, SPSD0 ; #3010H SRGR20 幀周期為16個CLKG 
stm #0eh,SPSA0 
stm #0a04h, SPSD0 ; #0A04H PCR0 FSX, CLKX輸出,FSR, 
CLKR輸入 
;=====初始化串口1====== 
串口1的初始化程序參見串口0 
;=====啟動接收======== 
stm #0,SPSA0 
stm #0001h, SPSD0 ;啟動串口0接收 
stm #1,SPSA0 
stm #00c0h, SPSD0 ;內部產生時鐘產生FSG 
stm #0,SPSA1 
stm #0001h, SPSD1 ;啟動串口1接收 
stm #1,SPSA1 
stm #00c0h, SPSD1 ;內部產生時鐘產生FSG 
;==串口0接收中斷子程序=== 
.sect "brint0" 
host_brint0:  
rsbx intm ;關中斷 
ldm drr0,A 
stl A,*ar4+ ; 接收 
::: 
其它處理程序 
rete 


結束語 

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


本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯系該專欄作者,如若文章內容侵犯您的權益,請及時聯系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數據產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數據產業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數字經濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯合牽頭組建的NVI技術創(chuàng)新聯盟在BIRTV2024超高清全產業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現場 NVI技術創(chuàng)新聯...

關鍵字: VI 傳輸協議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉