<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > ARM9硬件接口學(xué)習之UART

ARM9硬件接口學(xué)習之UART

作者: 時(shí)間:2013-01-04 來(lái)源:網(wǎng)絡(luò ) 收藏
  在沒(méi)有引入之前,由于沒(méi)有OS,我們寫(xiě)程序燒到開(kāi)發(fā)板內執行后,并不能在程序的運行過(guò)程中打印一些提示信息告訴我們程序究竟運行了如何或者提供接口讓用戶(hù)去控制程序的運行路徑,最后也只能通過(guò)物理現象去判斷程序是否執行成功。

  使用串口我們便可以實(shí)現開(kāi)發(fā)板最基本的數據的發(fā)送和接收,實(shí)現同開(kāi)發(fā)板的交互,控制程序的運行,并且在程序運行中打印出一些信息進(jìn)行debug。實(shí)際上bootloader和kernel的控制臺(nfs模式)都是通過(guò)uart實(shí)現的。由此我們可以發(fā)現uart在實(shí)際開(kāi)發(fā)中是非常重要的。

  1. s3c2410串口基礎

  S3C2410A 詳細的規格說(shuō)明請參考s3c2410的datasheet。

  1) S3c2410的uart默認使用的系統時(shí)鐘是PCLK。

  這和計算uart的波特率有關(guān)。

  2) 的功能模塊及數據傳輸流程

  每一個(gè)uart都包含一個(gè)波特率發(fā)生器(Baudrate Generator),發(fā)送器(Transmitter),接收器(Receiver)以及一個(gè)控制邏輯(Control Unit)。

  波特率發(fā)生器使用的時(shí)鐘可以為PCLK(默認)或者UEXTCLK(主要是為了達到更高的波特率,默認使用PCLK最高為230.4k bps)。發(fā)送器和接受器分別包括一個(gè)16-byte的FIFO以及一個(gè)數據移位器(data shifter)。數據通過(guò)發(fā)送引腳(TxDn)和接收引腳(RxDn)進(jìn)行發(fā)送和接收。

  發(fā)送數據時(shí),CPU通過(guò)內部總線(xiàn)將要發(fā)送的數據寫(xiě)入Transmit buffer,對程序員來(lái)講即將數據寫(xiě)入Transmit Holding Register(若使用FIFO Mode也是寫(xiě)入這個(gè)寄存器,硬件內部會(huì )自動(dòng)判斷)。然后Transmitter按照Buad-rate Generator產(chǎn)生的波特率將Transmit Buffer內的數據移入Transmit Shifter, 最后通過(guò)TXDn引腳發(fā)送出去。

  接收數據時(shí),接收引腳(RxDn)按一定波特率通過(guò)UART接口模塊進(jìn)行數據接收進(jìn)來(lái)存放在Receive Shifter然后再移入Receive Buffer。對程序員來(lái)講即通過(guò)Receive Holding Register讀取接收到的數據(類(lèi)似發(fā)送,不管是否使用FIFO Mode都是讀該寄存器獲取接收到的數據)。

  Transmit Holding Register和Receive Holding Register都是8 bit大小的寄存器,即每次可讀寫(xiě)一個(gè)字節數據。

  3) 波特率的計算

  波特率時(shí)鐘主要是用來(lái)提供串口數據發(fā)送和接收時(shí)所需要的時(shí)鐘信號。

  計算方法為源時(shí)鐘(默認為PCLK)除以16以及一個(gè)16位分頻因子(divisor)。分頻因子的值存儲在baudrate divisor register (UBRDIVn)內,由用戶(hù)指定。

  通常我們計算波特率的方法為根據想要的波特率反過(guò)來(lái)計算divisor, 然后將該值寫(xiě)入Divisor Register(UBRDIVn)寄存器內。公式如下:

  UBRDIVn = (int)(PCLK/(bps x 16) ) -1

  Bps為我們需要設置的波特率,比如115200。

  2. s3c2410串口實(shí)驗

  實(shí)驗代碼很簡(jiǎn)單,非常適合串口編程入門(mén)。

  內容為:通過(guò)串口打印出一行信息提示用戶(hù)輸入一個(gè)字符。若用戶(hù)輸入’e’即退出程序。若輸入其他字符則重復嘗試。

  下面具體分析:(部分內容引用自《S3C2410完全開(kāi)發(fā)流程》,這里感謝其作者的貢獻)

  UART的寄存器有11X3個(gè)(3個(gè)UART)之多,我們選最簡(jiǎn)單的方法來(lái)進(jìn)行本實(shí)驗,用到的寄存器也有8個(gè)。不過(guò)初始化就用去了5個(gè)寄存器,剩下的3個(gè)用于接收、發(fā)送數據。如此一來(lái),操作UART倒也不復雜。本板使用UART0:

  1) 初始化:

  a. 把使用到的引腳GPH2、GPH3定義為T(mén)XD0、RXD0:

  GPHCON |= 0xa0; //GPH2,GPH3 set as TXD0,RXD0

  GPHUP = 0x0c; //GPH2,GPH3內部上拉

  b.ULCON0 ( UART channel 0 line control register ):設為0x03

  此值含義為:8個(gè)數據位,1個(gè)停止位,無(wú)校驗,正常操作模式。

  c.UCON0 (UART channel 0 control register ):設為0x05

  除了位[3:0],其他位都使用默認值。位[3:0]=0b0101表示:發(fā)送、接收都使用“中斷或查詢(xún)方式”--本實(shí)驗使用查詢(xún)查詢(xún)方式。

  d.UFCON0 (UART channel 0 FIFO control register ):設為0x00

  每個(gè)UART內部都有一個(gè)16字節的發(fā)送FIFO和接收FIFO,但是本實(shí)驗不使用FIFO,設為默認值0

  e.UMCON0 (UART channel 0 Modem control register ):設為0x00

  本實(shí)驗不使用流控,設為默認值0

  f.UBRDIV0 ( R/W Baud rate divisior register 0 ):設為27

  UBRDIV0 = 27; //波特率為115200

  本實(shí)驗使用PLL,PCLK=50MHz,設置波特率為115200,則由公式

  UBRDIVn = (int)(PCLK / (bps x 16) ) -1

  可以計算得UBRDIV0 = 27,請使用S3C2410數據手冊第314頁(yè)的誤差公式驗算一下此波特率是否在可容忍的誤差范圍之內,如果不在,則需要更換另一個(gè)波特率(本實(shí)驗使用的115200是符合的)。


上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: ARM9 硬件接口 UART

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>