SDRAM小项目——uart发送模块

数据的输入:

        数据的输入是uart接收模块的输出:串—并—串(接收到的外部的串行数据进入内部寄存器转化为并行数据,再由内部寄存器读出,输出表现为串行数据),接收到的输入信号为tx_flag(po_trig)和tx_data[7:0]。

内部的中间变量:

        tx_data_reg:为寄存器存储输入并行数据

        tx_flag:当开始发送数据的时候为高,停止发送数据时候为低

        baud_cnt:波特计数器,发送一个波特所需要的时钟周期,当计数器记满之后采样,拉高bit_flag电平,输出一个数据

        bit_flag:波特计数器记满之后拉高一个时钟周期,比特计数器加1

        bit_cnt:记满8比特后拉低tx_flag;此时不再发送数据(当第一个bit_flag来的时候发送起始位)计数0-8

数据的输出:

        rs_tx:当bit_flag拉高的时候发送一个数据

时序图:

代码:

`define sim
module uart_tx(	input 			sclk,input			srst,output reg		rs232_tx,input			tx_trig,input [7:0]		tx_data
);//******************************************************
//		degine parameter and internal signal
//******************************************************
`ifndef sim
localparam		baud_end		=		5207;
`else
localparam		baud_end		=		56;
`endiflocalparam		bit_end			=		8;reg 		[7:0]		tx_data_reg;
reg						tx_flag;
reg			[12:0]		baud_cnt;
reg						bit_flag;
reg			[3:0]		bit_cnt;//========================================================
//				main code
//========================================================always@(posedge sclk or negedge srst) beginif(srst == 1'b0)tx_data_reg		<=		'd0;else if(tx_trig == 1'b1 && tx_flag == 1'b0)tx_data_reg		<=		tx_data;
endalways@(posedge sclk or negedge srst)beginif(srst == 1'b0)tx_flag		<=		1'b0;else if(tx_trig == 1'b1)tx_flag		<=		1'b1;else if(bit_cnt == bit_end && bit_flag == 1'b1)tx_flag		<=		1'b0;
endalways@(posedge sclk or negedge srst)beginif(srst == 1'b0)baud_cnt	<=	'd0;else if(baud_cnt == baud_end)baud_cnt	<= 	'd0;else if(tx_flag == 1'b1)baud_cnt	<=	baud_cnt + 1'b1;else baud_cnt	<= 	'd0;
endalways@(posedge sclk or negedge srst)beginif(srst == 1'b0)bit_flag	<=	'b0;else if(baud_cnt == baud_end)bit_flag	<=	1'b1;else bit_flag	<=	1'b0;
endalways@(posedge sclk or negedge srst)beginif(srst == 1'b0)bit_cnt <= 'd0;else if(bit_cnt == bit_end && bit_flag == 1'b1)bit_cnt	<=	'd0;else if(bit_flag == 1'b1)bit_cnt	<=	bit_cnt + 1'b1;//else //	bit_cnt <= 	'd0;
endalways@(posedge sclk or negedge srst) beginif(srst == 1'b0)rs232_tx	<= 1'b1;else if(tx_flag == 1'b1)case(bit_cnt)0:	rs232_tx	<= 1'b0;1:	rs232_tx	<= tx_data_reg[0];2:	rs232_tx	<= tx_data_reg[1];3:	rs232_tx	<= tx_data_reg[2];4:	rs232_tx	<= tx_data_reg[3];5:	rs232_tx	<= tx_data_reg[4];6:	rs232_tx	<= tx_data_reg[5];7:	rs232_tx	<= tx_data_reg[6];8:	rs232_tx	<= tx_data_reg[7];default:rs232_tx	<=	1'b1;endcaseelse rs232_tx	<=	1'b1;
endendmodule

错误1:`define `ifndef写成`ifdef  导致仿真的时候baud_cnt计数太大

错误2:srst写成1有效

测试代码:

`timescale 1ns/1nsmodule tb_uart_tx;reg				sclk;reg 			srst;reg 			tx_trig;reg 	[7:0]	tx_data;wire 			rs232_tx;initial	beginsclk	=	1'b1;srst	= 	1'b0;#100srst	=	1'b1;endalways#5	sclk	=	~sclk;initial begintx_data	<=	8'b0;tx_trig	<=	'b0;#200tx_trig	<=	'b1;tx_data	<=	8'h55;#10						//1 clktx_trig	<=	'b0;enduart_tx		uart_tx_inst(	.sclk	(sclk)			, .srst	(srst)			,.rs232_tx	(rs232_tx)	,.tx_trig		(tx_trig)	,.tx_data		(tx_data)	
);endmodule

注意1:if  else语句 else if的适用范围

注意2:当仿真验证通过但是加载到开发板出错以后  考虑逻辑问题,考虑连线出错没有。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【机组期末速成】计算机的运算方法|进制转换|无符号数与有符号数|数的定点表示与浮点表示|定点运算

&#x1f3a5; 个人主页&#xff1a;深鱼~&#x1f525;收录专栏&#xff1a;计算机组成原理&#x1f304;欢迎 &#x1f44d;点赞✍评论⭐收藏 目录 前言&#xff1a; 一、本章考点总览 二、考点分析 1、日常我们采用十进制来表示数据&#xff0c;计算机如何表示&#xf…

24、Qt使用QCustomPlot

一、下载文件 进入官网&#xff0c;选择“Download”、QCustomPlot.tar.gz Qt Plotting Widget QCustomPlot - Download 二、创建项目 创建一个"Qt Widget Application"项目&#xff0c;基类选择“QMainWindow”&#xff0c;把刚才下载的压缩包里的“qcustomplot.…

K8S网络类型

k8s的网络类型 k8s的通信模式 1 pod内部之间容器与容器之间的通信&#xff0c;在同一个pod中容器是共享资源和网络&#xff0c;使用同一个网络命名空间&#xff0c;可以直接通信 2 同一个node节点之内&#xff0c;不同pod之间的通信&#xff0c;每个pod都有一个全局的真实ip地…

美国Top科技公司年薪大曝光,OpenAI 600万高居榜首!

全美顶尖AI公司年薪大曝光&#xff01; OpenAI 600万高居榜首&#xff0c;微软、英伟达只有OpenAI 的一半。 近日&#xff0c;美国一家帮助博士生协商薪资的公司Rora发布了一份薪资报告&#xff0c;公布了这些顶尖AI公司给研究人员开出的平均薪水。 以下是部分顶级AI公司的名…

数据结构和算法-B树(B树的查找 B树的最大高度和最小高度)

文章目录 回顾&#xff1a;二叉查找树五叉查找树如何查找查找成功查找失败如何保证查找效率 B树B树的高度小结 回顾&#xff1a;二叉查找树 五叉查找树 进一步对范围划分&#xff0c;处于不同划分进入不同子树 四个数做划分&#xff0c;此时有五个区间 此时一个节点对应多个关…

[RoarCTF2019] TankGame

不多说&#xff0c;用dnspy反编译data文件夹中的Assembly-CSharp文件 使用分析器分析一下可疑的FlagText 发现其在WinGame中被调用&#xff0c;跟进WinGame函数 public static void WinGame(){if (!MapManager.winGame && (MapManager.nDestroyNum 4 || MapManager.n…

基于javaWeb的图书馆管理系统

概述 基于Spring Spring MVC MyBatis的图书馆管理系统&#xff0c;使用Maven进行包管理。主要功能包括&#xff1a;图书查询、图书管理、图书编辑、读者管理、图书的借阅与归还以及借还日志记录等。 环境配置 开发环境&#xff1a;IDEA &#xff0c;mysql5.7&#xff0c;m…

leaflet学习笔记-初始化vue项目(一)

leaflet简介 Leaflet是一款开源的轻量级交互式地图可视化JavaScript库&#xff0c;能够满足大多数开发者的地图可视化需求&#xff0c;其最早的版本大小仅仅38 KB。Leaflet能够在主流的计算机或移动设备上高效运行&#xff0c;其功能可通过插件进行扩展&#xff0c;拥有易于使用…

2023年房产赛道短视频平台营销观察

我国房地产经历20年的高速发展时期&#xff0c;地产相关从业人员依靠传统带看售楼处就能有相当规模的人流量&#xff0c;热门项目开盘可日销百套。 疫情三年&#xff0c;购房者的信息获取的习惯从线下踩盘变成线上观看短视频/直播&#xff0c;房企也越来越重视线上销售、抖音直…

C++ 一个有bug的贪吃蛇。。。。。。。。

C 一个有bug的贪吃蛇。。。。。。。。 #include <graphics.h> #include<Windows.h> #include<Mmsystem.h> #include<conio.h> #include<time.h> #include<stdio.h> #include<easyx.h> using namespace std; #pragma warning(di…

【AI】计算机视觉VIT文章(Transformer)源码解析

论文&#xff1a;Dosovitskiy A, Beyer L, Kolesnikov A, et al. An image is worth 16x16 words: Transformers for image recognition at scale[J]. arXiv preprint arXiv:2010.11929, 2020 源码的Pytorch版&#xff1a;https://github.com/lucidrains/vit-pytorch 0.前言 …

Tinker 环境下数据表的用法

如果我们要自己手动创建一个模型文件&#xff0c;最简单的方式是通过 make:model 来创建。 php artisan make:model Article 删除模型文件 rm app/Models/Article.php 创建模型的同时顺便创建数据库迁移 php artisan make:model Article -m Eloquent 表命名约定 在该文件中&am…