On 03/14/2017 04:41 PM, Linus Walleij wrote: > On Mon, Mar 6, 2017 at 10:52 PM, Timur Tabi <timur@xxxxxxxxxxxxxx> wrote: > >> On ACPI platforms, the kernel has no control over the muxing (aka function) >> of the various pins. Firmware configures the TLMM controller for all pins, >> and configures them for whatever functions they're supposed to be. > > I think it would be better if pin control and ACPI play along, and I bet that > will happen in the future. This is I guess a question for ACPI standardization > work. Maybe. During the development of the ACPI standard, everyone made a big stink about how muxing should be handled by the firmware and never touched by the OS. It would be a significant reversal if they decide to add mux configuration to ACPI. >> Therefore, on ACPI, the driver should never change the function of any pin. >> If it's set to something other than 0, then it should never touch that pin. >> Don't write to it, don't change the direction, and definitely don't change >> the function. > > Does that mean that pins with 0 are free to play around with? Yes. >> So would it be acceptable, for example, to change msm_gpio_set() such that >> if the function of that pin is non-zero, just return an error? > > I would ask the driver maintainer about his opinion, and also whoever > is an authority on ACPI for the TLMM-chips, I am no expert > in ACPI. Hell I'm not even good at device tree. Not to mention SFI. > Oh well... Well, I was hoping that Stephen would respond to this question. :-) My point is, if the driver knows that the GPIO cannot be written to (because it's muxed to something else), shouldn't the driver return with an error if the caller attempts to write? -- Qualcomm Datacenter Technologies, Inc. as an affiliate of Qualcomm Technologies, Inc. Qualcomm Technologies, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project. -- To unsubscribe from this list: send the line "unsubscribe linux-gpio" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html