Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp792482pxb; Thu, 21 Oct 2021 09:33:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy5CDTRReFGJaCeoN7qzyAdOL2sfReUVWX4LD1Edqsa9osff0zX9SvW8+op1B/aYgKUy3EV X-Received: by 2002:a17:906:7632:: with SMTP id c18mr9004862ejn.317.1634833984017; Thu, 21 Oct 2021 09:33:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634833984; cv=none; d=google.com; s=arc-20160816; b=GDeh/cMxxypO3N5SJFidroiAXh9jCkCUqh4MF/tExoONaFLxhF+mkv/G2w1bT1VhGn afkpvVYLXAmpKd/5ZBs59wKuCZufzv948C/rwkEv7hEvGjICLBGzVa9R8gX0H09Q/5kx 3DCy0DIv7F8ZbNlGMe0ZF8GpSdz/VckAp1IfC8t1HYdtgWDT5u6xAt9+30exHqkhm/lu P16euRKq+ldh0Fp9Y57mINCeNVI+c0Gs8TbUNFnlWgcXCALxnCWC73Ngs6AYI0vamowq l0Ph03iCm2shYy8nFdxoTWXkOUdnfyRHO9QR3ELdW+kSuK4SjxuF5PD8O6jQ/VEAfvUS 4CbA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=K0XMSCW4PJfqgy5xuR5tYu4lQjQEVh+6j+EzWLXQKoM=; b=CUVyAj99OBnAc6pcDJ6gAM4iGkZjLPpuL29nxzEqIEND/edicw3e5gzzmktK7/1KPR 6AoBk4KkjbyftJXMol+lAy9eO4x3/Cfh4c/4zBG5ViyooXfPSVVWcIDOhHSNXRFvFUn1 RScekCX6WLOYkISsPBCkwjFaVZlNBxcjeEFK0RElaWPvdfakBQtxRtc3ZyA3Y2Ib7WZg Rk1l38uT/0vSy83BZxjeubetfcv2g6C23o9NC8nip4uGrZqi/1jb3NW3dy8jeNRZ1DED VR2Ma20H+m6icmehMJRBJvrcESayFEu1sA++LdHjf4+MYPOw5w8l6O+jqW8S+3pP6vcg CJ8g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=HpS1VmHK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id sb15si9300443ejc.427.2021.10.21.09.32.39; Thu, 21 Oct 2021 09:33:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=HpS1VmHK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231489AbhJUQbu (ORCPT + 99 others); Thu, 21 Oct 2021 12:31:50 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39922 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231853AbhJUQbt (ORCPT ); Thu, 21 Oct 2021 12:31:49 -0400 Received: from mail-lj1-x22b.google.com (mail-lj1-x22b.google.com [IPv6:2a00:1450:4864:20::22b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 485E0C0613B9 for ; Thu, 21 Oct 2021 09:29:33 -0700 (PDT) Received: by mail-lj1-x22b.google.com with SMTP id w23so863325lje.7 for ; Thu, 21 Oct 2021 09:29:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=K0XMSCW4PJfqgy5xuR5tYu4lQjQEVh+6j+EzWLXQKoM=; b=HpS1VmHK4Z+mJXCOqPDXVxVggN8ickgTs7tYxswzjYu5O1B99oUajaKO+YjXVppv2u HPilm7++yMOo29RMWBUJSKelJzwkTSC1Qdn6ihbtWJxaQn7YIH5YvPKUAIcc3ZeT9LGI 6B1nd3B74jmHlApM00NrsAIyYDuGq167TLhNRWDdxJSXvYLKO3oaVx57cIWYO4quWbvX qkzpUSGSQ7hFYKRXziNUk7xHoKBh2HXBTwizx+aSYaJ7GU3HanMvEkMWnihW0xvh3W3a iPQZTKm6+nZc1h92XmgmO2f7JhnAAFsebcir151Hi0HVPwS9xbW7ek44sHqU8ss1uV1p iEhg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=K0XMSCW4PJfqgy5xuR5tYu4lQjQEVh+6j+EzWLXQKoM=; b=vQMmLN6ES+h5dFPXsl4EFYg8MM0F4N+nFZSI7KVMUbiS8977IdB0uP+MOOvr/+29O4 qyfD6OPXCG8rY/eOmGvHKT7wpGfzHcFjRbE0euJVp4blJQq8xcrv/swI9oF1TcNeXrWU tJs6JMUiRs/zHq6qvn2kZtTIpPcO9D95z0gDxePpna87gRZPM2DtV3FclvM4dOm2ri9C 8kQy2AA+V7NBfYIUri4Nzcu9Q7zdSh9x4ZtoWYHDItP48JffXMG6mX6tARx4aC5G9+JU deLlFDGV9x+1EJIj5b/PtH1dTfyyBjjxb6T3KewB8tNVocW6dUS2TY7nHX9hN9w8akSb d5tA== X-Gm-Message-State: AOAM532MP17Wj4ESVvxy6pHHPRXf/i/KWgWmTcOM+mywob5O92sX3n4y /W2fwl65F6xaEU/d8Wk+H9+uTM4ZNhkekL1dYggjeg== X-Received: by 2002:a05:651c:907:: with SMTP id e7mr3714592ljq.300.1634833771594; Thu, 21 Oct 2021 09:29:31 -0700 (PDT) MIME-Version: 1.0 References: <20210929144451.113334-1-ulf.hansson@linaro.org> <20210929144451.113334-3-ulf.hansson@linaro.org> In-Reply-To: From: Ulf Hansson Date: Thu, 21 Oct 2021 18:28:54 +0200 Message-ID: Subject: Re: [PATCH 2/2] PM: sleep: Fix runtime PM based cpuidle support To: "Rafael J. Wysocki" Cc: Daniel Lezcano , Linux PM , Maulik Shah , Peter Zijlstra , Vincent Guittot , Len Brown , Bjorn Andersson , Linux ARM , Linux Kernel Mailing List Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 21 Oct 2021 at 17:46, Rafael J. Wysocki wrote: > > On Thu, Oct 21, 2021 at 5:09 PM Rafael J. Wysocki wrote: > > > > On Thu, Oct 21, 2021 at 4:05 PM Ulf Hansson wrote: > > > > > > On Thu, 21 Oct 2021 at 15:45, Rafael J. Wysocki wrote: > > > > > > > > On Thu, Oct 21, 2021 at 1:49 PM Ulf Hansson wrote: > > > > > > > > > > On Wed, 20 Oct 2021 at 20:18, Rafael J. Wysocki wrote: > > > > > > > > > > > > On Wed, Sep 29, 2021 at 4:44 PM Ulf Hansson wrote: > > > > > > > > > > > > > > In the cpuidle-psci case, runtime PM in combination with the generic PM > > > > > > > domain (genpd), may be used when entering/exiting an idlestate. More > > > > > > > precisely, genpd relies on runtime PM to be enabled for the attached device > > > > > > > (in this case it belongs to a CPU), to properly manage the reference > > > > > > > counting of its PM domain. > > > > > > > > > > > > > > This works fine most of the time, but during system suspend in the > > > > > > > dpm_suspend_late() phase, the PM core disables runtime PM for all devices. > > > > > > > Beyond this point and until runtime PM becomes re-enabled in the > > > > > > > dpm_resume_early() phase, calls to pm_runtime_get|put*() will fail. > > > > > > > > > > > > > > To make sure the reference counting in genpd becomes correct, we need to > > > > > > > prevent cpuidle-psci from using runtime PM when it has been disabled for > > > > > > > the device. Therefore, let's move the call to cpuidle_pause() from > > > > > > > dpm_suspend_noirq() to dpm_suspend_late() - and cpuidle_resume() from > > > > > > > dpm_resume_noirq() into dpm_resume_early(). > > > > > > > > > > > > > > Diagnosed-by: Maulik Shah > > > > > > > Suggested-by: Maulik Shah > > > > > > > Signed-off-by: Ulf Hansson > > > > > > > --- > > > > > > > drivers/base/power/main.c | 6 ++---- > > > > > > > 1 file changed, 2 insertions(+), 4 deletions(-) > > > > > > > > > > > > > > diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c > > > > > > > index cbea78e79f3d..1c753b651272 100644 > > > > > > > --- a/drivers/base/power/main.c > > > > > > > +++ b/drivers/base/power/main.c > > > > > > > @@ -747,8 +747,6 @@ void dpm_resume_noirq(pm_message_t state) > > > > > > > > > > > > > > resume_device_irqs(); > > > > > > > device_wakeup_disarm_wake_irqs(); > > > > > > > - > > > > > > > - cpuidle_resume(); > > > > > > > } > > > > > > > > > > > > > > /** > > > > > > > @@ -870,6 +868,7 @@ void dpm_resume_early(pm_message_t state) > > > > > > > } > > > > > > > mutex_unlock(&dpm_list_mtx); > > > > > > > async_synchronize_full(); > > > > > > > + cpuidle_resume(); > > > > > > > dpm_show_time(starttime, state, 0, "early"); > > > > > > > trace_suspend_resume(TPS("dpm_resume_early"), state.event, false); > > > > > > > } > > > > > > > @@ -1336,8 +1335,6 @@ int dpm_suspend_noirq(pm_message_t state) > > > > > > > { > > > > > > > int ret; > > > > > > > > > > > > > > - cpuidle_pause(); > > > > > > > - > > > > > > > device_wakeup_arm_wake_irqs(); > > > > > > > suspend_device_irqs(); > > > > > > > > > > > > > > @@ -1467,6 +1464,7 @@ int dpm_suspend_late(pm_message_t state) > > > > > > > int error = 0; > > > > > > > > > > > > > > trace_suspend_resume(TPS("dpm_suspend_late"), state.event, true); > > > > > > > + cpuidle_pause(); > > > > > > > mutex_lock(&dpm_list_mtx); > > > > > > > pm_transition = state; > > > > > > > async_error = 0; > > > > > > > -- > > > > > > > > > > > > Well, this is somewhat heavy-handed and it affects even the systems > > > > > > that don't really need to pause cpuidle at all in the suspend path. > > > > > > > > > > Yes, I agree. > > > > > > > > > > Although, I am not really changing the behaviour in regards to this. > > > > > cpuidle_pause() is already being called in dpm_suspend_noirq(), for > > > > > everybody today. > > > > > > > > Yes, it is, but pausing it earlier will cause more energy to be spent, > > > > potentially. > > > > > > > > That said, there are not too many users of suspend_late callbacks in > > > > the tree, so it may not matter too much. > > > > > > > > > > > > > > > > Also, IIUC you don't need to pause cpuidle completely, but make it > > > > > > temporarily avoid idle states potentially affected by this issue. An > > > > > > additional CPUIDLE_STATE_DISABLED_ flag could be used for that I > > > > > > suppose and it could be set via cpuidle_suspend() called from the core > > > > > > next to cpufreq_suspend(). > > > > > > > > > > cpuidle_suspend() would then need to go and fetch the cpuidle driver > > > > > instance, which in some cases is one driver per CPU. Doesn't that get > > > > > rather messy? > > > > > > > > Per-CPU variables are used for that, so it is quite straightforward. > > > > > > > > > Additionally, since find_deepest_state() is being called for > > > > > cpuidle_enter_s2idle() too, we would need to treat the new > > > > > CPUIDLE_STATE_DISABLED_ flag in a special way, right? > > > > > > > > No, it already checks "disabled". > > > > > > Yes, but that would be wrong. > > > > Hmmm. > > > > > The use case I want to support, for cpuidle-psci, is to allow all idle > > > states in suspend-to-idle, > > > > So does PM-runtime work in suspend-to-idle? How? > > > > > but prevent those that rely on runtime PM > > > (after it has been disabled) for the regular idle path. > > > > Do you have a special suspend-to-idle handling of those states that > > doesn't require PM-runtime? > > Regardless, pausing cpuidle in the suspend-to-idle path simply doesn't > make sense at all, so this needs to be taken care of in the first > place. Right, I do agree, don't get me wrong. But, do we really want to treat s2-to-idle differently, compared to s2-to-ram in regards to this? Wouldn't it be a lot easier to let cpuidle drivers to opt-out for cpuidle_pause|resume(), no matter whether it's for s2-to-idle or s2-to-ram? > > The problem with PM-runtime being unavailable after dpm_suspend() > needs to be addressed in a different way IMO, because it only affects > one specific use case. It's one specific case so far, but we have the riscv driver on its way, which would suffer from the same problem. Anyway, an option is to figure out what platforms and cpuidle drivers, that really needs cpuidle_pause|resume() at this point and make an opt-in solution instead. This could then be used by runtime PM based cpuidle drivers as well. Would that be a way forward? Kind regards Uffe