005-Zynq基操之如何去玩EMIO接口(走过路过千万不要错过)

news2024/9/22 21:11:58

文章目录

  • 前言
  • 一、EMIO是啥含义
  • 二、两种EMIO的使用
    • 1.PS端外设引出来的EMIO
    • 2.正常的EMIO口
    • 3.PS端驱动源码
  • 总结


前言

今天分享这个主要原因是,把最基础的EMIO接口弄清楚咋操作的,咱们就可以做一些由PS端控制PL端的器件小功能,最常见的就是我们驱动某些图像传感器时,需要配置一些信号啥的,包括复位信号,休眠信号这些(对,我说的就是你,ov5640的rst和pwdn信号),学会了最基础的操作,用你聪明的小脑壳去拓展一下,多玩玩你就熟悉了。


一、EMIO是啥含义

网上一大堆对于EMIO接口的介绍,话不多说,我直接给出自己的理解。Zynq它分为PL和PS两大单元,PS其实是主要的控制单元,PL你可以看作是挂载到PS上的一个外设,专门用来做一些数据量比较大的、需要并行进行处理的工作。而PS其实跟我们的单片机差不多,带有浮点数运算,做一些对速度、实时性没什么要求的操作。

它这个PS上面引出来的接口中,有两个接口分别是MIO接口和EMIO接口,这两个整体就被称之为GPIO口。那么MIO接口其实它是固定在PS上面的,它是没有办法被映射到PL上面去的,你可以认做它是属于PS的专用接口。而EMIO不同,我觉得它就是一个外部接口,它可以被配置并且被映射到PL端去,具体怎么被映射,其实就是你在Zynq核里面把EMIO接口配置好,然后把这个接口从bd里面引出来,再到PL端的v文件把这个引脚例化出来即可。

EMIO和MIO接口都属于GPIO接口,各自有对应的引脚号,其中MIO引脚号是0-53,EMIO是54-117号引脚

二、两种EMIO的使用

1.PS端外设引出来的EMIO

我们的接口其实是可以配置成很多功能的,比如I2C,比如UART。这两种比较通用的接口就可以配置成EMIO接口输出,由于这都是直接引用的PS端代码去进行驱动的,我们只需要在PS端去写入数据即可,然后把这个引出来的EMIO接口在PL端进行例化,跟你的外设对应好。比如你如果PL端弄了一个串口,那么你就可以把tx和rx两个接口通过EMIO接口引出去,然后约束成你串口对应的引脚号,这样你PS端发送的数据就可以通过PL端的串口输出了。
在这里插入图片描述
具体就是在MIO Configuration里面将想要输出的外设口勾选,并且把MIO的接口改成EMIO接口,这样你的接口才能顺利导出到PL端。
在这里插入图片描述
在bd里面将这几个接口make external即可,这种接口一般只需要跟我们外部驱动的引脚连接在一起即可,将bd文件例化后添加到我们的顶层文件中,配置好管脚信号的约束即可。其余如果想驱动这几个管脚的话只需要在PS端进行操作,比如你串口在PL端,那么只需要在PS端操作xil_printf这个函数即可。
在这里插入图片描述

2.正常的EMIO口

另外一种EMIO口就是我们专门去设置并且引出来,同样是MIO_Configuration,我们找到GPIO口对应的地方,同时勾选EMIO GPIO,选择位宽为2位(因为此处设计是ov5640的rst和pwdn引脚),点击勾选ok以后即可。
在这里插入图片描述
cmos_control引脚就是我们要引出的cmos控制信号,我们在bd里面可以例化出来。
在这里插入图片描述
我喜欢的例化方式是通过位拼接去例化,因为这里面带着我要驱动的两个信号,例化的格式是高位在前,低位在后。因为EMIO口对应引脚号54-117,故cmos_rstn这个信号就是54引脚号,cmos_pwdn是55引脚号。
在这里插入图片描述

3.PS端驱动源码

完成了例化以后,我们就可以打开PS端了,可以直接新建一个c和h文件,名字您随意,代码我附在下面
在GPIO的c文件中,我们只需要改动XGpioPs_SetDirectionPin和XGpioPs_SetOutputEnablePin函数,其中前者是设置我们接口的方向,1代表输出,0代表输入。后者是使能我们的端口,1是使能,0是不使能。rstn和pwdn都在GPIO的h文件中定义了。

#include "gpio.h"
int PsGpioSetup()
{
	XGpioPs_Config *GPIO_CONFIG ;
	int Status ;
	GPIO_CONFIG = XGpioPs_LookupConfig(XPAR_XGPIOPS_0_DEVICE_ID) ;
	Status = XGpioPs_CfgInitialize(&Gpio, GPIO_CONFIG, GPIO_CONFIG->BaseAddr) ;
	if (Status != XST_SUCCESS)
	{
		return XST_FAILURE ;
	}
	XGpioPs_SetDirectionPin(&Gpio, rstn, 1) ;
	XGpioPs_SetOutputEnablePin(&Gpio, rstn, 1);
	XGpioPs_SetDirectionPin(&Gpio, pwdn, 1) ;
	XGpioPs_SetOutputEnablePin(&Gpio, pwdn, 1);
	return XST_SUCCESS ;
}

#ifndef _GPIO_H_
#define _GPIO_H_
#include "xgpiops.h"
#define rstn	54
#define pwdn	55
XGpioPs Gpio;
int PsGpioSetup() ;
#endif 

在我们的主函数中进行调用即可,格式如下面的代码所示,这样就可以对rstn和pwdn进行配置了。

	PsGpioSetup() ;
	XGpioPs_WritePin(&Gpio, rstn, 0) ;//cmos_rstn
	usleep(10000);
	XGpioPs_WritePin(&Gpio, pwdn, 0) ;//cmos_pwdn
	usleep(1000000);
	XGpioPs_WritePin(&Gpio, rstn, 1) ;//复位成功,正式进行配置
	usleep(1000000);

总结

今天晚上本来点卤肉饭来着,结果店家说没有了,给我换了猪脚饭,味道还可以,就是肉稍微肥了一点,配上一杯酸梅汁儿,味道真不错。人生三大乐事,写代码,健身,吃饭

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

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

相关文章

MySQL 5.7.35下载安装使用_忘记密码_远程授权

文章目录 MySQL 5.7.35下载安装使用_忘记密码_远程授权MySQL下载地址mysql安装点击安装,最好以管理员身份运行选择自定义安装选择64位勾选启动自定义产品执行点击同意点击下一步点击执行下一步配置数据库端口号设置登录密码,如果密码忘记,下面…

Java学习苦旅(二十三)——二叉搜索树

本篇博客将详细讲解二叉搜索树。 文章目录 二叉搜索树概念操作查找插入删除 性能分析 结尾 二叉搜索树 概念 二叉搜索树又称二叉排序树,它或者是一棵空树,或者是具有以下性质的二叉树: 若它的左子树不为空,则左子树上所有节点的值都小于根…

解决Docker报错问题:Docker Desktop – Unexpected WSL error

最近因为准备在NAS上通过Docker容器方式安装MYSQL,发现https://hub.docker.com网站被墙了,无法自动安装,同时又找不到靠谱的离线镜像,所以准备在Window上安装Docker,通过电脑的网络代理制作离线镜像再上传到NAS上。 在…

使用即时设计绘制原型设计方便吗?和Axure RP相比怎么样?

对于原型设计,APP 和 Web 都是一样的,因为产品原型是用来确定需求的工具。我们使用这种工具的目的是为了快速迭代,从而深入挖掘和筛选产品的需求。 绘制原型,最重要的原则是:快速、清晰! Axure 工具的优缺…

【搜索引擎】elastic search核心概念

前言 本文不涉及ES的具体安装下载、操作、集群的内容,这部分内容会放在后面一篇文章中。本文只包含ES的核心理论,看完本文再去学ES的细节会事半功倍。 目录 1.由日志存储引出的问题 2.什么是ES? 3.ES的数据结构 4.ES的核心原理 5.联系作…

第11课 利用windows API捕获桌面图像并通过FFmpeg分享

在上一章,我们已经实现了一对一音视频对话功能。在实际应用中,我们常需要把自己的电脑桌面分享给他人以实现桌面共享功能,这种功能在视频会议、在线教学等场景中很常见,这种功能如何实现呢?这节课我们就来解决这个问题…

MySQL练习-DDL语法练习

文章目录 1、数据库操作2、表操作3、DDL数据类型 突然想起来好久没写过SQL了,写一下SQL练习一下😊 个人写sql比较喜欢用小写😁 什么是DDL:DDL是对数据库和表的操作 在这里练习DLL的时候先不添加约束,后面会把约束集中…

Demo:基于elementplus的弹窗嵌套表单进行二次封装

基于elementplus的弹窗嵌套表单进行二次封装 所见即所得&#xff1a;简单封装方便工作 ProForm.vue代码&#xff1a; <!--* Author: 忆往昔* LastEditTime: 2024-01-6 14:36:00* email: 15871856064163.com --> <template><div class"penk-form-contain…

微信小程序:flex常用布局

在我们平时微信小程序开发过程中为了页面能达到设计小伙伴的预期&#xff0c;追求还原度&#xff0c;那我们肯定会使用很多常用的布局方式&#xff0c;那我们今天就介绍一下微信小程序中常用的一些flex布局 1、常用flex布局 /** 水平垂直居中 **/ .flex-center {display: fle…

鸿鹄电子招投标系统源码实现与立项流程:基于Spring Boot、Mybatis、Redis和Layui的企业电子招采平台

随着企业的快速发展&#xff0c;招采管理逐渐成为企业运营中的重要环节。为了满足公司对内部招采管理提升的要求&#xff0c;建立一个公平、公开、公正的采购环境至关重要。在这个背景下&#xff0c;我们开发了一款电子招标采购软件&#xff0c;以最大限度地控制采购成本&#…

普中STM32-PZ6806L开发板(HAL库函数实现-温度传感器DS18B20)

简介 主芯片STM32F103ZET6, 通过引脚PG11 连接DS18B20, 读取DS18B20采集的温度数据;电路原理图 DS18B20电路图 DS18B20 与 主芯片连接引脚 其他知识 DS18B20资料 DS18B20数据手册 DS18B20 简介 单线通讯的温度传感器, 测量温度在-55℃ 到 125℃&#xff0c; 在-10C 到…

[大厂实践] 重新发明后端子集

子集算法有助于优化服务间连接利用率&#xff0c;降低资源使用。但随机或轮询子集算法在动态拓扑环境中会造成较高的连接扰动。本文介绍了谷歌在解决连接扰动方面所做的思考和实践&#xff0c;并介绍了当前最新的Rocksteadier子集算法。原文: Reinventing Backend Subsetting a…

算法的复杂度分析

[王有志](https://www.yuque.com/wangyouzhi-u3woi/dfhnl0/hqrch62un0cc9sp2?singleDoc# 《&#x1f525;快来关注我》)&#xff0c;一个分享硬核Java技术的互金摸鱼侠加入Java人的提桶跑路群&#xff1a;[共同富裕的Java人](https://www.yuque.com/wangyouzhi-u3woi/dfhnl0/n…

pytorch集智-2单车预测器

完整代码在个人主页简介链接pytorch路径下可找到 1 单车预测器1.0 1.1 人工神经元 对于sigmoid函数来说&#xff0c;w控制函数曲线的方向&#xff0c;b控制曲线水平方向位移&#xff0c;w控制曲线在y方向的幅度 1.2 多个人工神经元 模型如下 数学上可证&#xff0c;有限神经…

前端ui库搜集

涟漪动画效果 - MDUI 开发文档, Material Design 前端框架添加涟漪动画效果后&#xff0c;会在点击元素时&#xff0c;产生向外扩散的水波纹效果。https://www.mdui.org/docs/ripple#ripple https://semantic-ui.com/ https://getuikit.com/ https://www.purecss.cn/grids.htm…

iview table 表格合并行鼠标悬停时的高亮

背景&#xff1a; Iview里面的表格没有提供鼠标移入移出的事件。 而且当开启鼠标悬浮高亮的时候会显示异常&#xff0c;并没有高亮合并后的整行&#xff0c;还是高亮子行。 高亮前&#xff1a; 高亮异常情况&#xff1a; 解决后&#xff1a; 解决方案&#xff1a; 一、思路&…

第6章 密码学和对称密钥算法

6.1 密码学基本知识 6.1.1 密码学的目标 安全从业者可借助密码系统实现4个基本目标&#xff1a;保密性、完整性、身份认证和不可否认性。 其中每个目标的实现都需要满足诸多设计要求&#xff0c;而且并非所有密码系统都是为达到所有4个目标而设计的。 下面的小节将详细讲解这…

我的剑,传给能挥舞它的人--量化书籍推荐!

这篇笔记介绍量化入门的参考书目。 前1/4叹为观止&#xff0c;再1/4勉强点赞&#xff0c;再1/4乏善可陈&#xff0c;最后1/4简直不忍卒读。这是我对某本名书的评价&#xff0c;希望你并不会将这句话还给我。“不会的”&#xff0c;我安慰自己。不是文章多好&#xff0c;但你们…

云卷云舒:【实战篇】对象存储迁移

云卷云舒&#xff1a;【实战篇】MySQL迁移-CSDN博客 1. 简介 对象存储与块存储、文件存储并列为云计算三大存储模型。提供海量存储空间服务&#xff0c;具备快速的数据存取性能、高可靠和数据安全性&#xff0c;通过标准的RESTful API接口和丰富的SDK包来提供服务&#xff0c…

基于SSM的校内信息服务发布系统的设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…