×
单片机 > 单片机程序设计 > 详情

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

发布时间:2020-07-08 发布时间:
|

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字符发送,不管发送什么字符,都会把发送的字符返回串口调试助手显示。从而实现了串口的收发功能。





『本文转载自网络,版权归原作者所有,如有侵权请联系删除』

热门文章 更多
浅谈msp430f5529入门(2)----时钟配置.例程分析