<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • 帶硬件地址識(shí)別的UART IP 的設(shè)計(jì)和實(shí)現(xiàn)

    時(shí)間:2024-10-10 18:37:20 理工畢業(yè)論文 我要投稿
    • 相關(guān)推薦

    帶硬件地址識(shí)別的UART IP 的設(shè)計(jì)和實(shí)現(xiàn)

    摘要:在通信和控制系統(tǒng)中,常使用異步串行通信控制器(UART)實(shí)現(xiàn)系統(tǒng)輔助信息的傳輸。為實(shí)現(xiàn)多點(diǎn)通信,通常用軟件識(shí)別發(fā)往本站點(diǎn)或其它站點(diǎn)的數(shù)據(jù),這會(huì)加大CPU的開銷。介紹了一種基于FPGA的UART IP,由硬件實(shí)現(xiàn)多點(diǎn)通信時(shí)的數(shù)據(jù)過濾功能,降低了CPU的負(fù)擔(dān),提高了系統(tǒng)性能。

    在通信和控制系統(tǒng)中,常使用異步串行通信實(shí)現(xiàn)多塊單板之間的輔助通信,各個(gè)單板通過總線方式連接。為了實(shí)現(xiàn)點(diǎn)對(duì)點(diǎn)通信,需要由軟件定義一套較復(fù)雜的通信協(xié)議,過濾往來的數(shù)據(jù),消耗了CPU較多的時(shí)間。89C51單片機(jī)有一種九位通信方式,采用一位地址位來實(shí)現(xiàn)通信對(duì)象的選擇,只對(duì)發(fā)往本地址的地址發(fā)生中斷進(jìn)而接收數(shù)據(jù)。通用的UART芯片如16C550和89C51等構(gòu)成總線式的通信系統(tǒng)時(shí),需要由CPU通過軟件處理接收到的地址和產(chǎn)生九位的數(shù)據(jù)。本文介紹的UART采用Verilog HDL硬件描述語言設(shè)計(jì),可以用FPGA實(shí)現(xiàn),可應(yīng)用于SoC設(shè)計(jì)中。其主要特性如下:

    ·全硬件地址識(shí)別,過濾數(shù)據(jù)不需要CPU的介入;支持一個(gè)特殊地址,可用于監(jiān)聽和廣播。

    ·支持查詢和中斷兩種工作方式,中斷可編程。

    ·接收和發(fā)送通路分別有128Byte FIFO,每個(gè)接收字節(jié)附帶狀態(tài)信息。

    ·設(shè)計(jì)采用Verilog HDL語言,全同步接口,可移植性好。

    ·支持自環(huán)測(cè)試功能。

    ·波特率可以編程,支持八位或者九位兩種數(shù)據(jù)格式。

    設(shè)計(jì)的UART的九位串行數(shù)據(jù)格式如圖1所示。在空閑狀態(tài),數(shù)據(jù)線處于高電平狀態(tài)。總線由高到低跳變,寬度為一個(gè)波特率時(shí)間的負(fù)脈沖為開始位,然后是8bit的數(shù)據(jù)位。數(shù)據(jù)位后面是lbit的地址信息位。如果此位是1,表示發(fā)送的字節(jié)是地址信息;如果此位是0,傳輸?shù)氖钦?shù)據(jù)信息。地址指示位后是串行數(shù)據(jù)的停止位。

    1 UART設(shè)計(jì)

    UART采用模塊化、層次化的設(shè)計(jì)思想,全部設(shè)計(jì)都采用Verilog HDL實(shí)現(xiàn),其組成框圖如圖2所示。整個(gè)UART IP由串行數(shù)據(jù)發(fā)送模塊、串行數(shù)據(jù)接收模塊、接收地址識(shí)別模塊、接收和發(fā)送HIFO、總線接口邏輯、寄存器和控制邏輯構(gòu)成。串行發(fā)送模塊和接收完成并/串及串/并的轉(zhuǎn)換,接收地址的識(shí)別由接收地址識(shí)別模塊完成。發(fā)送和接收HIFO用于緩存發(fā)送和接收的數(shù)據(jù)。總線接口邏輯用于連接UART IP內(nèi)部總線和HOST接口。寄存器和控制邏輯實(shí)現(xiàn)UART IP內(nèi)部所有數(shù)據(jù)的收發(fā)、控制和狀態(tài)寄存器、內(nèi)部中斷的控制及波特率信號(hào)的產(chǎn)生。以下詳細(xì)說明主要部分的設(shè)計(jì)原理。

    1.1 串行數(shù)據(jù)發(fā)送模塊

    串行數(shù)據(jù)發(fā)送模塊將數(shù)據(jù)或地址碼由并行轉(zhuǎn)換為串行,并從串行總線輸出。設(shè)計(jì)采用有限狀態(tài)機(jī)實(shí)現(xiàn),分為空閑、取數(shù)、發(fā)送三個(gè)狀態(tài)。其狀態(tài)遷移如圖3所示。各個(gè)狀態(tài)說明如下:

    空閑狀態(tài):狀態(tài)機(jī)不斷檢測(cè)發(fā)送使能位、UART使能位和發(fā)送FIFO空/滿標(biāo)志位,如果使能位為高、UART使能打開且FIFO空標(biāo)志位為低,串行發(fā)送進(jìn)入取數(shù)狀態(tài)。

    取數(shù)狀態(tài):在此狀態(tài),分兩個(gè)周期從發(fā)送FIFO中取出待發(fā)送的數(shù)據(jù)或者地址,然后進(jìn)入發(fā)送狀態(tài)。

    發(fā)送狀態(tài):在此狀態(tài),狀態(tài)機(jī)按照九位串行數(shù)據(jù)的格式依次發(fā)送開始位、數(shù)據(jù)位、地址指示位。待停止位發(fā)送完畢后,返回空閑狀態(tài)。一個(gè)字節(jié)的數(shù)據(jù)發(fā)送完畢后,進(jìn)行下一個(gè)字節(jié)數(shù)據(jù)的發(fā)送流程。

    1.2 串行數(shù)據(jù)接收模塊

    串行數(shù)據(jù)接收模塊用于檢測(cè)串行數(shù)據(jù)的開始位,將串行總線上的串行數(shù)據(jù)轉(zhuǎn)換成并行數(shù)據(jù)并輸出。接收邏輯也采用有限狀態(tài)機(jī)實(shí)現(xiàn),分為空閑狀態(tài)、尋找開始位、接收數(shù)據(jù)和保存數(shù)據(jù)四個(gè)狀態(tài)。其狀態(tài)遷移圖如圖4所示。各個(gè)狀態(tài)說明如下:

    空閑狀態(tài):在此狀態(tài),不斷檢測(cè)接收使能、UART使能和串行輸入信號(hào)的狀態(tài)。如果串行輸入信號(hào)出現(xiàn)由高到低的電平變化且UART使能和接收使能都為高,則將采樣計(jì)數(shù)器復(fù)位,并進(jìn)入尋找開始位狀態(tài)。

    尋找開始位:在此狀態(tài),狀態(tài)機(jī)等待半個(gè)波特率的時(shí)間,然后重新檢測(cè)串行輸入的電平。如果為低,則判斷收到的開始位有效,進(jìn)入接收數(shù)據(jù)狀態(tài);否則認(rèn)為數(shù)據(jù)總線上出現(xiàn)干擾,開始位無效,重新返回空閑狀態(tài)。

    接收數(shù)據(jù):在此狀態(tài),依次接收串行數(shù)據(jù)線上的數(shù)據(jù)位、地址指示位和停止位,結(jié)束后進(jìn)入保存數(shù)據(jù)狀態(tài)。

    保存數(shù)據(jù):此狀態(tài)將收到的串行數(shù)據(jù)以并行方式從接口的并行總線輸出,然后返回空閑狀態(tài),準(zhǔn)備進(jìn)行下一個(gè)字節(jié)數(shù)據(jù)的搜索和接收。

    為提高對(duì)串行輸入上突發(fā)干擾的抵抗能力,對(duì)于接收數(shù)據(jù),在脈沖的中間位置連續(xù)采樣三次,較多的電平作為接收的有效數(shù)據(jù)。所有接收數(shù)據(jù)的采樣頻率為接收波特率的16倍。

    1.3 硬件地址識(shí)別模塊

    硬件地址識(shí)別模塊用于從接收到的數(shù)據(jù)中判斷出地址和數(shù)據(jù),在地址識(shí)別功能打開時(shí),選擇數(shù)據(jù)通過或者丟棄;而該功能關(guān)閉時(shí),所有數(shù)據(jù)都會(huì)通過。地址識(shí)別模塊是一個(gè)有兩個(gè)狀態(tài)的有限狀態(tài)機(jī),分為地址和數(shù)據(jù)兩個(gè)狀態(tài)。其狀態(tài)遷移圖如圖5所示。狀態(tài)說明如下:

    地址狀態(tài):在此狀態(tài)時(shí),判斷接收到的數(shù)據(jù)以及地址識(shí)別使能位。如果地址識(shí)別功能沒有打開,對(duì)于接收的任何地址,都進(jìn)入數(shù)據(jù)狀態(tài)。如果地址識(shí)別功能打開,則將收到的地址和本地地址比較,如果相等,則保存此地址,進(jìn)入數(shù)據(jù)狀態(tài);否則繼續(xù)在此狀態(tài)接收數(shù)據(jù)和地址,將收到的數(shù)據(jù)忽略。

    數(shù)據(jù)狀態(tài):將接收到的數(shù)據(jù)輸出,

    【帶硬件地址識(shí)別的UART IP 的設(shè)計(jì)和實(shí)現(xiàn)】相關(guān)文章:

    IP協(xié)議設(shè)計(jì)實(shí)現(xiàn)—重裝模塊(一)03-07

    計(jì)算機(jī)硬件測(cè)試系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)12-11

    SoC設(shè)計(jì)中IP復(fù)用和驗(yàn)證策略03-07

    新聞發(fā)布系統(tǒng)的設(shè)計(jì)和實(shí)現(xiàn)03-07

    利用ASP獲取客戶端真實(shí)IP地址03-18

    淺談學(xué)校校園網(wǎng)絡(luò)IP地址的管理及IP、MAC、端口的綁定畢業(yè)論文11-17

    TM1300 PCI-XIO口的UART和USB接口設(shè)計(jì)03-19

    旅游云講解系統(tǒng)的設(shè)計(jì)和實(shí)現(xiàn)12-04

    DMB-T系統(tǒng)中FFT處理器的研究和硬件實(shí)現(xiàn)03-07

    主站蜘蛛池模板: 国产美女精品一区二区三区 | 亚洲精品无码永久在线观看你懂的| 国产欧美精品一区二区三区| 精品国产乱码久久久久久浪潮| 91精品国产综合久久久久久| 亚洲精品综合久久| 国产精品偷窥熟女精品视频| 精品视频在线免费观看| 久久九九亚洲精品| 亚洲欧美国产∧v精品综合网 | 日产精品99久久久久久| 精品久久久无码中文字幕| 久久夜色精品国产亚洲| 国产精品揄拍100视频| 午夜不卡久久精品无码免费| 日韩一区二区精品观看| 国产午夜精品一区二区| 日本一区精品久久久久影院 | 亚洲国产精品综合久久网络| 国产三级精品三级在专区| 亚洲色图国产精品| 国产在视频线精品视频二代| 国产美女精品一区二区三区| 久久精品人人做人人爽97 | 精品久久香蕉国产线看观看亚洲 | 久久精品国产欧美日韩| 国产精品高清2021在线| 国产精品美女久久久久av爽| 94久久国产乱子伦精品免费| 欧美精品/日韩精品/国产精品 | 999国内精品永久免费观看| 青青草原精品99久久精品66| 三上悠亚久久精品| 日本伊人精品一区二区三区| 久久精品无码一区二区无码| 国产精品亚洲成在人线| 国产乱人伦偷精品视频免下载| 久久精品a亚洲国产v高清不卡| 精品人妻中文av一区二区三区| 国产精品无码一区二区三区电影| 国产成人精品白浆久久69|