本發(fā)明涉及一種基于ARM的參數(shù)識別系統(tǒng)的網(wǎng)絡(luò)協(xié)議的工作方法,屬于網(wǎng)絡(luò)通信及衛(wèi)星移動通信領(lǐng)域。
背景技術(shù):
S標準以全球通信系統(tǒng)標準GSM(Global System for Communication)為基礎(chǔ)衍化而來,是針對地球同步衛(wèi)星移動通信設(shè)置的標準,由ETSI(European Telecommunication Standards Institute)歐洲電信標準委員會制定。T衛(wèi)星系統(tǒng)廣泛應(yīng)用于歐洲、中東、非洲的北部、中部、東部以及亞洲和澳大利亞等地區(qū),并為這些地區(qū)提供衛(wèi)星通信網(wǎng)絡(luò),涉及手持設(shè)備(如手機)和一些海事設(shè)施的通信,用以傳輸一些傳統(tǒng)設(shè)施(如GSM,UMTS,WLAN等)不能傳輸?shù)恼Z音、傳真和以IP為基礎(chǔ)的數(shù)據(jù)。
S標準設(shè)計的網(wǎng)絡(luò)分為三個部分,分別為地面發(fā)射部分,空間轉(zhuǎn)接部分和用戶終端系統(tǒng),如圖1所示。
S標準設(shè)計的網(wǎng)絡(luò)中使用的信道可以分為兩類,一種是傳輸語音和傳真數(shù)據(jù)的業(yè)務(wù)信道,另一種是為了發(fā)送信令或同步數(shù)據(jù)的控制信道。為保證信道中數(shù)據(jù)傳輸?shù)目煽啃?,論文“非協(xié)作通信中基于卷積碼的信息截獲技術(shù)研究”【山東大學(xué),梅文杰,碩士畢業(yè)論文,2015.4.25】中針對部分特殊信道,如頻率校正信道、通用公共信道和業(yè)務(wù)信道,提出一種加密算法,以及業(yè)務(wù)信道上的密碼參數(shù)盲識別算法,但該文并未給出密碼參數(shù)盲識別算法的具體硬件實現(xiàn)方法。
技術(shù)實現(xiàn)要素:
針對現(xiàn)有技術(shù)存在的缺陷及不足,本發(fā)明提出一種基于ARM的某通信系統(tǒng)的網(wǎng)絡(luò)協(xié)議及其實現(xiàn)。本發(fā)明為S標準中的業(yè)務(wù)信道密碼參數(shù)盲識別的參數(shù)識別系統(tǒng),設(shè)計并實現(xiàn)了一套基于ARM的網(wǎng)絡(luò)接口。本實現(xiàn)方法將參數(shù)識別系統(tǒng)以及第三方接收機隔離,對外只提供TCP接口,以保證該參數(shù)識別系統(tǒng)內(nèi)部的穩(wěn)定性及對外的唯一性,且具體實現(xiàn)過程提高了系統(tǒng)的健壯性及可維護性。本發(fā)明提出的網(wǎng)絡(luò)協(xié)議中,對一些重要數(shù)據(jù)進行卷積碼編碼之后在進行傳輸,以保證傳輸?shù)目煽啃浴?/p>
本發(fā)明采用的技術(shù)方案如下:
一種基于ARM的參數(shù)識別系統(tǒng)的網(wǎng)絡(luò)協(xié)議的工作方法,該系統(tǒng)包括ARM處理器、一個100M網(wǎng)口、網(wǎng)口插座和一個FPGA模塊,網(wǎng)口插座采用RJ45接口,內(nèi)置變壓器;ARM處理 器通過數(shù)據(jù)線、地址線及控制信號線連接FPGA模塊,ARM處理器經(jīng)RJ45接口和接收機相連接,接收機遵循TCP/IP協(xié)議的本網(wǎng)絡(luò)協(xié)議進行通信;FPGA模塊能完成參數(shù)識別算法,利用ARM處理器實現(xiàn)對外數(shù)據(jù)的接收和發(fā)送,以及與FPGA模塊的數(shù)據(jù)交互;ARM處理器與FPGA模塊數(shù)據(jù)交互過程包括兩方面:當ARM處理器對接收機發(fā)送過來的數(shù)據(jù)進行處理之后,通過與FPGA中的數(shù)據(jù)線及其地址線,將處理后的數(shù)據(jù)發(fā)送到FPGA的接收數(shù)據(jù)緩沖區(qū),并通過控制信號線告知FPGA所需操作;FPGA模塊完成參數(shù)識別后,會將數(shù)據(jù)保存在FPGA模塊的發(fā)送數(shù)據(jù)緩沖區(qū),ARM處理器可通過讀取該緩沖區(qū)以得到所需數(shù)據(jù),該網(wǎng)絡(luò)協(xié)議包含五種指令,共用一種數(shù)據(jù)包結(jié)構(gòu),在ARM處理器芯片中刷入Linux系統(tǒng),并通過C語言實現(xiàn)服務(wù)端的應(yīng)用程序,該程序控制指令的收發(fā)及處理過程,將該程序放入ARM啟動目錄,以達到ARM處理器開機后自動啟動該程序的目的,該網(wǎng)絡(luò)協(xié)議使用的數(shù)據(jù)包結(jié)構(gòu)采用包頭加包體結(jié)構(gòu),包含五字節(jié)的包頭信息,以及若干字節(jié)的通信報文,包頭首字節(jié)為指令類型,第二三字節(jié)為通信報文長度,第四字節(jié)為附帶參數(shù)信息即通話唯一標識長度,第五字節(jié)為最大允許的包長度,該最大包長度固定為65536字節(jié),五種指令為:
⑴請求識別指令:通信報文為通話唯一標識和密文數(shù)據(jù)報,通話唯一標識可自由定義,密文數(shù)據(jù)報的數(shù)組以每22字節(jié)為一組,第一組為報頭,其余為上下行數(shù)據(jù),報頭前三字節(jié)依次為類型、下行數(shù)據(jù)幀數(shù)、上行數(shù)據(jù)幀數(shù),其后字節(jié)目前留空;上下行數(shù)據(jù)以每22字節(jié)為一組,其中每組數(shù)組包含19比特的幀號,以及待識別的48*2比特的時隙數(shù)據(jù);
⑵發(fā)送識別結(jié)果指令:通信報文為通話唯一標識和識別成功標識,通話唯一標識可自行定義,識別成功標識長度為一字節(jié):1代表識別成功,0代表識別失?。?/p>
⑶請求密鑰流指令:通信報文為通話唯一標識和請求密鑰流數(shù)據(jù)報,請求密鑰流數(shù)據(jù)報長度固定為40比特,其中前兩比特為每幀密鑰流長度,之后依次為19比特的起始幀號和19比特的結(jié)束幀號;
⑷返回密鑰流指令:通信報文為通話唯一標識和密鑰流數(shù)據(jù),密鑰流數(shù)據(jù)報由三部分組成:兩字節(jié)的每幀數(shù)據(jù)長度,19字節(jié)的起始幀號,n幀數(shù)據(jù);
⑸心跳包:長度為零,只發(fā)送包頭;
其中第一、三種指令是為接收機設(shè)計的指令,第二、四指令是為ARM處理器而設(shè)計,第五種指令由接收機和ARM處理器每隔五秒相互發(fā)送一次,當連續(xù)二十秒未收到心跳包,則重新建立連接;前四種指令需相互配合,才能完成接收機對參數(shù)識別算法的調(diào)用;
上述網(wǎng)絡(luò)協(xié)議的工作方法,其步驟如下:
1)接收機連接ARM處理器對外提供的TCP端口,連接成功后接收機遵循本網(wǎng)絡(luò)接口向ARM處理器發(fā)送指令,將待識別的數(shù)據(jù)以48*2比特為一幀,首先接收機對每幀數(shù)據(jù)進行預(yù) 編碼,預(yù)編碼采用卷積碼的方式,具體過程如下:
a)將每幀的96比特數(shù)據(jù)統(tǒng)一成信息序列u=u(u1,u2...u96);
b)計算生成矩陣,采用二元(2,1,4)卷積碼結(jié)構(gòu),則兩路脈沖沖激響應(yīng)為 構(gòu)造出如下生成矩陣:
c)計算輸出碼字,利用如下公式求得輸出碼字c
得到預(yù)編碼數(shù)據(jù)后,將19比特幀號與預(yù)編碼之后的數(shù)據(jù)封裝成22比特一組的數(shù)據(jù),將上下行數(shù)據(jù)都封裝成22比特一組的數(shù)據(jù)后,與通話唯一標識一起封裝成請求識別指令發(fā)送到FPGA模塊;
2)ARM處理器首先接收接收機發(fā)送的五字節(jié)包頭,依次判斷指令類型,通信報文長度,通話唯一標識長度,若ARM處理器接收到的指令為請求識別指令,首先根據(jù)通信報文長度接收指定長度的字節(jié)數(shù)到本地緩沖區(qū),之后根據(jù)密文數(shù)據(jù)報第一組數(shù)組確定上下行數(shù)據(jù)長度,然后每22字節(jié)一組解析出19比特幀號以及預(yù)編碼數(shù)據(jù),利用維特比譯碼方法將預(yù)編碼數(shù)據(jù)轉(zhuǎn)為48*2比特的時隙數(shù)據(jù),將時隙數(shù)據(jù)以每次48比特通過與FPGA模塊相連的端口傳輸?shù)紽PGA的內(nèi)存空間,傳輸16次等待一次識別結(jié)果,當全部數(shù)據(jù)識別完成后,向接收機發(fā)送識別結(jié)果指令;
3)接收機收到指令后,首先接收五字節(jié)的包頭,依次判斷指令類型,通信報文長度,通話唯一標識長度,若接收到的指令為識別結(jié)果指令,則將19比特的起始幀號與結(jié)束幀號經(jīng)過卷積碼編碼之后,與每幀長度一起封裝成請求密鑰流指令;
4)ARM處理器收到接收機的指令后,首先接收字節(jié)的包頭,依次判斷指令類型,通信報文長度,通話唯一標識長度,若接收到的指令為請求密鑰流指令,首先解析出每幀長度以及起始幀號,并計算出共請求的幀數(shù)n,之后根據(jù)起始幀號從FPGA模塊指定地址讀取n幀數(shù)據(jù),最后將每幀長度、起始幀號、n幀數(shù)據(jù)封裝成返回密鑰流指令,并向接收機發(fā)送該指令;
5)重復(fù)步驟1)、2)、3)、4),當連續(xù)二十秒未收到心跳包,按斷開連接處理,接收機與FPGA模塊重新建立連接,再重復(fù)步驟1)2)3)4)5)。
所述的ARM,過去稱作進階精簡指令集機器(Advanced RISC Machine,更早稱作:Acorn RISC Machine),是一個32位精簡指令集(RISC)處理器,其廣泛地使用在許多嵌入式系統(tǒng)設(shè)計。
所述的FPGA(Field-Programmable Gate Array),即現(xiàn)場可編程門陣列,它是在PAL、GAL、CPLD等可編程器件的基礎(chǔ)上進一步發(fā)展的產(chǎn)物。
所述的TCP是英文Transmission Control Protocol的縮寫,TCP端口就是為TCP協(xié)議通信提供服務(wù)的端口。
所述的RJ45是布線系統(tǒng)中信息插座連接器的一種,由插頭和插座組成,插頭有8個凹槽和8個觸點,用于數(shù)據(jù)電纜的端接,實現(xiàn)設(shè)備、端線、配線架模塊間的連接及變更。
本發(fā)明的有益效果如下:
1.本發(fā)明將參數(shù)識別系統(tǒng)以及接收機隔離,對外只提供TCP接口,以保證該參數(shù)識別系統(tǒng)內(nèi)部的穩(wěn)定性及對外的唯一性;
2.本發(fā)明數(shù)據(jù)包統(tǒng)一采用包頭加包體的結(jié)構(gòu),提高了該協(xié)議的健壯性及可維護性;
3.本發(fā)明采用ARM處理器,靈活性高,能夠擴展多種功能;
4.本發(fā)明對一些重要數(shù)據(jù)進行卷積碼編碼之后在進行傳輸,以保證傳輸?shù)目煽啃浴?/p>
附圖說明
圖1為S標準設(shè)計的網(wǎng)絡(luò)結(jié)構(gòu),當衛(wèi)星電話發(fā)射呼叫信號后,空間段接收信號并進行轉(zhuǎn)接,發(fā)射到公用開關(guān)電話網(wǎng)絡(luò)PSTN(Public Switched Telephone Network)進行維護和相關(guān)設(shè)置的工作,其中信號由空間段到地面段采用C-Band,真正發(fā)送到用戶的信號運用L-band的點波束為載波;
圖2是本發(fā)明的參數(shù)識別系統(tǒng)中的ARM處理器與FPGA模塊、接收機相連的結(jié)構(gòu)框圖,ARM處理器經(jīng)RJ45接口和接收機相連接,ARM處理器通過數(shù)據(jù)線、地址線及控制信號線連接FPGA模塊。
具體實施方式
下面結(jié)合附圖和實施例對本發(fā)明作進一步說明,但不限于此。
實施例:
本發(fā)明實施例如圖2所示,一種基于ARM的參數(shù)識別系統(tǒng)的網(wǎng)絡(luò)協(xié)議的工作方法,該系統(tǒng)包括ARM處理器、一個100M網(wǎng)口、網(wǎng)口插座和一個FPGA模塊,網(wǎng)口插座采用RJ45接口,內(nèi)置變壓器;ARM處理器通過數(shù)據(jù)線、地址線及控制信號線連接FPGA模塊,ARM處理器經(jīng)RJ45接口和接收機相連接,接收機遵循TCP/IP協(xié)議的本網(wǎng)絡(luò)協(xié)議進行通信;FPGA模塊能完成參數(shù)識別算法,利用ARM處理器實現(xiàn)對外數(shù)據(jù)的接收和發(fā)送,以及與FPGA模塊的數(shù)據(jù)交互;ARM處理器與FPGA模塊數(shù)據(jù)交互過程包括兩方面:當ARM處理器對接收機發(fā)送過來的數(shù)據(jù)進行處理之后,通過與FPGA中的數(shù)據(jù)線及其地址線,將處理后的數(shù)據(jù)發(fā)送到FPGA的接收數(shù)據(jù)緩沖區(qū),并通過控制信號線告知FPGA所需操作;FPGA模塊完成參數(shù)識別后,會將數(shù)據(jù)保存在FPGA模塊的發(fā)送數(shù)據(jù)緩沖區(qū),ARM處理器可通過讀取該緩沖區(qū)以得到所需數(shù)據(jù),該網(wǎng)絡(luò)協(xié)議包含五種指令,共用一種數(shù)據(jù)包結(jié)構(gòu),在ARM處理器芯片中刷入Linux系統(tǒng),并通過C語言實現(xiàn)服務(wù)端的應(yīng)用程序,該程序控制指令的收發(fā)及處理過程,將該程序放入ARM啟動目錄,以達到ARM處理器開機后自動啟動該程序的目的,該網(wǎng)絡(luò)協(xié)議使用的數(shù)據(jù)包結(jié)構(gòu)采用包頭加包體結(jié)構(gòu),包含五字節(jié)的包頭信息,以及若干字節(jié)的通信報文,包頭首字節(jié)為指令類型,第二三字節(jié)為通信報文長度,第四字節(jié)為附帶參數(shù)信息即通話唯一標識長度,第五字節(jié)為最大允許的包長度,該最大包長度固定為65536字節(jié),五種指令為:
⑴請求識別指令:通信報文為通話唯一標識和密文數(shù)據(jù)報,通話唯一標識可自由定義,密文數(shù)據(jù)報的數(shù)組以每22字節(jié)為一組,第一組為報頭,其余為上下行數(shù)據(jù),報頭前三字節(jié)依次為類型、下行數(shù)據(jù)幀數(shù)、上行數(shù)據(jù)幀數(shù),其后字節(jié)目前留空;上下行數(shù)據(jù)以每22字節(jié)為一組,其中每組數(shù)組包含19比特的幀號,以及待識別的48*2比特的時隙數(shù)據(jù);
⑵發(fā)送識別結(jié)果指令:通信報文為通話唯一標識和識別成功標識,通話唯一標識可自行定義,識別成功標識長度為一字節(jié):1代表識別成功,0代表識別失??;
⑶請求密鑰流指令:通信報文為通話唯一標識和請求密鑰流數(shù)據(jù)報,請求密鑰流數(shù)據(jù)報長度固定為40比特,其中前兩比特為每幀密鑰流長度,之后依次為19比特的起始幀號和19比特的結(jié)束幀號;
⑷返回密鑰流指令:通信報文為通話唯一標識和密鑰流數(shù)據(jù),密鑰流數(shù)據(jù)報由三部分組成:兩字節(jié)的每幀數(shù)據(jù)長度,19字節(jié)的起始幀號,n幀數(shù)據(jù);
⑸心跳包:長度為零,只發(fā)送包頭;
其中第一、三種指令是為接收機設(shè)計的指令,第二、四指令是為ARM處理器而設(shè)計,第 五種指令由接收機和ARM處理器每隔五秒相互發(fā)送一次,當連續(xù)二十秒未收到心跳包,則重新建立連接;前四種指令需相互配合,才能完成接收機對參數(shù)識別算法的調(diào)用;
上述網(wǎng)絡(luò)協(xié)議的工作方法,其步驟如下:
1)接收機連接ARM處理器對外提供的TCP端口,連接成功后接收機遵循本網(wǎng)絡(luò)接口向ARM處理器發(fā)送指令,將待識別的數(shù)據(jù)以48*2比特為一幀,首先接收機對每幀數(shù)據(jù)進行預(yù)編碼,預(yù)編碼采用卷積碼的方式,具體過程如下:
a)將每幀的96比特數(shù)據(jù)統(tǒng)一成信息序列u=u(u1,u2...u96);
b)計算生成矩陣,采用二元(2,1,4)卷積碼結(jié)構(gòu),則兩路脈沖沖激響應(yīng)為 構(gòu)造出如下生成矩陣:
c)計算輸出碼字,利用如下公式求得輸出碼字c
得到預(yù)編碼數(shù)據(jù)后,將19比特幀號與預(yù)編碼之后的數(shù)據(jù)封裝成22比特一組的數(shù)據(jù),將上下行數(shù)據(jù)都封裝成22比特一組的數(shù)據(jù)后,與通話唯一標識一起封裝成請求識別指令發(fā)送到FPGA模塊;
2)ARM處理器首先接收接收機發(fā)送的五字節(jié)包頭,依次判斷指令類型,通信報文長度,通話唯一標識長度,若ARM處理器接收到的指令為請求識別指令,首先根據(jù)通信報文長度接 收指定長度的字節(jié)數(shù)到本地緩沖區(qū),之后根據(jù)密文數(shù)據(jù)報第一組數(shù)組確定上下行數(shù)據(jù)長度,然后每22字節(jié)一組解析出19比特幀號以及預(yù)編碼數(shù)據(jù),利用維特比譯碼方法將預(yù)編碼數(shù)據(jù)轉(zhuǎn)為48*2比特的時隙數(shù)據(jù),將時隙數(shù)據(jù)以每次48比特通過與FPGA模塊相連的端口傳輸?shù)紽PGA的內(nèi)存空間,傳輸16次等待一次識別結(jié)果,當全部數(shù)據(jù)識別完成后,向接收機發(fā)送識別結(jié)果指令;
3)接收機收到指令后,首先接收五字節(jié)的包頭,依次判斷指令類型,通信報文長度,通話唯一標識長度,若接收到的指令為識別結(jié)果指令,則將19比特的起始幀號與結(jié)束幀號經(jīng)過卷積碼編碼之后,與每幀長度一起封裝成請求密鑰流指令;
4)ARM處理器收到接收機的指令后,首先接收字節(jié)的包頭,依次判斷指令類型,通信報文長度,通話唯一標識長度,若接收到的指令為請求密鑰流指令,首先解析出每幀長度以及起始幀號,并計算出共請求的幀數(shù)n,之后根據(jù)起始幀號從FPGA模塊指定地址讀取n幀數(shù)據(jù),最后將每幀長度、起始幀號、n幀數(shù)據(jù)封裝成返回密鑰流指令,并向接收機發(fā)送該指令;
5)重復(fù)步驟1)、2)、3)、4),當連續(xù)二十秒未收到心跳包,按斷開連接處理,接收機與FPGA模塊重新建立連接,再重復(fù)步驟1)2)3)4)5)。
本發(fā)明所使用的ARM處理器是由三星公司推出的一款低功耗、高性價比的S3C6410處理器。