当时gpio子系统进行读取时返回必定是0
因此,首先必须使用platform驱动来管理gpio和pinctrl子系统,然后如果按照正点原子所教的设备树引脚设置为0x10B0则会导致读取到的电平值为0。
解决方法:
将设备树中的引脚设置为
pinctrl_gpioled: gpioledgrp {
fsl,pins =<
MX6UL_PAD_GPIO1_IO03__GPIO1_IO03 0x400110B0
>;
};
即将原来的0X10B0改为0x400110B0,即可顺利读取到设置成输出模式的io的电平值了
具体原理可以参考
NXP i.MX6 GPIO value值读取为0
但其实我还遇到了一个问题,那就是我所写的项目中需要注册多个gpio,并且需要监控他们的变化。在注册过程中,
static const struct of_device_id LNG_platform_of_match[] = {
{.compatible = "mini,gpioled"},
{ .compatible = "gpio-bounce" },
{ .compatible = "gpio-water-high" },
{ .compatible = "gpio-water-low" },
{ .compatible = "gpio-vacuum" },
{ .compatible = "gpio-absorb" },
{ .compatible = "gpio-stir" },
{ .compatible = "gpio-up1" },
{ .compatible = "gpio-up2" },
{ .compatible = "mini,gpio-add1" },
{ .compatible = "gpio-add2" },
{/* sentinel */},
};
该匹配函数每有一个子节点便会匹配一次并执行一次probe函数。然后我的probe函数中放入了驱动的注册部分,就会一直报错,但并不影响最终的使用。具体情况如下
目前还没有找到具体的解决方法。先挖个坑,后续找到了我会进行更新。