热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

13.基础实验(2)异步串口收发的实现

异步串口收发的实现一、实验内容实现串口接收来自串口调试助手发送的数据,然后直接通过自己实现的串口程序将数据发送出去二、系统框图三、设计分析从串口接收开始&#x
异步串口收发的实现

一、实验内容

实现串口接收来自串口调试助手发送的数据,然后直接通过自己实现的串口程序将数据发送出去

二、系统框图

三、设计分析

从串口接收开始,这个比较容易实现。参考链接串口通信协议

img

不考虑奇偶校验位,一个字节的串口的发送过程,包含1个低电平的起始位,一个高电平的停止位,中间8个数据位,且数据位是从低位发送到高位。只要保证前一刻为高电平,下一时刻为低电平,则可以确定开始串口开始接收数据,因为不发送数据时,即空闲状态下相应的电平为高电平。

从起始位开始,检测串口的数据的接收。延时一个半起始位的时间后,检测第一个数据位的电平,然后再延时一个数据位的时间,检测第二数据位,直到检测最后一个数据位,这时便检测到了整个字节的数据(停止位不考虑)。具体可以使用下面的时序图实现。

一是控制标志位的时序图。

image-20201230201432344

一个数据位占用的时钟周期数BAUD为时钟频率/波特率,计数到半个计数单元HALF = 1/2 BAUD时,half_baud_flag拉高一个时钟周期,baud_flag则在计算到BAUD计数时拉高一个时钟周期。baud_flag和half_baud_flag分别作为读取数据位和数据位计数的重要标志。

二是uart_rx实现的时序图。

image-20201230201558215

根据先前产生的baud_flag和half_baud_flag,分别实现计数和数据移位读取,当计数到8时,数据清零。同时只要计数baud_cnt为1-8时读取数据位,进行相应的移位,从高位向低位移动。最后,输出相应的结果。

uart_tx的时序图和uart_rx基本类似,这里不再进行分析。

四、实验步骤

根据波形编写相关代码,速度会非常快。将波特率和时钟频率作为参数,可以随时进行修改。

五、实际波形仿真

接收端功能实现之后,再实现发送端。

接收端功能调试

先使用modelsim进行仿真。从结果来看,获得的数据是正确的。

image-20210104214836236

再看看相关的计数,也是正确的。

image-20210104215028056

整体波形的设计也是正确的。

image-20210104215127080

再使用signal tap II实际查看结果。看是否真的获得了正确的数据。

首先rx的下降沿表示数据的开始,rx_cnt开始计数。

image-20210105093807401

然后baud_cnt和baud_flag的产生。

image-20210105093928949

最重要的是rx_data和rx_en的产生。

image-20210105094117008

发现rx_en信号没有正确的产生。其实这部分在modelsim仿真时问题就出现,只不过没有仔细地分析,这是大忌。

发现代码有问题,重新修改后,查看编译效果。

image-20210105094644435

如上图所示,刚好和数据数据同步。

至此,接收端功能实现成功。

发送端功能调试

直接使用signal tap ii查看结果。

发现串口并没有接收到正确的数据,为什么呢。

image-20210105113406500

查看波形查找问题。

image-20210105113501342

发现tx开始数据时,并不是从高电平到低电平的跳变。问题并不是出在这,后面的时序中存在高电平到低电平的跳变也没有数据输出。

image-20210105125725216

发现问题出在没有进行相关的引脚配置,导致出现了问题。

整体联调

发现部分数据出现了错误。

image-20210105133047177

再用ila抓取数据,发现是接收端的问题。

主要是接收端的数据来自外部时钟,存在时序违例,需要打俩拍后,才开始接收相关数据,否则就会出现问题。

always @(posedge clk)
beginrx_r <&#61; {rx_r[1:0], rx};
end

问题解决&#xff0c;搞定了。

六、总结与讨论*

1.外部时钟信号的输入时&#xff0c;打俩拍解决时序违例的问题。这点需要牢记于心&#xff0c;不能瞎搞。


推荐阅读
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 解读MySQL查询执行计划的详细指南
    本文旨在帮助开发者和数据库管理员深入了解如何解读MySQL查询执行计划。通过详细的解析,您将掌握优化查询性能的关键技巧,了解各种访问类型和额外信息的含义。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • Google最新推出的嵌入AI技术的便携式相机Clips现已上架,旨在通过人工智能技术自动捕捉用户生活中值得纪念的时刻,帮助人们减少照片数量过多的问题。 ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
  • 解决微信电脑版无法刷朋友圈问题:使用安卓远程投屏方案
    在工作期间想要浏览微信和朋友圈却不太方便?虽然微信电脑版目前不支持直接刷朋友圈,但通过远程投屏技术,可以轻松实现在电脑上操作安卓设备的功能。 ... [详细]
  • 本文深入探讨了 Java 编程语言的基础,特别是其跨平台特性和 JVM 的工作原理。通过介绍 Java 的发展历史和生态系统,帮助初学者理解如何编写并运行第一个 Java 程序。 ... [详细]
  • C++构造函数与初始化列表详解
    本文深入探讨了C++中构造函数的初始化列表,包括赋值与初始化的区别、初始化列表的使用规则、静态成员初始化等内容。通过实例和调试证明,详细解释了初始化列表在对象创建时的重要性。 ... [详细]
  • PHP 5.5.0rc1 发布:深入解析 Zend OPcache
    2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • libsodium 1.0.15 发布:引入重大不兼容更新
    最新发布的 libsodium 1.0.15 版本带来了若干不兼容的变更,其中包括默认密码散列算法的更改和其他重要调整。 ... [详细]
author-avatar
卜弃miao_286
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有