hi3531串口波特率计算

简介: 波特率配置<br> 通过配置寄存器UART_IBRD 和UART_FBRD 可以设置UART 工作的波特率,波特率<br> 计算公式为:<br> 当前波特率=UART 参考时钟频率(1/2 总线时钟频率)/(16 x 分频系数)<br> 分频系数有整数和小数两部分组成,分别对应寄存器UART_IBRD 和UART_FBRD。<br> 例如:UART 参考时钟频率为60MHz,如果
波特率配置
通过配置寄存器UART_IBRD 和UART_FBRD 可以设置UART 工作的波特率,波特率
计算公式为:
当前波特率=UART 参考时钟频率(1/2 总线时钟频率)/(16 x 分频系数)
分频系数有整数和小数两部分组成,分别对应寄存器UART_IBRD 和UART_FBRD。
例如:UART 参考时钟频率为60MHz,如果配置UART_IBRD 为0x1E,UART_FBRD
为0x00,按照波特率计算公式,则当前的波特率为60/(16 x 30)=0.125Mbit/s。
UART 波特率配置的典型值为:9,600bit/s、14,400bit/s、19,200bit/s、38,400bit/s、
57,600bit/s、76,800bit/s、115,200bit/s、230,400bit/s、460,800bit/s。
分频系数值的计算以及分频系数寄存器的配置举例如下:
如果要求波特率为230400bit/s,并且UART 参考时钟频率为100MHz,那么分频系数
为(100 x 106)/(16 x 230400)=27.1267,因此IBRD(整数部分)为27,FBRD(小
数部分)为0.1267。
计算6bit UART_FBRD 寄存器中的数值:根据m=integer(FBRDx2n+0.5)
(n=UART_FBRD 寄存器的宽度),计算出m=integer(0.1267x26+0.5)=8,在
UART_IBRD 寄存器中配置0x001B,UART_FBRD 寄存器中配置0x08。
当分频系数小数部分配置成8 时,波特率除数的实际数值为27+8/64=27.125,产生的
波特率为(100 x 106)/(16 x 27.125)=230414.75,误差率为(230414.75–230400)
/230400x100=0.006%。
使用6bit UART_FBRD 寄存器最大的误差率为1/64 x 100=1.56%,当m=1 时会出现,
误差率累计超过64 个时钟周期。
相关文章
|
5月前
|
芯片
STC15F100E单片机模拟串口
STC15F100E单片机模拟串口
STC15F100E单片机模拟串口
|
5月前
【RTThread】修改Finsh打印串口波特率
【RTThread】修改Finsh打印串口波特率
如何在上电时获取MCU的复位源
如何在上电时获取MCU的复位源
STM32:USART串口外设(内含:1.USART简介+2.USART基本结构+3.数据帧+4.起始位侦测+5.数据采样+6.波特率发生器)
STM32:USART串口外设(内含:1.USART简介+2.USART基本结构+3.数据帧+4.起始位侦测+5.数据采样+6.波特率发生器)
344 0
STM32:USART串口外设(内含:1.USART简介+2.USART基本结构+3.数据帧+4.起始位侦测+5.数据采样+6.波特率发生器)
|
存储 开发工具 芯片
ZYNQ-UART串口中断测试
ZYNQ-UART串口中断测试
669 0
ZYNQ-UART串口中断测试
使用示波器测量串口波特率
使用示波器测量串口波特率
499 0
使用示波器测量串口波特率
|
数据格式
【STM32】串口通讯USART串口中断配置
【STM32】串口通讯USART串口中断配置
551 0
|
网络安全 芯片
可编程 USB 转串口适配器开发板 时钟芯片参数读取与修改
DS1302 是实时时钟芯片,SPI 接口,可以对年、月、日、周、时、分、秒进行计时,且具有闰年补偿等多种功能。DS1302 内部有一个 31×8 的用于临时性存放数据的 RAM 寄存器。
可编程 USB 转串口适配器开发板 时钟芯片参数读取与修改
|
传感器
STM32:串口协议(内含:1.通信接口+2.串口通信+3.硬件电路+4.电平标准+5.串口参数及时序+6.串口时序)
STM32:串口协议(内含:1.通信接口+2.串口通信+3.硬件电路+4.电平标准+5.串口参数及时序+6.串口时序)
382 0
STM32:串口协议(内含:1.通信接口+2.串口通信+3.硬件电路+4.电平标准+5.串口参数及时序+6.串口时序)