On Mon, 10 Apr 2017, Hans de Goede wrote: > Where the new_action trigger_mask gets filled with the triger_mask > from the irq_data, which is a further hint that looking at > irqd_get_trigger_type(&desc->irq_data) rather then at > (old->flags IRQF_TRIGGER_MASK) is probably the right fix. > > Note btw that 4b357daed698 is (part of) what is breaking things for > my use-case, I request the irq with IRQF_TRIGGER_NONE but > 4b357daed698 modifies that before comparing the new trigger flags > to the old. The issue here is, that at the time of the first setup_irq() the trigger type in irq_data is NONE. As a consequence the following is a NOOP: if (!new->trigger) new->flags |= get_type(irqdata); Now the irq is started up for the first time and then the actual trigger type gets established, but that's to late to fix up new->flags. So yes, we should change the logic for the shared case to: if (old) { oldtype = get_type(irqdata); if (oldtype != newtype) goto mismatch; That should cover all cases. Thanks, tglx -- To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html