《第六章 S3C2410的串口UART及编程课件.ppt》由会员分享,可在线阅读,更多相关《第六章 S3C2410的串口UART及编程课件.ppt(34页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第六章第六章 S3C2410的串口的串口UART及编程及编程 主要内容:主要内容:v6.1 S3C2410的串口的串口UART概述概述v6.2 UART的控制寄存器的控制寄存器v6.3 UART通信程序例子通信程序例子6.1 S3C2410的串口的串口UART概述概述6.1.1 S3C2410串行通信(串行通信(UART)单元)单元vS3C2410 UART单元提供单元提供3个独立的异步串行通信个独立的异步串行通信接口,皆可工作于中断和接口,皆可工作于中断和DMA模模v式。使用系统时钟最高波特率达式。使用系统时钟最高波特率达230. 4 kb/s,如果,如果使用外部设备提供的时钟,可以达到更高
2、的速率。使用外部设备提供的时钟,可以达到更高的速率。每一个每一个UART单元包含一个单元包含一个16字节的字节的FIFO发送缓冲发送缓冲器和一个器和一个16字节的字节的FIFO接收缓冲器,用于数据的接接收缓冲器,用于数据的接收和发送。收和发送。vS3C2410X UART支持可编程波特率、红外发支持可编程波特率、红外发送送/接收接收( 只只UART2 )、1个或个或2个停止位、个停止位、5位位/6位位/7位位/8位数据宽度和奇偶校验。位数据宽度和奇偶校验。6.1.2 波特率的产生波特率的产生v波特率由一个专用的波特率由一个专用的UART波特率分频寄存波特率分频寄存器器(UBRDIVn)(n=0
3、2)控制,计算公式如)控制,计算公式如下下 UBRDIVn=(int)ULK/(波特率波特率 16)1或者或者 UBRDIVn=(int) PLK/(波特率波特率 16)16.1.3 UART通信操作通信操作v下面简略介绍下面简略介绍UART操作,关于数据发送、操作,关于数据发送、数据接收、中断产生、波特率产生、查询检数据接收、中断产生、波特率产生、查询检测模式、红外模式和自动流控制的详细介绍,测模式、红外模式和自动流控制的详细介绍,请参照相关教材和数据手册。请参照相关教材和数据手册。v发送数据帧是可编程的。一个数据帧包含发送数据帧是可编程的。一个数据帧包含1个个起始位、起始位、58个数据位、
4、个数据位、1个可选的奇偶校验个可选的奇偶校验位和位和12位停止位,停止位位数通过行控制位停止位,停止位位数通过行控制寄存器寄存器ULCONn配置。配置。6.2 UART的控制寄存器的控制寄存器6.2.1 UART线路控制寄存器线路控制寄存器ULCONnv该寄存器的位该寄存器的位6决定是否使用红外模式,决定是否使用红外模式,位位5、位、位4和位和位3决定校验方式,位决定校验方式,位2决定决定停止位长度,位停止位长度,位1和位和位0决定每帧的数据决定每帧的数据位数。具体如表位数。具体如表6-1所示所示:v6.2.2 UART控制寄存器控制寄存器UCONnv该寄存器决定UART的各种模式,见表6-2
5、所示:6.2.3 UART FIFO控制寄存器控制寄存器UFCONnvS3C2410 UART每通道有每通道有16个字节的先入先个字节的先入先出(出(FIFO)接收缓冲器和)接收缓冲器和16个字节的先入先个字节的先入先出(出(FIFO)发送缓冲器,如果在程序中使用)发送缓冲器,如果在程序中使用它们,必须要对它们,必须要对UART FIFO控制寄存器控制寄存器UFCONn进行定义,进行定义,UFCONn的配置如表的配置如表6-3所示:所示:6.2.4 UART 调制解调器控制寄存器调制解调器控制寄存器UMCONn(n=0或或1)发送寄存器发送寄存器UTXH和接收寄存器和接收寄存器URXHv这两个
6、寄存器存放发送和接收的数这两个寄存器存放发送和接收的数据,当然只有据,当然只有1字节字节(8位数据位数据)。需。需要注意的是,在发生溢出错误时,要注意的是,在发生溢出错误时,接收的数据必须被读出来,否则会接收的数据必须被读出来,否则会引发下次溢出错误。引发下次溢出错误。6.2.6 UART TX/RX 状态寄存器状态寄存器UTRSTATvUART TX/RX状态寄存器UTRSTAT配置见表6-5:6.3 UART通信程序例子通信程序例子vUART通信电平可有三种形式,通信电平可有三种形式,TTL电平,电平,RS232或或RS485。嵌入式控制系统大多具有小、巧、轻、。嵌入式控制系统大多具有小、
7、巧、轻、灵、薄的特点,许多传感器和灵、薄的特点,许多传感器和S3C2410一体或距离一体或距离很近,没有干扰,例如多参数监护仪等医疗设备,很近,没有干扰,例如多参数监护仪等医疗设备,为简化电路,可采用为简化电路,可采用TTL电平直接与电平直接与S3C2410相连。相连。v如果通信距离在几十米左右并是点对点通信可如果通信距离在几十米左右并是点对点通信可采用采用RS232接口,否则只能采用接口,否则只能采用RS485通信。在工通信。在工程上程上UART通信大多采用三线制(发送连对方接收、通信大多采用三线制(发送连对方接收、接收连对方发送,双方共地)。本节在介绍接收连对方发送,双方共地)。本节在介绍
8、RS232接口电路的同时给出了一个接口电路的同时给出了一个UART通信程序实例。通信程序实例。6.3.1 RS232接口电路接口电路v本实验平台的电路中,本实验平台的电路中,UART0与与S3C2410连连接电路如图接电路如图6-1所示,所示,UART0只采用两根接只采用两根接线线RXD0和和TXD0 (RS232只能实现点对点通只能实现点对点通信,且两点要共地信,且两点要共地),因此只能进行简单的数,因此只能进行简单的数据传输及接收。据传输及接收。UART0采用美信采用美信332电平转电平转换器换器(MAX332)做电平转换做电平转换 图6-1 UART0X与S3C2410的连接电路图 6.
9、3.2 UART实验程序实验程序v/-v/ 头文件头文件uart0.hv/-v#define TX_INTTYPE 1 /1:发送中断电平触发标志:发送中断电平触发标志v#define RX_INTTYPE 1 /1:接收中断电平触发标志:接收中断电平触发标志vextern void Uart_Port_Set(void); /保存本程序使用的端口原状态保存本程序使用的端口原状态vextern void Uart_Port_Return(void); /恢复本程序使用的端口原状恢复本程序使用的端口原状态态vextern void Uart_Uclk_En(int, int); /串行通信使用串
10、行通信使用UCLKvextern void Uart_Pclk_En(int, int); / 串行通信使用串行通信使用PCLK vvoid Test_Uart0_Int(void); /UART0初始化初始化v/-v/ UART实验程序实验程序v/-v#include v#include v#include 2410addr.hv#include 2410lib.hv#include def.hv#include uart0.hvvoid Uart_Port_Set(void);vvoid Uart_Port_Return(void);vvoid _irq Uart0_TxInt(void)
11、 ; /发送中断服务程序发送中断服务程序vvoid _irq Uart0_RxIntOrErr(void); /接收字符和错误代码中断服务接收字符和错误代码中断服务程序程序vvoid _sub_Uart0_RxInt(void); /接收字符子中断服务程序,从上接收字符子中断服务程序,从上面程序分出面程序分出vvolatile U32 save_rGPHCON,save_rGPHDAT,save_rGPHUP;vvolatile U32 save_ULCON0,save_UCON0,save_UFCON0,save_UMCON0;v/* 定义一些变量,做临时保存端口数据和状态的缓冲区,通信结束
12、,端定义一些变量,做临时保存端口数据和状态的缓冲区,通信结束,端口数据和状态要恢复口数据和状态要恢复*/vVolatile U32 isTxint isRxint; /定义二个变量,分别做发送和接收中定义二个变量,分别做发送和接收中断结束与否标志断结束与否标志vvolatile static char *uart0TxStr;/ UART0发送字串地址发送字串地址vvolatile static char *uart0RxStr;/ UART0接收字串地址接收字串地址v/-v/ 保存保存UART实验使用的端口和寄存器实验使用的端口和寄存器v/-vvoid Uart_Port_Set(void)
13、vv /保存保存H口控制寄存器口控制寄存器v save_rGPHCON=rGPHCON; v save_rGPHDAT=rGPHDAT;v save_rGPHUP=rGPHUP;v /配置配置UART口口v rGPHCON&=0 x3c0000;v rGPHCON|=0 x2faaa; /H口控制寄存器口控制寄存器nRTS1,nCTS1功能功能使能使能v rGPHUP|=0 x1ff; /Uart 口上拉禁止口上拉禁止v /rINTSUBMSK=0 x7ff; /屏蔽全部子中断屏蔽全部子中断v save_ULCON0=rULCON0; /保存保存UART控制寄存器控制寄存器 v save_UC
14、ON0=rUCON0; v save_UFCON0=rUFCON0; v save_UMCON0=rUMCON0; v /Initialize UART0, portv v/-v/ 恢复恢复UART实验使用的端口和寄存器实验使用的端口和寄存器v/-vvoid Uart_Port_Return(void)v v /Pop UART GPIO port configurationv rGPHCON=save_rGPHCON;v rGPHDAT=save_rGPHDAT;v rGPHUP=save_rGPHUP;v /Pop Uart control registers v rULCON0=save
15、_ULCON0; v rUCON0 =save_UCON0; v rUFCON0=save_UFCON0; v rUMCON0=save_UMCON0; v vv/-v/ UART通信使用通信使用UCLK做波特率发生器做波特率发生器vvoid Uart_Uclk_En(int ch,int baud)vv v int ch, baud;v Uart_Printf(nSelect UART channel0:UART0;1:UART1;2:UART2:n);v ch=Uart_GetIntNum(); /从键盘读通道号从键盘读通道号v Uart_Printf(nSelect baud rate
16、:n); v baud=Uart_GetIntNum(); /从键盘读波特率从键盘读波特率v if(ch = 0) /选选UART0v Uart_Select(0);v rUCON0|=0 x400; /选选UCLKv rUBRDIV0=( (int)(UCLK/16./baud) -1 ); /波特率因子寄存器波特率因子寄存器v Uart_Printf(UCLK is enabled by UART0.n); v vfor(i=0;i100;i+ v UART实验使用实验使用PCLKv/-vvoid Uart_Pclk_En(int ch, int baud)vv int ch, baud;
17、vUart_Printf(nSelect UART channel0:UART0/1:UART1/2:UART2:n);v ch=Uart_GetIntNum();v Uart_Printf(nSelect baud rate :n);v baud=Uart_GetIntNum();v v if(ch = 0) 选选UART0v Uart_Select(0);vrUCON0&=0 x3ff;/ Select PCLKv rUBRDIV0=( (int)(PCLK/16./baud) -1 ); /Baud rate divisior registerv Uart_Printf(PCLK is
18、enabled by UART0.n); v v v for(i=0;iUART0 Tx interrupt test is good!rn; /发送的实验字发送的实验字串串vUart_Printf(Uart channel 0 Tx Interrupt Testn);/在终端上提示在终端上提示vpISR_UART0=(unsigned)Uart0_TxInt; /设中断向量,即发送中断服设中断向量,即发送中断服务程序入口务程序入口vrULCON0=(06)|(03)|(02)|(3); /* 正常发送,无效验,一个停止正常发送,无效验,一个停止位,位,8个数据位个数据位v 选选 UCLK *
19、/ v rUCON0&=0 x400;vrUCON0|=(TX_INTTYPE9)|(RX_INTTYPE8)|(07)|(06)|(05)|(04)|(12)|();v /选时钟,发送,接收中断选时钟,发送,接收中断v Uart_TxEmpty(0); /等,直到发送缓冲器空,此时会产生等,直到发送缓冲器空,此时会产生发送中断发送中断v rINTMSK=(BIT_UART0); / 总中断屏蔽(总中断屏蔽(UART0位)打开位)打开v rINTSUBMSK=(BIT_SUB_TXD0); / 子中断屏蔽(子中断屏蔽(UART0发送位)发送位)打开打开v while(isTxInt);/* 从
20、此处进入中断,中断结束又返回这里等下次中断,从此处进入中断,中断结束又返回这里等下次中断,直到发送结束直到发送结束 visTxInt=0跳出,在超级终端上可看到发给它的字符跳出,在超级终端上可看到发给它的字符 */v v/ UART0接收中断实验,接收中断实验,UART0接收从键盘上输入的字符,按接收从键盘上输入的字符,按ENTER键接收结键接收结束束visRxInt=1;/接收中断标志,接收结束,接收中断标志,接收结束,isRxInt=0v uart0RxStr=(char *)UARTBUFFER;/ 接收字串缓冲区首地址设定接收字串缓冲区首地址设定vUart_Printf(nUart c
21、hannel 0 Rx Interrupt Test:n);/提示提示vUart_Printf(After typing ENTER key, you will see the characters which was typed by you.);vUart_Printf(nTo quit, press ENTER key.!n);vUart_TxEmpty(0) ;/*等,直到发送缓冲器空,(等上面发送的最后一个字符等,直到发送缓冲器空,(等上面发送的最后一个字符被对方取走,才进行接收实验)被对方取走,才进行接收实验)*/vpISR_UART0 =(unsigned)Uart0_RxInt
22、OrErr;/ 设中断向量,即接收中断服务设中断向量,即接收中断服务程序入口程序入口vrULCON0=(06)|(03)|(02)|(3); /正常接收,无效验,一个停止位,正常接收,无效验,一个停止位,8个数个数据位据位vrUCON0 &= 0 x400; /选选 UCLKvrUCON0|= (TX_INTTYPE9)|(RX_INTTYPE8)|(07)|(16)|(05)|(04)|(12)|(1);v /选时钟,发送,接收中断选时钟,发送,接收中断v ClearPending(BIT_UART0); /清清UART0中断挂起中断挂起vrINTMSK=(BIT_UART0); /中断打开
23、中断打开vrSUBSRCPND=(BIT_SUB_TXD0|BIT_SUB_RXD0|BIT_SUB_ERR0); vrINTSUBMSK=(BIT_SUB_RXD0|BIT_SUB_ERR0);/ 子子中断打开中断打开vwhile(isRxInt); /* 从此处进入中断,中断结束又返回这里从此处进入中断,中断结束又返回这里等下次中断,直到接收结束等下次中断,直到接收结束isRxInt=0跳出跳出 */v rINTSUBMSK|=(BIT_SUB_RXD0|BIT_SUB_ERR0);/ 中中断结束断结束,屏蔽子中断屏蔽子中断(0通道接收位通道接收位)vrINTMSK|=(BIT_UART0
24、); /中断结束,屏蔽总中断中断结束,屏蔽总中断(0通通道道UART位位)v vUart_Printf(%sn,(char *)UARTBUFFER);/打印接收的打印接收的字符串,实际就是在终端上显示字符串,实际就是在终端上显示vUart_Port_Return(); /恢复口状态恢复口状态vv/-v/ UART初始化初始化v/-vvoid Uart_Init(int pclk,int baud)vv int i;v static int whichUart=0;v if(pclk = 0)v pclk = PCLK;v/UART0vrULCON0 = 0 x3; /正常模式正常模式,无效验
25、无效验,1个停止位个停止位,8个数据位个数据位vrUCON0 = 0 x245;v10 9 8 7 6 5 4 3:2 1:0v/Clock Sel, Tx Int, Rx Int, Rx Time Out, Rx err, Loop-back, Send break, Transmit Mode, Receive Modev/ 0 1 0 0 1 0 0 01 01v/ PCLK Level Pulse Disable Generate Normal Normal Interrupt or Pollingv v rUBRDIV0=( (int)(pclk/16./baud+0.5) -1 ); / 波特率因子波特率因子 v vv/-v/ UART实验主程序实验主程序v/-vvoid main(void)vvUart_Init(0,115200);/ UART初始化初始化vTest_Uart0_Int();/* 该程序同时完成发送中断实验和接收中断实验,发送的字该程序同时完成发送中断实验和接收中断实验,发送的字符串由发送程序设定。接收的字符串由键盘发出,按符串由发送程序设定。接收的字符串由键盘发出,按ENTER结束接收。先做发结束接收。先做发送,后做接收送,后做接收 */v
限制150内