OpenCores 串口IP核使用记录

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的仿真和硬件上测试结果如图:
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值