《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > ARM9硬件接口學習之UART
ARM9硬件接口學習之UART
摘要: 在沒有引入UART之前,由于沒有OS,我們寫程序燒到開發(fā)板內(nèi)執(zhí)行后,并不能在程序的運行過程中打印一些提示信息告訴我們程序究竟運行了如何或者提供接口讓用戶去控制程序的運行路徑,最后也只能通過物理現(xiàn)象去判斷程序是否執(zhí)行成功。
關鍵詞: ARM ARM9 硬件接口 UART
Abstract:
Key words :

     在沒有引入UART之前,由于沒有OS,我們寫程序燒到開發(fā)板內(nèi)執(zhí)行后,并不能在程序的運行過程中打印一些提示信息告訴我們程序究竟運行了如何或者提供接口讓用戶去控制程序的運行路徑,最后也只能通過物理現(xiàn)象去判斷程序是否執(zhí)行成功。

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

  1. s3c2410串口基礎

  S3C2410A UART詳細的規(guī)格說明請參考S3c2410的datasheet。

  1) S3C2410的uart默認使用的系統(tǒng)時鐘是PCLK。

  這和計算uart的波特率有關。

  2) UART的功能模塊及數(shù)據(jù)傳輸流程

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

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

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

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

  Transmit Holding Register和Receive Holding Register都是8 bit大小的寄存器,即每次可讀寫一個字節(jié)數(shù)據(jù)。

  3) 波特率的計算

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

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

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

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

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

  2. s3c2410串口實驗

  實驗代碼很簡單,非常適合串口編程入門。

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

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

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

  1) 初始化:

  a. 把使用到的引腳GPH2、GPH3定義為TXD0、RXD0:

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

  GPHUP = 0x0c;   //GPH2,GPH3內(nèi)部上拉

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

  此值含義為:8個數(shù)據(jù)位,1個停止位,無校驗,正常操作模式。

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

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

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

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

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

  本實驗不使用流控,設為默認值0

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

  UBRDIV0 = 27;   //波特率為115200

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

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

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

  2) 發(fā)送數(shù)據(jù):

  a.UTRSTAT0 ( UART channel 0 Tx/Rx status register ):

  位[2]:無數(shù)據(jù)發(fā)送時,自動設為1。當我們要使用串口發(fā)送數(shù)據(jù)時,先讀此位以判斷是否有數(shù)據(jù)正在占用發(fā)送口。

  位[1]:發(fā)送FIFO是否為空,本實驗未用此位

  位[0]:接收緩沖區(qū)是否有數(shù)據(jù),若有,此位設為1。本實驗中,需要不斷查詢此位一判斷是否有數(shù)據(jù)已經(jīng)被接收。

  b.UTXH0 (UART channel 0 transmit buffer register ):

  把要發(fā)送的數(shù)據(jù)寫入此寄存器。

關鍵字:ARM9 硬件接口 UART

 

3) 接收數(shù)據(jù):

  a.UTRSTAT0:如上描述,我們用到位[0]

  b.URXH0 (UART channel 0 receive buffer register ):

  當查詢到UTRSTAT0 位[0]=1時,讀此寄存器獲得串口接收到的數(shù)據(jù)。

  4) 實驗源代碼

  /* main.c */

  #include "uart.h"

  #include "clock.h"

  #include "watchdog.h"

  int Main(void)

  {

  char key = ' ';

  clock_init(); //初始化時鐘

  uart_init(); //初始化串口

  close_watchdog();

  uart_send("uart communication success!\r\n");

  while(1)

  {

  uart_send("If you want to quit ,please pess 'e'\r\n");

  key = uart_get();

  if (key == 'e')

  {

  uart_send ("you pressed 'e' and you'll quit!\r\n");

  break;

  }

  else

  {

  uart_send("you pressed ");

  uart_send(&key);

  uart_send(",retry!\r\n");

  }

  }

  uart_send("the program exited by user!\r\n");

  return 0;

  }

  下面是串口相關部分源碼:

  void uart_init(void)

  {

  ULCON0 = 0x03;     //8N1

  UCON0 = 0x005; //中斷或查詢方式

  UFCON0 = 0x00;    //不使用FIFO

  UMCON0 = 0x00;    //不使用流控

  UBRDIV0 = 27;    //波特率為115200

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

  GPHUP = 0x0c;    //GPH2,GPH3內(nèi)部上拉

  }

  void uart_send(char * c)

  {

  for (; *c != '\0'; c++)

  {

  while(!(UTRSTAT0 & TXD0READY)) ;     //不斷查詢,直到可以發(fā)送數(shù)據(jù)

  UTXH0 = *c ;                        //發(fā)送數(shù)據(jù)

  }

  }

  unsigned char uart_get(void)

  {

  while(!(UTRSTAT0 & RXD0READY)) ;     //不斷查詢,直到接收到了數(shù)據(jù)

  return URXH0;                        //返回接收到的數(shù)據(jù)

 

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲欧美国产一区二区三区| 久久久精品国产免费观看同学| 亚洲在线一区二区| 亚洲日韩欧美视频一区| 在线免费精品视频| 国产综合久久| 国产日韩综合一区二区性色av| 国产精品久久久一区麻豆最新章节| 欧美日韩99| 欧美久色视频| 欧美激情国产精品| 欧美激情第六页| 欧美激情精品久久久久久| 美玉足脚交一区二区三区图片| 久久婷婷激情| 老鸭窝毛片一区二区三区 | 午夜精品久久久久久99热软件| 一区二区三区国产精品| 一本色道久久综合狠狠躁篇的优点 | 欧美午夜激情视频| 欧美人成在线| 欧美日韩精品一区二区在线播放 | 最新日韩精品| 亚洲黄色一区二区三区| 91久久综合| 99国产精品99久久久久久粉嫩| 亚洲裸体在线观看| 在线视频免费在线观看一区二区| 一区二区三区欧美激情| 亚洲在线视频观看| 欧美一区二区视频网站| 久久国产精品一区二区| 久久免费高清视频| 欧美成人精品| 欧美日韩视频一区二区| 国产精品毛片大码女人| 国产日韩欧美在线播放不卡| 国产一区二区按摩在线观看| 黄色av日韩| 亚洲人成啪啪网站| 一区二区不卡在线视频 午夜欧美不卡'| 在线一区二区三区四区| 亚洲欧美中文日韩v在线观看| 欧美中文字幕| 亚洲精品欧美| 亚洲影音一区| 小处雏高清一区二区三区| 久久精品国产亚洲5555| 欧美成人午夜视频| 欧美视频在线播放| 国产一区二区福利| 亚洲精品在线免费观看视频| 一本在线高清不卡dvd | 亚洲人屁股眼子交8| 亚洲午夜激情网站| 久久国产综合精品| 欧美69wwwcom| 国产精品久久久一本精品| 国产一区二区三区在线观看免费视频 | 99精品欧美一区| 小处雏高清一区二区三区| 久久中文久久字幕| 欧美日韩亚洲系列| 国产一区二区三区丝袜| 亚洲精品护士| 欧美一区二区视频在线观看2020| 亚洲精品一区二区三区四区高清| 亚洲欧美日韩区| 欧美成人国产| 国产片一区二区| 91久久久久| 欧美专区日韩专区| 亚洲午夜视频在线| 久久亚洲精品一区| 欧美性事在线| 亚洲东热激情| 在线亚洲免费| 亚洲人成人99网站| 久久精品国产亚洲一区二区三区| 欧美日韩p片| 狠狠久久亚洲欧美专区| 中文一区字幕| 日韩一级免费| 久热精品视频| 国产欧美一区二区在线观看| 亚洲美女黄色| 亚洲精品久久久久久下一站 | 久久久成人精品| 国产精品jizz在线观看美国| 原创国产精品91| 校园春色综合网| 亚洲女与黑人做爰| 欧美精品一区二区视频| 黄色成人精品网站| 亚洲欧美中日韩| 亚洲欧美成人在线| 欧美日韩美女| 亚洲黄一区二区| 亚洲第一区在线| 久久久7777| 国产欧美日韩一区| 亚洲在线观看视频网站| 亚洲一区亚洲二区| 欧美日韩国产美| 亚洲日本成人| 最新国产乱人伦偷精品免费网站| 久久久久青草大香线综合精品| 国产精品美女视频网站| 99国产精品国产精品久久 | 欧美国产乱视频| 激情久久中文字幕| 久久不见久久见免费视频1| 性久久久久久久久| 欧美视频一区二区三区四区| 亚洲九九爱视频| 日韩一级在线观看| 欧美二区在线观看| 亚洲国产精品精华液2区45 | 亚洲欧美国产制服动漫| 欧美日韩在线影院| 日韩午夜激情| 99国产一区二区三精品乱码| 欧美成人精品| 亚洲精品国产精品久久清纯直播| 亚洲欧洲在线一区| 欧美不卡高清| 亚洲国产一区二区a毛片| 亚洲精品国产精品乱码不99按摩| 欧美mv日韩mv亚洲| 一区二区三区自拍| 亚洲人成绝费网站色www| 欧美激情女人20p| 亚洲破处大片| 一区二区三区欧美激情| 欧美三日本三级三级在线播放| 99riav1国产精品视频| 亚洲永久视频| 国产女人水真多18毛片18精品视频| 亚洲欧美日本国产有色| 久久av一区二区三区漫画| 国产日韩欧美综合精品| 欧美制服第一页| 欧美www视频| 日韩小视频在线观看| 亚洲一区二区三区免费视频| 国产精品护士白丝一区av| 亚洲一区欧美二区| 久久激情五月丁香伊人| 狠狠色狠狠色综合系列| 亚洲人久久久| 国产精品国产三级国产aⅴ入口 | 亚洲欧美综合一区| 国产一区二区电影在线观看 | 亚洲第一偷拍| 欧美精品免费在线| 国产精品99久久不卡二区| 久久激情视频久久| 亚洲国产婷婷香蕉久久久久久99| 亚洲天堂av电影| 国产欧美精品日韩| 亚洲高清免费| 欧美日韩激情小视频| 亚洲一区二区三区精品在线 | 欧美色道久久88综合亚洲精品| 亚洲一区二区免费视频| 久久综合福利| 日韩西西人体444www| 久久国产精品99精品国产| 亚洲二区在线视频| 亚洲一区二区三区在线| 国产一区二区三区黄视频| 亚洲精品久久久久久久久久久久久 | 欧美一级二区| 亚洲国产99| 午夜精品成人在线| **欧美日韩vr在线| 亚洲性视频网站| 好吊视频一区二区三区四区| 99国产精品久久久久老师| 国产精品亚洲аv天堂网| 亚洲激情亚洲| 国产精品区免费视频| 亚洲国产成人精品久久| 欧美午夜精品电影| 亚洲激情av在线| 国产精品拍天天在线| 亚洲精品欧洲精品| 国产毛片精品视频| 9l国产精品久久久久麻豆| 国产欧美在线看| 一区二区三区国产在线观看| 国内精品久久久久影院 日本资源| 一区二区成人精品| 国精产品99永久一区一区| 亚洲一区二区三区在线视频| 激情综合视频| 欧美一二三视频| 一本色道久久综合亚洲精品婷婷| 女人色偷偷aa久久天堂| 西西人体一区二区|