国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

零基礎學FPGA(九)牛刀小試——串行口通信電路設計

發(fā)布時間:2016-2-24 09:55    發(fā)布者:designapp
關鍵詞: FPGA , 狀態(tài)機
  以前在學單片機的時候,覺得串口通信其實很簡單,只要一個指令數(shù)據(jù)就能輕易的接收或者發(fā)送。前幾天試著用FPGA實現(xiàn),發(fā)現(xiàn)里面的學問還不少,并沒有想象的那么簡單。當然代碼肯定是參考別人的,不過我還是認真研究了整段代碼的,下面的程序就是我在看懂了別人代碼后自己敲的,花了也不少時間,理解的也差不多,下面我就在這里給那些和我一樣的初學者介紹一下吧,解釋的不對的地方還望各位大神指正,大家好一起學習~
  1、頂層模塊
  寫程序都一樣,不能多有的程序都寫在一個模塊里,那樣看起來很麻煩,出了錯誤也不好維護,對于一些小的程序我們可以寫在一個模塊里,但程序一旦復雜起來還是要懂得模塊化編程的,對于頂層模塊,最好是只寫接口就好了,例如:
  


  這段代碼中,rx_232是我們的底層模塊名,后面跟著的那個rx呢是我們自己取的名字,是任意的。后面的一大串呢就是接口,為了直觀呢,建議大家采用我的這種寫法,看上去比較清楚明白,括號里面的接口是我們頂層文件的接口,括號外面的是我們調用底層模塊的接口,這些接口要一一對應正確才能保證數(shù)據(jù)之間的傳輸。
  在頂層模塊中,我們只定義了數(shù)據(jù)輸入接口,用來接收數(shù)據(jù),數(shù)據(jù)輸出接口,用于發(fā)送數(shù)據(jù),時鐘接口,和復位接口。這四個接口是有輸入輸出關系的,對于其他的接口,是屬于我們整個模塊內部的接口,是模塊與模塊之間的接口,既非輸入,也非輸出,相當于一根導線一樣,所以我們把他們定義成wire型變量
  


  2、波特率選擇模塊
  單片機或者計算機在串口通信時的傳輸速率用波特率表示,9600bps表示的就是每秒鐘傳送9600位的數(shù)據(jù)
  這里之所以計數(shù)到5027,在這里算一下。
  1秒傳送9600位,那么傳送一位的時間就可以算出,即1s=1000_000_000ns,所以傳送一位數(shù)據(jù)需要1000_000_000/9600=
  104166ns,而我們的時鐘周期為20ns,因此需要計數(shù)到104166/20=5028個時鐘周期
  下面是串口通信時序圖
  


  我再來解釋一下這個圖吧,我當時學單片機的時候還真是沒怎么重視這張圖,只知道只要一個指令就可以發(fā)送,沒有真正搞清楚是怎么發(fā)送和接受的,那就在這里復習一下吧
  計算機和單片機之間進行通信,這里用的是rs232通信方式,即通信之前,計算機和單片機之前要設定好相同的波特率,只有波特率相同了才能進行通信。
  其次,計算機發(fā)送數(shù)據(jù)時要先發(fā)送一個起始位,一般是低電平,后面跟著的是8位數(shù)據(jù)位,奇偶校驗位,停止位等,當起始位低電平信號傳送到我們的接收端口時,在接收模塊中會發(fā)送一個命令給波特率時鐘計數(shù)器,開始計時,計時到一半的時候會產生一個采樣高脈沖信號,當接收模塊檢測到這個高脈沖之后就會將數(shù)據(jù)存到寄存器中,當檢測到第11個脈沖信號時,也就是代表一幀的數(shù)據(jù)接收完畢,發(fā)送模塊就給波特率選擇模塊發(fā)送一個停止信號告訴它停止計時。同時,當數(shù)據(jù)接收完畢之后也會產生一個信號告訴發(fā)送模塊,信號已經(jīng)接收完畢,準備發(fā)送,這個時候發(fā)送模塊再給波特率計時模塊發(fā)送一個信號開始計時,計數(shù)到某一位的中間時產生一個采樣信號,當發(fā)送模塊檢測到采樣信號之后就將寄存器里的數(shù)據(jù)送到發(fā)送端,每次只送一位,這樣就實現(xiàn)了數(shù)據(jù)的接收與發(fā)送。
  下面是波特率計時模塊的主要程序部分
  


  3、數(shù)據(jù)接收模塊
  在接收模塊中,為了準確的檢測計算機發(fā)送來的數(shù)據(jù)起始位的那個低電平信號,用到了邊沿脈沖檢測法,可以有效的避免毛刺現(xiàn)象帶來的問題
  


  下面是發(fā)送部分的主要程序段
  


  4、數(shù)據(jù)發(fā)送模塊
  發(fā)送模塊原理上和接受模塊是一樣的,不同點就是接收模塊通過邊沿檢測法檢測起始位低電平信號來啟動接收數(shù)據(jù),而發(fā)送模塊是通過檢測數(shù)據(jù)發(fā)送完畢后,我們認為的置一個低電平信號,發(fā)送模塊通過檢測這個低電平信號來啟動發(fā)送。見下圖
  


  下面是生成的RTL視圖
  


  下面是測試結果
  

                               
               
本文地址:http://www.qingdxww.cn/thread-161110-1-1.html     【打印本頁】

本站部分文章為轉載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據(jù)著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區(qū)
  • 了解一下Microchip強大的PIC18-Q24 MCU系列
  • 想要避免發(fā)生災難,就用MPLAB® SiC電源仿真器!
  • 安靜高效的電機控制——這才是正確的方向!
  • 為何選擇集成電平轉換?
  • 貿澤電子(Mouser)專區(qū)

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 精品卡通动漫在线观看视频一区 | 2020国产精品 | 香蕉视频国产精品人 | 欧美va在线观看 | 2021久久伊人精品中文字幕有 | 99久久国内精品成人免费 | 欧美整片在线观看 | 99这里只有精品6 | 午夜视频免费看 | 日韩在线欧美在线 | 日韩在线看片中文字幕不卡 | 一级毛片成人免费看免费不卡 | 国产99久久九九精品免费 | 他是谁电视剧免费观看 天堂 | 日韩在线 在线播放 | 久久精品成人一区二区三区 | 青青草原在线新免费 | h动漫免费观看 | 精品国产中文一级毛片在线看 | 日本在线视频免费看 | 亚洲色图欧美一区 | 在线天堂网| 色播亚洲视频在线观看 | 亚洲播播播 | a毛片在线免费观看 | 视频三区| 免费啪视频 | 高傲名媛野外耻辱调教 | 日韩成人在线免费视频 | 欧美视频亚洲色图 | 99热这里只有免费国产精品 | 国产91在线看 | 亚洲导航深夜福利 | 99视频在线 | 乱中年女人伦中文字幕久久 | 男人扒开女人下狂躁视频 | 麻豆国产精品高中生视频 | 国产91系列 | 美女又黄又免费的视频 | 欧美日韩在线免费看 | 日韩在线视频观看 |