《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > 嵌入式UART接口模塊的設計
嵌入式UART接口模塊的設計
摘要: 為了解決外設和計算機之間的信息交換問題,即需要設計一個信息交換的中間環節接口。UART控制器是最常用的接口。
Abstract:
Key words :

  引言

  在計算機的數據通信中,外設一般不能與計算機直接相連,它們之間的信息交換主要存在以下問題:

  (1)速度不匹配。外設的工作速度和計算機的工作速度不一樣,而且外設之間的工作速度差異也比較大。

 ?。?)數據格式不匹配。不同的外設在進行信息存儲和處理時的數據格式可能不同,例如最基本的數據格式可分為并行數據和串行數據。

 ?。?)信息類型不匹配。不同的外設可能采用不同類型的型號,有些是模擬信號,有些是數字信號,因此采用的處理方式也不同。

  為了解決外設和計算機之間的信息交換問題,即需要設計一個信息交換的中間環節接口。UART控制器是最常用的接口。

  通用異步收發器(UniversalAsynchrONousReceiv2er/Transmitter,UART)是輔助計算機與串行設備之間的通信,作為RS232通信接口的一個重要的部分,目前大部分的處理器都集成了UART。

  1 UART的數據格式

  UART的數據傳輸格式如圖1所示。

UART的數據傳輸格式

圖1 UART的數據傳輸格式

  由于數字圖像亞像素在計算機中是用8位二進制表示,因此UART傳輸的有效數據位為8位。傳輸線在空閑時為高電平,因此有效數據流的開始位設為0。

  接著傳輸8位有效數據位,先從最低位開始傳送。奇偶檢驗位可以設置為奇檢驗、偶校驗或者不設置校驗位,由于本系統使用的傳輸速率不高,為了加快開發進程,減少電路面積,因此沒有設計奇偶檢驗模塊,數據流中不設奇偶檢驗位。最后停止位為高電平。

  2 UART的基本結構

  設計的UART主要由UART內核、信號檢測器、移位寄存器" title="移位寄存器">移位寄存器、波特率發生器和計數器組成,如圖2所示。

UART基本結構

圖2 UART基本結構

  UART各個功能模塊的功能如下文所述。

  2.1 信號檢測器模塊

  信號檢測器用于對RS232的輸入信號進行實時監測,一旦發現新的數據則立即通知UART內核。信號檢測器的仿真波形如圖3所示。

信號檢測器仿真波形圖

圖3 信號檢測器仿真波形圖

  其中,RxD第一次為低時,new_data信號闡述輸出,之后RxD又變低,但由于信號檢測器處于鎖定狀態,所以new_data信號并沒有輸出;最后,reset_n信號將信號檢測器復位,RxD再次變低時,new_data又有輸出??梢娦盘枡z測器的實現完全正確,其功能完全符合設計要求。

  2.2 移位寄存器模塊

  移位寄存器模塊的作用是存儲輸入或者輸出數據。

  當UART接收RS232輸入時,移位寄存器在波特率模式下采集RS232輸入信號,且保存結果;當進行RS232輸出時,UART內核首先將數據加載到移位寄存器內,再使移位寄存器在波特率模式下將數據輸出到RS232輸出端口上。移位寄存器的仿真波形圖如圖4所示。

關鍵字:嵌入式" title="嵌入式">嵌入式 UART接口模塊" title="UART接口模塊">UART接口模塊

 

移位寄存器仿真波形圖

圖4 移位寄存器仿真波形圖

  如圖4所示,移位寄存器在復位后的每個時鐘的上升沿工作。由于數據發送時是先發送有效數據的最低位,因此移位寄存器是將接收的數據由高位向低位移動,dout輸出移位寄存器的最低位。圖中的regs數據用16進制表示。

  2.3 波特率發生器模塊

  波特率發生器的功能是產生和RS232通信所采用的波特率同步的時鐘,這樣才能方便地按照RS232串行通信的時序要求進行數據接收或者發送。比如,波特率為9600b/s,即每秒傳輸9600b數據,則同步的波特率時鐘頻率為9600Hz,周期為1/9600=0.10417。

  設計波特率時鐘的基本思路就是設計一個計數器,該計數器工作在速度很高的系統時鐘下,當計數器計數到某數值時將輸出置高,再計數到一定的數值后再將輸出置低,如此反復便能夠得到所需的波特率時鐘。該系統所用的FPGA系統時鐘為50MHz,RS232通信的波特率為9600b/s,則波特率時鐘的每個周期相當于

  5208個系統時鐘周期。假如要得到占空比為50%的波特率時鐘,只要使得計數器在計數到1604時將輸出置高,之后在計數到5208時將輸出置低并且重新計數,就能實現和9600波特率同步的時鐘。

  為了便于仿真,使計數器計到2時將輸出置高,之后計到4時將輸出置地并且重新計數。波特率發生器的仿真波形圖如圖5所示。

波特率發生器仿真波形圖

圖5 波特率發生器仿真波形圖

  觀察波形可以看到波特率發生器每經過4個時鐘周期輸出1個完整的波特率時鐘周期,占空比為1/2,并且在每次輸出波特率時鐘周期之后輸出1個系統時鐘脈寬的提示信號indicator,UART通過此信號來了解波特率發生器已輸出的波特率時鐘周期個數。由波形圖可見波特率發生器的工作完全滿足設計的要求。

  2.4 計數器模塊

  計數器模塊的功能是可控的,在輸入時鐘的驅動下進行計數,當達到計數上閾時給UART內核一個提示信號。在不同的工作狀態下,計數器模塊的輸入時鐘是不同的。UART在數據發送之前需要進行數據加載(即將串行序列保存在移位寄存器內),在此工程中計數器模塊的輸入時鐘為系統時鐘,因為此時移位寄存器也工作在系統時鐘下。除了數據加載,另外2個需要計數器模塊的過程是數據接收和數據發送。

  由于這兩個過程中移位寄存器工作在波特率時鐘下,所以計數器模塊的時鐘就是與波特率時鐘同步的波特率發生器提示信號indicator,這樣每輸出1個完整的波特率時鐘周期計數器就能增加1。

  計數器的仿真波形圖如圖6所示。

計數器仿真波形圖

圖6 計數器仿真波形圖

  計數器在復位后并且ce有效時開始計數,并且在第10個時鐘周期輸出提示信號overflow。

  2.5 發送數據緩沖器模塊

  發送數據緩沖器模塊的功能是將要發送的并行數據轉換成串行數據,并且在輸出的串行數據流中加人起始位和停止位。緩沖器首先將要發送的8位數據寄存,并在最低位后添加起始位‘0’,在最高位前添加停止位‘1’,組成10位要發送的數據,然后根據UART內核模塊的計數值將相應的數據送入移位寄存器輸入端。

  UART內核模塊輸出的計數值是從0依次計到9,即先將要發送數據的最低位送入移位寄存器。發送數據緩沖器的仿真波形圖如圖7所示。

發送數據緩沖器仿真波形圖

圖7 發送數據緩沖器仿真波形圖

  由波形圖可知,發送數據緩沖器在復位后,在輸入的計數值si_count為0時,send_si輸出起始位‘0’。在輸入的計數值si_count為1~8時,send_si分別輸出send_bus上相應的數據位。在輸入的計數值si_count為9時,send_si輸出停止位‘1’。

  2.6 UART內核模塊

  UART內核模塊是整個設計的核心。在數據接收時,UART內核模塊負責控制波特率發生器和移位寄存器,使得移位寄存器在波特率時鐘的驅動下同步地接收并且保存RS232接收端口上的數據。在數據發送時,UART內核模塊首先根據待發送數據產生完整的發送數據序列(包括起始位、數據位和停止位),之后控制移位寄存器將序列加載到移位寄存器的內部寄存器里,最后再控制波特率發生器驅動移位寄存器將數據串行輸出。UART內核模塊的主要功能是控制數據接收、數據加載和數據發送的過程,這可以用狀態機來實現,其狀態圖如圖8所示。

UART內核狀態轉移圖

圖8 UART內核狀態轉移圖

 ?。?)數據加載過程。數據的接收過程可以定義3個狀態:空閑“idle”狀態、接收“receive”和接收完成“receive_over”。UART內核模塊在復位后進入空閑狀態。如果信號檢測器檢測到數據傳輸,即new_data=‘1’,UART內核檢測到此信號就會進入接收狀態。

  在UART進入由空閑狀態轉為接收狀態過程中,需要進行一系列的接收預備操作,包括將子模塊復位、選擇移位寄存器串行輸入數據以及選擇移位寄存器的輸入時鐘等。進入接收狀態后,波特率發生器開始工作,其輸出波特率時鐘驅動移位寄存器同步的存儲RS232接收端口上的數據,并且其提示信號“indicator”驅動計數器進行計數。當所有數據接收完成,計數器也達到了其計數的上閾,此時overflow=‘1’,通知UART內核進入接收狀態。UART內核進入接收完成狀態的同時,會檢奇偶校驗的結果,同時使得子模塊使能信號無效,以停止各個子模塊。

  UART內核的接收完成狀態僅保持1個時鐘周期,設置這個狀態的作用是借用一個時鐘周期復位信號檢測器,準備接收下次數據傳輸。

  檢測器,準備接收下次數據傳輸。

  (2)數據加載和發送過程。數據加載和發送的過程都是為發送數據而設定的,所以將它們放在一起進行介紹,可以用4個狀態來實現上述的過程,即空閑、加載、發送和發送完成。其中的空閑狀態是UART內核復位后的空閑狀態,與上面介紹的數據接收過程的空閑狀態一致。數據加載過程在數據發送過程之前進行。

  UART內核復位后進入空閑狀態,當探測到發送控制信號有效時,即send=‘1’,便會進入加載狀態開始數據加載。在進入加載狀態的同時,UART內核會將移位寄存器、計數器復位,并且通過選擇信號使得移位寄存器的輸入為發送數據緩沖器模塊產生的串行數據序列,使得移位寄存器和計數器的工作時鐘為系統時鐘。

  進入加載狀態后,在UART內核控制下,發送數據緩沖器模塊會將完整的待發送序列加載到移位寄存器的數據輸入端,發送的序列是和系統時鐘同步的,移位寄存器在系統時鐘的驅動下不斷讀入輸入端數據并保存在內部寄存器內。在移位寄存器加載數據的同時,計數器也在時鐘的驅動下進行計數,由于都是工作在系統時鐘下,所以當所有數據被加載時,計數器也達到了計數的上閾(即串行數據的總量),此時overflow=‘1’,通知UART內核進入發送狀態。UART內核進入發送狀態的同時會改變幾個選擇信號,比如將移位寄存器的時鐘設為波特率時鐘,將計數器時鐘設為波特率的提示信號,最重要的是將輸出信號送到RS232的發送端口TxD上。發送的過程和接收類似,移位寄存器在波特率時鐘的驅動下內部寄存器的數據串行的發送出去,同時計數器在波特率發生器的提示信號驅動下進行計數。

  UART內核在計數器到達計數上閾后便進入發送完成模式,并且輸出發送完成信號。

3 UART頂層模塊的仿真測試

  將上述各個模塊的VHDL代碼生成原理圖符號,并在原理圖編輯工具中將各個模塊連接起組成1個完整的UART模塊。為了驗證UART模塊的正確性,對UART的發送過程和接收過程分別進行了波形仿真。

  為便于觀察波形,波特率產生器設置為4個系統時鐘產生一個完整的波特率時鐘。圖9是UART模塊接收過程的仿真波形圖。

UART數據接收過程的仿真波形圖

圖9 UART數據接收過程的仿真波形圖

  由仿真波形圖可以看出,接收端RxD上的數據序列為0101010101,起始位‘0’后為數據位“10101010”,最后一位為停止位‘1’。在10個波特率時鐘之后,UART發出1個接收完成信號recv=‘1’,并在數據輸出端“new_data”將接收的數據輸出給后續數據處理模塊。由于發送數據時首先發送數據的最低位,因此接收的數據應為“01010101”,將光條放置數據輸出端“new_data”的數據輸出波形上,可以從數據欄看到此時數據輸出端new_data=“01010101”,UART數據接收功能完全正確。

  圖10為UART發送過程仿真波形。由圖可以看出,send=‘1’后待發送數據為“01010101”,將待發送數據加上起始位和停止位,并從最低位開始發送,則發送端txd上的數據序列為“0101010101”,發送停止位后,發送結束信號send_over=‘1’。圖10證明UART數據發送功能完全正確。

UART數據發送過程的仿真波形圖

圖10 UART數據發送過程的仿真波形圖

  4 結語

  介紹了UART在可編程邏輯器件FPGA上的實現,并通過實際電路驗證了設計的功能,使用FPGA不僅可以方便地用串口協議與PC機進行串行通信,而且擴展了板級系統的接口功能。應用在可編程器件FP2GA內部,可以很大程度地減少電路板的使用面積,并提高系統的穩定性和可編程性。

 

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          国内精品视频久久| 亚洲国产婷婷| 一本久道久久综合中文字幕| 一区二区三区在线看| 欧美精品一区视频| 一区二区日韩| 在线日韩av永久免费观看| 国产精品久久久久婷婷| 91久久精品国产91性色| 久久亚洲国产精品一区二区| 欧美日本在线视频| 国内精品伊人久久久久av一坑| 国产精品亚洲综合色区韩国| 亚洲人成欧美中文字幕| 一本色道久久综合狠狠躁的推荐| 欧美极品在线观看| 欧美一区二区三区成人| 国内伊人久久久久久网站视频| 一区二区高清视频在线观看| 欧美韩日精品| 亚洲欧美成aⅴ人在线观看| 国产一区二区三区成人欧美日韩在线观看| 久久久av水蜜桃| 亚洲一区二区三区久久| 欧美国产丝袜视频| 欧美精品一区视频| 亚洲国产一区二区三区青草影视| 国产日韩欧美制服另类| 久久午夜av| 欧美激情国产精品| 国产精品丝袜91| 欧美日本一区二区高清播放视频| 在线播放国产一区中文字幕剧情欧美| 亚洲欧美日韩国产中文| 欧美大片va欧美在线播放| 国产精品久久久久毛片软件| 激情成人av| 久久久综合视频| 免费在线观看日韩欧美| 亚洲小说欧美另类婷婷| 国产精品视频免费一区| 91久久久精品| 伊人久久大香线| 亚洲欧洲精品一区二区三区| 欧美日韩不卡| 欧美一级黄色网| 久久久综合网| 国产精品久在线观看| 国产综合在线看| 国产午夜精品理论片a级大结局| 亚洲一本视频| 午夜在线a亚洲v天堂网2018| 久久亚洲影音av资源网| 欧美激情片在线观看| 欧美精品自拍偷拍动漫精品| 久久在线91| 久久久蜜臀国产一区二区| 欧美一区二区三区久久精品| 欧美三级电影一区| 久久亚洲色图| 一本色道久久综合亚洲精品小说| 激情五月综合色婷婷一区二区| 欧美美女视频| 亚洲精品国产精品国自产在线| 久久精品国产亚洲精品| 亚洲欧美视频在线观看| 久久精品视频在线免费观看| 欧美一激情一区二区三区| 欧美日韩一级片在线观看| 国产视频在线观看一区| 9色精品在线| 久久婷婷亚洲| 午夜精品成人在线视频| 亚洲国产岛国毛片在线| 欧美激情一级片一区二区| 亚洲精品久久久久久下一站| 亚洲精品乱码久久久久久按摩观| 欧美日韩免费观看一区二区三区| 欧美中文字幕在线观看| 亚洲第一区在线观看| 国产精品免费看久久久香蕉| 99精品热6080yy久久| 亚洲精品综合| 国产欧美精品在线观看| 亚洲视频网站在线观看| 欧美精品一区二区三区一线天视频| 国产精品卡一卡二| 欧美激情国产日韩精品一区18| 久久综合九色综合网站| 国产亚洲观看| 欧美日韩免费看| 影音先锋日韩资源| 亚洲欧洲一区二区三区久久| 亚洲精品视频啊美女在线直播| 欧美日韩1080p| 136国产福利精品导航| 亚洲一区二区久久| 亚洲国产三级在线| 久久久久久久久久码影片| 老牛嫩草一区二区三区日本| 欧美黑人多人双交| 欧美一级一区| 亚洲专区一区二区三区| 一个色综合av| 国产精品福利av| 国产精品永久免费| 在线看片一区| 欧美日韩极品在线观看一区| 亚洲精品久久久久久久久久久久| 国产精品试看| 久久综合99re88久久爱| 欧美日韩播放| 激情五月***国产精品| 亚洲小说欧美另类婷婷| 激情懂色av一区av二区av| 国产欧美一区二区三区久久人妖| 国产一区亚洲| 国产一区二区精品久久91| 欧美日本韩国一区二区三区| 国产精品xxxxx| 男人的天堂成人在线| 一区二区三区亚洲| 国产精品久久婷婷六月丁香| 亚洲国产精品久久久| 欧美成人dvd在线视频| 国产日本欧美一区二区三区| 久久久免费观看视频| 欧美在线亚洲在线| 欧美日韩亚洲网| 亚洲欧美成人一区二区三区| 欧美日韩国产在线播放网站| 久久国产精品久久久久久久久久| 国产日韩欧美一区二区三区在线观看| 国产精品夫妻自拍| 国产精品swag| 国产精品久久久久一区二区三区| 欧美精品一区二区三区视频| 久久久99精品免费观看不卡| 欧美高清在线| 国产精品免费久久久久久| 午夜国产欧美理论在线播放| 免费毛片一区二区三区久久久| 欧美激情综合五月色丁香小说| 久久久久www| 欧美日韩在线三级| 国产伦精品一区二区三区免费| 国产精品入口麻豆原神| 欧美色视频一区| 99视频热这里只有精品免费| 欧美日韩中文字幕精品| 久久综合网hezyo| 伊人色综合久久天天五月婷| 国模大胆一区二区三区| 久久国产精品高清| 欧美精品国产精品| 久久天天躁夜夜躁狠狠躁2022| 亚洲精品久久久蜜桃| 亚洲人成在线播放| 久久精品午夜| 黄色小说综合网站| 日韩亚洲精品视频| 久久成人在线| 夜夜精品视频| 久久久精品国产免费观看同学| 国产精品一区一区| 欧美不卡视频一区发布| 亚洲无人区一区| 亚洲精品乱码久久久久久久久| 日韩视频欧美视频| 亚洲精品男同| 国产日韩欧美不卡在线| 欧美日韩极品在线观看一区| 麻豆九一精品爱看视频在线观看免费| 永久555www成人免费| 美女网站久久| 免费观看成人网| 国内外成人免费激情在线视频网站| 欧美激情精品久久久久久变态| 久久伊伊香蕉| 欧美国产高潮xxxx1819| 蜜桃av一区二区三区| 久热re这里精品视频在线6| 久久久久久久成人| 日韩一区二区精品视频| 亚洲九九九在线观看| 久久综合激情| 国产精品久久久一区二区三区| 国产精品第一区| 久久一区二区视频| 欧美亚洲一区二区三区| 好吊色欧美一区二区三区四区| 亚洲一区二区三区影院| 欧美日韩在线播| 亚洲欧美激情精品一区二区| 91久久国产精品91久久性色| 国产精品欧美一区喷水| 亚洲国产日韩欧美在线图片| 国产婷婷97碰碰久久人人蜜臀| 亚洲人体大胆视频| 国产精品久久久久久久久久久久| 蜜臀99久久精品久久久久久软件| 狠狠久久亚洲欧美| 黄色免费成人| 蜜臀久久99精品久久久画质超高清| 久久综合伊人77777麻豆| 国产精品久久久久久久一区探花| 欧美成人在线免费观看| 久久久91精品| 1204国产成人精品视频| 久久xxxx精品视频| 亚洲精品视频啊美女在线直播| 美国成人毛片| 欧美理论视频| 免费高清在线一区| 国产美女精品| 欧美日本三级| 亚洲缚视频在线观看| 91久久久一线二线三线品牌| 国产日韩专区在线| 国内精品久久久久久久影视麻豆| 欧美精品18+| 国产精品第一页第二页第三页| 在线精品亚洲| 欧美日韩国产天堂| 黄色影院成人| 久久免费精品视频| 国产视频一区在线观看一区免费| 亚洲永久字幕| 亚洲美女视频网| 一区二区电影免费观看| 亚洲激情社区| 国产在线精品成人一区二区三区| 国产精品国产三级国产| 日韩视频在线观看| 欧美大尺度在线观看| 欧美一级视频一区二区| 老司机久久99久久精品播放免费| 欧美三区视频| 在线性视频日韩欧美| 国产精品久久久久久久久久尿| 国产欧美一区二区三区久久| 久久久久久久久久久久久女国产乱| 久久久亚洲成人| 亚洲一级在线| 亚洲国产天堂久久国产91| 欧美精品日日鲁夜夜添| 伊人久久大香线蕉综合热线| 亚洲美女免费精品视频在线观看| 午夜精品av| 亚洲黄色大片| 国产免费成人av| 欧美亚洲视频| 亚洲毛片在线观看.| 国产精品xxxav免费视频| 欧美日韩精品综合| 亚洲激情精品| 国产啪精品视频| 亚洲精品视频在线观看免费| 欧美一区二区三区在线免费观看| 亚洲在线观看视频| 日韩视频在线观看一区二区| 欧美三级特黄| 亚洲少妇最新在线视频| 国内精品免费午夜毛片| 亚洲人成亚洲人成在线观看图片| 免费久久久一本精品久久区| 欧美激情aaaa| 伊人久久大香线蕉综合热线| 亚洲国产高清一区二区三区| 欧美理论在线播放| 亚洲国产成人av| 久久阴道视频| 亚洲二区在线| 亚欧成人在线| 在线免费高清一区二区三区| 久久综合久久综合这里只有精品| 激情成人综合| 欧美日本国产视频| 欧美体内谢she精2性欧美| 久久亚洲精品网站| 亚洲精品久久久久久久久久久久| 一区视频在线看| 尤物视频一区二区| 欧美久久电影| 亚洲大胆av| 国产午夜精品在线观看| 欧美日韩国产高清| 久久亚洲一区二区| 国产精品v亚洲精品v日韩精品| 久久久人人人| 女人天堂亚洲aⅴ在线观看| 亚洲国产成人tv| 国产婷婷一区二区| 欧美四级在线观看| 亚洲欧洲美洲综合色网| 欧美日一区二区三区在线观看国产免| 精品电影一区| 亚洲国产精品v| 午夜精品一区二区三区在线| 亚洲第一二三四五区| 美腿丝袜亚洲色图| 欧美在线视频免费观看| 久久久一区二区三区| 国产精品自拍三区| 欧美三级日韩三级国产三级| 欧美fxxxxxx另类| 在线观看成人av| 久久久久久久久久久久久女国产乱| 在线精品国精品国产尤物884a| 欧美高清视频一区二区三区在线观看| 欧美成人亚洲成人| 午夜免费日韩视频| 久久九九国产精品怡红院| 午夜精品偷拍| 国产精品日本精品| 你懂的视频一区二区| 久久国内精品视频| 亚洲精品一区二区三| 性亚洲最疯狂xxxx高清| 国产精品电影在线观看| 亚洲欧美国产高清| 9久草视频在线视频精品| 欧美日韩亚洲一区二区三区在线| 久久久久**毛片大全| 久久综合网hezyo| 亚洲一区欧美激情| 欧美午夜精品久久久久久超碰| 国产午夜一区二区三区|