欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

一種基于VHDL可控制起停傳輸移位寄存器操作方法與流程

文檔序號(hào):12476157閱讀:935來源:國(guó)知局
一種基于VHDL可控制起停傳輸移位寄存器操作方法與流程

本發(fā)明涉及通信領(lǐng)域移位寄存器,尤其涉及一種基于VHDL可控制起停傳輸移位寄存器操作方法。



背景技術(shù):

移位寄存器在應(yīng)用領(lǐng)域中常用來進(jìn)行數(shù)據(jù)緩沖,實(shí)現(xiàn)串入并出等方式,完成功能的同時(shí)可提高傳輸過程中的穩(wěn)定性,是EDA技術(shù)中不可或缺的一個(gè)設(shè)計(jì)環(huán)節(jié)。

目前,常用的基于VDHL的移位寄存器只考慮對(duì)數(shù)據(jù)進(jìn)行移位計(jì)算,在時(shí)鐘控制下對(duì)數(shù)據(jù)進(jìn)行存入取出,不考慮數(shù)據(jù)傳輸?shù)钠鹗寂c停止。即使有的移位寄存器考慮了起始問題,但由于時(shí)序邏輯所限制,檢測(cè)到幀頭的起始標(biāo)識(shí)時(shí),往往對(duì)其進(jìn)行丟棄,從下一幀的用戶數(shù)據(jù)開始傳輸,同樣的,幀尾也會(huì)被丟棄。這使得數(shù)據(jù)在接口傳輸中帶來了很大不便,當(dāng)存在通信協(xié)議約束時(shí),下游模塊需要上游模塊發(fā)送整個(gè)幀,即包含幀頭和幀尾的部分,那么必須要求幀的完整性。



技術(shù)實(shí)現(xiàn)要素:

本發(fā)明公開一種基于VHDL語言的可以控制起始與停止傳輸?shù)拇休斎氩⑿休敵龅囊莆患拇嫫鞑僮鞣椒?,能夠根?jù)協(xié)議設(shè)定傳輸數(shù)據(jù)的起始和停止時(shí)間,能夠避免數(shù)據(jù)塊內(nèi)重復(fù)數(shù)據(jù)的串?dāng)_,能夠避免丟棄幀頭幀尾的數(shù)據(jù)。相對(duì)于現(xiàn)有技術(shù)更加穩(wěn)定與有效,可靠性強(qiáng)。

為了實(shí)現(xiàn)上述目的,本發(fā)明采用如下方案:

一種基于VHDL可控制起停傳輸移位寄存器操作方法,包括步驟:

步驟一:初始化(即開始);

步驟二:掃描讀數(shù);

步驟三:判斷是否為幀頭;

步驟四:執(zhí)行幀頭是操作或者幀頭否操作;

所述步驟四的幀頭否操作是重復(fù)執(zhí)行一次步驟二掃描讀數(shù)。

所述步驟四的幀頭是操作包括:

S1:打開控制信號(hào);

S2:移位寄存;

S3:按bit讀數(shù)

S4:判斷bit位是否是第8位

S5:執(zhí)行bit第8位是操作或者bit第8位否操作。

所述bit第8位否操作是繼續(xù)所述按bit讀數(shù)的步驟。

所述bit第8位是操作包括:

S6:所述bit的下一bit數(shù)據(jù)進(jìn)行所述移位寄存;

S7:所述bit數(shù)據(jù)并行輸出;

S8:幀尾判斷;

S9:執(zhí)行幀尾是操作或者幀尾否操作。

所述幀尾否操作是繼續(xù)執(zhí)行所述bit數(shù)據(jù)并行輸出。

所述幀尾是操作包括:

S10::所述幀傳輸停止;

S11:關(guān)閉控制信號(hào);

S12:所述幀的下一幀掃描讀數(shù)。

所述S10和S11兩個(gè)步驟無先后順序。

本發(fā)明的有益效果是能夠?qū)崿F(xiàn)幀頭和幀尾標(biāo)志的識(shí)別,且在不丟棄幀頭和幀尾的情況下進(jìn)行數(shù)據(jù)的串入并出傳輸。同時(shí)避免了三個(gè)問題,一是避免了下游模塊對(duì)數(shù)據(jù)傳輸時(shí)再次添加幀頭幀尾的麻煩,二是避免數(shù)據(jù)段中出現(xiàn)與幀頭幀尾相同的數(shù)據(jù)時(shí)出現(xiàn)突然中斷或傳輸數(shù)據(jù)混亂的問題,三是幀與幀間的數(shù)據(jù)存在傳輸間隔時(shí),能夠避免無效數(shù)據(jù)的傳輸且能隨時(shí)根據(jù)需要繼續(xù)傳輸。

附圖說明

圖1為本發(fā)明幀數(shù)據(jù)結(jié)構(gòu)示意圖。

圖2為本發(fā)明移位寄存示意圖。

圖3為本發(fā)明設(shè)計(jì)方案的流程框圖。

圖4為本發(fā)明第一實(shí)施例數(shù)據(jù)傳輸仿真圖。

圖5為本發(fā)明控制單元信號(hào)仿真圖。

圖6為本發(fā)明控制有效數(shù)據(jù)傳輸仿真圖。

圖7為本發(fā)明控制無效信號(hào)仿真圖。

具體實(shí)施方式

下面結(jié)合附圖對(duì)本發(fā)明具體實(shí)施例做出詳細(xì)說明。

數(shù)據(jù)傳輸以幀為單位,一個(gè)完整幀的結(jié)構(gòu)如圖1所示。其中幀頭作為每一幀傳輸?shù)钠鹗紭?biāo)識(shí),類似“身份驗(yàn)證”,具有該幀頭的數(shù)據(jù)才會(huì)被接收;幀頭之后為用戶數(shù)據(jù),為本次傳輸?shù)男畔?;幀尾作為結(jié)束標(biāo)志,通常包含校驗(yàn)信息等,有的場(chǎng)合可不加。

首先,確定并行輸出的長(zhǎng)度,即每個(gè)Byte的長(zhǎng)度,一般為8bit(該方案說明以8為例)。通過滑窗方法(窗的長(zhǎng)度要大于等于Byte長(zhǎng)度),檢測(cè)所輸入的8位數(shù)據(jù)是否為幀頭。

當(dāng)檢測(cè)到為幀頭時(shí),即開始讀取數(shù)據(jù),并開啟控制信號(hào),兩者互不干擾,且無先后順序,使得在檢測(cè)到幀尾前都不會(huì)中斷數(shù)據(jù)傳輸,且即使數(shù)據(jù)與幀頭編碼相同,也不會(huì)造成混亂。

讀取數(shù)據(jù)進(jìn)行移位寄存,如圖2所示,后7位依次前移一位,即令1到7位依次代替原本的2到8位,丟棄原本的第8位,讀取串行進(jìn)入的一位數(shù)作為新的第1位。按bit位讀取數(shù)據(jù),每當(dāng)bit位數(shù)為8的時(shí)候,對(duì)數(shù)據(jù)并行輸出,即把八位數(shù)同時(shí)輸出。當(dāng)檢測(cè)到輸出的數(shù)據(jù)為幀尾時(shí),停止輸出,此幀傳輸完畢,并關(guān)閉控制信號(hào),以便進(jìn)行下一幀的檢測(cè)與傳輸。

控制信號(hào)單元起著很重要的作用,也是該方案能夠?qū)崿F(xiàn)的重要一環(huán)。其保證了自檢測(cè)到幀頭后到檢測(cè)到幀尾前,不會(huì)受到數(shù)據(jù)與幀頭幀尾編碼相同的干擾,從而保證了整個(gè)傳輸過程中不會(huì)發(fā)生碼元混亂。同時(shí),由于控制信號(hào)單元,能夠使得幀與幀之間的時(shí)間間隔不會(huì)對(duì)傳輸造成任何影響。可以隨時(shí)開始傳幀,也可以隨時(shí)停止。

整個(gè)設(shè)計(jì)方案的流程框圖如圖3所示,本發(fā)明寄存器操作方法包括以下步驟:

步驟一:初始化(即開始);

步驟二:掃描讀數(shù);

步驟三:判斷是否為幀頭;

步驟四:執(zhí)行幀頭是操作或者幀頭否操作;

其中,步驟四的幀頭否操作是重復(fù)執(zhí)行一次步驟二掃描讀數(shù)。

步驟四的幀頭是操作包括S1-S5步:

S1:打開控制信號(hào);

S2:移位寄存;

S3:按bit讀數(shù)

S4:判斷bit位是否是第8位

S5:執(zhí)行bit第8位是操作或者bit第8位否操作。

其中S5中bit第8位否操作是繼續(xù)所述按bit讀數(shù)的步驟。

S5中bit第8位是操作包括(S6-S9):

S6:所述bit的下一bit數(shù)據(jù)進(jìn)行所述移位寄存;

S7:所述bit數(shù)據(jù)并行輸出;

S8:幀尾判斷;

S9:執(zhí)行幀尾是操作或者幀尾否操作。

其中S9的幀尾否操作是繼續(xù)執(zhí)行所述bit數(shù)據(jù)并行輸出。

S9中幀尾是操作包括(S10-S12):

S10::所述幀傳輸停止;

S11:關(guān)閉控制信號(hào);

S12:所述幀的下一幀掃描讀數(shù)。

其中S10和S11兩個(gè)步驟無先后順序。

實(shí)施例一:

選用Xilinx的ISEDesignSuite14.6的仿真軟件對(duì)寄存器進(jìn)行仿真。如圖4所示,假定…均為無效信息;編寫VHDL代碼文件,描述以上所述方案流程;編寫Testbench激勵(lì)文件,以驗(yàn)證VHDL文件的正確性;通過激勵(lì)文件,采用Xilinx自帶的iSim仿真器進(jìn)行仿真,生成仿真圖。

例如,假定1Byte數(shù)據(jù)為8bit組成,幀頭framehead數(shù)據(jù)為10101010,幀尾frametail數(shù)據(jù)為00111100,測(cè)試信號(hào)rx為00(10101010 10010011 00000000 11111111 11000000 00111100)00111111 00000000(10101010 11111111……)其中括號(hào)內(nèi)為需要傳輸?shù)挠行畔?,其余信息均為無效信息。

圖3所示流程圖中所描述的控制單元信號(hào),即為data_en,data_start,data_done與cnt。如圖5所示,置高用data_en置高來表示輸出為有效信息。設(shè)定信號(hào)data_start與data_done,前者置高表示檢測(cè)到幀頭,后者置高表示檢測(cè)到數(shù)據(jù)幀尾。設(shè)定計(jì)數(shù)器信號(hào)cnt,其作用是結(jié)合data_start與data_done進(jìn)行判決,保證在檢測(cè)到幀頭但還未檢測(cè)到幀尾時(shí),若用戶數(shù)據(jù)中出現(xiàn)與幀頭相同的情況,data_start不會(huì)再次置高,使得傳輸過程發(fā)生混亂;同樣,若用戶數(shù)據(jù)中出現(xiàn)與幀尾相同的情況,data_done不會(huì)提前置高,使得傳輸未完成即停止。

另外,通過對(duì)計(jì)數(shù)信號(hào)的控制,可以控制data_en的控制時(shí)間,保證有效信息輸出的時(shí)間與data_en的置高時(shí)間相吻合。如圖6所示,所有有效信息都在data_en置高期間輸出。

如圖7所示,一幀結(jié)束后,data_en會(huì)置低,直到檢測(cè)到下一幀的幀頭。期間所有的信息均為無效信息,不會(huì)進(jìn)入傳輸通路中來。

本發(fā)明的有益效果是能夠?qū)崿F(xiàn)幀頭和幀尾標(biāo)志的識(shí)別,且在不丟棄幀頭和幀尾的情況下進(jìn)行數(shù)據(jù)的串入并出傳輸。同時(shí)避免了三個(gè)問題:一是避免了下游模塊對(duì)數(shù)據(jù)傳輸時(shí)再次添加幀頭幀尾的麻煩;二是避免數(shù)據(jù)段中出現(xiàn)與幀頭幀尾相同的數(shù)據(jù)時(shí)出現(xiàn)突然中斷或傳輸數(shù)據(jù)混亂的問題;三是幀與幀間的數(shù)據(jù)存在傳輸間隔時(shí),能夠避免無效數(shù)據(jù)的傳輸且能隨時(shí)根據(jù)需要繼續(xù)傳輸。

以上對(duì)本發(fā)明的實(shí)施例進(jìn)行了詳細(xì)說明,但所述內(nèi)容僅為本發(fā)明的較佳實(shí)施例,不能被認(rèn)為用于限定本發(fā)明的實(shí)施范圍。凡依本發(fā)明申請(qǐng)范圍所作的均等變化、改進(jìn)或組合等,均應(yīng)仍歸屬于本發(fā)明的專利涵蓋范圍之內(nèi)。

當(dāng)前第1頁(yè)1 2 3 
網(wǎng)友詢問留言 已有0條留言
  • 還沒有人留言評(píng)論。精彩留言會(huì)獲得點(diǎn)贊!
1
定边县| 松阳县| 攀枝花市| 昌都县| 广灵县| 车致| 定日县| 冷水江市| 柳江县| 拜泉县| 开阳县| 玛纳斯县| 东平县| 旬阳县| 洱源县| 海门市| 平湖市| 上杭县| 宣武区| 无极县| 育儿| 江安县| 长沙市| 辉南县| 绥江县| 黑龙江省| 喀什市| 石台县| 习水县| 德保县| 蒲江县| 永宁县| 布尔津县| 阿拉尔市| 右玉县| 元江| 黑龙江省| 清镇市| 清镇市| 古蔺县| 合川市|