xym-ee
  • 计算机与嵌入式开发学习
  • 1-1.编程基础
    • C 语言
      • C 中的数据
      • C 语言基础
      • 字符输入输出
      • 函数
      • 数组和指针
      • 字符串处理
      • 存储类别
      • 文件 I/O
      • 复杂数据类型
      • 位操作
      • 预处理和 C 库
    • 数据结构和算法入门
    • leetcode 刷算法题
      • 递归与栈
      • 二叉树与递归
      • 回溯问题
      • 动态规划 1
    • 基本工具和使用
      • shell
      • shell 脚本
      • vim 编辑器
      • 命令行数据整理
      • 命令行环境和配置
  • 1-2.计算机系统基础(CSAPP)
    • 1.计算机基础
    • 2.数据的表示
    • 3.加减运算
    • 4.乘除运算
    • 5.程序的表示转换和链接
    • 6.IA32指令
    • 7.过程调用
    • 10.程序的链接
  • 1-3.数字电路、计算机组成
    • 1.数字电路、virtual circuit board
    • 2.计算机组成/steam:Turing Complete
    • 3.微机原理与接口技术(8086)
  • 1-4.计算机网络
    • 1.从浏览器开始
    • 2.协议栈和网卡
    • 3.网络设备
    • 4.运营商、接入网
    • 5.服务器
    • 6.数据返回浏览器
    • socket编程
  • 1-5.操作系统
    • 0.绪论
      • 1.应用视角的操作系统
      • 2.硬件视角的操作系统
      • 3.数学视角的操作系统
      • 4.状态机模型的应用
    • 1.并发
      • 1.并发 bug 的解决思路
      • 2.互斥
      • 3.同步
      • 4.信号量
      • 5.真实并发
      • 6.调试技巧
      • 7.os kernel 实现
    • 2.虚拟化
      • 1.操作系统上的进程
      • 2.进程的地址空间
      • 3.系统调用和unix shell
      • 4.C 标准库的实现
      • 5.linux 操作系统
      • 6.可执行文件和加载
      • 7.动态链接和加载
      • 8.内核的实现
      • 9.fork 的应用
    • 3.持久化
      • 1.存储设备的原理
      • 2.输入输出设备模型
      • 3.设备驱动程序
      • 4.文件系统 API
      • 5.fat 和 unix 文件系统
      • 6.持久数据的可靠性
    • 总结
  • 2-1.嵌入式裸机开发
    • 嵌入式系统通信接口与协议
    • cortex-m 内核芯片裸机开发
    • MPU
  • 2-2.中等规模系统开发
    • LVGL 图形库
    • 裸机开发的软件框架
    • 基于 rtos 开发
  • 2-3.armv7-m架构与 rtos 原理
    • armv7-m 架构
    • rt-thread 内核实现
    • rt-thread 驱动开发
  • 3-1.linux 应用开发基础
  • 3-2.linux 镜像构建
    • uboot 使用
    • uboot 适配
    • uboot 启动分析
    • uboot 自定义命令
    • linux 内核适配
    • linux 内核启动分析
    • busybox 根文件系统构建
  • 3-3.linux 驱动开发
    • 驱动开发基础
    • sysfs
    • led 驱动
    • 设备树
    • pinctrl 和 gpio 子系统
    • 并发控制
由 GitBook 提供支持
在本页
  • 设备树添加 Pinctrl
  • GPIO 子系统
  • gpio api

这有帮助吗?

  1. 3-3.linux 驱动开发

pinctrl 和 gpio 子系统

  • 设备树中添加节点,在 reg 属性中设置寄存器地址

  • 驱动中获得 reg 的物理地址,完成映射

  • 设置 GPIO

    • 复用功能设置

    • 电气属性设置

    • GPIO 方向设置

这个芯片是 NXP 的,对于 STM32 来说,也是类似的。因此 linux 内核针对 PIN 配置开发了 pinctrl 子系统。对于 GPIO 的配置开发了 gpio 子系统。

大多数SOC的pin都是可以复用的,

pin 子系统完成的工作

  • 获取设备树中的 pin 信息

  • 设置复用功能

  • 设置电气属性

对于使用者,只需要在设备树中设置好某个 pin 的相关属性即可,剩下的工作全都由 pinctrl 子系统来完成。

iomuxc: iomuxc@020e0000 {
  compatible = "fsl,imx6ul-iomuxc";
  reg = <0x020e0000 0x4000>;
};

在不同开发板中,添加了更多属性

&iomuxc {
  pinctrl-names = "default";
  pinctrl-0 = <&pinctrl_hog_1>;
  imx6ul-evk {
    pinctrl_hog_1: hoggrp-1 {
      fsl,pins = <
        MX6UL_PAD_UART1_RTS_B__GPIO1_IO19     0x17059 /* SD1 CD */
        MX6UL_PAD_GPIO1_IO05__USDHC1_VSELECT  0x17059 /* SD1 VSELECT */
        MX6UL_PAD_GPIO1_IO09__GPIO1_IO09      0x17059 /* SD1 RESET */
      >;
    };

举例,pinctrl_hog_1 节点中,和热拔插有关的 PIN 集合。UART1_RTS_B 这个引脚作为 SD 卡的检测引脚。MX6UL_PAD_UART1_RTS_B__GPIO1_IO19 为宏定义,包含了寄存器的便宜地址以及值。

iomuxc 中的 compatible 属性为 "fsl,imx6ul-iomuxc",可以在 kernel 源码全局搜索,在 drivers/pinctrl/freescale/pinctrl-imx6ul.c 中可以找到 of_device_id 中匹配到的值。因此 pinctrl-imx6ul.c 中完成 PIN 的配置工作。

设备树添加 Pinctrl

GPIO 子系统

pinctrl 将一个 PIN 设置好复用功能和电气属性,如果设置为 GPIO ,那么 linux 也提供 gpio 子系统。

  • 初始化 GPIO

  • 读写 API

只要在设备树中添加 GPIO 相关信息,就可以在驱动程序中使用 gpio 子系统的 API 来操作了。所有的设置过程都由内核实现。

gpio api

对于驱动开发来说,设置好设备树后就可以使用 gpio 的 API 来操作了。一些常用的

  • int gpio_request(unsigned gpio, const char *label)

申请一个 GPIO ,使用前一定要申请

上一页设备树下一页并发控制

最后更新于11个月前

这有帮助吗?