Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757470AbdLUBjX (ORCPT ); Wed, 20 Dec 2017 20:39:23 -0500 Received: from mail-ot0-f193.google.com ([74.125.82.193]:34878 "EHLO mail-ot0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1757298AbdLUBjU (ORCPT ); Wed, 20 Dec 2017 20:39:20 -0500 X-Google-Smtp-Source: ACJfBov+TFtS8NXALYs6OXKk+vxuR1XKFJXjCXP0FpfDAp6Q12VEtjgnZOGHjxDp8cV7ixbaEmgkgFK5sPr8ozkirbk= MIME-Version: 1.0 In-Reply-To: <1513778960-10073-2-git-send-email-ulf.hansson@linaro.org> References: <1513778960-10073-1-git-send-email-ulf.hansson@linaro.org> <1513778960-10073-2-git-send-email-ulf.hansson@linaro.org> From: "Rafael J. Wysocki" Date: Thu, 21 Dec 2017 02:39:19 +0100 X-Google-Sender-Auth: wsL8kVg7dnc3WMWFXHzjDLAAdHA Message-ID: Subject: Re: [PATCH v2 1/3] phy: core: Move runtime PM reference counting to the parent device To: Ulf Hansson Cc: Kishon Vijay Abraham I , Linux Kernel Mailing List , "Rafael J . Wysocki" , Linux PM , Yoshihiro Shimoda , Geert Uytterhoeven , Linux-Renesas Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1635 Lines: 35 On Wed, Dec 20, 2017 at 3:09 PM, Ulf Hansson wrote: > The runtime PM deployment in the phy core is deployed using the phy core > device, which is created by the phy core and assigned as a child device of > the phy provider device. > > The behaviour around the runtime PM deployment cause some issues during > system suspend, in cases when the phy provider device is put into a low > power state via a call to the pm_runtime_force_suspend() helper, as is the > case for a Renesas SoC, which has its phy provider device attached to the > generic PM domain. > > In more detail, the problem in this case is that pm_runtime_force_suspend() > expects the child device of the provider device, which is the phy core > device, to be runtime suspended, else a WARN splat will be printed > (correctly) when runtime PM gets re-enabled at system resume. So we are now trying to work around issues with pm_runtime_force_suspend(). Lovely. :-/ > In the current scenario, even if a call to phy_power_off() triggers it to > invoke pm_runtime_put() during system suspend, the phy core device doesn't > get runtime suspended, because this is prevented in the system suspend > phases by the PM core. > > To solve this problem, let's move the runtime PM deployment from the phy > core device to the phy provider device, as this provides the similar > behaviour. Changing this makes it redundant to enable runtime PM for the > phy core device, so let's avoid doing that. I'm not really convinced that this approach is the best one to be honest. I'll have a deeper look at this in the next few days, stay tuned. Thanks, Rafael