裸机开发-GPIO外设

devtools/2025/3/15 16:13:27/

重新开始学ZYNQ开发,学完上linux系统

基础知识:ZYNQ 的三种GPIO :MIO、EMIO、AXI - FPGA/ASIC技术 - 电子发烧友网

GPIO是ZYNQ PS端的一个IO外设,用于观测(input)和控制(output)器件引脚的状态 

MIO(Multiplexed I/O)多路复用IO。是ZYNQ PS端的一部分,将来自PS外设和静态存储器接口的访问多路复用到PS引脚上,直接连接到PS端的引脚,用于控制外设(如LED、按键等)。MIO的引脚位置是固定的,不需要像PL端那样进行引脚约束。

EMIO(Extended MIO),扩展的MIO。EMIO是PS与PL的接口,当PS引脚不够用的时候,可以使用EMIO来进行扩展,从而使用PL的IO;当某个设备硬件已经连接到PL端,但是通过Verilog代码实现较复杂的时候,可以用EMIO让PS端来驱动。

 GPIO分组:Bank0:32位控制MIO[31:0];Bank1:32位控制MIO[53:32];                                        Bank2:32位控制EMIO[31:0];Bank3:32位控制EMIO[63:32]。

软件通过GPIO可以独立且动态的编程,作为输入/输出以及中断模式。

实验任务一:点灯大师(基于寄存器)使用PS端的MIO控制两个LED,实现LED闪烁的效果,闪烁间隔为1s。

第一步:在vivado上block design中创建了一个最小系统(system)作为zynq的ps端。在最小系统(DDR3+UART)中添加了GPIO(通用输入输出)外设,负责管理和控制MIO引脚的状态。GPIO通过MIO引脚直接连接到LED,实现对其的控制。

 第二步:代码逻辑控制ps端,通过GPIO的数据手册中的几个寄存器控制LED.

#include <stdio.h>
#include "xil_io.h"
#include "sleep.h"#define GPIOPS_BASE_ADDRESS 	 0xE000A000  // GPIO基地址
#define XGPIOPS_DIRM_OFFSET 	 0x00000204  // 方向模式寄存器偏移地址
#define XGPIOPS_OUTEN_OFFSET 	 0x00000208  // 输出使能寄存器偏移地址
#define XGPIOPS_DATA_LSW_OFFSETR 0x00000000  // 带屏蔽的数据寄存器偏移地址int main() {printf("GPIO MIO TEST!\n");// 对GPIO引脚进行配置// 配置方向模式寄存器,使MIO7和MIO8为输出模式Xil_Out32(GPIOPS_BASE_ADDRESS + XGPIOPS_DIRM_OFFSET, 0x00000180);  // 0000_0000_0000_0000_0000_0001_1000_0000// 配置输出使能寄存器,使MIO7和MIO8输出使能Xil_Out32(GPIOPS_BASE_ADDRESS + XGPIOPS_OUTEN_OFFSET, 0x00000180); // 0000_0000_0000_0000_0000_0001_1000_0000while (1) {// 点亮MIO7,熄灭MIO8Xil_Out32(GPIOPS_BASE_ADDRESS + XGPIOPS_DATA_LSW_OFFSETR, 0xff7f0080); // 0000_0000_0000_0000_0000_0000_1000_0000sleep(1); // 延迟1秒Xil_Out32(GPIOPS_BASE_ADDRESS + XGPIOPS_DATA_LSW_OFFSETR, 0xff7f0000); // 0000_0000_0000_0000_0000_0000_1000_0000sleep(1); // 延迟1秒// 点亮MIO8,熄灭MIO7Xil_Out32(GPIOPS_BASE_ADDRESS + XGPIOPS_DATA_LSW_OFFSETR, 0xfeff0100); // 0000_0000_0000_0000_0000_0001_0000_0000sleep(1); // 延迟1秒Xil_Out32(GPIOPS_BASE_ADDRESS + XGPIOPS_DATA_LSW_OFFSETR, 0xfeff0000); // 0000_0000_0000_0000_0000_0001_0000_0000sleep(1);}return 0;
}

实验任务二:点灯大师(基于库函数)使用PS端的MIO控制两个LED,实现LED闪烁的效果,闪烁间隔为1s(和实验一逻辑是一样)。

#include <stdio.h>
#include "xparameters.h"
#include "xgpiops.h"
#include "sleep.h"#define GPIO_DEVICE_ID		XPAR_XGPIOPS_0_DEVICE_ID
#define MIO_LED0            7 //MIO 7
#define MIO_LED1            8 //MIO 7XGpioPs Gpio;int main(){XGpioPs_Config *ConfigPtr;printf("GPIO TEST SUCCESS!\n");//对GPIO进行初始化(两步)    /* Initialize the GPIO driver. *///第一步:根据器件ID去查找器件的配置信息ConfigPtr = XGpioPs_LookupConfig(GPIO_DEVICE_ID);//第二步:对GPIO的驱动进行初始化XGpioPs_CfgInitialize(&Gpio, ConfigPtr,ConfigPtr->BaseAddr);//设置引脚的方向,0为输入,1为输出XGpioPs_SetDirectionPin(&Gpio, MIO_LED0, 1);XGpioPs_SetDirectionPin(&Gpio, MIO_LED1, 1);//设置输出使能,1:使能输出,0:不使能输出XGpioPs_SetOutputEnablePin(&Gpio, MIO_LED0, 1);XGpioPs_SetOutputEnablePin(&Gpio, MIO_LED1, 1);while(1){//对引脚输出为高电平,点亮LED灯XGpioPs_WritePin(&Gpio, MIO_LED0, 0x1);sleep(1);//交替闪烁XGpioPs_WritePin(&Gpio, MIO_LED1, 0x1);sleep(1);//对引脚输出为低电平,熄灭LED灯   /* Set the GPIO output to be low. */XGpioPs_WritePin(&Gpio, MIO_LED0, 0x0);sleep(1);XGpioPs_WritePin(&Gpio, MIO_LED1, 0x0);sleep(1);}return 0;
}

上板验证:

实验任务3:使用两个用户按键分别控制PS端的两个LED灯的亮灭,其中一个按键需要通过EMIO进行扩展(PL端的参与)。需要增加GPIO输入的功能,实验二GPIO用于输出。


http://www.ppmy.cn/devtools/167327.html

相关文章

jenkins 配置邮件问题整理

版本&#xff1a;Jenkins 2.492.1 插件&#xff1a; A.jenkins自带的&#xff0c; B.安装功能强大的插件 配置流程&#xff1a; 1. jenkins->系统配置->Jenkins Location 此处的”系统管理员邮件地址“&#xff0c;是配置之后发件人的email。 2.配置系统自带的邮件A…

优选算法的匠心之艺:二分查找专题(一)

专栏&#xff1a;算法的魔法世界 个人主页&#xff1a;手握风云 目录 一、二分查找算法 二、例题讲解 2.1. 二分查找 2.2. 在排序数组中查找元素的第一个和最后一个位置 2.3. x 的平方根 2.4. 搜索插入位置 一、二分查找算法 可能很多老铁在之前可能接触过朴素的二分查找…

利用余弦相似度在大量文章中找出抄袭的文章

我前面的2篇文章分别讲了如果利用余弦相似度来判断2篇文章的相似度&#xff0c;来确定文章是否存在抄袭&#xff0c;和余弦相似度的原理&#xff0c;即余弦相似度到底是怎么来判断文章的相似性高低的等等。这一篇再说下&#xff0c;对于文章字数多和大量文章时&#xff0c;如果…

机器学习的下一个前沿是因果推理吗?——探索机器学习的未来方向!

机器学习的进化&#xff1a;从预测到因果推理 机器学习凭借强大的预测能力&#xff0c;已经彻底改变了多个行业。然而&#xff0c;要实现真正的突破&#xff0c;机器学习还需要克服实践和计算上的挑战&#xff0c;特别是在因果推理方面的应用。未来&#xff0c;因果推理或许将…

ACL初级总结

ACL–访问控制列表 1.访问控制 在路由器流量流入或者流出的接口上,匹配流量,然后执行相应动作 permit允许 deny拒绝 2.抓取感兴趣流 3.ACL匹配规则 自上而下逐一匹配,若匹配到了则按照对应规则执行动作,而不再向下继续匹配 思科:ACL列表末尾隐含一条拒绝所有的规则 华为:AC…

C盘清理技巧分享:释放空间,提升电脑性能

目录 1. 引言 2. C盘空间不足的影响 3. C盘清理的必要性 4. C盘清理的具体技巧 4.1 删除临时文件 4.2 清理系统还原点 4.3 卸载不必要的程序 4.4 清理下载文件夹 4.5 移动大文件到其他盘 4.6 清理系统缓存 4.7 使用磁盘清理工具 4.8 清理Windows更新文件 4.9 禁用…

网络安全 与 加密算法

计算机中的网络安全 在本篇中介绍了以下几个方面: 机密性 密码学 对称加密算法(DES, 3DES, AES) 公开秘钥算法 RSA大素数的获取 完整性 散列函数(MD5, SHA-1, 并没有提及算法实现) 报文鉴别(MAC) 数字签名 端点鉴别 应用 SSL(TCP网络安全) 运行时安全 防火墙的基本知…

母婴商城系统Springboot设计与实现

项目概述 《母婴商城系统Springboot》是一款基于Springboot框架开发的母婴类电商平台&#xff0c;旨在为母婴产品提供高效、便捷的在线购物体验。该系统功能全面&#xff0c;涵盖用户管理、商品分类、商品信息、商品资讯等核心模块&#xff0c;适合母婴电商企业或个人开发者快…