【紫光同创国产FPGA教程】——【PGL22G第七章】串口收发实验例程

news2024/11/29 7:46:11

本原创教程由深圳市小眼睛科技有限公司创作,版权归本公司所有,如需转载,需授权并注明出处
 

适用于板卡型号:

紫光同创PGL22G开发平台(盘古22K)

一:盘古22K开发板(紫光同创PGL22G开发平台)简介

盘古22K开发板是基于紫光同创Logos系列PGL22G芯片设计的一款FPGA开发板,全面实现国产化方案,板载资源丰富,高容量、高带宽,外围接口丰富,不仅适用于高校教学,还可以用于实验项目、项目开发,一板多用,满足多方位的开发需求。

二:实验目的

MES22GP开发板集成了一路USB转串口模块,采用的USB-UART芯片CP2102 , USB接口采用USB Type C接口,可以用一根USB Type C线连接到PC的USB口进行串口数据通信,如下图所示(详情请查看“MES22GP开发板硬件使用手册”)。

串口通信时波特率设置为115200bps,数据格式为1位起始位、8位数据位、无校验位、1位结束位。板子1s向串口助手发送一次十进制显示的“www.meyesemi.com”,通过串口助手向板子以十六进制形式发送数字(00~FF),LED以二进制显示亮起。

二:实验原理

串口原理

从下图我们可以看到标准串口接口是9根线,具体含义如下:

数据线:

TXD(pin 3):串口数据输出(Transmit Data)

RXD(pin 2):串口数据输入(Receive Data)

握手:

RTS(pin 7):发送数据请求(Request to Send)

CTS(pin 8):清除发送(Clear to Send)

DSR(pin 6):数据发送就绪(Data Send Ready)

DCD(pin 1):数据载波检测(Data Carrier Detect)

DTR(pin 4):数据终端就绪(Data Terminal Ready)

地线:

GND(pin 5):地线

其它:

RI(pin 9):铃声指示

通常我们用RS232串口仅用到了9根传输线中的三根:TXD,RXD,GND。但是对于数据传输,双方必须对数据传输采用使用相同的波特率,约定同样的传输模式(传输架构,握手条件等)。尽管这种方法对于大多数应用已经足够,但是对于接收方过载的情况这种使用受到限制。

RS232的串口连接方式:

串口传输协议如下:

起始位:先发出一个逻辑”0”信号,表示传输字符的开始。

数据位:可以是5~8位逻辑”0”或”1”。如ASCII码(7位),扩展BCD码(8位)。

校验位:数据位加上这一位后,使得“1”的位数应为偶数(偶校验)或奇数(奇校验)。

停止位:它是一个字符数据的结束标志。

可以是1位、1.5位、2位的高电平。

空闲位:处于逻辑“1”状态,表示当前线路上没有资料传送。

波特率:uart中的波特率就可以认为是比特率,即每秒传输的位数(bit)。一般选波特率都会有9600,19200,115200等选项。其实意思就是每秒传输这么多个比特位数(bit)。

引入波特率的概念后可得到串口的传输节奏如下:

串口传输步骤

串口发送流程

串口接收流程

串口发送字符

从前面串口协议中可以了解到串口每次传输可以以有5~8bit数据,在计算机中字符通常用ASCII码(7bit)表示,所以字符的发送可以用ASCII码发送。

查询ASCII码表格可得到:“www.meyesemi.com”用到的字符对应ASCII码;

四:实验源码设计

从实验目的分析可将实验做如下划分:

从原理上分析波特率的计算是一个计数器,发射和接收可复用,我们在设计时为保持TX,或RX的完整性,故将波特周期计数器集成在各自模块内部;

上述分析仅仅搭建好MES22GP的与PC通信的桥梁UART,传输的数据没有体现。故而需要增加发送数据模块,与接收数据模块;

串口发射模块设计

目标:接收到一个发送命令信号时,将data[7:0] ->依次发出{start,data[0:7],stop}共10bit数据(无校验位,停止位1bit);

有两种方法可以将一个并行数据串行化;

方法一:通过bit计数与baud计数控制移位输出;

方法二:通过bit计数与baud计数控制状态跳转,在状态机中输出;

方法一的module如下:

方法二的module设计如下:

串口接收模块设计

串口接收模块是发射模块的逆过程,设计思路区别不大,但是有如下几点需要注意:

1.接收开始信号,当rx下降沿到来后保持几个时钟周期的低电平,表明进入接收start;

2.接收数据提取位置,前面讲发射的时候都是在波特周期开始的位置变更数据,接收数据提取时需要在rx稳定时刻取数,去波特周期的中间位置取数;

3.最终输出数据锁存,在最后1bit存入寄存器后需要对接收数据锁存,并在之后需要给出数据使能信号,表示输出数据有效;

Module设计如下:

串口发射控制模块设计

目标:产生1S间隔的触发信号并输出第一个发送字节,busy的下降沿时输出下一个字节;

Module如下:

串口实验顶层模块设计

目标:板子1s向串口助手发送一次十进制显示的“www.meyesemi.com”,通过串口助手向板子以十六进制形式发送数字,LED以二进制显示亮起。

Uart_data_gen模块产生一个间隔1S钟的触发信号,同时输出第一个发送字节,等待uart_tx输出的busy下降沿到来,获知uart_tx进入空闲状态可发送下一个byte时,再次给出串口发送的触发脉冲,并输出下一个字节;

Uart_rx模块接收到数据后输出一个rx_en信号(接收数据使能信号)、一组接收数据信号;接收的数据信号是锁存的,可直接点亮LED灯;

具体的module实现如下:

五:实验现象

用SSCOM串口调试工具,波特率设置为115200bps,数据格式为1位起始位、8位数据位、无校验位、1位结束位,用Type-C连接开发板与电脑后有如下现象:

实验现象一:在串口工具中每隔1S中打印一次:“www.meyesemi.com”;

实验现象二:在串口工具上以Hex格式发送55;我们可看到MES22GP板卡上的LED1,LED3,LED5,LED7被点亮,LED2,LED4,LED6,LED8为熄灭状态;

发 送AA;我 们 可 看 到MES22GP板 卡 上 的LED2,LED4,LED6,LED8被点亮,LED1,LED3,LED5,LED7为熄灭状态。

也可以试着发送其他数据(00~FF),看一下LED灯的变化;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/975532.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PACS三维医学影像处理系统源码

三维医学图像处理系统(PACS)源码 系统概述: 影像归档和通信系统PACS集影像存储服务器、影像诊断工作站及RIS报告系统于一身,主要有图像处理模块、影像数据管理模块、RIS报告模块、光盘存档模块、DICOM通讯模块、胶片打印输出等模块组成&…

攻防世界-easychallenge

原题 解题思路 下载下来是一个pyc文件,还是反编译python工具 final就是flag,先经过异或,又经过base32加密。倒过来操作就行。

大数据Hadoop入门之集群的搭建

hadoop的三种运行模式 本地模式:测试本地的hadoop是否能够运行,用来运行官方的代码。伪分布模式:原先有人拿来测试,目前测试都不用这个模式了。完全分布模式:多台服务器组成分布式环境,生产环境使用 分布式主机文件同步命令 sc…

如何调试 C# Emit 生成的动态代码?

首先声明一下,这是一个很深的话题,也是朋友真实遇到的,它用 DynamicMethod ILGenerator 生成了很多动态方法,然而这动态方法中有时候经常会遇到溢出异常,寻求如何调试 动态方法体,我知道如果用 visual stu…

Java---多线程

并发编程 多线程 在同一段时间内一台计算机的内部有多个线程正在运行,一台计算机一次可以处理多个任务。 多线程的优点 提高CPU的利用率:计算机中一个任务的执行不是一直都会使用CPU,也有可能在任务执行的过程中出现缺少资源的情况&#…

骨传导耳机危害有哪些?骨传导耳机值得入手吗?

事实上,只要是正常使用,骨传导耳机并不会对身体造成伤害,并且在众多耳机种类中,骨传导耳机可以说是相对健康的一种耳机,这种耳机最独特的地方便是声波不经过外耳道和鼓膜, 而是直接将人体骨骼结构作为传声介…

mysql、MHA高可用配置即故障切换

MHA概述 一套优秀的MySQL高可用环境下故障切换和主从复制的软件 MHA的出现就是解决MySQL 单点的问题 MySQL故障过程中,MHA能做到0-30秒内自动完成故障切换 MHA能在故障切换的过程中最大程度上保证数据的一致性以达到真正意义上的高可用 MHA的组成(核…

智能手机收入和出货量双双下滑,造车成本不断增长,小米集团仍面临风险

来源:猛兽财经 作者:猛兽财经 华尔街分析师对小米集团第二季度的业绩预测 在8月29日小米集团(01810)公布其2023年第二季度财报之前,华尔街分析师曾预测该公司第二季度的业绩将超出2023年第一季度的业绩。 根据S&P …

SpringBoot2.0(Spring读取配置文件常用方法,打war包在Tomcat中启动)

目录 一,SpringBoot中读取配置文件的常用方法1.1,使用Value读取1.2,使用ConfigurationProperties1.3,使用Environment1.4,自定义配置文件读取 二,SpringBoot部署war项目到tomcat9和启动原理 一,…

RabbitMq消息模型-队列消息

队列消息分为2种: 基本模型(SimpleQueue)、工作模型(WorkQueue) 队列消息特点: 消息不会丢失 并且 有先进先出的顺序。消息接收是有顺序的,不是随机的,仅有一个消费者能拿到数据&…

代码随想录算法训练营第五十六天|583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结篇

583. 两个字符串的删除操作 文档讲解 : 代码随想录 - 583. 两个字符串的删除操作 状态:再次回顾。 动态规划五部曲: 确定dp数组(dp table)以及下标的含义 dp[i][j]:以i-1为结尾的字符串word1,和…

肖特基二极管SBD,SOD-123封装有哪些型号?

肖特基二极管,常用二极管之一,对于电子工程师来说,并不陌生。肖特基二极管,又称肖特基势垒二极管、热载流子二极管,英文Schottky Barrier Diode,缩写SBD,是利用金属-半导体(M-S)接触特性制成&am…

C语言:扫雷小游戏

文接上一篇博文C语言:三子棋小游戏。本篇博文是使用C语言来实现扫雷小游戏的。这里不对扫雷的规则进行赘述。玩家通过键盘输入坐标来探雷。博主在实现扫雷之前从未看过扫雷实现的相关视频,所以这里实现的扫雷完全是博主的原生思路,具有逻辑性…

用python开发一个炸金花小游戏

众所周知扑克牌可谓是居家旅行、桌面交友的必备道具, 今天我们用 Python 来实现一个类似炸金花的扑克牌小游戏,先来看一下基本的游戏规则。 炸(诈)金花又叫三张牌,是在全国广泛流传的一种民间多人纸牌游戏…

乐信仍面临资产质量下降和拖欠率上升风险

来源:猛兽财经 作者:猛兽财经 公司介绍 乐信(LX)成立于2013年10月,是中国领先的新消费数字科技服务商。旗下业务包括线上分期购物商城分期乐,全场景信用消费产品乐花卡,新型分期购物平台买吖,助力金融机构…

广告、政府、IT三重合作:凭爱校对轻松搞定文本质量

在广告创意、政府政策和IT开发这三个看似不相关的领域中,有一个共同的需求:高质量的文本内容。本文将探讨如何通过使用“爱校对”工具,在这三个行业内确保文本质量,从而提高工作效率和准确性。 广告行业:语境与创意的完…

EDM邮件营销:使用EDM代发实现更高发送率

虽然现在进入数字时代,但电子邮件依然是企业跟客户之间沟通最有效的方式之一。为了吸引并且留存目标用户,各大企业都在努力做好EDM(Electronic Direct Mail)邮件营销。但是通常用电子邮箱发送外贸邮件会有发送数量和自动化的限制&…

固定资产管理怎么写报告

撰写固定资产管理报告时,需要考虑以下几个维度的数据:  资产总量和分类:列出公司的固定资产总量、种类以及各类型资产的数量。  资产使用情况:统计各类型资产的使用率、闲置率、报废率等数据,以及不同部门的资产使…

西电Latex毕业模板使用时的小技巧

西电Latex毕业模板 配置的环境:textlivetextstudio \qqad 空格 参考文献先设置成bib,放到tex文件下,然后如下操作就可以将参考文献加载进去 如果搜不到相关文献的bib格式,可以用zotero软件将下载好的文件导出为bib格式&#xf…

43、Flink之Hive 读写及详细验证示例

Flink 系列文章 1、Flink 部署、概念介绍、source、transformation、sink使用示例、四大基石介绍和示例等系列综合文章链接 13、Flink 的table api与sql的基本概念、通用api介绍及入门示例 14、Flink 的table api与sql之数据类型: 内置数据类型以及它们的属性 15、Flink 的ta…