02_gpio子系统

总结

驱动程序还想控制gpio 可以不用读写寄存器 直觉用gpio子系统开发的接口就能用了
轻松做输入输出 获取当前值

详细介绍

用设备树里的节点 gpio1 介绍

imx6ull.dtsi
gpio1 记录了控制器相关的寄存器基地址

gpio1: gpio@209c000 {
				compatible = "fsl,imx6ul-gpio", "fsl,imx35-gpio";
				reg = <0x209c000 0x4000>;
				interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>,
					     <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>;
				clocks = <&clks IMX6UL_CLK_GPIO1>;  //初始化外设时钟
				gpio-controller;  //表明gpio1是gpio控制器
				#gpio-cells = <2>;
				interrupt-controller; //表明gpio1是中断控制器
				#interrupt-cells = <2>;
				gpio-ranges = <&iomuxc  0 23 10>, <&iomuxc 10 17 6>,
					      <&iomuxc 16 33 16>; //表明gpio1和pinctrl子系统关系
				gpio子系统引脚编号和pinctrl子系统引脚编号的关系
				
			};
<&iomuxc 16 33 16>;  &iomuxc 引用pinctrl子系统的iomuxc节点
16 33  16 : gpio子系统引脚编号和pinctrl子系统引脚编号的关系   gpio的16号引脚 对应pinctrl子系统的33号引脚,对应关系的长度为16

在这里插入图片描述

其他设备节点想要使用gpio子系统的话怎么使用

比如rgb节点 用的话增加了下面的属性
rgb_led_red rgb_led_green rgb_led_blue

rgb_led{
    #address-cells = <1>;
    #size-cells = <1>;
    pinctrl-names = "default";
    compatible = "fire,rgb_led";
    pinctrl-0 = <&pinctrl_rgb_led>;
    rgb_led_red = <&gpio1 4 GPIO_ACTIVE_LOW &gpio1 10 GPIO_ACTIVE_LOW>;
    rgb_led_green = <&gpio4 20 GPIO_ACTIVE_LOW>;
    rgb_led_blue = <&gpio4 19 GPIO_ACTIVE_LOW>;
    status = "okay";
};
rgb_led_red:自定义属性,&gpio1 4 表示引用了gpio1: gpio@209c000节点 GPIO1_IO04表示在gpio1的编号,GPIO_ACTIVE_LOW表示低电平有效
函数使用
常用函数
of_find_node_by_path()函数

函数原型:

inline struct device_node *of_find_node_by_path(const char *path)

参数:

  • path:设备树节点的绝对路径

返回值:

  • 成功:目标节点

  • 失败:NULL

of_get_named_gpio()函数

用来获取gpio的编号
函数原型:

static inline int of_get_named_gpio(struct device_node *np,const char *propname, int index)

参数:

  • np:指定的设备树节点
  • propname:GPIO属性名== rgb_led_red
  • index:引脚索引值 比如rgb_led_red 有两个属性 需要选择gpio1 10 GPIO_ACTIVE_LOW index填写1

返回值:

  • 成功:GPIO编号
  • 失败:负数
gpio_request()函数

把gpio引脚放入pinctrl子系统中 避免不同外设使用一个引脚
函数原型:

static inline int gpio_request(unsigned gpio, const char *label)

参数:

  • gpio:要申请的GPIO编号
  • label:给 gpio 设置个名字

返回值:

  • 成功:0
  • 失败:负数
gpio_free()函数

函数原型:

static inline void gpio_free(unsigned gpio);

参数:

  • gpio:要释放的GPIO编号

返回值:

gpio_direction_output()函数

函数原型:

static inline int gpio_direction_output(unsigned gpio , int value);

参数:

  • gpio:要操作的GPIO编号

  • value:设置默认输出值

返回值:

  • 成功:0
  • 失败:负数
gpio_direction_input()函数

函数原型:

int gpio_direction_input(unsigned gpio)

参数:

  • gpio:要操作的GPIO编号

返回值:

  • 成功:0
  • 失败:负数
gpio_get_value()函数

函数原型:

#define gpio_get_value __gpio_get_value
int __gpio_get_value(unsigned gpio)

参数:

  • gpio:要操作的GPIO编号

返回值:

  • 成功: GPIO的电平值
  • 失败:负数
gpio_set_value()函数

函数原型:

#define gpio_set_value __gpio_set_value
void __gpio_set_value(unsigned gpio, int ;)

参数:

  • gpio:要操作的GPIO编号
  • value:要设置的输出值

返回值:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值