cortex m0 lpc1114自动波特率程序
扫描二维码
随时随地手机看文章
LPC1114的自动波特率检测功能,可以用于你能想到的任何应用方面。广泛应用于支持AT命令的产品。
自动波特率检测,需要串口给单片机发送一个字节,该字节的bit1和bit0必须是01或11。例如,发送0x01、0x11、0x51、0x03、0x63等字节都可以。
由于A和a的ascii字符分别是0x41和0x61,符合字符要求,所以发送A或a也可以进行自动波特率检测。
新建一个工程,结构如下图所示:
在main.c文件中,加入以下代码:
#include “lpc11xx.h”
#include “uart.h”
void AutoBaud(void)
{
uint32_t baud;
uint8_t dlm, dll;
LPC_UART->ACR = 0x03; // 允许自动波特率
while ((LPC_UART->ACR & 0x01) != 0x0); // 等待自动波特率测量完成
LPC_UART->ACR |= 0x01 << 8; // 清除自动波特率中断标志
LPC_UART->LCR = 0x83;
dlm = LPC_UART->DLM;
dll = LPC_UART->DLL;
LPC_UART->LCR = 0x03;
LPC_UART->FCR = 0x07; //允许FIFO,清空RxFIFO 和 TxFIFO
baud = ((SystemCoreClock/LPC_SYSCON->SYSAHBCLKDIV) / (16 * (256 * dlm + dll)));
UART_send_byte(baud>>24);
UART_send_byte(baud>>16);
UART_send_byte(baud>>8);
UART_send_byte(baud);
}
int main()
{
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时钟
while(1)
{
AutoBaud();
}
}
第3~20行,定义自动波特率测试函数。
第7行,给ACR寄存器bit0和bit1写1,启动自动波特率,设置为模式1。自动波特率有两种模式,模式0和模式1的区别在于检测波特率发送的字节前两位,模式0,支持发送的字节bit1和bit0为01;模式1,支持发送的字节bit1和bit0为01或11。
第8行,检测ACR寄存器的bit0,当自动波特率检测完成后,会自动把ACR寄存器bit0位清0,所以观察此位就可以判断自动波特率测试是否完成。
第9行,给ACR寄存器bit8写1,清除中断标志。
第10行,打开锁存器访问允许位。
第11、12行,获取除数锁存器的值。
第13行,关闭锁存器的访问允许。
第14行,清空串口收发FIFO。
第15行,计算波特率。
第16行,把检测到的波特率发送到串口。
打开串口调试助手,波特率任意设置,在发送区发送字符A或a,或者十六进制的0x01等符合要求的数据。在接收区就会收到当前设置的波特率。在接收区接收到的数据是十六进制,换算成十进制以后,你会发送波特率和串口调试助手上的波特率有一些差别。例如:4800接收到的数据是4807;9600接收到的数据是9615;115200接收到的数据是115740。这些并不是检测不准确。而是串口波特率的设置存在误差,而这些误差在可以保证正常通信的范围之内。