From mboxrd@z Thu Jan 1 00:00:00 1970 From: Thomas Gleixner Subject: Re: [PATCH 1/3] irq / PM: New driver interface for wakeup interruptsn Date: Fri, 1 Aug 2014 15:43:21 +0200 (CEST) Message-ID: References: <20140724212620.GO3935@laptop> <1624300.2IhdzCt5pu@vostro.rjw.lan> <19816559.O6O5RjzKM1@vostro.rjw.lan> Mime-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Return-path: Received: from www.linutronix.de ([62.245.132.108]:41807 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750876AbaHANnZ (ORCPT ); Fri, 1 Aug 2014 09:43:25 -0400 In-Reply-To: <19816559.O6O5RjzKM1@vostro.rjw.lan> Sender: linux-pm-owner@vger.kernel.org List-Id: linux-pm@vger.kernel.org To: "Rafael J. Wysocki" Cc: Peter Zijlstra , linux-kernel@vger.kernel.org, Linux PM list , Dmitry Torokhov On Fri, 1 Aug 2014, Rafael J. Wysocki wrote: > OK, I guess "IRQ_HANDLED from a wakeup interrupt" may be interpreted as > IRQ_HANDLED_PMWAKE. On the other hand, if that's going to be handled in > handle_irq_event_percpu(), then using a special return code would save us > a brach for IRQ_HANDLED interrupts. We could convert it to IRQ_HANDLED > immediately then. We can handle it at the end of the function by calling note_interrupt() unconditionally do the following there: if (suspended) { if (ret == IRQ_NONE) { if (shared) yell_and_abort_or_resume(); } else { abort_or_resume(); } } if (noirqdebug) return; > OK, I'll take a stab at the IRQF_SHARED thing if you don't mind. Definitely not :) > Here's my current understanding of what can be done for IRQF_NO_SUSPEND. > > In suspend_device_irqs(): > > (1) If all actions in the list have the same setting (eg. IRQF_NO_SUSPEND unset), > keep the current behavior. > (2) If the actions have different settings: > - Actions with IRQF_NO_SUSPEND set are not modified. > - Actions with IRQF_NO_SUSPEND unset are switched over to a stub handler. > - IRQS_SUSPEND_MODE (new flag) is set for the IRQ. Can we please do that in setup_irq() and let the shared ones always run through the stub? That keeps suspend/resume_device_irqs() simple. Thanks, tglx