RK3568之pinctrl子系统和GPIO子系统

第1章 两个子系统的区别与联系

1.1 pinctrl子系统

主要功能:引脚复用(pin multiplexing)和引脚配置(pin configuration)。

引脚复用:一个物理引脚可能有多个功能,例如可以是GPIO、串口TX、I2C SCL等。pinctrl子系统负责选择引脚的功能(即选择复用模式)。

引脚配置:例如设置引脚的上下拉电阻、驱动强度、 slew rate等电气特性。

引脚状态管理:睡眠、默认、激活等不同状态下的配置

在设备树中,pinctrl的配置通常被组织在pinctrl节点中,然后在具体设备节点中通过pinctrl-names和pinctrl-0等属性来引用。

1.2 GPIO子系统

主要功能:当引脚被配置为GPIO功能时,GPIO子系统提供了一套统一的接口来访问这些GPIO引脚,例如设置方向(输入/输出)、读写值、设置中断等,提供gpio_request()gpio_direction_output()等接口。

GPIO子系统会为每个GPIO控制器创建一个GPIO chip,这个chip提供了一系列操作GPIO的函数(如设置方向、读写等)。然后,这些GPIO可以通过一个全局的编号(即gpio number)来访问,维护全局GPIO编号空间,或者通过设备树中的gpio属性来指定。

第2章 pinctrl子系统

2.1 pinctrl子系统的语法

设备一般有三种状态:【"default", "sleep", "idle"】;这几种状态都是固定的。

实例分析一:

cpp 复制代码
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_hog_1>;
  1. 使用 pinctrl-names 表示设备的状态;这里仅仅是取了第0个状态来表示。

  2. 使用 pinctrl-0表示设备的第0个状态;第0个状态使用的是【pinctrl_hog_1】标签的配置。

实例分析二:

cpp 复制代码
pinctrl-names = "default", "wake up";
pinctrl-0 = <&pinctrl_hog_1>;
pinctrl-1 = <&pinctrl_hog_2>;
  1. 使用 pinctrl-names 表示设备的状态;这里不仅是取了第0个状态来表示,还取了第1个状态来表示。

  2. 使用 pinctrl-0表示设备的第0个状态;第0个状态使用的是【pinctrl_hog_1】标签的配置。

  3. 使用 pinctrl-1表示设备的第1个状态;第1个状态使用的是【pinctrl_hog_2】标签的配置。

实例分析三:

cpp 复制代码
pinctrl-names = "default", "wake up","idle";
pinctrl-0 = <&pinctrl_hog_1>;
pinctrl-1 = <&pinctrl_hog_2>;
pinctrl-2 = <&pinctrl_hog_3>;
  1. 使用 pinctrl-names 表示设备的状态;这里不仅是取了第0个状态来表示,而且取了第1个状态来表示,还取了第2个状态来表示。

  2. 使用 pinctrl-0表示设备的第0个状态;第0个状态使用的是【pinctrl_hog_1】标签的配置。

  3. 使用 pinctrl-1表示设备的第1个状态;第1个状态使用的是【pinctrl_hog_2】标签的配置。

  4. 使用 pinctrl-2表示设备的第2个状态;第2个状态使用的是【pinctrl_hog_3】标签的配置。

实例分析四:

cpp 复制代码
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_hog_1 &pinctrl_hog_2>;
  1. 使用 pinctrl-names 表示设备的状态;这里仅仅是取了第0个状态来表示。

  2. 使用 pinctrl-0表示设备的第0个状态;这里的第0个状态需要两个标签的配置才能完成。【pinctrl_hog_1】和【pinctrl_hog_2】标签的共同完成状态0的配置。

2.2 pinctrl实战

相关推荐
H__Rick18 小时前
C51单片机学习-DAY3
单片机·学习·mongodb
望眼欲穿的程序猿20 小时前
Hello World
嵌入式硬件·rust
bkspiderx20 小时前
Windows DLL核心技术:深入理解__declspec(dllexport)与__declspec(dllimport)
windows·stm32·单片机·dllimport·dllexport·windows dll·__declspec
ACP广源盛1392462567320 小时前
GSV5600@ACP#多接口协议转换芯片,物理 AI 便携终端的互联核心
大数据·人工智能·分布式·嵌入式硬件·spark
望眼欲穿的程序猿21 小时前
ESP32-S3 定时器中断
单片机·嵌入式硬件
电气_空空21 小时前
基于 LabVIEW 的深海气密采水器测控系统
单片机·嵌入式硬件·毕业设计·labview
星夜夏空991 天前
STM32单片机学习(37) —— PWR和BKP
stm32·单片机·学习
牛牛,牛1 天前
榨干最后一微安:STM32 的低功耗设计与中断唤醒机制深度剖析
单片机·嵌入式硬件
星华云1 天前
[STM32] SAR型ADC(逐次逼近型ADC)工作原理简介
stm32·单片机·嵌入式硬件
小娄~~1 天前
时钟控制器原理
单片机·嵌入式硬件