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

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

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处理器也都是类似的思路。

相关文章:

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

By Toradex秦海1). 简介为了提高处理器的设计灵活性和可用性&#xff0c;NXP的所有i.MX系列处理器都配备了基于 IOMUX Controller (IOMUXC)和IOMUX来使能Pin Mux功能&#xff0c;使得一个特定的IO管脚可以选择不同的可能多达8种的功能定义模块(ALT0, ALT1, ALT2, ALT3...)&…...

用Python的Supervisor進行進程監控以及自動啓動

python 限制同一时间只执行一个 作服務器端開發的同窗應該都對進程監控不會陌生&#xff0c;最近剛好要更換 uwsgi 爲 gunicorn&#xff0c;而gunicorn又剛好有這麼一章講進程監控&#xff0c;因此多研究了下。python 結合以前在騰訊工做的經驗&#xff0c;也會講講騰訊的服務…...

Centos和Window系统下Frp内网穿透

frp 是一个高性能的内网穿透的反向代理软件&#xff0c;支持 TCP、UDP、HTTP、HTTPS 等常见协议(TCP最常用)&#xff0c;可以将处于局域网或者家用电脑主机、办公电脑主机通过中转服务器的方式暴露在公网里&#xff0c;使用户可以通过访问公网的IP&#xff08;域名&#xff09;…...

春招冲刺(四):flex布局面试题总结

flex布局面试题总结 Q1&#xff1a;什么是弹性盒布局&#xff1f; 特点&#xff1a;让元素对不同屏幕尺寸和不同显示设备做好适应。在响应式网站表现较好。 一、容器属性 Q2&#xff1a;display:flex和display:inline-flex的作用 使容器变成弹性布局&#xff0c;为其子元素…...

我的 System Verilog 学习记录(7)

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

canvas复习笔记(绘制直线、矩形、圆形、圆弧)

canvas 画一条直线 <body><canvasid"c"width"300"height"200"style"border: 1px solid #ccc;"></canvas> </body><script>// 2、获取 canvas 对象const cnv document.getElementById("c");…...

LeetCode 653. 两数之和 IV - 输入二叉搜索树

653. 两数之和 IV - 输入二叉搜索树 难度&#xff1a;easy\color{Green}{easy}easy 题目描述 给定一个二叉搜索树 rootrootroot 和一个目标结果 kkk&#xff0c;如果二叉搜索树中存在两个元素且它们的和等于给定的目标结果&#xff0c;则返回 truetruetrue。 示例 1&#xf…...

【Datawhale图机器学习】图神经网络

图神经网络 GNN是一种连接模型&#xff0c;通过网络中节点之间的信息传递的方式来获取图中的依存关系&#xff0c;GNN通过从节点任意深度的邻居来更新该节点状态&#xff0c;这个状态能够表示状态信息。第一次在论文 The graph neural network model 中提出 与传统NN的区别&a…...

【项目精选】 javaEE采购管理系统(论文+视频+源码)

点击下载源码 本系统是一个独立的系统&#xff0c;用来解决企业采购信息的管理问题。采用JSP技术构建了一个 有效而且实用的企业采购信息管理平台&#xff0c;目的是为高效地完成对企业采购信息的管理。经过 对课题的深入分析&#xff0c;采购系统需实现以下功能模块&#xff1…...

【Servlet篇2】创建一个web项目

在上一篇文章当中&#xff0c;已经提到了什么是Maven&#xff0c;以及如何使用maven从中央仓库下载jar包。【Tomcat与Servlet篇1】认识Tomcat与Maven_革凡成圣211的博客-CSDN博客Tomcat&#xff0c;mavenhttps://blog.csdn.net/weixin_56738054/article/details/129228140?spm…...

Allegro如何手动让静态铜皮避让过孔操作指导

Allegro如何手动让静态铜皮避让过孔操作指导 在用Allegro做PCB设计的时候,如果铺的是静态铜皮,铜皮铺在过孔上会造成短路,需要手动避让下,如下图 下面介绍如何手动避让,具体操作如下 点击Shape点击Manual Void/Cavity...

Java使用SpringBoot的Filter来扩展管道请求

Java Spring Boot 是一个流行的 Java Web 开发框架&#xff0c;它提供了一些基本的 Web 管道功能。在 Spring Boot 中&#xff0c;Web 管道是通过一组过滤器、拦截器、控制器和视图解析器等组件组成的。 如果你需要扩展 Spring Boot Web 管道&#xff0c;可以考虑以下几种方式…...

「JVM 高效并发」锁优化

为了线程间更高效的共享数据及解决竞争问题&#xff0c;提高程序执行效率&#xff0c;JDK 6 做了大量锁优化&#xff0c;如适应性自旋&#xff08;Adaptive Spinning&#xff09;、锁消除&#xff08;Lock Elimination&#xff09;、锁膨胀&#xff08;Lock Coarsening&#xf…...

当园区物流遇上云计算,会发生什么事情?

顺丰供应链与亚马逊云科技的强强联手&#xff0c;可以给物流供应链企业带来怎样的启示&#xff1f;物流行业的数智化趋势在国内物流行业说起顺丰&#xff0c;相信是无人不知无人不晓。作为数字化供应链服务解决方案提供商&#xff0c;顺丰供应链可以提供端到端供应链的规划、管…...

作为测试开发岗的面试官,我都是怎么选人的?

最近一段时间面试了不少人&#xff0c;主要是一些测试开发岗&#xff0c;中高级的初级的也都有&#xff1b;也有一些偏业务测试岗的候选人。总结出了一些方法论&#xff0c;或者说更多的是个人作为面试官所遵守的一套面试准则。 1.什么是面试&#xff1f; 面试不仅仅是你问我…...

android事件分发机制源码分析

没什么用的前言责任链设计模式流程图源码分析 没什么用的前言 事件分发机制是面试中一道必问的题目&#xff0c;而我的应对方式则是&#xff0c;在网络上找一些博客看看&#xff0c;然后做一些笔记&#xff0c;最后在面试时将我自己记住的内容说出来。这种方式本身没有太大的…...

今天,小灰37岁了!

人们常常说&#xff0c;35岁是互联网人的中年危机。现在&#xff0c;小灰已经跨过了中年危机&#xff0c;倒不是因为小灰财务自由了&#xff0c;而是因为今天是小灰37岁的生日。年轻时候&#xff0c;小灰总觉得30岁是一个很遥远的年龄&#xff0c;而现在&#xff0c;小灰距离40…...

基于.NET 7 + iView 的前后端分离的通用后台管理系统开源框架

更多开源项目请查看&#xff1a;一个专注推荐.Net开源项目的榜单 今天给大家推荐一套前后端分离通用后台管理系统开源框架。 项目简介 这是基于.Net 7 Vue.js开发的、前后端分离框架&#xff0c;前端UI框架采用iView&#xff0c;该项目只有基础功能模块&#xff0c;不包含具…...

新一代通信协议—— RSocket

一、简介 RSocket 是一种二进制字节流传输协议&#xff0c;位于 OSI 模型中的5~6层&#xff0c;底层可以依赖 TCP、WebSocket、Aeron 协议。最初由 Netflix 开发&#xff0c;支持 Reactive Streams。其开发背后的动机是用开销更少的协议取代超文本传输协议(HTTP)&#xff0c;H…...

【编程实践】这个代码命名规范是真优雅呀!代码如诗!!(多读优秀的开源代码,多实践,你也可以一样优秀!)

目录 管理类命名 传播类命名 回调类命名 监控类命名 内存管理类命名 过滤检测类命名 结构类命名 常见设计模式命名 解析类命名 网络类命名 CRUD命名 其他 End 管理类命名 写代码&#xff0c;少不了对统一资源的管理&#xff0c;清晰的启动过程可以有效的组织代码…...

深入浅出Asp.Net Core MVC应用开发系列-AspNetCore中的日志记录

ASP.NET Core 是一个跨平台的开源框架&#xff0c;用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET Core 中的日志记录 .NET 通过 ILogger API 支持高性能结构化日志记录&#xff0c;以帮助监视应用程序行为和诊断问题。 可以通过配置不同的记录提供程…...

【Oracle APEX开发小技巧12】

有如下需求&#xff1a; 有一个问题反馈页面&#xff0c;要实现在apex页面展示能直观看到反馈时间超过7天未处理的数据&#xff0c;方便管理员及时处理反馈。 我的方法&#xff1a;直接将逻辑写在SQL中&#xff0c;这样可以直接在页面展示 完整代码&#xff1a; SELECTSF.FE…...

线程同步:确保多线程程序的安全与高效!

全文目录&#xff1a; 开篇语前序前言第一部分&#xff1a;线程同步的概念与问题1.1 线程同步的概念1.2 线程同步的问题1.3 线程同步的解决方案 第二部分&#xff1a;synchronized关键字的使用2.1 使用 synchronized修饰方法2.2 使用 synchronized修饰代码块 第三部分&#xff…...

django filter 统计数量 按属性去重

在Django中&#xff0c;如果你想要根据某个属性对查询集进行去重并统计数量&#xff0c;你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求&#xff1a; 方法1&#xff1a;使用annotate()和Count 假设你有一个模型Item&#xff0c;并且你想…...

测试markdown--肇兴

day1&#xff1a; 1、去程&#xff1a;7:04 --11:32高铁 高铁右转上售票大厅2楼&#xff0c;穿过候车厅下一楼&#xff0c;上大巴车 &#xffe5;10/人 **2、到达&#xff1a;**12点多到达寨子&#xff0c;买门票&#xff0c;美团/抖音&#xff1a;&#xffe5;78人 3、中饭&a…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵&#xff0c;其中每行&#xff0c;每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid&#xff0c;其中有多少个 3 3 的 “幻方” 子矩阵&am…...

SQL慢可能是触发了ring buffer

简介 最近在进行 postgresql 性能排查的时候,发现 PG 在某一个时间并行执行的 SQL 变得特别慢。最后通过监控监观察到并行发起得时间 buffers_alloc 就急速上升,且低水位伴随在整个慢 SQL,一直是 buferIO 的等待事件,此时也没有其他会话的争抢。SQL 虽然不是高效 SQL ,但…...

从面试角度回答Android中ContentProvider启动原理

Android中ContentProvider原理的面试角度解析&#xff0c;分为​​已启动​​和​​未启动​​两种场景&#xff1a; 一、ContentProvider已启动的情况 1. ​​核心流程​​ ​​触发条件​​&#xff1a;当其他组件&#xff08;如Activity、Service&#xff09;通过ContentR…...

Spring AI Chat Memory 实战指南:Local 与 JDBC 存储集成

一个面向 Java 开发者的 Sring-Ai 示例工程项目&#xff0c;该项目是一个 Spring AI 快速入门的样例工程项目&#xff0c;旨在通过一些小的案例展示 Spring AI 框架的核心功能和使用方法。 项目采用模块化设计&#xff0c;每个模块都专注于特定的功能领域&#xff0c;便于学习和…...

uniapp 集成腾讯云 IM 富媒体消息(地理位置/文件)

UniApp 集成腾讯云 IM 富媒体消息全攻略&#xff08;地理位置/文件&#xff09; 一、功能实现原理 腾讯云 IM 通过 消息扩展机制 支持富媒体类型&#xff0c;核心实现方式&#xff1a; 标准消息类型&#xff1a;直接使用 SDK 内置类型&#xff08;文件、图片等&#xff09;自…...