NXP iMX8系列处理器Pin Multiplexing定义说明

news2025/1/12 12:02:30

By Toradex秦海

1). 简介

为了提高处理器的设计灵活性和可用性,NXP的所有i.MX系列处理器都配备了基于 IOMUX Controller (IOMUXC)和IOMUX来使能Pin Mux功能,使得一个特定的IO管脚可以选择不同的可能多达8种的功能定义模块(ALT0, ALT1, ALT2, ALT3...),同时为了适配不同的功能模块,IOMUXC可以对应配置管脚的配置参数(比如上拉/下拉,驱动能力等等)。本文就基于NXP最新的i.MX8系列平台说明Pin Mux的定义和配置方式。

本文所演示的平台来自于Toradex Apalis iMX8嵌入式平台,这个平台是基于近年发布的NXP iMX8系列ARM处理器,核心为Cortex-A72/A53。

2. 准备

a). Apalis iMX8 ARM核心版配合Apalis Eva Board载板,并连接调试串口用于测试。

b). 参考这里下载Toradex Ycoto Linux BSP5 Linux Kernel (toradex_5.4-2.3.x-imx分支)用于后续Device Tree修改和编译。

3). 规划管脚功能定义

a). 参考Apalis iMX8 datasheet 文档 4.4 SoC Functions List章节来找到所需要的iMX8管脚的功能定义和默认状态,比如这里我们就用 X1 Pin 6作为示例,其基本信息如下图,有4个功能模块定义,目前在Toradex Ycoto Linux Device Tree中默认配置功能是黄色高亮显示的ALT1 PWM功能,Reset Sate参考datasheet 4.3 Pin Reset Status章节定义是Pull-Down (Input) 状态。

b). Device Tree中一个管脚的IOMUX定义由两部分组成,如下是上述管脚X1 Pin 6在Devcie tree中作为PWM功能的管脚Pin mux定义作为参考

--------------------------------

/* Apalis PWM3 */

pinctrl_pwm0: pwm0grp {

fsl,pins = <

IMX8QM_UART0_RTS_B_LSIO_PWM0_OUT 0x00000020

>;

};

--------------------------------

./ fsl,pins 里面的定义就是具体的Pin mux定义,包含两部分。第一部分是 PIN_FUNC_ID ,其由 <SoC Ball Name>_<Mux Mode>组成,示例中”IMX8QM_UART0_RTS_B”就是<SoC Ball Name>,而”LSIO_PWM0_OUT”就是<Mux Mode>,也就是具体的功能模块定义(ALT1)。PIN_FUNC_ID在Kernel Device Tree源代码中通过相应pinctrl头文件定义,下面是NXP iMX8/iMX8x/iMX8MM/iMX8MP系列处理器对应的头文件位置列表供参考

--------------------------------

Apalis iMX8 - <linux-toradex>/include/dt-bindings/pinctrl/pads-imx8qm.h

Colibri iMX8X - <linux-toradex>/include/dt-bindings/pinctrl/pads-imx8qxp.h

Verdin iMX8M Plus - <linux-toradex>/arch/arm64/boot/dts/freescale/imx8mp-pinfunc.h

Verdin iMX8M Mini - <linux-toradex>/arch/arm64/boot/dts/freescale/imx8mm-pinfunc.h

--------------------------------

./ 第二部分是管脚的配置参数(BIT_CONFIG),详细的定义需要从对应SoC处理器的Reference Manual文档 IOMUXD章节的对应管脚Pad Control 寄存器说明找到,比如上述示例引脚的相关定义可以从NXP iMX8QM Reference Manual 9.2.5.1.26 UART0_RTS_B (UART0_RTS_B) 章节找到,如下。

需要注意的是默认情况下Pin Ctrl寄存器29-27bit mux mode的配置保持000即可,因为这部分已经在前面PIN_FUNC_ID那里定义了。另外配置参数还有下面两个软件设置状态:

--------------------------------

NO_PAD_CTL(1 << 31) - 声明当前管脚无需配置参数

SION(1 << 30) - Software Input On Field,强制当前管脚Input Path而忽略mux mode设定的状态

--------------------------------

./ Kernel Documentation 关于NXP i.MX系列处理器的Pin Mux的说明可以参考如下

--------------------------------

<linux-toradex>/Documentation/devicetree/bindings/pinctrl/fsl,*-pinctrl.txt

--------------------------------

c). 基于上述描述,这里要将上述管脚功能定义从PWM修改为标准GPIO,并将GPIO管脚的初始状态设置为下拉(pull down)和高驱动能力(high drive strength)

./ 查找 pads-imx8qm.h 文件确定所需 PIN_FUNC_ID为 “IMX8QM_UART0_RTS_B_LSIO_GPIO0_IO22”

--------------------------------

#define IMX8QM_UART0_RTS_B_DMA_UART0_RTS_B IMX8QM_UART0_RTS_B 0

#define IMX8QM_UART0_RTS_B_LSIO_PWM0_OUT IMX8QM_UART0_RTS_B 1

#define IMX8QM_UART0_RTS_B_DMA_UART2_RX IMX8QM_UART0_RTS_B 2

#define IMX8QM_UART0_RTS_B_LSIO_GPIO0_IO22 IMX8QM_UART0_RTS_B 3

--------------------------------

./ 从iMX8QM Reference Manual UART0_RTS_B Pin Ctrl寄存器确认所需的 BIT_CONFIG参数是 0x00000040

4). 修改配置Device Tree文件

a). 修改方式由两种,一种是直接在Kernel源代码中修改设备对应的Device Tree文件源码然后重新编译Device Tree binary文件(.dtb)后部署,另外一种是通过生成Device Tree Overlay文件的方式直接部署,无需编译源代码。本文就简单示例通过源代码编译方式,如果需要了解Device Tree Overlay方式可以参考如下两个文档

./ https://developer.toradex.cn/knowledge-base/pin-multiplexing-in-device-tree

./ https://www.toradex.cn/blog/device-tree-overlay-shi-yong

./ https://developer.toradex.cn/knowledge-base/device-tree-overlays-linux

b). Device Tree源代码修改Patch如下,分别关闭默认占用X1 Pin 6的PWM功能,以及重新将X1 Pin6配置为GPIO通过iomuxc输出。另外,具体的Device Tree编译和部署可以参考如下文档

./ https://developer.toradex.cn/knowledge-base/build-u-boot-and-linux-kernel-from-source-code

./ https://developer.toradex.cn/device-tree-customization

./ https://developer.toradex.cn/knowledge-base/device-tree-customization-examples

--------------------------------

diff --git a/arch/arm64/boot/dts/freescale/imx8-apalis-eval.dtsi b/arch/arm64/boot/dts/freescale/imx8-apalis-eval.dtsi

index 0a4fe3898993..b75c649e706c 100644

--- a/arch/arm64/boot/dts/freescale/imx8-apalis-eval.dtsi

+++ b/arch/arm64/boot/dts/freescale/imx8-apalis-eval.dtsi

@@ -271,7 +271,7 @@

/* Apalis PWM3, MXM3 pin 6 */

&pwm0 {

- status = "okay";

+ status = "disabled";

};

/* Apalis PWM4, MXM3 pin 8 */

diff --git a/arch/arm64/boot/dts/freescale/imx8-apalis-v1.1.dtsi b/arch/arm64/boot/dts/freescale/imx8-apalis-v1.1.dtsi

index 0ece42889af8..8dfe04714ec7 100644

--- a/arch/arm64/boot/dts/freescale/imx8-apalis-v1.1.dtsi

+++ b/arch/arm64/boot/dts/freescale/imx8-apalis-v1.1.dtsi

@@ -426,7 +426,7 @@

<&pinctrl_mipi_dsi_0_1_en>, <&pinctrl_mipi_dsi1_gpios>,

<&pinctrl_mlb_gpios>, <&pinctrl_qspi1a_gpios>,

<&pinctrl_sata1_act>, <&pinctrl_sim0_gpios>,

- <&pinctrl_usdhc1_gpios>;

+ <&pinctrl_usdhc1_gpios>, <&pinctrl_gpio9>;

apalis-imx8qm {

/* Apalis AN1_ADC */

@@ -600,6 +600,13 @@

IMX8QM_MLB_DATA_LSIO_GPIO3_IO28 0x00000021

>;

};

+

+ /* Apalis Pin Mux Demo GPIO9 */

+ pinctrl_gpio9: gpio9grp {

+ fsl,pins = <

+ IMX8QM_UART0_RTS_B_LSIO_GPIO0_IO22 0x00000040

+ >;

+ };

/* Apalis I2C1 */

pinctrl_lpi2c2: lpi2c2grp {

--------------------------------

b). 测试部署Device Tree 文件

./ 在修改部署之前X1 Pin 6管脚的状态可以参考如下文章,通过连接LED硬件配合libgpiod库进行测试,由于被PWM驱动占用因此无论通过gpioset如何设置这个管脚,外部LED始终是不亮状态没有变化

https://www.toradex.cn/blog/nxp-imx8-qian-ru-shilinux-xialibgpiod-ying-yong-shi-li

--------------------------------

### 系统启动后查看PWM驱动状态,管脚对应的PWM设备(5d000000.pwm)状态正常 ###

root@apalis-imx8-07308034:~# cat /sys/kernel/debug/pwm

platform/57244000.pwm, 1 PWM device

pwm-0 (backlight ): requested enabled period: 6666667 ns duty: 3111111 ns polaritye

platform/5d030000.pwm, 1 PWM device

pwm-0 ((null) ): period: 2730667 ns duty: 0 ns polarity: normal

platform/5d020000.pwm, 1 PWM device

pwm-0 ((null) ): period: 2730667 ns duty: 0 ns polarity: normal

platform/5d010000.pwm, 1 PWM device

pwm-0 ((null) ): period: 2730667 ns duty: 0 ns polarity: normal

platform/5d000000.pwm, 1 PWM device

pwm-0 ((null) ): period: 2730667 ns duty: 0 ns polarity: normal

### 由于管脚被PWM驱动占用,因此启动后LED为灭状态,而且无论通过gpioset 如何设置,LED始终为灭状态,无法控制 ###

root@apalis-imx8-07308034:~# gpioset 0 22=1

root@apalis-imx8-07308034:~# gpioset 0 22=0

--------------------------------

c). 修改部署新的Device Tree binary “imx8qm-apalis-v1.1-eval.dtb”后,通过LED发现可以正常控制X1 Pin 6管脚作为输出的电平状态了

--------------------------------

### 系统启动后,基于管脚初始状态为Pull Down,连接的LED灯为灭状态 ###

root@apalis-imx8-07308034:~# gpioinfo 0 |grep -e "MXM3_6"

line 22: "MXM3_6" unused input active-high

### 查看PWM驱动状态,管脚对应的PWM设备(5d000000.pwm)已经没有了 ###

root@apalis-imx8-07308034:~# cat /sys/kernel/debug/pwm

platform/57244000.pwm, 1 PWM device

pwm-0 (backlight ): requested enabled period: 6666667 ns duty: 3111111 ns polarity:

inverse

platform/5d030000.pwm, 1 PWM device

pwm-0 ((null) ): period: 2730667 ns duty: 0 ns polarity: normal

platform/5d020000.pwm, 1 PWM device

pwm-0 ((null) ): period: 2730667 ns duty: 0 ns polarity: normal

platform/5d010000.pwm, 1 PWM device

pwm-0 ((null) ): period: 2730667 ns duty: 0 ns polarity: normal

### 通过如下命令将管脚配置为输出高电平,连接的LED灯为亮状态 ###

root@apalis-imx8-07308034:~# gpioset 0 22=1

### 翻转输出为低电平,,连接的LED灯为灭状态 ###

root@apalis-imx8-07308034:~# gpioset 0 22=0

--------------------------------

./如果将X1 Pin 6管脚的Pin Mux配置BIT_CONFIG参数改为0x00000020,也就是由Pull Down改为Pull Up,那么实际测试上电启动系统后,连接的LED灯为亮状态。

5). 总结

本文基于NXP iMX8处理器演示了Pin Multiplexing的定义和配置方法,其他i.MX处理器也都是类似的思路。

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

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

相关文章

YOLOv5全面解析教程⑤:计算mAP用到的Numpy函数详解

作者 | Fengwen、BBuf 本文主要介绍在One-YOLOv5项目中计算mAP用到的一些numpy操作&#xff0c;这些numpy操作使用在utils/metrics.py中。本文是《YOLOv5全面解析教程④&#xff1a;目标检测模型精确度评估》的补充&#xff0c;希望能帮助到小伙伴们。 欢迎Star、试用One-YOLOv…

openpnp - configure - 主次基准点矫正

文章目录openpnp - configure - 主次基准点矫正概述备注ENDopenpnp - configure - 主次基准点矫正 概述 查找问题, 视觉里程碑只剩下4个问题了. 先看下设备上的主校准点, 我设备上的主校准点在设备前部的一个铝合金块上, 一块只带一个mark点的小PCB, 两边用螺丝拧住了.比PCB…

(五十四)大白话索引的页存储物理结构,是如何用B+树来实现的?.md

上一次我们给大家说了主键索引的目录结构&#xff0c;只要在一个主键索引里包含每个数据页跟他最小主键值&#xff0c;就可以组成一个索引目录&#xff0c;然后后续你查询主键值&#xff0c;就可以在目录里二分查找直接定位到那条数据所属的数据页&#xff0c;接着到数据页里二…

腾讯云轻量应用服务器配置表汇总(2核2G/2核4G/4核8G/8核16G)

轻量应用服务器&#xff08;TencentCloud Lighthouse&#xff09;是新一代开箱即用、面向轻量应用场景的云服务器产品&#xff0c;助力中小企业和开发者便捷高效的在云端构建网站、Web应用、小程序/小游戏、APP、电商应用、云盘/图床和开发测试环境&#xff0c;相比普通云服务器…

我的 System Verilog 学习记录(7)

引言 本文简单介绍 SystemVerilog 语言的 testbench 组件间通信和数据交互。 前文链接&#xff1a; 我的 System Verilog 学习记录&#xff08;1&#xff09; 我的 System Verilog 学习记录&#xff08;2&#xff09; 我的 System Verilog 学习记录&#xff08;3&#xff…

使用msvc命令行或msbuild编译dx3程序

从这里下载&#xff1a;https://github.com/microsoft/DirectX-Graphics-Samples cl.exe /D "UNICODE" /D "_UNICODE" *.cpp /EHsc -I C:\Users\54930\Downloads\DirectX-Graphics-Samples-master\Samples\Desktop\D3D12nBodyGravity\src\WinPixEventRun…

为什么DNS安全很重要

几乎所有web流量都需要标准DNS查询&#xff0c;这为DNS攻击创造了机会&#xff0c;比如DNS劫持和中间人攻击。这些攻击可以将网站的入站流量重定向到网站的伪造副本&#xff0c;收集敏感用户信息&#xff0c;并使企业承担重大责任。目前防范DNS威胁的最普遍方法之一是采用DNSSE…

为什么地图可视化炙手可热?

我们在谈到数据可视化的时候&#xff0c;可能第一反应就是中间有一个地图样式的大屏图。但有没有想过&#xff0c;为什么大多数的可视化大屏中间都是一张地图的样子&#xff1f;这张地图样式的模块究竟是什么呢&#xff1f;它又是怎么做出来的&#xff1f; 其实这张地图样式的…

Linux基本命令复习-面试急救版本

1、file 通过探测文件内容判断文件类型&#xff0c;使用权是所有用户&#xff0c; file[options]文件名2、mkdir/rmdir 创建文件目录&#xff08;文件夹&#xff09;/删除文件目录 3、grep 指定文件中搜索的特定内容 4、find 通过文件名搜索文件 find name 文件名 5、ps 查…

电子科技大学 高级计算机系统结构 考试回忆

首先题量不算小&#xff0c;因此没有太多时间把题都记出来&#xff0c;但是叙述一下题的类型希望能帮到以后选了这门课大家&#xff0c;在网上确实没有搜到这门课有关考试的任何资料&#xff0c;所以我也没啥参考全凭记忆和老师的PPT结合。复习的时候老师给了大纲&#xff0c;就…

mysql字符串等值查询中条件字段值末尾有空格也能查到数据问题

一、事故还原 我们仍然使用学生信息表&#xff0c;但是我们只需要保留两个字段即可&#xff1a; CREATE TABLE student_info (id int(11) NOT NULL AUTO_INCREMENT COMMENT 学号,name varchar(20) CHARACTER SET utf8 DEFAULT NULL COMMENT 姓名, PRIMARY KEY (id) ) ENGINEIn…

挑战图像处理100问(26)——双线性插值

双线性插值是一种常用的图像插值方法&#xff0c;用于将低分辨率的图像放大到高分辨率。它基于一个假设&#xff1a;在两个相邻像素之间的值是线性的。 双线性插值考察444邻域的像素点&#xff0c;并根据距离设置权值。虽然计算量增大使得处理时间变长&#xff0c;但是可以有效…

电脑开机后进不了系统?原因以及解决方法

在日常使用电脑的过程中&#xff0c;我们有时候会遇到电脑开机后进不了系统的情况&#xff0c;这是令人十分烦恼的事情。那么&#xff0c;这种情况的出现可能是由于什么原因呢&#xff1f;接下来&#xff0c;本文将为您介绍电脑开机后无法进入系统的原因以及解决方法。 演示机型…

【Java】String类

1. String内部声明 jdk8以前&#xff1a; private final char value[]; final&#xff1a;指明数组一旦初始化&#xff0c;其地址就不能改变 jdk9以后&#xff1a; private final byte[] value;&#xff0c;为节省内存空间而优化 final&#xff1a;指明数组一旦初始化&…

这些让人变笨的食物你是不是天天吃?

我们关注食物的营养&#xff0c;关注它对身材、健康的影响。现在&#xff0c;我们发现有些食物&#xff0c;还会影响人的神经系统、认知能力。简而言之&#xff0c;就是有些食物可能会让人变笨。《美国医学会神经病学杂志》上的一项研究&#xff0c;分析了超加工食物与认知能力…

【蓝桥杯入门到入土】最基础的数组你真的掌握了吗?

文章目录一&#xff1a;数组理论基础二&#xff1a;数组知识点总结三&#xff1a;数组这种数据结构的优点和缺点是什么&#xff1f;四&#xff1a;实战解题1. 移除元素暴力解法双指针法2.有序数组的平方暴力解法双指针法最后说一句一&#xff1a;数组理论基础 首先要知道数组在…

【数据结构】堆的详解

本章的知识需要有树等相关的概念&#xff0c;如果你还不了解请先看这篇文章:初识二叉树 堆的详解一、二叉树的顺序结构及实现1、二叉树的顺序结构2、堆的概念及结构二、堆的简单实现 (以大堆为例)1、堆的定义2、堆的初始化3、堆的销毁4、堆的打印5、堆的插入6、堆顶元素的获取7…

网络传输:linux下的网络请求和下载(ping wget curl)、端口

一、下载和网络请求 1.ping命令 可以通过ping命令&#xff0c;检查指定的网络服务器是否可连通状态 语法&#xff1a;ping [-c num] ip或主机名 选项&#xff1a; -c 检查的次数&#xff0c;若不使用-c&#xff0c;将无限次数持续检查参数&#xff1a;ip或主机名&#xff0c…

基于Python的时间序列异常值检测

今天我们介绍一下使用python做时间序列数据分析和预测中异常值检测的方法&#xff0c;常用的异常值检测方法有以下几种&#xff1a; 3sigma: 基于正太分布&#xff0c;当数据值超过3个标准差(3sigma)时为异常值。z-score : z标准分数&#xff0c;它测量数据值到平均值的距离,当…

pandas对某一列的种类编码

文章目录背景实现背景 如果某一列的种类特别多&#xff0c;想要通过映射来编码&#xff0c;这样非常麻烦&#xff0c;所以可以对一个列全部一次性进行编码。 例如我的数据如下&#xff1a; 我需要编码专业这个列&#xff0c;我们可以看到这一列很多&#xff1a; 实现 使用…