From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756570AbbFPNLf (ORCPT ); Tue, 16 Jun 2015 09:11:35 -0400 Received: from foss.arm.com ([217.140.101.70]:36922 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756544AbbFPNLe (ORCPT ); Tue, 16 Jun 2015 09:11:34 -0400 Message-ID: <55802081.8050200@arm.com> Date: Tue, 16 Jun 2015 14:11:29 +0100 From: Sudeep Holla User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.7.0 MIME-Version: 1.0 To: Tomasz Figa , Javier Martinez Canillas CC: Sudeep Holla , Doug Anderson , Krzysztof Kozlowski , "linux-samsung-soc@vger.kernel.org" , Jason Cooper , Chanho Park , "linux-kernel@vger.kernel.org" , Kukjin Kim , Peter Chubb , Shuah Khan , Thomas Gleixner , "linux-arm-kernel@lists.infradead.org" Subject: Re: [PATCH v2 1/1] irqchip: exynos-combiner: Save IRQ enable set on suspend References: <1434087795-13990-1-git-send-email-javier.martinez@collabora.co.uk> <557AB00C.5040606@arm.com> <557AC23D.8040602@collabora.co.uk> <557AC85E.5070705@arm.com> <557AD728.7090908@collabora.co.uk> <557B34A7.4090507@collabora.co.uk> <557E82BC.7080203@collabora.co.uk> <557E947B.3030804@arm.com> <557EE890.2050001@collabora.co.uk> In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 16/06/15 13:32, Tomasz Figa wrote: > 2015-06-16 0:00 GMT+09:00 Javier Martinez Canillas : >> On 06/15/2015 11:01 AM, Sudeep Holla wrote: [...] >>> >>> Agreed. But I would suggest also to add MASK_ON_SUSPEND and >>> set_irq_wake also and then you can restore iff it's non-zero as >>> irq core will take care of most of the non-wakeup sources. >>> Because I am planning to push >> >> I've looking at this and a problem I found is that IIUC the >> set_irq_wake is not propagated from the the Exynos pinctrl / GPIO >> driver which is the combiner's external interrupt source so the >> callback is never called. Which means that right now only the >> state of the wakeup source IRQs can't be saved since that >> information is not present. >> >> The drivers/pinctrl/samsung/pinctrl-exynos.c driver enables and >> disables the combiner interrupts but its .irq_set_wake handler >> only updates the wakeup source mask for the external interrupts but >> does not call the combiner .set_irq_wake so that should be changed >> as well. >> > > As far as I'm aware of, wake-up events from pin controllers don't go > through GIC, but rather directly to PMU, which is a dedicated unit > responsible for power management and not a standalone interrupt > controller (well actually I saw a series making it a cascaded > controller some time ago, but I'm not sure if that went in). Based on > this, I don't think we have to call set_irq_wake on GIC. Correct me > if I'm wrong, though. Thanks for the details, this was my assumption when Doug confirmed that the combiner is also powered down, either there must be some bypass or a dedicated logic to wakeup. But I was not sure though so insisted set_irq_wake but based on what you say it's not required. Regards, Sudeep From mboxrd@z Thu Jan 1 00:00:00 1970 From: sudeep.holla@arm.com (Sudeep Holla) Date: Tue, 16 Jun 2015 14:11:29 +0100 Subject: [PATCH v2 1/1] irqchip: exynos-combiner: Save IRQ enable set on suspend In-Reply-To: References: <1434087795-13990-1-git-send-email-javier.martinez@collabora.co.uk> <557AB00C.5040606@arm.com> <557AC23D.8040602@collabora.co.uk> <557AC85E.5070705@arm.com> <557AD728.7090908@collabora.co.uk> <557B34A7.4090507@collabora.co.uk> <557E82BC.7080203@collabora.co.uk> <557E947B.3030804@arm.com> <557EE890.2050001@collabora.co.uk> Message-ID: <55802081.8050200@arm.com> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On 16/06/15 13:32, Tomasz Figa wrote: > 2015-06-16 0:00 GMT+09:00 Javier Martinez Canillas : >> On 06/15/2015 11:01 AM, Sudeep Holla wrote: [...] >>> >>> Agreed. But I would suggest also to add MASK_ON_SUSPEND and >>> set_irq_wake also and then you can restore iff it's non-zero as >>> irq core will take care of most of the non-wakeup sources. >>> Because I am planning to push >> >> I've looking at this and a problem I found is that IIUC the >> set_irq_wake is not propagated from the the Exynos pinctrl / GPIO >> driver which is the combiner's external interrupt source so the >> callback is never called. Which means that right now only the >> state of the wakeup source IRQs can't be saved since that >> information is not present. >> >> The drivers/pinctrl/samsung/pinctrl-exynos.c driver enables and >> disables the combiner interrupts but its .irq_set_wake handler >> only updates the wakeup source mask for the external interrupts but >> does not call the combiner .set_irq_wake so that should be changed >> as well. >> > > As far as I'm aware of, wake-up events from pin controllers don't go > through GIC, but rather directly to PMU, which is a dedicated unit > responsible for power management and not a standalone interrupt > controller (well actually I saw a series making it a cascaded > controller some time ago, but I'm not sure if that went in). Based on > this, I don't think we have to call set_irq_wake on GIC. Correct me > if I'm wrong, though. Thanks for the details, this was my assumption when Doug confirmed that the combiner is also powered down, either there must be some bypass or a dedicated logic to wakeup. But I was not sure though so insisted set_irq_wake but based on what you say it's not required. Regards, Sudeep