On 03/02/2014 05:52 PM, Graeme Gregory wrote: > On Fri, Feb 28, 2014 at 09:34:33AM -0700, Stephen Warren wrote: >> On 02/27/2014 10:58 PM, Mark Brown wrote: >>> On Thu, Feb 27, 2014 at 02:35:42PM -0700, Stephen Warren wrote: >>>> On 02/27/2014 02:02 PM, Graeme Gregory wrote: >>> >>>>>> +- ti,irq-externally-inverted : If missing, the polarity of the Palmas IRQ >>>>>> + output should be set to the opposite of the polarity indicated by the IRQ >>>>>> + specifier in the interrupts property. If absent, the polarity should be >>>>>> + configured to match. This allows the representation of an inverter between >>>>>> + the Palmas IRQ output and the interrupt parent's IRQ input. >>> >>>>> This has got to be the wrong way to do things, all this leads to is every >>>>> device doing this property in its own way and having totally inconsistent >>>>> properties all meaning the same thing. ... >> Another alternative might be to add an extra IRQ bit in the IRQ >> specifier (and something similar would be needed for GPIO specifiers) >> that indicates "inversion between source and destination". This could be >> queried by drivers in exactly the same way as the existing polarity/type >> IRQ flags. We'd need to update each individual IRQ controller binding to >> enable that flag, since each binding defines its own definition of such >> flags. (although in practice since most use the same centrally suggested >> flags, this wouldn't be any more than just saying yes, this binding >> allows that new flag to be used). >> > A new flag would meet my concerns of every chip doing basic inversion > in different ways. OK, I'll look into a new flag. The one thing I worry about is that we can either: 1) Have every IC driver with a configurable output polarity read a DT flag (and we can fully standardize it's name), which is 1 line of code per IC driver. or: 2) We can go through every single interrupt controller's DT binding and driver, and implement (document and parse) the new IRQ specifier flag there, and pass it throgh the Linux IRQ stack, yet we still need code in every IC driver to actually read the flag, so we haven't removed any code. It seems /much/ simpler, and no more of a maintenance or consistency burden, to just have the IC driver read the flag directly from their own DT. Still, as I said, I'll go try and code it up and see how bad it is in practice. -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html