《電子技術(shù)應用》
您所在的位置:首頁 > 可編程邏輯 > 設(shè)計應用 > 基于Verilog HDL的UART模塊設(shè)計與仿真
基于Verilog HDL的UART模塊設(shè)計與仿真
摘要: 文章標題:基于Verilog HDL的UART模塊設(shè)計與仿真。中國IT實驗室嵌入式開發(fā)頻道提供最全面的嵌入式開發(fā)培訓及行業(yè)的信息、技術(shù)以及相關(guān)資料的下載.
關(guān)鍵詞: FPGA Verilog HDL UART ModelSim
Abstract:
Key words :

  隨著微機應用和計算機網(wǎng)絡(luò)的發(fā)展,計算機與外界之間的信息交換變得越來越重要,為了保證串行通信的正常進行,提高串行通信的效率和CPU的利用率,在微機系統(tǒng)中采用專用的大規(guī)模集成電路來完成這些工作,這就是串行通信接口。通用異步接收發(fā)送器UART(Universal asynchronousreceiver/transmitter)主要用于控制設(shè)備之間的串行通信。廣泛應用于調(diào)制解調(diào)器Modem、手持工業(yè)設(shè)備、條形碼閱讀器、測試設(shè)備、消費產(chǎn)品與計算機PC、微處理器以及小型通信網(wǎng)絡(luò)之間的通信等。在SOC設(shè)計中,異步串行通信接口已成為不可缺少的一部分,它的性能優(yōu)劣將直接影響相應電子系統(tǒng)的性能和指標。

  1 UART原理

  串行通信是指外部設(shè)備和計算機間使用一根數(shù)據(jù)線(另外需要地線,可能還需要控制線)進行數(shù)據(jù)傳輸?shù)姆绞健?shù)據(jù)在一根數(shù)據(jù)線上一位一位傳輸,每一位數(shù)據(jù)都占據(jù)一個固定的時間長度。與并行通信方式相比,串行通信方式的傳輸速度較慢,但這種通信方式使用的數(shù)據(jù)線少,在遠距離通信中可以節(jié)約通信成本,因此得到了廣泛的應用。

  基本的UART只需要發(fā)送和接收兩條數(shù)據(jù)線就可以完成數(shù)據(jù)的全雙工通信,其基本功能是在發(fā)送端將控制器通過總線傳過來的并行數(shù)據(jù),以設(shè)定的格式,設(shè)定的頻率串行地傳輸出去,并同時在接收端將串行接收到的數(shù)據(jù),轉(zhuǎn)換成相應的并行數(shù)據(jù)發(fā)送出去。UART的基本幀格式如圖1所示。其中,起始位總是邏輯O狀態(tài),停止位總是邏輯l狀態(tài),其持續(xù)時間可選為1位、1.5位或2位,其數(shù)據(jù)位可為5、6、7、8位,校驗位可根據(jù)需要選擇奇校驗位,偶校驗位或無校驗位。

UART的基本幀格式

  2 UART的設(shè)計

  現(xiàn)今復雜的數(shù)字系統(tǒng)的設(shè)計往往采用自頂向下的設(shè)計方案,利用層次化結(jié)構(gòu)化的方法,將一個設(shè)計方案劃分為若干模塊,在不同層次的模塊都可以進行仿真,可以很方便地查看某一層次的代碼以改正仿真時發(fā)現(xiàn)錯誤。在本設(shè)計中UART主要由波特率發(fā)生器、接收模塊、發(fā)送模塊3部分組成,并具有l(wèi)位停止位和無校驗位。波特率發(fā)生器實現(xiàn)波特率的變換,利用外部時鐘信號產(chǎn)生一個所需波特率16倍的波特率時鐘,用來控制UART的接收與發(fā)送。接收模塊是用于接收串行信號,并將其轉(zhuǎn)化為并行數(shù)據(jù);而發(fā)送模塊則將準備輸出的并行數(shù)據(jù)按照UART的幀格式轉(zhuǎn)化為串行數(shù)據(jù)輸出。圖2為UART結(jié)構(gòu)圖。

UART結(jié)構(gòu)圖

  2.1 波特率發(fā)生器

  波特率表示的是每秒鐘傳送的二進制數(shù)據(jù)的位數(shù),即單位時間內(nèi)傳送的信息量。在串行異步傳送中,常用到的波特率為1 200、2 400、4 800、9 600、19 200等。波特率發(fā)生器實際上是一個分頻器,主要是產(chǎn)生和。RS-232通信所采用的波特率同步的時鐘。由于串行數(shù)據(jù)幀與接收數(shù)據(jù)時鐘是異步的,所以存 UART的接收端在什么時刻將數(shù)據(jù)移入寄存器,怎樣選擇可靠的采樣點是非常關(guān)鍵的。一般采用高速時鐘對串行數(shù)據(jù)采樣是非常有效的方法。在實際設(shè)計中,一般最大選擇16倍于波特率的時鐘頻率。實現(xiàn)波特率時鐘的基本思路就是設(shè)計一個計數(shù)器,該計數(shù)器工作在速度很高的系統(tǒng)時鐘下,通過總線寫入不同的數(shù)值到波特率發(fā)生器保持寄存器中,然后用計數(shù)器的方式生成所需要的各種波特率就能得到所需的波特率時鐘,仿真如圖3所示。

仿真如圖

  2.2 接收模塊

  接收模塊是整個UART的設(shè)計的重點,其主要功能是檢測數(shù)據(jù)的起始位,并對接收的數(shù)據(jù)進行串并轉(zhuǎn)換,并將接收好的數(shù)據(jù)儲存等待微機處理。由于串行數(shù)據(jù)幀與接收數(shù)據(jù)時鐘是異步的,接收功能實現(xiàn)的關(guān)鍵是接收器與每個接收字符同步。要保證異步通信的雙方準確無誤地交換信息,必須有效控制采集通信線路上的電平信號的時機。由異步串行通信的特點可知,接收同步是通過低電平起始位實現(xiàn)的。而為了保證采樣的正確性,采樣在數(shù)據(jù)位的中間進行,并且接收單元采樣數(shù)據(jù)的頻率與發(fā)送單元發(fā)送數(shù)據(jù)的頻率相同,是波特率時鐘周期的16倍,這樣可以有效地降低由于時鐘不匹配而導致的誤采樣。接收模塊的設(shè)計主要由狀態(tài)機實現(xiàn)其核心功能,采用獨熱編碼方式,雖然獨熱編碼多用了兩個觸發(fā)器,但所用組合電路可節(jié)省一些,使電路的速度和可靠性有顯著提高。控制接收器的起始/停止位檢測,接收數(shù)據(jù)的計數(shù),移位寄存的功能。狀態(tài)機分為5個狀態(tài),分別為:IDEL,CENTER,WAIT,SAMPLE,STOP。狀態(tài)轉(zhuǎn)換圖如圖4所示。

狀態(tài)轉(zhuǎn)換圖

  1)IDLE狀態(tài) 系統(tǒng)被復位后,接收狀態(tài)機進入IDLE狀態(tài),等待起始位到來,輸入數(shù)據(jù)在空閑時保持為1,當輸入由“l”跳變?yōu)?ldquo;0”時,狀態(tài)機跳轉(zhuǎn)到CENTER狀態(tài)。

  2)CENTER狀態(tài) 啟動起始位檢測電路,為排除噪聲干擾,狀態(tài)機等待8個脈沖,如果數(shù)據(jù)線上仍為低電平,則狀態(tài)機跳轉(zhuǎn)到WAIT狀態(tài),并啟動采樣電路。如果是噪聲干擾,則轉(zhuǎn)入IDLE態(tài)。

  3)WAIT狀態(tài) 狀態(tài)機WAIT狀態(tài),判斷數(shù)據(jù)接收是否完畢,若未完成采樣,則轉(zhuǎn)入SAMPLE狀態(tài)進行數(shù)據(jù)位的采樣檢測,同時啟動位計數(shù)器,用來控制數(shù)據(jù)接收的位數(shù)。無論停止位是幾位,狀態(tài)機只對停止位作一次采樣。接收完畢,轉(zhuǎn)入STOP狀態(tài)。

 

  4)SAMPLE狀態(tài) 在此狀態(tài)對串口輸入數(shù)據(jù)進行采樣,每次采樣均位于數(shù)據(jù)位的中心。并每接收完一位數(shù)據(jù),狀態(tài)機轉(zhuǎn)入WAIT狀態(tài)。

  5)STOP狀態(tài) 接收停止位,完成一個數(shù)據(jù)幀的接收,并將rec_ready置為1,表明收據(jù)接收完畢,待微機讀取。其仿真結(jié)果如圖5所示。

仿真結(jié)果

  2.3 發(fā)送模塊

  發(fā)送模塊的設(shè)計相對簡單,其功能是將要發(fā)送的并行數(shù)據(jù)轉(zhuǎn)換成串行數(shù)據(jù),并且在輸出的串行數(shù)據(jù)流中加入起始位和停止位。發(fā)送器首先將要發(fā)送的8位數(shù)據(jù)寄存,并在最低位后添加起始位‘0’,在最高位前添加停止位‘l’,組成10位要發(fā)送的數(shù)據(jù),然后根據(jù)UART內(nèi)核模塊的計數(shù)值將相應的數(shù)據(jù)送入移位寄存器輸入端。UART內(nèi)核模塊輸出的計數(shù)值是從0依次計到9,即先將要發(fā)送數(shù)據(jù)的最低位送入移位寄存器。仿真結(jié)果如圖6所示。

仿真結(jié)果

  2.4 UART各個模塊的整合

  在各模塊功能實現(xiàn)的基礎(chǔ)上,把它們有機地整合在一起,使波特率發(fā)生器能夠按照UART通訊的要求正常工作,接收模塊和發(fā)送模塊能夠根據(jù)各自的復位信號使整合模塊具有發(fā)送或接收功能。仿真結(jié)果如圖7所示。

仿真結(jié)果

  3 結(jié)束語

  本文介紹了基于Verilog HDL設(shè)計的UART模塊,采樣點選擇可靠,其可以準確判斷接收數(shù)據(jù)的起始,接收器與接收數(shù)據(jù)實現(xiàn)同步,串行數(shù)據(jù)能被準確接收,并通過在ModelSim下的仿真,可下載至可編程邏輯器件中實現(xiàn)UART功能。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久精品日产第一区二区三区| 欧美三级中文字幕在线观看| 亚洲精品欧美极品| 校园春色国产精品| 一区二区免费在线视频| 亚洲国产你懂的| 激情成人综合| 国产一区二区三区精品欧美日韩一区二区三区| 国产精品国产三级国产专播品爱网| 欧美久久视频| 欧美激情在线免费观看| 欧美成人性生活| 欧美二区不卡| 欧美日韩99| 欧美日本视频在线| 欧美片在线播放| 欧美日本在线播放| 欧美日本免费一区二区三区| 欧美精品成人| 欧美精品亚洲| 欧美日韩国产色综合一二三四| 欧美剧在线免费观看网站| 欧美激情按摩在线| 欧美精品一区二区视频| 欧美日韩成人| 欧美午夜视频网站| 国产精品久久久久久久久借妻 | 久久精品女人| 久久精品一区二区| 久久久91精品国产| 免费欧美视频| 欧美日韩亚洲成人| 国产精品乱码一区二三区小蝌蚪 | 国产日本亚洲高清| 国内精品福利| 亚洲国产成人一区| 99视频精品全部免费在线| 亚洲视频第一页| 亚洲免费一级电影| 久久国产手机看片| 亚洲美女在线观看| 亚洲欧美经典视频| 久久国产66| 欧美成年人视频| 欧美日韩不卡合集视频| 国产精品天天摸av网| 国产综合色一区二区三区| 亚洲大片免费看| 日韩亚洲一区二区| 亚洲综合另类| 亚洲电影下载| 一区二区三区日韩精品视频| 午夜精品久久久久久久白皮肤| 久久大逼视频| 欧美激情精品久久久久久免费印度| 欧美日韩一区三区| 国产伦精品一区二区三区照片91 | 国产精品久久夜| 狠狠入ady亚洲精品| 亚洲国产精品尤物yw在线观看| 一区二区三区高清不卡| 欧美一级理论片| 亚洲另类视频| 欧美一区二区在线| 牛牛影视久久网| 欧美午夜精品一区| 精品不卡一区| 一区二区三区波多野结衣在线观看| 性欧美大战久久久久久久免费观看 | 久久天天躁夜夜躁狠狠躁2022 | 一本色道久久| 亚洲精品三级| 性欧美xxxx视频在线观看| 亚洲精选中文字幕| 欧美一区二区三区四区在线观看地址 | 国产精品中文字幕欧美| 在线成人激情| 亚洲视频在线二区| 亚洲高清久久网| 午夜精品久久久久久久久久久久| 欧美高清日韩| 国产午夜精品全部视频在线播放| 亚洲伦理精品| 亚洲国产精品福利| 香蕉av福利精品导航| 欧美精品黄色| 玉米视频成人免费看| 亚洲欧美日韩在线播放| 中国成人黄色视屏| 免费欧美网站| 国内外成人在线视频| 亚洲视频在线观看| 一本色道**综合亚洲精品蜜桃冫| 久久婷婷久久一区二区三区| 国产精品美女一区二区在线观看| 91久久久在线| 亚洲国产裸拍裸体视频在线观看乱了 | 久久国产主播精品| 午夜精品一区二区三区在线播放| 欧美日本簧片| 亚洲福利视频二区| 亚洲第一在线| 久久精品视频va| 国产精品一级二级三级| 99视频精品在线| 日韩一级在线观看| 免费欧美高清视频| 精品成人在线视频| 性高湖久久久久久久久| 午夜亚洲激情| 欧美午夜精品伦理| 夜夜嗨一区二区三区| 一本色道久久综合亚洲精品小说 | 亚洲免费影视第一页| 欧美高清在线播放| 精品成人一区二区三区四区| 久久电影一区| 欧美在线视频观看免费网站| 国产精品久久一区二区三区| 夜夜躁日日躁狠狠久久88av| 一二三四社区欧美黄| 男人插女人欧美| 1000部精品久久久久久久久| 亚洲电影免费观看高清完整版在线观看 | 在线播放一区| 久久国产精品99精品国产| 久久av二区| 国产毛片久久| 欧美伊人久久| 久久久久久久久一区二区| 国产日韩欧美中文| 欧美一区网站| 久久人人97超碰国产公开结果| 国产午夜精品全部视频播放| 欧美在线综合视频| 久久在线观看视频| 亚洲大胆人体在线| 一本高清dvd不卡在线观看| 欧美日韩精品| 国产精品99久久久久久久女警 | 亚洲一区欧美激情| 欧美一区=区| 国产日韩综合| 亚洲第一精品夜夜躁人人爽| 蜜桃久久av一区| 亚洲欧洲在线一区| 亚洲一区综合| 国产三区精品| 亚洲激情视频| 欧美日韩一区三区四区| 亚洲欧美日韩中文视频| 久久阴道视频| 日韩视频免费观看高清在线视频| 亚洲一区二区成人在线观看| 国产欧美精品久久| 亚洲第一黄色| 欧美日韩精品一区二区在线播放| 亚洲一区二区在线播放| 久久久久久久久一区二区| 亚洲黄色在线视频| 亚洲综合另类| 激情婷婷亚洲| 宅男噜噜噜66一区二区66| 国产精品色婷婷久久58| 亚洲第一精品福利| 欧美日韩一区二区视频在线| 性欧美8khd高清极品| 欧美激情女人20p| 亚洲视频日本| 另类激情亚洲| 一区二区三区国产| 久久久久久久97| 亚洲久久在线| 久久国产一区| 亚洲人精品午夜| 久久av一区二区三区亚洲| 亚洲国产成人精品久久| 亚洲男人的天堂在线观看| 伊人狠狠色j香婷婷综合| 宅男精品导航| 尤物99国产成人精品视频| 亚洲一区www| 在线免费观看日本欧美| 午夜精品久久久久久久99热浪潮 | 亚洲美女啪啪| 欧美激情黄色片| 亚洲欧美精品在线| 欧美不卡一卡二卡免费版| 亚洲网站在线观看| 欧美成人a∨高清免费观看| 亚洲一级二级| 欧美激情中文字幕一区二区| 亚洲欧美日韩中文在线制服| 欧美日本免费| 亚洲国产第一| 国产欧美日韩不卡| 国产精品99久久99久久久二8| 在线成人av网站| 欧美专区在线观看一区| 日韩亚洲视频|