From mboxrd@z Thu Jan 1 00:00:00 1970 From: Nishanth Menon Subject: Re: [PATCHv3 8/9] ARM: OMAP2+: AM33XX: Basic suspend resume support Date: Thu, 8 Aug 2013 16:32:23 -0500 Message-ID: <52040E67.4050402@ti.com> References: <1375811376-49985-1-git-send-email-d-gerlach@ti.com> <1375811376-49985-9-git-send-email-d-gerlach@ti.com> <52038E88.2050604@ti.com> <5203B336.90102@ti.com> <5203C211.7040207@ti.com> <87iozfga1t.fsf@kernel.org> Mime-Version: 1.0 Content-Type: text/plain; charset="ISO-8859-1"; format=flowed Content-Transfer-Encoding: 7bit Return-path: Received: from comal.ext.ti.com ([198.47.26.152]:58022 "EHLO comal.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S966702Ab3HHVct (ORCPT ); Thu, 8 Aug 2013 17:32:49 -0400 In-Reply-To: <87iozfga1t.fsf@kernel.org> Sender: linux-omap-owner@vger.kernel.org List-Id: linux-omap@vger.kernel.org To: Kevin Hilman Cc: Dave Gerlach , Santosh Shilimkar , Russ Dill , linux-arm-kernel@lists.infradead.org, linux-omap@vger.kernel.org, Paul Walmsley , Vaibhav Bedia , Tony Lingren , Benoit Cousson On 08/08/2013 04:14 PM, Kevin Hilman wrote: > Dave Gerlach writes: > >> On 08/08/2013 10:03 AM, Santosh Shilimkar wrote: >>> $subject and patch don't match. >>> >>> On Thursday 08 August 2013 08:26 AM, Nishanth Menon wrote: >>>> On 08/08/2013 03:45 AM, Russ Dill wrote: >>>>> In reference to >>>>> the M3 handling it, the M3 wouldn't know which devices have a driver >>>>> bound and which don't. >>>> Does it need to? M3 firmware can pretty much define "I will force >>>> the device into low power state, and if the drivers dont handle >>>> things properly, fix the darned driver". M3 behavior should be >>>> considered as a "hardware" as far as Linux running on MPU is >>>> concerned, and firmware helps change the behavior by accounting for >>>> SoC quirks. *if* we have ability to handle this in the firmware, >>>> there is no need to carry this in Linux. >>>> >>> I agree with Nishant. I don't like this patch and IIRC, I gave same >>> comment in the last version. Linux need not know about all such firmware >>> quirks. Also all these M3 specific stuff, should be done somewhere >>> else. Probably having a small M3 driver won't be a bad idea. >> >> I am not opposed to doing it this way and letting the M3 firmware >> handle idling these modules, however the one concern raised in the >> last series is that an approach that does not acknowledge drivers will >> hide driver PM bugs. I suppose as long as I make sure to document that >> the devices are being idled by the M3 firmware this may not be an >> issue. I will look into implementing this. > > No, please don't start idling devices in firmware that are otherwise > managed by Linux. Keep the firmware simple and dumb. Linux is managing > these devices, it should manage their bugs too. > > This is not just about idling devices. This is about handling broken IP > blocks whose power-on reset state does not allow the the powerdomain to > reach its target state. That's just bad hardware design. Right, this is where M3 can help -> provide a consistent state for linux kernel to work with. by the fact that we want to keep majority of the power code inside master CPU, we are just letting M3 help us with nothing major at all.. tiny stuff like these can help "fix" the hardware design quirks by hiding it behind the firmware and modifying the hardware behavior. I know it breaks the purity of role, but as the next evolution, we might want to consider M3 something like an "accelerator" for power management activity.. (not saying it is that fast.. but conceptually). > > That being said, IMO, the kernel (specifically omap_device) should > handle this, and it should be rather easy to do in the omap_device layer > and keep the SoC suspend/resume core code simple and ignorant of these > "quirks." > > AFAICT, there's no reason these quirks need to be dealt with immediatly > on suspend. A slight delay should be fine, as long as it's before the > next suspend/idle attempt, right? > > Given that, what we need to do (and by we, I mean you) is to flag all > broken IP blocks, and let omap_device handle them in a suspend/resume > notifier (c.f. register_pm_notifier() and PM_POST_SUSPEND.) yes - that is the alternate that comes to mind. -- Regards, Nishanth Menon From mboxrd@z Thu Jan 1 00:00:00 1970 From: nm@ti.com (Nishanth Menon) Date: Thu, 8 Aug 2013 16:32:23 -0500 Subject: [PATCHv3 8/9] ARM: OMAP2+: AM33XX: Basic suspend resume support In-Reply-To: <87iozfga1t.fsf@kernel.org> References: <1375811376-49985-1-git-send-email-d-gerlach@ti.com> <1375811376-49985-9-git-send-email-d-gerlach@ti.com> <52038E88.2050604@ti.com> <5203B336.90102@ti.com> <5203C211.7040207@ti.com> <87iozfga1t.fsf@kernel.org> Message-ID: <52040E67.4050402@ti.com> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On 08/08/2013 04:14 PM, Kevin Hilman wrote: > Dave Gerlach writes: > >> On 08/08/2013 10:03 AM, Santosh Shilimkar wrote: >>> $subject and patch don't match. >>> >>> On Thursday 08 August 2013 08:26 AM, Nishanth Menon wrote: >>>> On 08/08/2013 03:45 AM, Russ Dill wrote: >>>>> In reference to >>>>> the M3 handling it, the M3 wouldn't know which devices have a driver >>>>> bound and which don't. >>>> Does it need to? M3 firmware can pretty much define "I will force >>>> the device into low power state, and if the drivers dont handle >>>> things properly, fix the darned driver". M3 behavior should be >>>> considered as a "hardware" as far as Linux running on MPU is >>>> concerned, and firmware helps change the behavior by accounting for >>>> SoC quirks. *if* we have ability to handle this in the firmware, >>>> there is no need to carry this in Linux. >>>> >>> I agree with Nishant. I don't like this patch and IIRC, I gave same >>> comment in the last version. Linux need not know about all such firmware >>> quirks. Also all these M3 specific stuff, should be done somewhere >>> else. Probably having a small M3 driver won't be a bad idea. >> >> I am not opposed to doing it this way and letting the M3 firmware >> handle idling these modules, however the one concern raised in the >> last series is that an approach that does not acknowledge drivers will >> hide driver PM bugs. I suppose as long as I make sure to document that >> the devices are being idled by the M3 firmware this may not be an >> issue. I will look into implementing this. > > No, please don't start idling devices in firmware that are otherwise > managed by Linux. Keep the firmware simple and dumb. Linux is managing > these devices, it should manage their bugs too. > > This is not just about idling devices. This is about handling broken IP > blocks whose power-on reset state does not allow the the powerdomain to > reach its target state. That's just bad hardware design. Right, this is where M3 can help -> provide a consistent state for linux kernel to work with. by the fact that we want to keep majority of the power code inside master CPU, we are just letting M3 help us with nothing major at all.. tiny stuff like these can help "fix" the hardware design quirks by hiding it behind the firmware and modifying the hardware behavior. I know it breaks the purity of role, but as the next evolution, we might want to consider M3 something like an "accelerator" for power management activity.. (not saying it is that fast.. but conceptually). > > That being said, IMO, the kernel (specifically omap_device) should > handle this, and it should be rather easy to do in the omap_device layer > and keep the SoC suspend/resume core code simple and ignorant of these > "quirks." > > AFAICT, there's no reason these quirks need to be dealt with immediatly > on suspend. A slight delay should be fine, as long as it's before the > next suspend/idle attempt, right? > > Given that, what we need to do (and by we, I mean you) is to flag all > broken IP blocks, and let omap_device handle them in a suspend/resume > notifier (c.f. register_pm_notifier() and PM_POST_SUSPEND.) yes - that is the alternate that comes to mind. -- Regards, Nishanth Menon