Xilinx FPGA:vivado实现串口的接收端

补充一些串口里用到的数值的相关知识点

接收端串口时序图:

程序设计:

`timescale 1ns / 1ps
/串口接收端    串行转并行
module uart_rx(input                  sys_clk ,input                  rst_n    ,input                  rx_data   ,  //输入串行数据output    reg[7:0]     uart_data , // 输出并行数据output    reg          rx_done     //数据传输完成结束信号      );parameter         SYSCLK =   50_000_000  ;parameter         Baud   =   115200      ;parameter         COUNT  =   SYSCLK/Baud ;//434   传输1比特所需要的时钟周期parameter         MID    =   COUNT/2     ;///产生开始信号(检测下降沿-----二级寄存)reg           rx_reg1     ;reg           rx_reg2     ;wire          start_flag    ;  开始信号reg           rx_flag       ;reg    [3:0]   cnt_bit      ;///0~9reg    [9:0]   cnt          ;///434reg    [7:0]   data_reg     ;always@(posedge sys_clk)if(!rst_n)beginrx_reg1 <= 1 ;  //处于空闲位  数据线上无数据rx_reg2 <= 1 ;  //处于空闲位  数据线上无数据endelsebeginrx_reg1 <= rx_data  ;rx_reg2 <= rx_reg1  ;endassign start_flag = ~rx_reg1 & rx_reg2  ;  //rx_flagalways@(posedge sys_clk )if(!rst_n)rx_flag <= 0 ;else if (start_flag)rx_flag <= 1 ;else if ( cnt_bit == 9 && cnt == MID -1 )rx_flag <= 0 ;elserx_flag <= rx_flag ;cnt 434  always@(posedge sys_clk )if(!rst_n)cnt <= 0;else if ( rx_flag == 1 )beginif ( cnt == COUNT -1) ///一定要减一,如果不减一,实际会计到435次,反算回去波特率就不是115200了cnt <= 0;elsecnt <= cnt +1 ;endelsecnt <= 0 ;/计数器always@(posedge sys_clk )if(!rst_n)cnt_bit <= 0 ;else if ( rx_flag )beginif ( cnt == COUNT -1)beginif(cnt_bit == 9)cnt_bit <= 0 ;elsecnt_bit <= cnt_bit +1 ;endelsecnt_bit <= cnt_bit     ;endelsecnt_bit <= 0 ;[7:0]uart_data/*cnt_bit = 0 起始位cnt_bit = 1-8 数据位cnt_bit = 9 停止位但是  [7:0]uart_data   没有uart[8]所以if ( cnt == MID -1 && cnt_bit > 0 && cnt_bit < 9 )uart_data[cnt_bit -1] <= rx_data ;*/
//    always@(posedge sys_clk )
//          if(!rst_n)
//          uart_data <= 0 ;
//          else if ( rx_flag )begin
//                if ( cnt == MID -1 && cnt_bit > 0 && cnt_bit < 9 )
//                uart_data[cnt_bit -1] <= rx_data ; //这里uart_data是不断随着cnt_bit变化的,只有在第九位的时候才有正确的最终值
//                else
//                uart_data <= uart_data ;
//          end
//          else
//          uart_data <= 0 ;因为这里要让uart_data只在rx_done的时候有值,所以定义一个中间寄存器data_regalways@(posedge sys_clk )if(!rst_n)data_reg <= 0 ;else if ( rx_flag )beginif ( cnt == MID -1 && cnt_bit > 0 && cnt_bit < 9 )data_reg[cnt_bit -1] <= rx_data ; //这里uart_data是不断随着cnt_bit变化的,只有在第九位的时候才有正确的最终值elsedata_reg <= data_reg ;endelsedata_reg <= 0 ;
//  其他赋值方法1
//      always@(posedge sys_clk )
//          if(!rst_n)
//             uart_data <= 0;
//          else if (cnt == MID -1)begin
//             case(cnt_bit)
//             0:  uart_data  <= 0  ;
//             1:  uart_data [0] <= rx_data  ;
//             2:  uart_data [1] <= rx_data  ;
//             3:  uart_data [2] <= rx_data  ;
//             4:  uart_data [3] <= rx_data  ;
//             5:  uart_data [4] <= rx_data  ;
//             6:  uart_data [5] <= rx_data  ;
//             7:  uart_data [6] <= rx_data  ;
//             8:  uart_data [7] <= rx_data  ;
//             9:  uart_data  <= uart_data  ;  ///停止位的时候数据传完,保持
//             endcase
//             end
//           else
//             uart_data  <= uart_data  ;//   其他赋值方法2
//    always@(posedge sys_clk )
//          if(!rst_n)
//          uart_data <= 0 ;
//          else if (cnt == MID -1 && cnt_bit > 0 && cnt_bit < 9)
//               uart_data <= {rx_data,uart_data[7:1]} ;
//          else
//               uart_data <= uart_data ;给uart_data赋值always@(posedge sys_clk )if(!rst_n)     uart_data <= 0 ;   else if (rx_flag)beginif (cnt_bit == 9 && cnt == MID/4 -1)uart_data <= data_reg ;elseuart_data <= uart_data ;endelseuart_data <= uart_data ; 可以保持到下一个数据到来uart_data <= 0 ;  只保持在rx_done处于高电平的时候/rx_donealways@(posedge sys_clk )if(!rst_n)           rx_done <= 0 ;else if (rx_flag)beginif ( cnt_bit == 9 && cnt == MID/2 -1)rx_done <= 1 ;elserx_done <= 0 ;       endelserx_done <= 0 ;  endmodule

仿真程序

`timescale 1ns / 1ps
module test_bench(  );reg                  sys_clk    ;reg                  rst_n      ;reg                  rx_data    ;  //输入串行数据wire[7:0]            uart_data  ; // 输出并行数据wire                 rx_done    ;//数据传输完成结束信号      parameter         SYSCLK =   50_000_000  ;parameter         Baud   =   115200      ;parameter         COUNT  =   SYSCLK/Baud ;//434   传输1比特所需要的时钟周期parameter         MID    =   COUNT/2     ;initialbeginsys_clk = 0 ;rst_n   = 0 ;#10rst_n   = 1 ;endalways #1 sys_clk = ~sys_clk ; //2nsinitialbeginuart_out (8'h34);uart_out (8'hef);uart_out (8'h98);uart_out (8'h70);uart_out (8'h14);end//任务函数task     uart_out   ;input      [7:0]    DATA   ;beginrx_data = 1 ;///空闲位初始#20 rx_data = 0 ;///起始位///传输1bit的计时次数*1周期时间=总时间#(COUNT*2)  rx_data = DATA[0] ;///数据位第一位#(COUNT*2)  rx_data = DATA[1] ;///数据位第二位#(COUNT*2)  rx_data = DATA[2] ;#(COUNT*2)  rx_data = DATA[3] ;#(COUNT*2)  rx_data = DATA[4] ;#(COUNT*2)  rx_data = DATA[5] ;#(COUNT*2)  rx_data = DATA[6] ;#(COUNT*2)  rx_data = DATA[7] ;#(COUNT*2)  rx_data = 1       ;#(COUNT*2)                    ;//停止位也需要时间endendtaskuart_rx  uart_rx1(.    sys_clk    (sys_clk  )   ,.    rst_n      (rst_n    )   ,.    rx_data    (rx_data  )   ,  //输入串行数据.    uart_data  (uart_data)   ,  // 输出并行数据.    rx_done    (rx_done  )      //数据传输完成结束信号      );
endmodule

仿真波形

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

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

相关文章

JDBC以及事务

1、JDBC是什么&#xff1f; JDBC是Java DataBase Connectivity&#xff08;Java语言链接数据库&#xff09; 2、JDBC的本质 JDBC是一套接口&#xff0c;有调用者&#xff08;java工程师&#xff09;和实现者&#xff08;SUN公司&#xff09;&#xff08;实现类被称为驱动&…

electron线上跨域问题

一、配置background.js win new BrowserWindow({webPreferences: {nodeIntegration: true, // 使渲染进程拥有node环境//关闭web权限检查&#xff0c;允许跨域webSecurity: false,// Use pluginOptions.nodeIntegration, leave this alone// See nklayman.github.io/vue-cli-p…

终于找到能在mac上正常保存密码的navicat了- navicat v17.0.9

找了一晚上&#xff0c;终于找到能在mac上正常保存密码的navicat了。 免费分享&#xff0c;不用关注公众号&#xff0c;不用看广告。如果帮助到你&#xff0c;可以的话帮忙给 https://github.com/gone-io/gone 点个星星。 链接: https://pan.baidu.com/s/1ZvGqSMNcv8uMCIpwf0…

Charls数据库+预测模型发二区top | CHARLS等七大老年公共数据库周报(6.19)

七大老年公共数据库 七大老年公共数据库共涵盖33个国家的数据&#xff0c;包括&#xff1a;美国健康与退休研究 (Health and Retirement Study, HRS)&#xff1b;英国老龄化纵向研究 &#xff08;English Longitudinal Study of Ageing, ELSA&#xff09;&#xff1b;欧洲健康、…

ThreadX简介

文章目录 1. 摘要2. ThreadX的特性2.1 免费开源2.2 安全认证级别高2.3 组件完善2.4 实时性高2.5 支持多核2.6 支持应用动态加载2.7 代码符合MISAR规范2.8 文档全面,例程丰富2.9 集成方便3. 移植示例4. 产品应用示例1. 摘要 在嵌入式系统领域,实时性能、系统稳定性以及广泛的…

Windows 10,11 Server 2022 Install Docker-Desktop

docker 前言 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。 docker-compose Compose 是用于定义和运行…

基于大语言模型的多意图增强搜索

随着人工智能技术的蓬勃发展&#xff0c;大语言模型&#xff08;LLM&#xff09;如Claude等在多个领域展现出了卓越的能力。如何利用这些模型的语义分析能力&#xff0c;优化传统业务系统中的搜索性能是个很好的研究方向。 在传统业务系统中&#xff0c;数据匹配和检索常常面临…

LangChain之Agent代理(下)

LangChain之Agent代理 OpenAI Functions Agent概述配置环境变量基本使用实际应用示例 OpenAI Tools Agent概述基本使用实际应用示例 ReAct Agent概述Google搜索APIinitialize_agentcreate_react_agent Structured Chat AgentSelf-Ask with Search Agent OpenAI Functions Agent…

stl之string

构造函数 void test1() {string s1;//不传参cout << s1 << endl;string s2("123456");cout << s2 << endl;string s3(s2);cout << s3 << endl;string s4(s2, 1, 5);cout << s4 << endl;string s5("123456&quo…

LLM vs SLM 大模型和小模型的对比

语言模型是能够生成自然人类语言的人工智能计算模型。这绝非易事。 这些模型被训练为概率机器学习模型——预测适合在短语序列中生成的单词的概率分布&#xff0c;试图模仿人类智能。语言模型在科学领域的重点有两个方面&#xff1a; 领悟情报的本质。 并将其本质体现为与真实…

gin-vue-amdin 新增路由

1&#xff1a;在api目录的example 下新建controller 层如下图&#xff08;&#xff09;&#xff1a; 在enter.go 中 加入 这个新建的结构体&#xff1a; 2&#xff1a;在router 的example 文件夹下 新建对应的路由文件 3&#xff1a;在initlize 的router 中 添加对应的代码&a…

推动多模态智能模型发展:大型视觉语言模型综合多模态评测基准

随着人工智能技术的飞速发展&#xff0c;大型视觉语言模型&#xff08;LVLMs&#xff09;在多模态应用领域取得了显著进展。然而&#xff0c;现有的多模态评估基准测试在跟踪LVLMs发展方面存在不足。为了填补这一空白&#xff0c;本文介绍了MMT-Bench&#xff0c;这是一个全面的…

【数学建模】——【python库】——【Pandas学习】

专栏&#xff1a;数学建模学习笔记 pycharm专业版免费激活教程见资源&#xff0c;私信我给你发 python相关库的安装&#xff1a;pandas,numpy,matplotlib&#xff0c;statsmodels 总篇&#xff1a;【数学建模】—【新手小白到国奖选手】—【学习路线】 第一卷&#xff1a;【数学…

互联网信息服务算法备案流程与要求

一、备案申请的办理流程 企业通过网信办的互联网信息服务算法备案系统&#xff08;https://beian.cac.gov.cn/#/index&#xff09;提交算法备案申请。填报信息包括三部分&#xff0c;分别是算法主体信息、产品及功能信息、算法信息。备案中比较重要的文件包括主体信息中的《落…

▶《强化学习的数学原理》(2024春)_西湖大学赵世钰 Ch5 蒙特卡洛方法【model-based ——> model-free】

PPT 截取必要信息。 课程网站做习题。总体 MOOC 过一遍 1、视频 学堂在线 习题 2、 过 电子书 是否遗漏 【下载&#xff1a;本章 PDF GitHub 页面链接 】 【第二轮 才整理的&#xff0c;忘光了。。。又看了一遍视频】 3、 过 MOOC 习题 看 PDF 迷迷糊糊&#xff0c; 恍恍惚惚。…

深度学习 - Transformer 组成详解

整体结构 1. 嵌入层&#xff08;Embedding Layer&#xff09; 生活中的例子&#xff1a;字典查找 想象你在读一本书&#xff0c;你不认识某个单词&#xff0c;于是你查阅字典。字典为每个单词提供了一个解释&#xff0c;帮助你理解这个单词的意思。嵌入层就像这个字典&#xf…

道路救援入驻派单小程序开源版开发

道路救援入驻派单小程序开源版开发 1、用户立即救援 2、后台收到救援通知&#xff0c;派单救援师傅. 道路救援入驻派单小程序通常会包含一系列功能&#xff0c;旨在方便救援服务提供商、用户和后台管理系统之间的交互。以下是一个可能的功能列表&#xff1a; 用户端功能&…

Camera开发-相机输出常用数据格式

作者简介&#xff1a; 一个平凡而乐于分享的小比特&#xff0c;中南民族大学通信工程专业研究生在读&#xff0c;研究方向无线联邦学习 擅长领域&#xff1a;驱动开发&#xff0c;嵌入式软件开发&#xff0c;BSP开发 作者主页&#xff1a;一个平凡而乐于分享的小比特的个人主页…

OpenGL-ES 学习(6)---- 立方体绘制

目录 立方体绘制基本原理立方体的顶点坐标和绘制顺序立方体颜色和着色器实现效果和参考代码 立方体绘制基本原理 一个立方体是由8个顶点组成&#xff0c;共6个面&#xff0c;所以绘制立方体本质上就是绘制这6个面共12个三角形 顶点的坐标体系如下图所示&#xff0c;三维坐标…

【极速入门版】编程小白也能轻松上手Comate AI编程插件

文章目录 概念使用错误检测与修复能力API生成代码生成json格式做开发测试 在目前的百模大战中&#xff0c;AI编程助手是程序员必不可少的东西&#xff0c;市面上琳琅满目的产品有没有好用一点的&#xff0c;方便一点的呢&#xff1f;今天工程师令狐向大家介绍一款极易入门的国产…