CH559 的UART1最高波特率问题

芯片手册P43有说明:

......

(1)、兼容 16C550 异步串口并且有所增强;
(2)、支持 5、6、7 或者 8 个数据位以及 1 或者 2 个停止位;
(3)、支持奇、偶、无校验、空白 0、标志 1 等校验方式;
(4)、可编程通讯波特率,支持 115200bps 以及最高达 3Mbps 的通讯波特率;


UART1可以支持高达3Mbps的波特率,基于官方的CH559EVT\EXAM\UART1 示例,将

主频改为56M,波特率改为 921600 回环测试发现均是乱码,改成460800,可以正常工作,

使用官方的公式

Fsys * 2 / SER1_DIV / 16 / 波特率

当波特率为 921600时,SER1_DIV设置为1,

那么需要填充的值为 56000000*2/1/16/921600 ≈ 7.6

那么经四舍五入后,误差为 (8-7.6)/7.6 * 100%= 5.2%,也是不满足串口通信的最低波特率误差的,


请问如何配置才能做到  3Mbps 的通讯波特率?谢谢!


当SER1_DIV设置为1,波特率除数设置为2时,实际波特率为3.5M。在使用波特率时需要考虑分频的理论误差问题,通常MCU需要整数的时钟,如果考虑一些特殊波特率可能要用到22.1184MHz、11.0592MHz作为时钟来源。


@TECH5,是否可以理解为如果使用56M主频(12M晶振),那么只能使用非标准的波特率,例如3.5M,而无法使用类似921600的波特率?如果要使用标准波特率,那么就要使用22.1184MHz、11.0592MHz晶振,那么USB的48MHz如何获得?还是此时USB无法兼容使用?


仅就CH559来说,串口使用时的波特率还是要按照12M内部时钟源来考虑,并不太适合采用其他频率时钟源。类似我们的CH438,外挂的晶振是专门用于产生波特率的,这种情况下可以根据需要的波特率来搭配不同频率的时钟源。


我也遇到相同的问题。

主频24M,需要产生9600,根据你的公式波特率误差不到千分之二,但是通讯乱码,修改为4800接收到了正确数据。

是不是公式有错误,计算公式多除了个2?

559的官方代码还有其它的错误~~~不是很省心


楼上的朋友,如果最终波特率差了1倍,而配置的主频是24M,芯片默认主频是12M,有没有可能代码中某个参与计算的宏定义参数没有改过来?


楼上的说得对,原始的程序是针对12M的,我改成下面这样了,正常:

#defineUART1_DEFAULT_DIV12


SER1_LCR |= bLCR_DLAB;   // DLAB位置1,写DLL、DLM和DIV寄存器

SER1_DIV = UART1_DEFAULT_DIV;   // 预分频

x = 10 * FREQ_SYS / UART1_DEFAULT_DIV / 16 / baud

x2 = x % 10;

x /= 10;


559的demo都是在12M模式的。



只有登录才能回复,可以选择微信账号登录