FPGA使用笔记:GPIO操作方式(用于测试设备io驱动性能)

news2025/1/16 8:49:02

一、前言

使用FPGA测试IO速率,用于后续驱动高速AD/DA等高速芯片做铺垫,很多芯片的驱动都是使用并行接口,不是使用专用接口的,这样采样速率的快慢就有CPU的时许周期决定了。

本文测试FPGA和STM32,后续如果用到更快的芯片也会补充此文,如果是带linux系统的,可以参照此贴

二、环境

编译软件QuartusII13.1、Keil5

语法Verilog、C

芯片EP4CE6F17C、STM32F407、STM32H750

三、正文

1.FPGA的EP4CE6F17C芯片测试

测试程序

module top_fpga(
 //global signal
 input clk, //50MHz
 
 //led
 output testF7, //high active
 output testD6 //high active
);
 
 //寄存器定义kbq,测试IO翻转速率
reg [31:0] timer1=0;
reg led_1=0;
reg led_2=0;
assign testF7 = led_1;
assign testD6 = led_2;
always @(posedge clk)
 if (timer1 == 32'd49) //1 秒计数(50M-1=49_999_999) (1ms d49_999)(1us d49)(100ns d4)()()
 timer1 <= 0; //计数器清零
 else
 timer1 <= timer1 + 1'b1; //计数器加 1
//LED 控制
always @(posedge clk)
	begin	//最快的时钟翻转速率,50M晶振20ns周期,实测io翻转20ns,一周期40ns
		led_1 <= !led_1; //LED 点亮 
		led_2 <= !led_1; //LED 点亮
	end
// if (timer1 == 32'd29)//计数器计到 0.5 us
//	begin	
//		led_1 <= 1'b1; //LED 点亮
//		led_2 <= 1'b1; //LED 点亮
//	end
// else if (timer1 == 32'd49) //计数器计到 1 us
//	begin	
//	led_1 <= 1'b0; //LED 灯灭
//	led_2 <= 1'b0; //LED 灯灭
//	end
// else
//	begin
//	led_1 <= led_1;
//	led_2 <= led_2;
//	end
endmodule

采用的是50M外部晶振给到时钟引脚,然后定时器判断时钟来翻转io高低电平,最终测试直接判断时钟上升沿,就翻转io状态,测试结果就是时钟的速率,50MHz的时钟周期是20ns,测试也是20ns电平保持,40ns周期。多个引脚同时控制,也不会有等待延迟,周期与单个引脚一样

使用逻辑分析仪测试结果如下图

使用示波器测试结果如下图

感觉这个还没有达到FPGA的极限,只是时钟晶振的极限,详细更快速的测试需要在多摸索摸索找找方法。也欢迎各位大佬指点提示。

2.STM32F407芯片测试

使用标准库

		GPIO_SetBits(GPIOB,GPIO_Pin_14);  //LED0对应引脚GPIOB.6拉高,亮  等同LED=1;
		GPIO_SetBits(GPIOB,GPIO_Pin_15);  //LED0对应引脚GPIOB.6拉高,亮  等同LED=1;

		GPIO_ResetBits(GPIOB,GPIO_Pin_14); //LED1对应引脚GPIOB.6拉低,灭 等同LED=0;
		GPIO_ResetBits(GPIOB,GPIO_Pin_15); //LED1对应引脚GPIOB.6拉低,灭 等同LED=0;

无延时控制高低电平翻转,使用单个引脚周期最快在120ns左右,双个引脚周期就变成了220ns左右,所有引脚控制是串行控制的,一个一个去控制,引脚配置如下,100M速度,理论应该是10ns翻转,20ns周期,但是函数执行消耗了50ns,所以这点就不如FPGA时许控制的严格 ,当系统更加复杂有多个进程芯片驱动时,更无法保障高速采集速率

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_14;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;//普通输出模式
  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  GPIO_Init(GPIOB, &GPIO_InitStructure);//初始化

3.STM32H750芯片测试

使用HAL库,被包装多一层,速度也无法达到预设引脚速率极致,使用very-fast引脚速度模式

无延时控制高低电平翻转,使用单个引脚周期最快在150ns左右,双个引脚周期就变成了300ns左右,3个引脚周期变成了400ns左右,说明stm32的引脚控制逻辑是串行的,一个一个去控制,当有多个引脚同时驱动某芯片时,时许周期就不是特别容易控制的了,下图是单个引脚测试图

四、结语

STM32适用低速ADC及其他芯片采集控制,不同系列32芯片采样率sps测试效果也不相同,追求采样率更高需使用FPGA

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

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

相关文章

探索大模型时代:全面解析Agent智能体的奥秘

前言&#xff1a; 在2024年&#xff0c;大模型圈子的Agent是一个绝对热门的话题&#xff0c;agent也被各种各样的公众人物所追捧 Agent智能体能够最大化的激发大模型潜能还有人说agent智能体式大模型时代的APP&#xff0c;也有人说agent是在toB场景落地的主要方式之一 无论任…

信创(国产化)方案

信创 信创&#xff0c;即信息技术应用创新&#xff0c;旨在实现信息技术自主可控 openEuler openEuler是一款开源、免费的操作系统&#xff0c;由openEuler社区运作&#xff0c;前身为运行在华为公司通用服务器上的操作系统EulerOS。openEuler作为一款开源、免费的操作系统&…

QT6.0如何开启白名单保活

1. 概述 使用Qt开发android应用往往会存在这样一个问题:我们的android应用和后台需要时刻保持通信,但是往往我们在切换任务或者息屏,将我们开发的应用变更为后台应用的时候,由于android的电池策略,会将后台的应用关闭掉从而释放资源供其他应用使用.会给应用带来不好的使用…

Dubbo从入门到应用:实战技巧和最佳实践

远程调用 一、Dubbo快速上手提供者DubboService 调用者DubboReference 开启Dubbo调用EnableDubbo 二、Dubbo快速入门1、添加 Dubbo 相关的 maven 依赖。2、定义服务接口3、 定义服务端的实现4、配置服务端及消费端 Yml 配置文件5、基于 Spring 配置服务端及消费端启动类6、消费…

每日学习笔记:C++ STL之堆栈容器stack

目录 stack定义 核心接口 stack class声明 stack class定义 用户自定义的Stack Class C11特色的插入元素的新形式 运用实例 stack定义 核心接口 stack class声明 stack class定义 用户自定义的Stack Class C11特色的插入元素的新形式 运用实例

springboot+vue 初始

1.控制器 2.文件上传拦截器 #过滤规则 # 默认访问static下面的文件http://localhost:8009/4.jpeg&#xff0c; # 带上static-path-pattern/static/**后&#xff0c;http://localhost:8009/static/4.jpeg spring.mvc.static-path-pattern/static/**#静态资源位置 spring.web.res…

【可能是全网最丝滑的LangChain教程】二十一、LangChain进阶之Memory

人生和电影不一样&#xff0c;人生要辛苦多了。 01 Memory介绍 Memory&#xff08;记忆&#xff09;是LangChain中的一个重要组成部分&#xff0c;它允许模型在处理请求时能够访问历史对话记录或其他相关上下文信息&#xff0c;从而使得对话更加连贯和自然。 LangChain Memor…

STM32标准库学习笔记-5.定时器-输出比较

参考教程&#xff1a;【STM32入门教程-2023版 细致讲解 中文字幕】 输出比较OC OC&#xff08;Output Compare&#xff09;输出比较输出比较可以通过比较CNT与CCR寄存器值的关系&#xff0c;来对输出电平进行置1、置0或翻转的操作&#xff0c;用于输出一定频率和占空比的PWM波…

vue使用海康视频web插件如何实现自适应

如果要实现自适应的话&#xff0c;就需要在不同的分辨率内设置不同的宽度和高度&#xff0c;可以监听当前屏幕的宽度和高度(可视区域的宽高)&#xff0c;划分不同的显示阶段 通过设置父级元素的宽度和高度实现子级视频的自适应 index.vue <template><div class&quo…

《机器学习》一元、多元线性回归的实现 No.4

一、一元线性回归实现 先直接看完整代码&#xff1a; import pandas as pd import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegressiondate pd.read_csv(data.csv) #导入数据plt.scatter(date[广告投入],date[销售额]) # 用散点图展示数据 plt.sh…

【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(一)

前言 终于到了之前C语言没有讲过的数据结构了&#xff0c;那就是二叉树了&#xff0c;关于二叉树的学习难度确实比前面学习的数据结构都要难一点&#xff0c;所以我们这个关于二叉树的博客大概率是有好几篇的。如有哪里出现错误也欢迎指出唔。 二叉树的概念 Java 中的二叉树是…

【Oracle点滴积累】解决ORA-20000: ORA-12899: value too large for column错误的方法

广告位招租&#xff01; 知识无价&#xff0c;人有情&#xff0c;无偿分享知识&#xff0c;希望本条信息对你有用&#xff01; 今天和大家分享ORA-20000: ORA-12899: value too large for column错误的解决方法&#xff0c;本文仅供参考&#xff0c;谢谢&#xff01; A fatal…

【C语言】二叉树的深度理解

&#x1f36c;个人主页&#xff1a;Yanni.— &#x1f308;数据结构&#xff1a;Data Structure.​​​​​​ &#x1f382;C语言笔记&#xff1a;C Language Notes 前言 在之前学习了二叉树的基本概念&#xff0c;但二叉树有着更深入知识理解&#xff0c;这篇文章可以帮助大…

2 种方式申请免费 SSL 证书,阿里云 Certbot

如何使用免费的 SSL 证书&#xff0c;有时在项目中需要使用免费的 SSL 证书&#xff0c;Aliyun 提供免费证书&#xff0c;三个月有效期&#xff0c;可以直接在aliyun 申请&#xff0c;搜索 SSL 证书&#xff0c;选择测试证书。 Aliyun 证书需要每三月来来换一次&#xff0c;页…

ubuntu中python 改为默认使用python3,pip改为默认使用pip3

一、安装pip和python&#xff08;有的话可跳过&#xff09; 更新软件源 sudo apt update !!!apt和apt-get apt apt-get、apt-cache 和 apt-config 中最常用命令选项的集合。 部分截图为apt-get&#xff0c;建议直接用apt 安装pip和python ubuntu 18.04和更高版本默认安…

申请中的专利可以用来申报高企吗

申请中的专利可以用来申报高企吗&#xff1f; 申请中的专利是否可以用于高新技术企业&#xff08;简称“高企”&#xff09;申报时&#xff0c;我们需要深入了解高企认定的具体条件和要求&#xff0c;以及专利在其中的角色和地位。 高新技术企业认定的基本条件 高新技术企业认定…

图像分类数据集|新冠肺炎|3类

新冠肺炎图像分类数据集&#xff0c;总共三类&#xff0c;获取地址在最后&#xff1a; 训练集&#xff1a; 251 测试集&#xff1a; 66 类别名&#xff1a; [‘Covid’, ‘Normal’, ‘Viral Pneumonia’] 数据集整理不易&#xff0c;获取地址如下&#xff1a; https://ite…

VM虚拟机-Ubuntu莫名其妙断网及解决

问题解决 由于Ubuntu下访问GitHub总是很慢&#xff0c;所以在鼓捣解决方法时不知怎么的直接给干的没法访问互联网了&#xff0c;虽然之前保存了快照&#xff0c;但恢复了几个快照都是没网&#xff08;ping不通&#xff09;&#xff0c;后续的解决方法如下。 在命令行中输入 …

EchoMimic—语音驱动图像

简介 EchoMimic是阿里巴巴达摩院推出的一个AI驱动的口型同步技术项目。通过一段音频和一张人物的面部照片&#xff0c;生成一个看起来像是在说话的视频&#xff0c;其中的人物口型动作与音频中的语音完美匹配。   EchoMimic优点&#xff1a; 1.口型同步生成&#xff1a;能根据…

WebRTC音视频开发读书笔记(六)

数据通道不仅可以发送文本消息, 还可以发送图片、二进制文件,将其类型binaryType属性设置成arraybuffer类型即可. 九\、文件传输 1、文件传输流程 &#xff08;1&#xff09;使用表单file打开本地文件 &#xff08;2&#xff09;使用FileReader读取文件的二进制数据 &#…