Zynq-7000、FMQL45T900的GPIO控制(三)---linux管脚编号计算

2023-12-06 02:50

本文主要是介绍Zynq-7000、FMQL45T900的GPIO控制(三)---linux管脚编号计算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文主要对在Linux下使用zynq-7000或者FMQL45T900控制MIO/EMIO

首先内核配置项

如下,这个不用太多关注,一般都是默认打开的

CONFIG_GPIO_SYSFS=y
CONFIG_SYSVIPC=y
CONFIG_GPIO_ZYNQ=y

两者的控制都是流程都是一样的,在细节上又区别

首先都在/sys/class/gpio/查看对应节点

FMQL45T900

Zynq-7000平台

这里两者的明显的区别在于FMQL45T900节点个数比较多有四个,这里简单分析一下原因

两者的GPIO的驱动设计不一样

Zynq驱动设计从设备树zynq-7000.dtsi可以看出确实只有一个节点

		gpio0: gpio@e000a000 {compatible = "xlnx,zynq-gpio-1.0";#gpio-cells = <2>;clocks = <&clkc 42>;gpio-controller;interrupt-controller;#interrupt-cells = <2>;interrupt-parent = <&intc>;interrupts = <0 20 4>;reg = <0xe000a000 0x1000>;};

 FMQL45T900中设备文件fmsh-psoc.dtsi可以看出有四个节点

gpio0: gpio@e0003000 {compatible = "snps,dw-apb-gpio";reg = <0xe0003000 0x100>;#address-cells = <1>;#size-cells = <0>;clocks = <&clkc NCLK_APB_GPIO>;status = "disabled";porta: gpio-controller@0 {compatible = "snps,dw-apb-gpio-port";bank-name = "porta";gpio-controller;#gpio-cells = <2>;snps,nr-gpios = <32>;reg = <0>;interrupt-controller;#interrupt-cells = <2>;interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;};};gpio1: gpio@e0003100 {compatible = "snps,dw-apb-gpio";reg = <0xe0003100 0x100>;#address-cells = <1>;#size-cells = <0>;clocks = <&clkc NCLK_APB_GPIO>;status = "disabled";portb: gpio-controller@0 {compatible = "snps,dw-apb-gpio-port";bank-name = "portb";gpio-controller;#gpio-cells = <2>;snps,nr-gpios = <22>;reg = <0>;interrupt-controller;#interrupt-cells = <2>;interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;};};gpio2: gpio@e0003200 {compatible = "snps,dw-apb-gpio";reg = <0xe0003200 0x100>;#address-cells = <1>;#size-cells = <0>;clocks = <&clkc NCLK_APB_GPIO>;status = "disabled";portc: gpio-controller@0 {compatible = "snps,dw-apb-gpio-port";bank-name = "portc";gpio-controller;#gpio-cells = <2>;snps,nr-gpios = <32>;reg = <0>;interrupt-controller;#interrupt-cells = <2>;interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;};};gpio3: gpio@e0003400 {compatible = "snps,dw-apb-gpio";reg = <0xe0003400 0x100>;#address-cells = <1>;#size-cells = <0>;clocks = <&clkc NCLK_APB_GPIO>;status = "disabled";portd: gpio-controller@0 {compatible = "snps,dw-apb-gpio-port";bank-name = "portd";gpio-controller;#gpio-cells = <2>;snps,nr-gpios = <32>;reg = <0>;interrupt-controller;#interrupt-cells = <2>;interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;};};

怎么计算我们需要操作的原理图上的IO管脚

Zynq-7000假如要操作MIO10

从上图可以看到设备中第一个IO编号为906,这个编号属于MIO的编号。即第一个GPIO为gpio906。你需要操作某个GPIO直接找出对应的GPIO编号,比如:我要使用MIO10对应第11个GPIO对应的编号为:gpio916。注意第一个为906对应MIO0。

FMQL45T900的计算稍微复杂一点,提供了四个根节点,分别对应每个bank

其他MIO/EMIO可以根据下表格计算出来,这里列举几个实际使用的IO

Linux节点

对应bank

对应IO

最大偏移量

gpiochip394

BANK3起始节点

EMIO32

32

gpiochip426

BANK2起始节点

EMIO0

32

gpiochip458

BANK1起始节点

MIO32

54-32

gpiochip480

BANK0起始节点

MIO0

32

这里列举几个实际使用的管脚对应的节点

MIO32 ->   gpiochip458

MIO43 ->   gpiochip469

EMIO0 ->   gpiochip426

EMIO5 ->   gpiochip431

EMIO6 ->   gpiochip432

EMIO7 ->   gpiochip433

EMIO8 ->   gpiochip434

EMIO9 ->   gpiochip435

EMIO10 ->  gpiochip436

用这几篇帖子深入探讨一下ZYNQ-7000/FMQL45T900的GPIO相关设计,都说GPIO最简单,这样记录下来起始还是很费劲的。可以根根据需求,直接跳转到相关的内容

Zynq-7000、FMQL45T900的GPIO控制(一)-----SDK配置GPIO普通输入输出模式,以及GPIO编号_大牛攻城狮的博客-CSDN博客

Zynq-7000、FMQL45T900的GPIO控制(二)-----SDK配置GPIO外部中断输入_大牛攻城狮的博客-CSDN博客

Zynq-7000、FMQL45T900的GPIO控制(三)---linux管脚编号计算_大牛攻城狮的博客-CSDN博客

Zynq-7000、FMQL45T900的GPIO控制(四)---linux应用层配置GPIO输入控制_大牛攻城狮的博客-CSDN博客

Zynq-7000、FMQL45T900的GPIO控制(五)---linux应用层配置GPIO输出控制_大牛攻城狮的博客-CSDN博客

Zynq-7000、FMQL45T900的GPIO控制(六)---linux驱动层配置GPIO输入输出控制_大牛攻城狮的博客-CSDN博客

(1条消息) Zynq-7000、FMQL45T900的GPIO控制(七)---linux驱动层配置GPIO中断输入_大牛攻城狮的博客-CSDN博客

这篇关于Zynq-7000、FMQL45T900的GPIO控制(三)---linux管脚编号计算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/460126

相关文章

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

Linux环境变量&&进程地址空间详解

《Linux环境变量&&进程地址空间详解》本文介绍了Linux环境变量、命令行参数、进程地址空间以及Linux内核进程调度队列的相关知识,环境变量是系统运行环境的参数,命令行参数用于传递给程序的参数,... 目录一、初步认识环境变量1.1常见的环境变量1.2环境变量的基本概念二、命令行参数2.1通过命令编程

Linux之进程状态&&进程优先级详解

《Linux之进程状态&&进程优先级详解》文章介绍了操作系统中进程的状态,包括运行状态、阻塞状态和挂起状态,并详细解释了Linux下进程的具体状态及其管理,此外,文章还讨论了进程的优先级、查看和修改进... 目录一、操作系统的进程状态1.1运行状态1.2阻塞状态1.3挂起二、linux下具体的状态三、进程的

Linux编译器--gcc/g++使用方式

《Linux编译器--gcc/g++使用方式》文章主要介绍了C/C++程序的编译过程,包括预编译、编译、汇编和链接四个阶段,并详细解释了每个阶段的作用和具体操作,同时,还介绍了调试和发布版本的概念... 目录一、预编译指令1.1预处理功能1.2指令1.3问题扩展二、编译(生成汇编)三、汇编(生成二进制机器语

Rsnapshot怎么用? 基于Rsync的强大Linux备份工具使用指南

《Rsnapshot怎么用?基于Rsync的强大Linux备份工具使用指南》Rsnapshot不仅可以备份本地文件,还能通过SSH备份远程文件,接下来详细介绍如何安装、配置和使用Rsnaps... Rsnapshot 是一款开源的文件系统快照工具。它结合了 Rsync 和 SSH 的能力,可以帮助你在 li