《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > LTE系統(tǒng)的CRC校驗算法研究及DSP實現
LTE系統(tǒng)的CRC校驗算法研究及DSP實現
來源:電子技術應用2010年第9期
羅友寶,李小文,谷向陽
重慶郵電大學 通信與信息工程學院,重慶400065
摘要: 通過對兩種常用CRC校驗算法的研究分析,為TD-LTE測試儀表系統(tǒng)選擇了一種最優(yōu)的CRC校驗算法,并在TMS320C64xDSP中實現。將CRC校驗程序在CCS3.3中運行,其結果驗證了算法的可行性、高效性。
中圖分類號: TN929.5
文獻標識碼: A
文章編號: 0258-7998(2010)09-0071-03
Research and DSP realization of CRC algorithm in LTE system
LUO You Bao,LI Xiao Wen,GU Xiang Yang
School of Communication and Information Engineering,Chongqing University of Posts and Telecommunications,Chongqing 400065,China
Abstract: Based on the LTE(long term evolution) CRC(cyclic redundancy check)codes, this paper researched two algorithms which were used very common. It choosed the most suitable CRC algorithm for the TD-LTE test system, and realized the algorithm in the TMS320C64x DSP. The running results of the CRC check program in CCS3.3 verify that the selected algorithm is feasible and effective.
Key words : long term evolution;CRC;look-up-table;block-xor long division;DSP Realization

    循環(huán)冗余校驗碼[1]CRC(Cyclic Redundancy Check)是數據通信領域中最常用的一種差錯校驗碼,其特征是信息字段和校驗字段的長度可以任意選定。
    為了完成信號傳輸過程中誤碼檢測,獲得正確無誤的傳輸數據,LTE(Long Term Evolution)系統(tǒng)針對不同的數據傳輸采用了多種格式的循環(huán)冗余碼,以適應系統(tǒng)高速率高性能的需求。
1 LTE系統(tǒng)中的循環(huán)冗余碼
    LTE作為準4G技術,以正交頻分復用OFDM(Orthogonal Frequency Division Multiplexing)和多輸入多輸出MIMO(Multiple-Input Multiple-Out-put)技術為基礎,下行采用正交頻分(OFDM)多址技術,上行采用單載波頻分(SC-FDMA)多址技術,在20 MHz頻譜帶寬下能夠提供下行100 Mb/s與上行50 Mb/s的峰值速率。
    LTE TDD(亦稱TD-LTE)系統(tǒng)采用了4種格式[2]的CRC:CRC24A、CRC24B、CRC16、CRC8。其生成多項式如下:

其中長度為24的CRC24A和CRC24B主要用于共享信道數據傳輸[3],長度為16的CRC16主要用于下行控制信道和廣播信道數據傳輸,長度為8的CRC8主要用于CQI(Control quality information)信息的傳輸。
2 CRC算法分析及選擇
    CRC的校驗原理非常簡單,它要求發(fā)送方和接收方采用同一個生成多項式g(x),且g(x)的首位和末位的系數必須為l。編碼時將待發(fā)送的數據t(x)除以g(x),得到的余數作為CRC校驗碼添加到t(x)的后面;譯碼時將接收到的數據r(x)除以g(x),如果余數為0,則說明校驗正確,否則校驗失敗,從而判斷數據幀是否出錯。在工程應用中,常用的CRC校驗算法主要有兩種:查表生成法和塊異或長除法。

   這種算法的優(yōu)點是運算量小、速度快、效率高;缺點是可移植性較差,且要事先計算出余式表,而不同長度的生成多項式的余式表不同,因此余式表會占用系統(tǒng)較大的存儲空間,增大系統(tǒng)資源開銷。
2.2 塊異或長除法
    塊異或長除法是依據CRC校驗碼的產生原理實現的。算法描述如下:
    (1)初始化,將寄存器初始化為0。
    (2)在信息比特后添加CRC長度個0,最終作為CRC添加的空間。
    (3)讀取一個數據塊(塊的大小由處理器的字的單位長度決定)。
    (4)判斷塊的最高位是否為‘1’,若為‘1’則數據塊與生成多項式做一次異或操作。
    (5)將數據左移一位,如果當前塊的剩余比特等于CRC生成多項式的長度,則轉入步驟(3);否則轉入步驟(4)。
    (6)如果所有數據都已經操作完畢,則計算結束,寄存器中的值為最終求得的CRC。
    這種算法的優(yōu)點是算法簡單、容易實現、修改靈活、可移植性好,對任意長度的生成多項式都適用;但因為它一次只能處理一位數據,因此計算效率低,運算量大。
    如前所述,在TD-LTE系統(tǒng)中采用了4種格式的CRC,如果采用查表算法,則需要建立4張查找表,會占用系統(tǒng)較大的存儲空間,且程序移植性差;如果采用塊異或長除法,則又會出現計算效率低,運算量大的問題。
    綜上分析,結合項目需求及系統(tǒng)硬件配置,考慮到系統(tǒng)所采用的高效DSP處理器——TMS320C64x(主頻最高可達到1.2 GHz)可以彌補塊異或長除法的低效性,系統(tǒng)最終采用塊異或長除法來實現。
3 CRC算法的DSP實現
3.1 硬件簡介

    TMS320C6000系列DSP是TI公司1997年2月推向市場的高性能DSP,綜合了目前DSP性價比高、功耗低等優(yōu)點。TMS320C64x系列在TMS320C6000 DSP芯片中處于領先水平,它不但提高了時鐘頻率,而且在體系結構上采用了VelociTI甚長指令集VLIW(Very Long Instruction Word)結構[5],片內有8個獨立功能單元的內核,每個周期可以并行執(zhí)行8條32 bit指令,最大峰值速度4 800 MIPS,2組共64個32 bit 通用寄存器,32 bit 尋址范圍,支持8/16/32/40位的數據訪問,片內集成大容量SRAM,最大可達8 Mbit。由于其出色的運算能力、高效的指令集、大范圍的尋址能力,使其特別適用于無線基站、測試儀表等對運算能力和存儲量有高要求的應用場合。
3.2 CRC校驗的DSP實現
    因為系統(tǒng)采用了4種格式的CRC,如果對每種格式進行單獨實現,不僅任務繁瑣,而且增加了系統(tǒng)的代碼量,更給代碼測試和維護增加了難度。因此本實現采用統(tǒng)一實現,即同一個程序,支持系統(tǒng)中的所有CRC格式,僅需在程序頭部增添一點格式判斷的代碼即可。
    雖然TMS320C64x DSP處理器的字長為32 bit,但是為了兼容4種格式的CRC,最終決定數據的分塊長度為半字,即16 bit,這樣做的目的就是為了支持CRC24,因為TMS320C64x DSP的寄存器在用作邏輯移位寄存器使用時,其有效長度為40 bit。
    根據LTE協(xié)議,輸入數據按大端模式輸入。為了處理方便,每次讀入半字都將其倒序,采用低端對齊的方式進行CRC除法,因此,CRC多項式也必須經過倒序。最后生成的CRC也是倒序的,需要再次倒序,然后進行加擾[2](如果必要的話),最后添加到輸入數據后面。倒序可使用指令“BITR”,簡單易行。
    輸出數據仍為大端模式。由前面所述可知:CRC8的生成多項式倒序值為0x1b3;CRC16的生成多項式倒序值為0x10811;CRC24A的生成多項式倒序值為0x1be64c3;CRC24B的生成多項式倒序值為0x18c0003。
    值得注意的是:輸入數據后面應該多寫入一個字的0,因為每次取半字處理,當剩余比特為最大15 bit且CRC為最長24 bit時,組合起來也不會超過40 bit,避免特殊性的出現,以便統(tǒng)一處理。同時完成CRC計算過后,可以直接將CRC添加到原數據之后,而不擔心其會覆蓋系統(tǒng)中的其他數據,引起不必要的錯誤。
    圖1為CRC計算及添加的程序實現流程。當CRC格式為CRC16、CRC24A、CRC24B時,讀取的第一個數據塊(半字)在第一次內循環(huán)中將只作16次的移位,而沒有異或操作,表面上看在這里應該加一個判斷,如果是這種情況則直接將數據右移16 bit,然后接著處理第二個數據塊。但這樣會對后續(xù)的數據塊造成麻煩,因為每個數據塊到達此處都需判斷一次,當數據量比較大時,會帶來更大的開銷,因此在程序流程中可以忽略此問題。

    在接收端,CRC的校驗與發(fā)送端的計算基本相同,只是由于LTE系統(tǒng)的特殊性,如果在發(fā)送端CRC曾被加擾過,則在接收端校驗之前,應先從接收到的數據末尾截取出CRC進行解擾,然后再將解擾后的CRC添加回去,最后對整個接收數據進行CRC校驗。如果CRC校驗正確,則接收數據正確;否則接收數據錯誤,在此程序流程不再贅述。
4 性能分析
    在DSP軟件實現中,通過指令并行,盡量優(yōu)化程序循環(huán)體[6],減少或消除程序中的“NOP”指令。對于不同格式的CRC,根據它們所用的環(huán)境以及數據的大致長度,通過程序仿真運行,可以得到統(tǒng)計結果如表1。
    表1的數據長度僅為個別舉例,但不失一般性。從表中可以看出,雖然塊異或長除法的運算量較大,但是當運用TMS320C64x芯片實現時,由于處理器的超高主頻,其計算速率也非???,完全可以忽略它的計算量。因此,本實現采用塊異或長除法不僅簡化了程序實現方法,還減少了模塊程序代碼,節(jié)約了系統(tǒng)存儲空間。

    本文從理論分析出發(fā),根據TD-LTE系統(tǒng)特性,選擇了一種最優(yōu)的CRC校驗算法,并在TMS320C64x芯片上加以實現,詳細講述了塊異或長除法在DSP中的實現方法。程序運行結果表明,本實現能夠滿足LTE系統(tǒng)的需要,具有可行性和高效性。

參考文獻
[1] 王新梅.糾錯碼原理與方法[M].西安:西安電子科技大學出版社,2003.
[2] 3GPP TS 36.212 v8.7.0:Multiplexing and channel coding.(Release 8)[S].2009-05.
[3] Qualcomm Europe.Generator polynomial for transport block CRC[EB/OL].Http://www.3gpp.org,2007.10.
[4] 張莉麗,張振權,劉仁.CRC查表生成算法匯編的實現及其優(yōu)化[J].計算機應用,2005(4).
[5] Texas Instruments Incorporated.TMS320C64x/C64x+DSP CPU and Instruction Set Reference Guide[EB/OL].Http://www.ti.com.cn,2008.
[6] Texas Instruments Incorporated.TMS320C6000系列DSP編程工具與指南[M].田黎育,何佩琨,朱夢宇,譯.北京:清華大學出版社,2006:32-50.

此內容為AET網站原創(chuàng),未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美天堂亚洲电影院在线播放| 国产主播喷水一区二区| 亚洲欧美另类久久久精品2019| 亚洲人成亚洲人成在线观看| 校园春色综合网| 亚洲综合视频网| 中文日韩在线视频| 99综合电影在线视频| 亚洲精品在线一区二区| 亚洲精品久久嫩草网站秘色| 亚洲成人资源| 亚洲高清激情| 亚洲高清视频在线观看| 在线看欧美视频| 激情文学一区| 伊人狠狠色丁香综合尤物| 国内久久精品| 伊人久久男人天堂| 亚洲国产成人久久综合一区| 亚洲国产精品久久久久秋霞蜜臀| 亚洲风情在线资源站| 亚洲电影免费观看高清完整版在线观看 | 麻豆精品网站| 欧美黄色aaaa| 欧美日韩一区二区精品| 国产精品久久午夜| 国产欧美一区二区色老头| 国产日韩欧美在线播放| 国产一区二区三区日韩欧美| 激情亚洲网站| 日韩系列欧美系列| 亚洲性感激情| 久久se精品一区精品二区| 亚洲欧洲日本一区二区三区| 99热免费精品在线观看| 亚洲欧美bt| 久久婷婷综合激情| 欧美激情自拍| 国产精品久久久久久超碰| 国产日韩高清一区二区三区在线| 一区二区视频在线观看| 亚洲日本理论电影| 亚洲淫性视频| 91久久精品一区二区别| 亚洲午夜视频在线观看| 久久福利视频导航| 欧美成人激情视频免费观看| 欧美日韩另类一区| 国产欧美日韩综合精品二区| 在线成人性视频| 一区二区三区国产盗摄| 欧美在线视频免费观看| 99视频日韩| 久久精品国产99国产精品澳门| 欧美jizzhd精品欧美巨大免费| 欧美日一区二区在线观看 | 欧美亚韩一区| 黄色成人在线观看| 一本色道久久综合亚洲精品小说 | 欧美一区二区三区日韩| 亚洲激情在线播放| 亚洲在线视频一区| 美日韩精品视频免费看| 国产精品高清一区二区三区| 尤物99国产成人精品视频| 日韩视频在线观看| 久久精品国产亚洲aⅴ| 一本色道久久综合亚洲精品小说 | 亚洲福利视频一区| 亚洲视频在线观看网站| 久久蜜桃精品| 国产精品激情| 亚洲区免费影片| 欧美有码在线视频| 亚洲综合国产| 欧美激情一二区| 国产在线不卡视频| 亚洲视频观看| 9人人澡人人爽人人精品| 久久久av网站| 国产精品看片资源| 亚洲精品视频在线观看网站| 欧美中文在线观看国产| 亚洲欧美激情诱惑| 欧美久久精品午夜青青大伊人| 国产在线精品自拍| 亚洲欧美国产不卡| 亚洲一区二区三区在线| 欧美精品一区在线播放| 在线观看欧美日韩| 欧美一区二区日韩一区二区| 亚洲性感美女99在线| 欧美黄色网络| 亚洲第一黄色| 久久精品国产久精国产思思 | 久久国产精品久久久久久| 欧美日韩综合网| 亚洲精品麻豆| 亚洲精品一区在线观看| 美女主播精品视频一二三四| 国产无一区二区| 亚洲愉拍自拍另类高清精品| 亚洲视频1区| 欧美久久一级| 亚洲欧洲日本专区| 亚洲人成网站777色婷婷| 久久综合999| 精品成人免费| 久久经典综合| 久久久.com| 国产亚洲精品自拍| 亚洲欧美综合| 欧美影院在线播放| 国产乱人伦精品一区二区| 一区二区三区四区蜜桃| 亚洲一级网站| 国产精品v欧美精品v日韩精品| 一本色道久久综合狠狠躁篇的优点 | 一区二区三区国产在线| 亚洲一区二区三区四区中文| 欧美日韩中国免费专区在线看| 亚洲精品欧美日韩| 一区二区三区欧美视频| 欧美性事免费在线观看| 宅男精品视频| 性欧美暴力猛交69hd| 国产模特精品视频久久久久 | 国产精品毛片a∨一区二区三区|国 | 亚洲精品乱码久久久久久按摩观| 欧美91精品| 亚洲精品美女在线观看| 在线视频亚洲一区| 欧美亚洲不卡| 亚洲尤物在线视频观看| 久久精品视频亚洲| 激情成人在线视频| 亚洲人成小说网站色在线| 欧美精彩视频一区二区三区| 亚洲免费黄色| 欧美亚洲专区| 狠狠88综合久久久久综合网| 91久久中文字幕| 欧美日韩在线播放一区二区| 亚洲免费婷婷| 久久尤物视频| 亚洲精品一区在线观看| 亚洲一区在线视频| 国产亚洲成av人在线观看导航| 亚洲高清三级视频| 欧美看片网站| 亚洲免费一在线| 另类专区欧美制服同性| 亚洲精品偷拍| 欧美在线观看视频在线| 在线高清一区| 亚洲伊人伊色伊影伊综合网| 国产伦理精品不卡| 亚洲二区精品| 欧美三级资源在线| 欧美一区二区三区免费观看| 欧美成人精品三级在线观看| 99视频+国产日韩欧美| 久久国产日韩欧美| 91久久精品网| 亚洲欧美成人综合| 精品电影一区| 亚洲男人第一av网站| 精品成人一区二区三区| 亚洲一区三区在线观看| 一区二区三区在线免费观看| 亚洲视频一区二区在线观看| 国产亚洲一区精品| 在线亚洲欧美视频| 国产中文一区二区| 亚洲一区日韩在线| 亚洲第一区中文99精品| 午夜精品一区二区三区在线播放 | 一区二区成人精品| 国产中文一区二区| 亚洲资源av| 亚洲国产成人精品女人久久久 | 亚洲尤物精选| 欧美激情一区在线观看| 欧美亚洲在线观看| 欧美日韩国产区一| 久久精品国内一区二区三区| 欧美日韩视频在线第一区| 久久不射中文字幕| 国产精品成人一区二区三区夜夜夜| 欧美诱惑福利视频| 国产精品久久久久久久久借妻| 91久久久久久| 国产综合视频| 亚洲欧美日本另类| 亚洲精品一区二区三区蜜桃久 | 欧美顶级大胆免费视频| 欧美亚洲免费| 欧美性色aⅴ视频一区日韩精品| 亚洲欧洲日本国产| 国自产拍偷拍福利精品免费一|