cortex m0 lpc1114 串口uart查询收发数据
扫描二维码
随时随地手机看文章
LPC1114有一个串口,具备标准9针串口的所有功能引脚:
RXD、TXD、RTS、CTS、DTR、DSR、DCD、IR
一般情况下,我们只用到RXD和TXD。在这一章,只对RXD和TXD的使用做介绍。
可以用于程序下载。
可以设置奇校验、偶校验、无校验。
可以设置数据位为5~8,可以设置停止位为1、1.5、2。
具有自动波特率检测功能。
查询方式串口收发数据
新建一个工程,结构如下图所示:
在uart.h文件中,输入以下代码:
#ifndef __NXPLPC11XX_UART_H__
#define __NXPLPC11XX_UART_H__
extern uint8_t Recived_data;
extern void UART_init(uint32_t baudrate);
extern uint8_t UART_recive(void);
extern void UART_send_byte(uint8_t byte);
extern void UART_send(uint8_t *Buffer, uint32_t Length);
#endif
在uart.c文件中,输入以下代码:
#include “lpc11xx.h”
#include “uart.h”
void UART_init(uint32_t baudrate)
{
uint32_t DL_value,Clear=Clear; // (用这种方式定义变量解决编译器的Warning)
LPC_SYSCON->SYSAHBCLKCTRL |= (1<<16); // 使能IOCON时钟
LPC_IOCON->PIO1_6 &= ~0x07;
LPC_IOCON->PIO1_6 |= 0x01; //把P1.6脚设置为RXD
LPC_IOCON->PIO1_7 &= ~0x07;
LPC_IOCON->PIO1_7 |= 0x01; //把P1.7脚设置为TXD
LPC_SYSCON->SYSAHBCLKCTRL &= ~(1<<16); // 禁能IOCON时钟
LPC_SYSCON->UARTCLKDIV = 0x1; //时钟分频值为1
LPC_SYSCON->SYSAHBCLKCTRL |= (1<<12);//允许UART时钟
LPC_UART->LCR = 0x83; //8位传输,1个停止位,无几偶校验,允许访问除数锁存器
DL_value = SystemCoreClock/16/baudrate ; //计算该波特率要求的除数锁存寄存器值
LPC_UART->DLM = DL_value / 256; //写除数锁存器高位值
LPC_UART->DLL = DL_value % 256; //写除数锁存器低位值
LPC_UART->LCR = 0x03; //DLAB置0
LPC_UART->FCR = 0x07; //允许FIFO,清空RxFIFO 和 TxFIFO
Clear = LPC_UART->LSR; //读UART状态寄存器将清空残留状态
}
uint8_t UART_recive(void)
{
while(!(LPC_UART->LSR & (1<<0)));//等待接收到数据
return(LPC_UART->RBR); //读出数据
}
void UART_send_byte(uint8_t byte)
{
LPC_UART->THR = byte;
while ( !(LPC_UART->LSR & (1<<5)) );//等待发送完
}
第3~21行,定义了串口初始化函数。
第22~26行,定义了串口接收函数。
第27~31行,定义了串口发送函数。
第5行,定义两个变量:DL_value和Clear。DL_value记录波特率锁存器值,Clear用于清空UART状态寄存器。如果只是写成uint32_t Clear,当你编译的时候,将会产生一个提醒:variable“Clear”was set but never used.而写成uint32_t Clear=Clear就会排除这个提示,当然,不排除这个提醒也不会影响程序的正常执行。
第6~11行,把P1.6和P1.7所在引脚配置为RXD TXD。
第14行,设置串口的协议,并开启除数锁存器的访问允许。因为接下来我们要给除数锁存器写值配置串口波特率了。
第15行,计算波特率值。公式详见官方数据手册。
第16、17行,写锁存器值。
第18行,关闭锁存器配置允许。
第19行,清空串口收发FIFO。
第20行,清空串口状态寄存器。
第19和20行,都是为了保证串口的正常通信数据采集正确。
第24行,检测LSR寄存器的bit0,看是否接收到数据。
第25行,返回接收到的数据。
第29行,把要发送的数据给了THR寄存器。
第30行,检测LSR寄存器bit5,看是否发送完数据。
从接收和发送函数,可以看出,收到的数据(RBR)和发送的数据(THR)保存在不同的寄存器。这一点,和普通51以及STM32是有区别的。例如,普通51单片机的收发数据都用SBUF,STM32收发数据都用DR。
在main.c文件中,输入以下代码:
#include “lpc11xx.h”
#include “uart.h”
void delay(void)//
{
uint16_t i,j;
for(i=0;i<5000;i++)
for(j=0;j<1000;j++);
}
int main()
{
uint8_t rec_buf;
UART_init(9600); // 把串口波特率配置为9600
while(1)
{
rec_buf = UART_recive(); // 从串口接收字符
UART_send_byte(rec_buf); // 把接收到的字节发回串口
}
}
主函数实现的功能是,把接收的数据再发回去。打开串口调试助手,波特率配置为9600,选择ASCII字符发送,不管发送什么字符,都会把发送的字符返回串口调试助手显示。从而实现了串口的收发功能。