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

Zynq PS端外设之GPIO

1. GPIO(通用输入/输出)

GPIO外设有4个Bank,Bank0/1通过MIO连接到PS的引脚上;Bank2/3通过EMIO连接到PL的引脚上。
注意:Bank1的电平要改成LVCOMS 1.8

  • GPIO寄存器
    在这里插入图片描述

    寄存器:
    DATA_RO:	读取GPIO的输入
    DATA:		设置GPIO的输出值
    MASK_DATA_LSW/MASK_DATA_MSW:	数据掩码寄存器,MASK_DATA_LSW 控制Bank的低16位,MASK_DATA_MSW控制高16位
    DIRM:		方向模式寄存器,控制I/O引脚是输入还是输出
    OEN:		使能输出寄存器,控制是否启用输出
    

2.GPIO的使用

2.1 MIO

MIO不需要添加引脚约束,Zynq勾选MIO,SDK即可直接使用GPIO。

  • Vivado开发
    在这里插入图片描述

  • SDK开发

#include "xparameters.h" //器件参数信息
#include "xstatus.h"     //包含XST_FAILURE和XST_SUCCESS的宏定义
#include "xil_printf.h"  //包含print()函数
#include "xgpiops.h"     //包含PS GPIO的函数#define GPIO_DEVICE_ID      XPAR_XGPIOPS_0_DEVICE_ID
#define MIOLED0    0     //连接到MIO0int main()
{// 1.初始化GPIOint Status;XGpioPs Gpio;XGpioPs_Config *ConfigPtr;ConfigPtr = XGpioPs_LookupConfig(GPIO_DEVICE_ID);Status = XGpioPs_CfgInitialize(&Gpio, ConfigPtr, ConfigPtr->BaseAddr);if (Status != XST_SUCCESS){return XST_FAILURE;}// 2.设置指定引脚的方向:0输入,1输出XGpioPs_SetDirectionPin(&Gpio, MIOLED0, 1);// 3.使能指定引脚输出:0禁止输出使能,1使能输出XGpioPs_SetOutputEnablePin(&Gpio, MIOLED0, 1);// 4.向指定引脚写入数据:0或1XGpioPs_WritePin(&Gpio, MIOLED0, 0x0);while (1);return XST_SUCCESS;
}

2.2 EMIO

EMIO(Extended MIO,扩展的MIO)

  • Vivado开发

    1. 勾选EMIO
      在这里插入图片描述
    2. 引出管脚并添加管脚约束
      在这里插入图片描述
  • SDK开发

    #include "stdio.h"
    #include "xparameters.h"
    #include "xgpiops.h"#define GPIOPS_ID XPAR_XGPIOPS_0_DEVICE_ID   //PS端  GPIO器件 ID
    #define EMIO_KEY 54  //PL_KEY0 连接到EMIO0int main()
    {// 1.初始化GPIOXGpioPs gpiops_inst;XGpioPs_Config *gpiops_cfg_ptr;gpiops_cfg_ptr = XGpioPs_LookupConfig(GPIOPS_ID);XGpioPs_CfgInitialize(&gpiops_inst, gpiops_cfg_ptr, gpiops_cfg_ptr->BaseAddr);// 2.设置指定引脚的方向:0输入,1输出XGpioPs_SetDirectionPin(&gpiops_inst, EMIO_KEY, 0);// 3.读取GPIO的值char key_value = 0;XGpioPs_ReadPin(&gpiops_inst, EMIO_KEY);while(1){}return 0;
    }
    

    注意:BANK2的EMIO0编号为 54 (从0 开始编号)

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

相关文章:

  • Spring Boot项目开发常见问题及解决方案(上)
  • Elasticsearch: 高级搜索
  • STM32 拓展 电源控制
  • SpringBootWeb案例-1
  • HTML——57. type和name属性
  • 应用架构模式-总体思路
  • vue 虚拟滚动 vue-virtual-scroller RecycleScroller
  • DC-DC 降压转换器设计提示和技巧
  • 多模态论文笔记——Coca
  • @Cacheable 注解爆红(不兼容的类型。实际为 java. lang. String‘,需要 ‘boolean‘)
  • java相互加密解密
  • PostgreSQL中FIRST_VALUE、LAST_VALUE、LAG 和 LEAD是窗口函数,允许返回在数据集的特定窗口(或分区)内访问行的相对位置
  • 树莓派之旅-第一天 系统的烧录和设置
  • 数据库工程师进阶秘籍:云计算基础知识题目精选与答案(附PDF)
  • 【HAProxy】如何在Ubuntu下配置HAProxy服务器
  • C#编写的盘符图标修改器 - 开源研究系列文章
  • (四)配置有线网口、SSH登陆、文件传输以及运行交叉编译程序测试
  • 离线的方式:往Maven的本地仓库里安装依赖
  • 《深入浅出HTTPS​​​​​​​​​​​​​​​​​》读书笔记(22):密钥协商算法
  • kubernetes学习-Service
  • Springcloud项目-前后端联调(一)
  • 洛谷P1525 [NOIP2010 提高组] 关押罪犯(种子并查集基础)
  • 【算法刷题指南】模拟
  • 学习笔记078——Java Properties类使用详解
  • 若依使用 Undertow 替代 Tomcat 容器
  • 多输入多输出 | Matlab实现WOA-CNN鲸鱼算法优化卷积神经网络多输入多输出预测
  • Elasticsearch:基础概念
  • Spring MVC的@ResponseBody与@RequestBody
  • 智能商业分析 Quick BI
  • LUA基础语法