CC2530基础实验三:Uart

距离上一次发,五个月了……
贴代码了,Uart是最常用的串行通信方式了,每个单片机一定都会自带至少一个uart用于通信,CC2530也不例外。当然CC2530的是Usart,即通用同步异步串行接收发送器,即可以使用异步Uart模式,也可以使用同步SPI模式。

代码及解析

#include <ioCC2530.h>
#include "string.h"

/****************************
该示例简单的使用了CC2530的Usart模块。
上电后会自动的通过Uart发送一段文字。
在按下KET1时会发送出数字“1”。
在串口助手中给CC2530发送数字“0”,板载的LED1会改变状态。
****************************/

#define LED1 P1_0   //定义LED1为P10口控制
#define KEY1 P0_1   //定义KEY1为P01口控制

#define uchar unsigned char 
#define uint unsigned int 

/*本地函数*/
void initUART(void);
void initLED(void);
void sendmsg(char *);
void delay(int n);

char temp=0;

int main(void)
{
  /*初始化LED*/
  initLED();
  /*初始化Uart*/
  initUART();
  
  sendmsg("新冠新冠快离开!\r\n\r\n");
  
  while(1)
  {
    /*Uart发送相关代码段*/
    if(KEY1 == 0)   //如果有按键按下
    {
      delay(40);    //延时以消抖
      if(KEY1 == 0)
      {
        sendmsg("1\r\n");   //检测到按键1按下后发送数字1
      }
    }
    
    /*Uart接受相关代码段*/
    if(0 != temp)   //如果Uart接收到数据
    {
      if(temp == 0x30)    //如果接受到数字0
      {
        LED1 = !LED1;   //改变LED1状态
      }
      temp = 0;   //清除temp
    }
  }
}
#pragma vector = URX0_VECTOR
__interrupt void UART0_ISR(void) 
{ 
    URX0IF = 0;   //清除中断标志位
    temp = U0DBUF;    //将接收缓冲区的8位数据存入temp中
}

void initLED(void)
{
  P1DIR |= 0x03;    //P1_0/P1_1定义为输出
  LED1 = 1;   //LED1灯初始化为关
}

void initUART(void)
{
  P0SEL |= 0x0C;    //将端口0_4/0_5设置为外设功能
  U0GCR |= 11;
  U0BAUD |= 216;    //设置波特率为57600
  U0CSR |= 0XC0;    //将USART设置为Uart功能,并使能Usart接收器
 			
  URX0IF = 0;   //清除接收中断标志位
  EA = 1;   //开启总中断开关,以能够使用系统的中断功能
  URX0IE = 1;   //Usart0中断功能使能
}

/*延时函数*/
void delay(int n)
{
  int i,j;
  for(i=0;i<n;i++)
    for(j=0;j<1000;j++);
}

/*Uart发送函数*/
void sendmsg(char *data)
{
  while(1)
  {
    if('\0' == *data)   //一旦检测到字符串结束,就退出,一个字符串总是以'\0'作为结尾
    {
      break;
    }
    
    U0DBUF = *data++;   //否则就将当前字符传入发送缓冲区中
    while(UTX0IF == 0);   //等待发送完成,发送完成后UTX0IF会被系统自动置1
    UTX0IF = 0;   //清除发送完成状态
  }
}

另一个版本

当然还有一个代码比较多的版本,也是我当时实验的时候检查的版本。用了DMA和FSM,记录一下

上一篇:C51+led1602


下一篇:opencv-saturate_cast防溢出函数