当前位置: 首页 > news >正文

fpga入门 串口定时1秒发送1字节

一、 程序说明

FPGA通过串口定时发送数据,每秒发送1字节,数据不断自增
参考小梅哥教程

二、 uart_tx.v

`timescale 1ns / 1psmodule uart_tx(input		wire 				    sclk,input		wire				    rst_n,output		reg	                   uart_tx);parameter  		CLK_FREQ 	    = 50000000;	//时钟频率50M
parameter  		UART_BAUD 	    = 115200;	//时钟频率50M
parameter  		MAX_BIT_COUNT 	= 9;	//时钟频率50M
localparam 		MAX_BAUD_CNT 	= CLK_FREQ / UART_BAUD;//434reg [7:0] write_data;   //发送数据//运行计数器
reg [31:0] run_cnt;	//波特率计数器
always @(posedge sclk or negedge rst_n)
beginif(rst_n == 1'b0)run_cnt <= 32'd0;else if(run_cnt == CLK_FREQ)run_cnt <= 0;elserun_cnt <= run_cnt + 1;
end//波特率计数器
reg [8:0] baud_cnt;	//波特率计数器
reg en_baud_cnt;	//波特率计数器开关
always @(posedge sclk or negedge rst_n)
beginif(rst_n == 1'b0)baud_cnt <= 8'd0;else if(en_baud_cnt == 1'b1) beginif(baud_cnt == MAX_BAUD_CNT)baud_cnt <= 8'd0;elsebaud_cnt <= baud_cnt + 1;endelsebaud_cnt <= baud_cnt;
end//发送位计数器
reg [4:0] bit_cnt = 0;	//波特率计数器
always @(posedge sclk or negedge rst_n)
beginif(rst_n == 1'b0)bit_cnt <= 4'd0;else if(baud_cnt == MAX_BAUD_CNT)beginif(bit_cnt ==  MAX_BIT_COUNT)bit_cnt <= 4'd0;elsebit_cnt <= bit_cnt + 1;endelsebit_cnt <= bit_cnt;
end //位发送逻辑
always @(posedge sclk or negedge rst_n)
beginif(rst_n == 1'b0)uart_tx <= 1'b0;else if(baud_cnt == MAX_BAUD_CNT/2)beginif(bit_cnt ==  0)uart_tx <= 1'b0;else if(bit_cnt == MAX_BIT_COUNT)uart_tx <= 1'b1;elsebegincase(bit_cnt)1:uart_tx <= write_data[0];2:uart_tx <= write_data[1];3:uart_tx <= write_data[2];4:uart_tx <= write_data[3];5:uart_tx <= write_data[4];6:uart_tx <= write_data[5];7:uart_tx <= write_data[6];8:uart_tx <= write_data[7];default:uart_tx <= uart_tx;endcaseend//uart_tx <= write_data[bit_cnt-1];endelseuart_tx <= uart_tx;
endalways @(posedge sclk or negedge rst_n)
beginif(rst_n == 1'b0)en_baud_cnt <= 1'b0;else if(run_cnt == 0) beginen_baud_cnt <= 1'b1;endelse if(bit_cnt ==  MAX_BIT_COUNT && baud_cnt == MAX_BAUD_CNT)en_baud_cnt <= 1'b0;elseen_baud_cnt <= en_baud_cnt;
endalways @(posedge sclk or negedge rst_n)
beginif(rst_n == 1'b0)write_data <= 8'd0;else if(run_cnt == 0)write_data <= write_data + 1;elsewrite_data <= write_data;
endendmodule

三、 运行截图

在这里插入图片描述

http://www.lryc.cn/news/364851.html

相关文章:

  • 总结一下自己,最近三年,我做了哪些工作
  • SpringCloud Gateway基础入门与使用实践总结
  • TensorBoard在pytorch训练过程中如何使用,及数据读取问题解决方法
  • 【Vue】普通组件的注册使用-全局注册
  • 爬虫之反爬思路与解决手段
  • 2.1.4 采用配置类与注解方式使用MyBatis
  • 微信小程序云开发实现利用云函数将数据库表的数据导出到excel中
  • python 字符串(str)、列表(list)、元组(tuple)、字典(dict)
  • 【源码】SpringBoot事务注册原理
  • 技巧:合并ZIP分卷压缩包
  • 数据挖掘 | 实验三 决策树分类算法
  • Python机器学习预测区间估计工具库之mapie使用详解
  • Linux基础指令磁盘管理002
  • Python怎么添加库:深入解析与操作指南
  • Python | 虚拟环境的增删改查
  • 【MySQL数据库】:MySQL内外连接
  • C# FTP/SFTP 详解及连接 FTP/SFTP 方式示例汇总
  • 二、【源码】实现映射器的注册和使用
  • Android Compose 十:常用组件列表 监听
  • Wireshark 如何查找包含特定数据的数据帧
  • 【深度学习入门篇一】阿里云服务器(不需要配环境直接上手跟学代码)
  • app,waf笔记
  • 数据仓库之维度建模
  • 解决远程服务器连接报错
  • 通过电脑查看Wi-Fi密码的方法,提供三种方式
  • Nvidia 目前的市值为 3.01 万亿美元,超过苹果Apple
  • 用langchain搭配最新模型ollama打造属于自己的gpt
  • 工业互联网基本概念及关键技术(295页PPT)
  • Python pandas openpyxl excel合并单元格,设置边框,背景色
  • 【vue3|第7期】 toRefs 与 toRef 的深入剖析