1553B總線中曼徹斯特編解碼器的設(shè)計_第1頁
1553B總線中曼徹斯特編解碼器的設(shè)計_第2頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、1553B總線中曼徹斯特編解碼器的設(shè)計0引言曼徹斯特曼徹斯特碼是一種總線數(shù)據(jù)傳輸雙極性碼。在數(shù)字信號基帶傳輸中,通過這種信道編碼技術(shù)可使傳送數(shù)據(jù)同時攜帶時鐘信息,故也稱其為自同步曼徹斯特碼。在信道傳輸中曼徹斯特碼有很好的抗干擾能力。接收端可以將分離出的時鐘用于解碼,從而簡化了解碼過程。針對曼徹斯特碼特點(diǎn),可采用位同步方法提取時鐘,常采用濾波法和數(shù)字鎖相環(huán)法。濾波法采用的窄帶濾波器不適合數(shù)字電路使用。數(shù)字鎖相環(huán)法通過比較接收碼元和本地碼元為定時時鐘的相位來添加扣除時鐘脈沖,以達(dá)到調(diào)整相位的目的,但電路實(shí)現(xiàn)過于復(fù)雜。本文提出的時鐘分離電路比數(shù)字鎖相環(huán)簡單,而且提取出來的時鐘可以準(zhǔn)確地采樣到曼徹斯特

2、碼信號。1曼徹斯特碼曼徹斯特碼是一種廣泛用于以太網(wǎng)、短距離無線通信、航空電子綜合系統(tǒng)中總線數(shù)據(jù)傳輸?shù)碾p極性碼。它的每個碼元中點(diǎn)都存在一個電平跳變,1信號為一個從1到0的負(fù)跳變;0信號為一個從0到1的正跳變。由于曼徹斯特碼在頻譜中存在很強(qiáng)的定式分量,解碼時可將分離出的時鐘用來解碼。另一方面,1553B1553B傳輸電纜呈容性負(fù)載特性,所以在信號傳輸中,直流和低頻分量將受到很大的衰減。曼徹斯特碼頻譜中不存在直流分量,而且低頻分量也大大減小,很適合在1553B電纜中傳輸。MIL-STD-1553B協(xié)議中采用的曼徹斯特碼數(shù)據(jù)格式。同步頭:占三位碼元長度。命令字或狀態(tài)字同步頭的前15倍碼元長度為高電平;

3、后15倍碼元長度為低電平,數(shù)據(jù)字同步頭剛好相反。同步頭用于區(qū)分字的類型以及標(biāo)識字傳輸開始。數(shù)據(jù):16位數(shù)據(jù)位。圖中bit3為數(shù)據(jù)最高位,依次遞減,bitl8為數(shù)據(jù)最低位。奇偶校驗(yàn)位:這里采用奇校驗(yàn)。將16位數(shù)據(jù)按位同或的結(jié)果作為奇校驗(yàn)位。2曼徹斯特編碼器的設(shè)計設(shè)計由于曼徹斯特碼的每個碼元在其中心存在電平跳變,所以編碼器的發(fā)送時鐘頻率至少應(yīng)選擇信息傳輸速率的2倍頻。通常編碼器的實(shí)現(xiàn)方式有2種,基于移位寄存器,或者數(shù)據(jù)選擇器。移位寄存器型編碼器需要在編碼開始后將同步頭位、數(shù)據(jù)位、奇偶校驗(yàn)位通過字符格式編排器編排成一個并行數(shù)據(jù),然后在發(fā)送時鐘的控制下串行移位輸出;數(shù)據(jù)選擇器型編碼器需要在編碼開始后啟

4、動一個計數(shù)器,在計數(shù)器的控制下分別送出同步頭、數(shù)據(jù)位、奇偶效驗(yàn)位。本文的編碼器采用后者,其結(jié)構(gòu)框圖。21編碼過程編碼過程如下:(1)檢測編碼周期是否開始,編碼周期開始后將同步頭類型、16位并行數(shù)據(jù)存儲到內(nèi)部寄存器中,與此同時計數(shù)器ent開始計數(shù)。(2)在計數(shù)器cnt的控制下通過碼型生成器發(fā)出同步頭、數(shù)據(jù)位、奇偶校驗(yàn)位。(3)在當(dāng)前字的曼徹斯特碼發(fā)送完成后回到過程(1)等待發(fā)送下一個字2.2端口說明rst_n為異步復(fù)位信號;elk為系統(tǒng)時鐘,頻率為信息傳輸速率的12倍;ene_trigger(輸入,高有效)的編碼開始的觸發(fā)信號;enc_csw(輸入,高有效)表示要發(fā)送的字為命令字或狀態(tài)字;enc

5、_dw(輸入,高有效)表示要發(fā)送的字為數(shù)據(jù)字;enc_data(輸入)表示16位要發(fā)送的并行數(shù)據(jù);tx_data_p(輸出)表示發(fā)出的曼徹斯特原碼;tx_data_n(輸出)表示發(fā)出的曼徹斯特反碼。2.3子模塊說明(1)6分頻電路將系統(tǒng)時鐘6分頻輸出占空比為16的編碼時鐘使能信號enc_clk_en,該信號的頻率為信息傳輸速率的2倍,其他3個模塊只有在采樣到該信號高電平后才會觸發(fā)。在復(fù)雜時序電路設(shè)計中通過引入時鐘使能信號可減少設(shè)計中的時鐘信號,提高電路的可靠性。(2)保持寄存器在enc_clk_en有效且采樣到enc_trigger為1時,將enc_csw,enc_dw,enc_data存入內(nèi)

6、部寄存器csw_reg,dw_reg,data_reg中。(3)計數(shù)器在enc_clk_en有效時采樣到enc_trigger為1時,將計數(shù)使能信號置為1,并在其控制下開始計數(shù),計數(shù)范圍為039。(4)碼型生成器碼型生成器通過對16位并行數(shù)據(jù)data_reg做同或運(yùn)算產(chǎn)生奇偶校驗(yàn)結(jié)果。在計數(shù)器cnt的控制下發(fā)送出曼徹斯特碼。發(fā)送過程如下(以tx_data_p說明):cnt(05):根據(jù)同步頭類型,依次發(fā)送111000(csw_reg有效)或000111(dw_reg有效)。cnt(637):發(fā)送數(shù)據(jù)位,在碼元前半個周期發(fā)送原碼,后半個周期發(fā)出反碼。ent(3839):發(fā)送奇偶校驗(yàn)位,計數(shù)到38

7、時,發(fā)送奇偶校驗(yàn)位原碼,39時發(fā)送其反碼。3曼徹斯特解碼器解碼器的設(shè)計解碼器需要將收到的曼徹斯特碼解碼,得出16位并行數(shù)據(jù),并給出各種校驗(yàn)結(jié)果。本文設(shè)計的解碼器邏輯結(jié)構(gòu)。31解碼過程(1)同步頭檢測,當(dāng)檢測到同步頭后觸發(fā)整個解碼過程開始,并給出同步頭類型。(2)檢測到同步頭后,計數(shù)器ent開始計數(shù),在ent的控制下進(jìn)行解碼。包括碼型轉(zhuǎn)換與移位操作,同步頭類型輸出、曼徹斯特碼型校驗(yàn)、奇偶校驗(yàn)、字連續(xù)性校驗(yàn)等。(3)當(dāng)碼的串并轉(zhuǎn)換以及各種校驗(yàn)都完成后,給出并行數(shù)據(jù)和校驗(yàn)結(jié)果信號,在ent的控制下最終給出數(shù)據(jù)有效信號data_ready。協(xié)議模塊可在該信號有效(高電平)時檢測其他校驗(yàn)信號,并決定是否

8、取走并行數(shù)據(jù)。3.2端口說明rst_n為異步復(fù)位信號;elk為系統(tǒng)時鐘,頻率是信息傳輸速率的12倍;rx_data(輸入)為收到的曼徹斯特原碼;data_ready(輸出,高有效)為數(shù)據(jù)有效信號,該信號有效期間可檢測其他校驗(yàn)輸出信號,若數(shù)據(jù)有效可取走16位并行數(shù)據(jù);esw(輸出,高有效)為收到字類型為命令字或狀態(tài)字;dw(輸出,高有效)表示收到字類型為數(shù)據(jù)字;data(輸出)表示解碼輸出的16位并行數(shù)據(jù);parity_right(輸出,高有效)為奇偶校驗(yàn)結(jié)果;manehester_right(輸出,高有效)為曼徹斯特碼型校驗(yàn)結(jié)果;word_continue(輸出,高有效)為字連續(xù)性校驗(yàn)結(jié)果,有

9、效時表示當(dāng)前收到的字與上一次收到字之間是連續(xù)的。3.3子模塊說明(1)時鐘分離模塊時鐘分離模塊。該模塊將曼徹斯特碼自帶的時鐘信號分離,得到elk2_en,并在該信號有效(高電平)時采樣,經(jīng)過三級寄存器保持輸出的曼徹斯特碼信號rx_data_reg_2。采樣時刻總出現(xiàn)在每個碼元正負(fù)電平的中點(diǎn)處,而這也是曼徹斯特碼采樣的最佳時刻,。時鐘分離電路結(jié)構(gòu),收到的曼徹斯特碼rx_data為異步信號,通過DFF1,DFF2,DFF3三級采樣保持電路可消除亞穩(wěn)態(tài)。edge_eheek在每個曼碼電平跳變后產(chǎn)生一個脈沖,該信號將對cnt_elk2和elk2_en同步清零,以達(dá)到調(diào)整相位的目的。ent_clk2是一

10、個6進(jìn)制計數(shù)器,當(dāng)計數(shù)到1時通過比較器給出同步置位脈沖set,它將對elk2_en同步置1。(2)同步頭識別模塊該模塊始終檢測同步頭,并給出同步頭類型。檢測方法如下,在采樣到時鐘使能信號elk2_en有效時,將rx_data_reg_2存入移位寄存器syne_reg9:0中,當(dāng)檢測到syne_reg5:0為“111000”或“000111”時,給出同步頭有效信號syne_1,用于觸發(fā)計數(shù)器和碼型轉(zhuǎn)換移位模塊工作。(3)計數(shù)模塊計數(shù)器ent是一個40進(jìn)制計數(shù)器,在ent的控制下完成整個解碼過程。當(dāng)收到同步頭有效信號syne_1時,將計數(shù)器使能信號e

11、nt_enb置為有效(高電平),并在其控制下開始計數(shù)。(4)碼型轉(zhuǎn)換與移位電路該模塊在移位使能信號data_sample有效,且采樣到采樣使能信號elk2_en時,將rx_data_reg_2移入一個17位寄存器data_reg16:O中,移位完成后,將得到一個16位并行數(shù)據(jù)data_reg16:1和一個奇偶校驗(yàn)位data_reg0。(5)校驗(yàn)?zāi)K該電路將檢測并輸出同步頭類型、奇偶校驗(yàn)結(jié)果、曼徹斯特碼檢測結(jié)果、字連續(xù)性檢測結(jié)果。同步頭類型檢測:當(dāng)ent計數(shù)到3時,將同步頭檢測結(jié)果syne_esw和syn_dw分別寄存輸出給esw和dw。奇偶校驗(yàn):將17位并行數(shù)據(jù)data_reg16:0按位同或

12、后在ent計數(shù)到33時將效驗(yàn)結(jié)果輸出給parity_right。曼徹斯特碼型的有效性校驗(yàn):對16位曼徹斯特碼和1位奇偶校驗(yàn)碼的碼型進(jìn)行檢測。當(dāng)收到同步頭有效信號syne_1時將mangehester_rig-ht信號置為1,之后將每個碼元曼徹斯特檢測結(jié)果與mangehester_right做與運(yùn)算,再寄存輸出到mangchester_right。當(dāng)中間某個碼元曼徹斯特碼出錯時,mangchester_right將變?yōu)?,并在之后的檢測中一直保持為0,直到收到下一個字的sync_l信號。字連續(xù)性檢測:若前一個字與當(dāng)前字連續(xù),則在前一個字cnt計數(shù)到39時,當(dāng)前字的同步頭有效信號sync_1應(yīng)為高

13、電平,若不連續(xù),sync_1為低電平。所以在cnt=39時將sync_1寄存輸出給word_continue可表征字的連續(xù)性。(6)數(shù)據(jù)有效輸出模塊當(dāng)所有校驗(yàn)和移位都完成時,在cnt為3438之間輸出數(shù)據(jù)有效信號data_ready。4仿真及FPGA實(shí)現(xiàn)在TESTBENCH中將編碼器曼徹斯特碼的輸出直接連到解碼器曼徹斯特碼的輸入端。圖6為正確曼徹斯特碼的時序仿真波形圖,傳輸速率為10Mb/s,系統(tǒng)時鐘為120MHz。圖6的上半部分為編碼器信號波形,下半部分為解碼器信號波形。發(fā)送消息為連續(xù)的4個字:第1個為命令字,后3個為數(shù)據(jù)字。為了全面驗(yàn)證設(shè)計功能,需要注入不同類型的錯誤來檢測解碼器的查錯能力。其中,包括同步頭類型錯,曼徹斯特碼型錯,奇偶校驗(yàn)錯,字不連續(xù)錯等。測試過程完全按照GJB5186相關(guān)要求進(jìn)行。該設(shè)計

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論