- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
串行通
信的实现
数字设计FPGA 应用 卢有亮
UART串行接口设计及通信实现
通用异步收发传输器(Universal Asynchronous Receiver/Transmitter)
,通常称作UART,是一种异步收发传输器。
数字设计FPGA 应用 卢有亮
异步串行接口原理分析
1.串行通信电气特性
通常,UART串行接口采用RS-232-C电气标准进行通信。RS-232-C是美国电子工业
协会EIA (Electronic Industry Association)制定的一种串行物理接口标准。对于
一般的通信,不需要掌握RS-232-C的所有信号的定义,只需要使用其中的2个信号TXD
(数据发送)和RXD (数据接收),另外,参加通信的设备要将GND (地)要连到一起
(共地)。
数据线TxD和RxD的电平标准为: 逻辑1=-3V~-15V;逻辑0=+3~+15V
RS-232-C标准规定的数据传输速率为9600、19200、115200等波特率。波特率是
衡量资料传送速率的指标,表示每秒钟传送的符号数。如果波特率为9600,那么发送
和接收数据都应该为9600bits/s。本节采用9600bit/s进行通信。
数字设计FPGA 应用 卢有亮
数字设计FPGA 应用 卢有亮
数字设计FPGA 应用 卢有亮
UART串行数据格式
起始位 (逻辑0 )+数据位(本节为8位数据位)+奇偶校验位(本节为偶校验)+
停止位(本节使用1位停止位)+空闲位(逻辑1)
位序号 0 1 2 3 4 5 6 7 8 9 10
号
启
格式 动 D0 D1 D2 D3 D4 D5 D6 D7 P 停止位
位
0x55 0 1 0 1 0 1 0 1 0 0 1
0x56 0 0 1 1 0 1 0 1 0 0 1
0x57 0 1 1 1 0 1 0 1 0 1 1
0x58 0 0 0 0 1 1 0 1 0 1 1
数字设计FPGA 应用 卢有亮
通信的安全性问题
串行异步通信,发送方和接收方使用各自的时钟。例如从FPGA电路板和计算机之间
的通信,因此,不能保证两者的时钟完全相同。
为保证接收数据的准确性,因此需要用较高的采样率进行采样,本节采用16倍
的采样率进行采样,简单的选取中间采样点的值作为接收的数据。如图采用16倍波
特率的采样率执行采样,一个比特可采集16个点,选取中间点即从第一个采样点开
始的第8或第9个采样点(笑脸附近上升沿)采集该位数据,在接收双方始终频率相
差不大的情况下,能够正确的完成通信。
数字设计FPGA 应用 卢有亮
功能设计和演示
预计实现的功能(演示):
将拨码开关代表的数据发送到串口(8位);
从串口接收电脑发来的数据,以数码管显示(8位
)。
数字设计FPGA 应用 卢有亮
主模块的设计
⚫ 调用分频模块
⚫ 调用数码管显示IP
⚫ 调用按键消抖动IP
⚫ 调用串口发送模块
⚫ 调用串口接收模块
数字设计FPGA 应用 卢有亮
主模块的设计
module v1( divclk my_divclk (.clk(clk),.clk_ms(clk_ms),.btnclk (clk_20ms)
文档评论(0)