当前位置:首页 > 单片机 > 单片机
[导读]LPC1114有一个串口,具备标准9针串口的所有功能引脚:RXD、TXD、RTS、CTS、DTR、DSR、DCD、IR一般情况下,我们只用到RXD和TXD。在这一章,只对RXD和TXD的使用做介绍。可以用于程序下载。可以设置奇校验、偶校验、无校

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


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除( 邮箱:macysun@21ic.com )。
换一批
延伸阅读
关闭