cortex m0 lpc1114 串口uart查询收发数据

  • 学习8735次

LPC1114有一个串口,具备标准9针串口的所有功能引脚:

RXD、TXD、RTS、CTS、DTR、DSR、DCD、IR

一般情况下,我们只用到RXD和TXD。在这一章,只对RXD和TXD的使用做介绍。

可以用于程序下载。

可以设置奇校验、偶校验、无校验。

可以设置数据位为5~8,可以设置停止位为1、1.5、2。

具有自动波特率检测功能。

查询方式串口收发数据

新建一个工程,结构如下图所示:

新建串口工程

在uart.h文件中,输入以下代码:

  1. #ifndef?? __NXPLPC11XX_UART_H__
  2. #define?? __NXPLPC11XX_UART_H__
  3. extern uint8_t Recived_data;
  4. extern void UART_init(uint32_t baudrate);
  5. extern uint8_t UART_recive(void);
  6. extern void UART_send_byte(uint8_t byte);
  7. extern void UART_send(uint8_t *Buffer, uint32_t Length);
  8. #endif

在uart.c文件中,输入以下代码:

  1. #include “lpc11xx.h”
  2. #include “uart.h”
  3. void UART_init(uint32_t baudrate)
  4. {
  5. ? ?uint32_t DL_value,Clear=Clear;?? // (用这种方式定义变量解决编译器的Warning)
  6. ? ?LPC_SYSCON->SYSAHBCLKCTRL |= (1<<16); // 使能IOCON时钟
  7. ? ?LPC_IOCON->PIO1_6 &= ~0x07;
  8. ? ?LPC_IOCON->PIO1_6 |= 0x01; //把P1.6脚设置为RXD
  9. ? ?LPC_IOCON->PIO1_7 &= ~0x07;
  10. ? ?LPC_IOCON->PIO1_7 |= 0x01; //把P1.7脚设置为TXD
  11. ? ?LPC_SYSCON->SYSAHBCLKCTRL &= ~(1<<16); // 禁能IOCON时钟
  12. ? ?LPC_SYSCON->UARTCLKDIV = 0x1; //时钟分频值为1
  13. ? ?LPC_SYSCON->SYSAHBCLKCTRL |= (1<<12);//允许UART时钟
  14. ? ?LPC_UART->LCR = 0x83;?? //8位传输,1个停止位,无几偶校验,允许访问除数锁存器
  15. ? ?DL_value = SystemCoreClock/16/baudrate ;? //计算该波特率要求的除数锁存寄存器值
  16. ? ?LPC_UART->DLM = DL_value / 256; ?? //写除数锁存器高位值
  17. ? ?LPC_UART->DLL = DL_value % 256; ? //写除数锁存器低位值
  18. ? ?LPC_UART->LCR = 0x03;??? //DLAB置0
  19. ? ?LPC_UART->FCR = 0x07;??? //允许FIFO,清空RxFIFO 和 TxFIFO
  20. ? ?Clear = LPC_UART->LSR;?? //读UART状态寄存器将清空残留状态
  21. }
  22. uint8_t UART_recive(void)
  23. {
  24. ? ?while(!(LPC_UART->LSR & (1<<0)));//等待接收到数据
  25. ? ?return(LPC_UART->RBR);??????????????? //读出数据
  26. }
  27. void UART_send_byte(uint8_t byte)
  28. {
  29. ? ?LPC_UART->THR = byte;
  30. ? ?while ( !(LPC_UART->LSR & (1<<5)) );//等待发送完
  31. }

第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文件中,输入以下代码:

  1. #include “lpc11xx.h”
  2. #include “uart.h”
  3. void delay(void)//
  4. {
  5. ? ?uint16_t i,j;
  6. ? ?for(i=0;i<5000;i++)
  7. ? ? ? for(j=0;j<1000;j++);
  8. }
  9. int main()
  10. {
  11. ? ?uint8_t rec_buf;
  12. ? ?UART_init(9600); // 把串口波特率配置为9600
  13. ? ?while(1)
  14. ? ?{
  15. ? ? ? rec_buf = UART_recive(); // 从串口接收字符
  16. ? ? ? UART_send_byte(rec_buf); // 把接收到的字节发回串口
  17. ? ?}
  18. }

主函数实现的功能是,把接收的数据再发回去。打开串口调试助手,波特率配置为9600,选择ASCII字符发送,不管发送什么字符,都会把发送的字符返回串口调试助手显示。从而实现了串口的收发功能。

发表评论