单片机
返回首页

MCU_S3C2410之UART分析

2016-08-03 来源:eefocus

功能分析

寄存器分析

代碼分析

///////////////////////////////////////////////////////////////////////UART 初始化/////////////////////////////////////////////////////////////////////////////////////

void Uart_Init(int pclk,int baud)
{
 int i;
 if(pclk == 0)
 pclk = PCLK;       //APB IS USED FOR APB
 rUFCON0 = 0x0; //关闭UART0的FIFO
 rUFCON1 = 0x0; //关闭UART1的FIFO
 rUFCON2 = 0x0; //关闭UART2的FIFO

MCU_S3C2410之UART分析 - smalming - SmalmingS Blog

 

 


 rUMCON0 = 0x0;//关闭UART0自动流控制AFC (一般不进行握手协议控制)
 rUMCON1 = 0x0;//关闭UART1自动流控制AFC (UART2没有自动流控制功能)

MCU_S3C2410之UART分析 - smalming - SmalmingS Blog


 


 //UART0
 rULCON0 = 0x3; //Normal,No parity,1 stop bit,8 bits data基本协议控制

MCU_S3C2410之UART分析 - smalming - SmalmingS Blog

 


 rUCON0 = 0x245;

MCU_S3C2410之UART分析 - smalming - SmalmingS Blog

MCU_S3C2410之UART分析 - smalming - SmalmingS Blog

 

Transmit MODE:发送模式有请求中断发送和请求DMA发送

TX interrupt Type :当发送保持寄存器为空时(Non-FIFO MODE)或达到TX FIFO触发水平时触发中断的电平类型

(TX FIFO触发水平:00 = Empty  01 = 4-byte  10 = 8-byte  11 = 12-byte  in  UFCONn)

 

Receive  MODE 接收模式有请求中断读取和请求DMA读取

RX interrupt Type :当接收保持寄存器为空时(Non-FIFO MODE)或达到RX FIFO触发水平时触发中断的电平类型(RX FIFO触发水平:00 = 4-byte  01 = 8-byte  10 = 12-byte  11 = 16-byte  in  UFCONn)

 

 

 rUBRDIV0=( (int)(pclk/16/baud) -1 );

MCU_S3C2410之UART分析 - smalming - SmalmingS Blog


 
 //UART1
 rULCON1 = 0x3;
 rUCON1  = 0x245;
 rUBRDIV1=( (int)(pclk/16/baud) -1 );
   


 //UART2
  rULCON2 = 0x3;
  rUCON2  = 0x245;
  rUBRDIV2=( (int)(pclk/16/baud) -1 );
    
    for(i=0;i<100;i++);
}

总结UART的控制寄存器:有ULCON、UCON、UFCON、UMCON、UBRDIV

///////////////////////////////////////////////////////////////////////UART 初始化////////////////////////////////////////////////////////////////////////////////////

 

 

 

 

 

 

///////////////////////////////////////////////////////////////////////UART 发送////////////////////////////////////////////////////////////////////////////////////

void Uart_SendByte(int data)
{
    if(whichUart==0)
     {
         if(data==' ')
         {
              while(!(rUTRSTAT0 & 0x2));

MCU_S3C2410之UART分析 - smalming - SmalmingS Blog

non FIFO=1 Byte BUFFER REGISTER(HOLDING REGISTER)+SHIFTER REGISTER

FIFO mode = 16 Byte BUFFER REGISTER(FIFO REGISTER)+SHIFTER REGISTER


              Delay(10);                 //because the slow response of hyper_terminal 
              WrUTXH0(' ');

MCU_S3C2410之UART分析 - smalming - SmalmingS Blog
         }
         while(!(rUTRSTAT0 & 0x2));   //Wait until THR is empty.
         Delay(10);
          WrUTXH0(data);
     }
     else if(whichUart==1)
     {
         if(data==' ')
         {
              while(!(rUTRSTAT1 & 0x2));
              Delay(10);                 //because the slow response of hyper_terminal 
              rUTXH1 = ' ';
         }
         while(!(rUTRSTAT1 & 0x2));   //Wait until THR is empty.
         Delay(10);
         rUTXH1 = data;
    }   
     else if(whichUart==2)
     {
         if(data==' ')
         {
              while(!(rUTRSTAT2 & 0x2));
              Delay(10);                 //because the slow response of hyper_terminal 
              rUTXH2 = ' ';
         }
         while(!(rUTRSTAT2 & 0x2));   //Wait until THR is empty.
         Delay(10);
         rUTXH2 = data;
     }       
}         

///////////////////////////////////////////////////////////////////////UART 发送////////////////////////////////////////////////////////////////////////////////////

 

 

 

 

 

///////////////////////////////////////////////////////////////////////UART 接收////////////////////////////////////////////////////////////////////////////////////

char Uart_Getch(void)

{
     if(whichUart==0)
     {       
         while(!(rUTRSTAT0 & 0x1)); //Receive data ready
         return RdURXH0();

MCU_S3C2410之UART分析 - smalming - SmalmingS Blog
     }
     else if(whichUart==1)
     {       
         while(!(rUTRSTAT1 & 0x1)); //Receive data ready
         return RdURXH1();
     }
     else if(whichUart==2)
     {
         while(!(rUTRSTAT2 & 0x1)); //Receive data ready
         return RdURXH2();
     }

 

///////////////////////////////////////////////////////////////////////UART 接收////////////////////////////////////////////////////////////////////////////////////

总结UART有状态寄存器UTRSTAT、UERSTAT、UFSTAT、UMSTAT

有数据寄存器UTXH和URXH

进入单片机查看更多内容>>
相关视频
  • RISC-V嵌入式系统开发

  • SOC系统级芯片设计实验

  • 云龙51单片机实训视频教程(王云,字幕版)

  • 2022 Digi-Key KOL 系列: 你见过1GHz主频的单片机吗?Teensy 4.1开发板介绍

  • TI 新一代 C2000™ 微控制器:全方位助力伺服及马达驱动应用

  • MSP430电容触摸技术 - 防水Demo演示

精选电路图
  • 家用电源无载自动断电装置的设计与制作

  • PIC单片机控制的遥控防盗报警器电路

  • 用数字电路CD4069制作的万能遥控轻触开关

  • 使用ESP8266从NTP服务器获取时间并在OLED显示器上显示

  • 用NE555制作定时器

  • RS-485基础知识:处理空闲总线条件的两种常见方法

    相关电子头条文章