cortex m0 lpc1114自动波特率程序

  • 学习4372次

LPC1114的自动波特率检测功能,可以用于你能想到的任何应用方面。广泛应用于支持AT命令的产品。

自动波特率检测,需要串口给单片机发送一个字节,该字节的bit1和bit0必须是01或11。例如,发送0x01、0x11、0x51、0x03、0x63等字节都可以。

由于A和a的ascii字符分别是0x41和0x61,符合字符要求,所以发送A或a也可以进行自动波特率检测。

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

新建串口工程

在main.c文件中,加入以下代码:

  1. #include “lpc11xx.h”
  2. #include “uart.h”
  3. void AutoBaud(void)
  4. {
  5. uint32_t baud;
  6. uint8_t dlm,? dll;
  7. LPC_UART->ACR? = 0x03;?????? // 允许自动波特率
  8. while ((LPC_UART->ACR & 0x01) != 0x0);?????? ? // 等待自动波特率测量完成
  9. LPC_UART->ACR |= 0x01 << 8;?????? ? // 清除自动波特率中断标志
  10. LPC_UART->LCR = 0x83;
  11. dlm = LPC_UART->DLM;
  12. dll = LPC_UART->DLL;
  13. LPC_UART->LCR = 0x03;
  14. LPC_UART->FCR = 0x07;??? //允许FIFO,清空RxFIFO 和 TxFIFO
  15. baud = ((SystemCoreClock/LPC_SYSCON->SYSAHBCLKDIV) / (16 * (256 * dlm + dll)));
  16. UART_send_byte(baud>>24);
  17. UART_send_byte(baud>>16);
  18. UART_send_byte(baud>>8);
  19. UART_send_byte(baud);
  20. }
  21. int main()
  22. {
  23. LPC_SYSCON->SYSAHBCLKCTRL |= (1<<16); // 使能IOCON时钟
  24. LPC_IOCON->PIO1_6 &= ~0x07;
  25. LPC_IOCON->PIO1_6 |= 0x01; //把P1.6脚设置为RXD
  26. LPC_IOCON->PIO1_7 &= ~0x07;
  27. LPC_IOCON->PIO1_7 |= 0x01; //把P1.7脚设置为TXD
  28. LPC_SYSCON->SYSAHBCLKCTRL &= ~(1<<16); // 禁能IOCON时钟
  29. LPC_SYSCON->UARTCLKDIV = 0x1; //时钟分频值为1
  30. LPC_SYSCON->SYSAHBCLKCTRL |= (1<<12);//允许UART时钟
  31. while(1)
  32. {
  33. AutoBaud();
  34. }
  35. }

第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。这些并不是检测不准确。而是串口波特率的设置存在误差,而这些误差在可以保证正常通信的范围之内。

发表评论