On 10/11, Linus Walleij wrote: > On Wed, Oct 4, 2017 at 12:03 AM, Stephen Boyd <sboyd@xxxxxxxxxxxxxx> wrote: > > > Could we remove the pin direction finding part here in > > gpiochip_add_pin_range() and lazily resolve the pin direction > > when a pin is requested? We would need a similar check in the msm > > specific debugfs code where we skip pins that aren't requested. > > This is basically a revert of commit 72d320006177 ("gpio: set up > > initial state from .get_direction()"). > > It seems reasonable for the gpiolib to be able to call this > function immediately after registering the new GPIO chip > with its vtable. I agree. I don't see the benefit though. Reading the direction later would achieve the same effect and also work for ACPI qcom platforms. > > I think it is more up to the driver to numb the reply with > some dummy return value (i.e. input mode) or refactor the > callback so that it is acceptable for gpiolib to get an -EINVAL > or so from the driver (again it will assume input mode) if the > driver can't return the direction at this time. > For qcom platforms the driver will never be able to return the direction for these certain pins because reading the register is not allowed by the firmware. Doing so will cause the device to crash with a security violation. If you don't want to delay reading the direction until request time, we should have the DT msm pinctrl drivers leave the get_direction() pointer as NULL. We don't need to read the direction on DT platforms to make anything work. -- Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project -- To unsubscribe from this list: send the line "unsubscribe linux-arm-msm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html