IP核来源:https://opencores.org/projects/uart2bus
仅使用了这个IP核当中的串口收发模块。
Github项目地址:
https://github.com/SaltyFishX/UARTCore
波特率计算公式解释:
计算公式:
baud_freq=16*baud_rate/gcd(global_clock_freq,16 * baud_rate)
baud_limit = (global_clock_freq / gcd(global_clock_freq, 16*baud_rate)) - baud_freq
注意:
baud_limit为计数器计数上限,系统时钟计数满则产生一个分频的脉冲信号。
baud_freq为计数器计数步长值。
gcd:求最大公约数
转自博客:https://blog.csdn.net/qq_43042339/article/details/103798512
串口发送输出:
1个起始位,8个数据位,没有校验位,1个结束位。
问题:
波特率与计算的相差一个数量级,具体如图所示。
一个位的时间间隔为8680ps,但波特率11520的时间间隔应为8680ns,目前该问题尚未解决。
2020.08.15更新:
问题解决了,太晚了注意不集中,timescale设置错了,设成了1ps/1ps,导致50M时钟错误,应该设成1ns/1ns,改过以后仿真结果和昨天的图差不多,但是时间间隔从ps变成了ns。
部署到黑金AX301(芯片为EP4CE6F17)上也能够成功使用,对原来的工程进行了一定的改变与削减(
因为用不到那么多功能),不断通过串口发送05和0F,最终结果如图:
之后准备对串口接收进行测试与部分改变,然后将改过的IP核放到Github里,便于以后移植。
2020.08.16更新
串口接收测试:
接收测试成功,明天进行硬件上的测试。
2020.08.17更新
串口接收和发送测试
测试成功,废话不多说直接上图
所存问题:
目前虽然实现了串口的发送和接收,但是只能接收单个字节,比如我发567串口就只能返回5,后面再进行改进。
2020.08.18更新
问题解决了,在uart2bus的文件里没睡醒加了一个1ms的延时。。导致tx_begin信号给的不及时,调试ok了以后Modelsim的仿真和硬件上测试结果如图: