From: Bjorn Helgaas <helgaas@kernel.org>
To: Chen-Yu Tsai <wenst@chromium.org>
Cc: Bartosz Golaszewski <brgl@kernel.org>,
Manivannan Sadhasivam <mani@kernel.org>,
Bjorn Helgaas <bhelgaas@google.com>,
linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org,
Manivannan Sadhasivam <manivannan.sadhasivam@oss.qualcomm.com>,
Bartosz Golaszewski <bartosz.golaszewski@oss.qualcomm.com>
Subject: Re: [PATCH v2] PCI/pwrctrl: Do not power off on pwrctrl device removal
Date: Mon, 23 Mar 2026 11:28:10 -0500 [thread overview]
Message-ID: <20260323162810.GA826479@bhelgaas> (raw)
In-Reply-To: <20260226092234.3859740-1-wenst@chromium.org>
On Thu, Feb 26, 2026 at 05:22:33PM +0800, Chen-Yu Tsai wrote:
> With the move to explicit pwrctrl power on/off APIs, the caller, i.e.
> the PCI driver should manage the power state. The pwrctrl drivers should
> not try to clean up or power off when they are removed, as this might
> end up disabling an already disabled regulator, causing a big warning.
> This can be triggered if a PCI controller driver's .remove() callback
> calls pci_pwrctrl_destroy_devices() after pci_pwrctrl_power_off_devices().
>
> Drop the devm cleanup parts that turn off regulators from the pwrctrl
> drivers.
>
> Fixes: b921aa3f8dec ("PCI/pwrctrl: Switch to pwrctrl create, power on/off, destroy APIs")
> Cc: Manivannan Sadhasivam <manivannan.sadhasivam@oss.qualcomm.com>
> Signed-off-by: Chen-Yu Tsai <wenst@chromium.org>
> Reviewed-by: Bartosz Golaszewski <bartosz.golaszewski@oss.qualcomm.com>
Applied to pci/for-linus for v7.0, thanks!
> ---
> Changes since v1:
> - Keep the release function for the PCI slot driver to free the
> regulators
>
> I ran into this while integrating the new pci_pwrctrl_*() API into the
> MediaTek driver. I am sending this separately since this change is
> unrelated and does not conflict with or depend on the other changes for
> the driver itself.
>
> I think this should be merged for fixes.
>
> ---
> drivers/pci/pwrctrl/pci-pwrctrl-pwrseq.c | 12 ------------
> drivers/pci/pwrctrl/slot.c | 1 -
> 2 files changed, 13 deletions(-)
>
> diff --git a/drivers/pci/pwrctrl/pci-pwrctrl-pwrseq.c b/drivers/pci/pwrctrl/pci-pwrctrl-pwrseq.c
> index 0d0377283c37..c7e4beec160a 100644
> --- a/drivers/pci/pwrctrl/pci-pwrctrl-pwrseq.c
> +++ b/drivers/pci/pwrctrl/pci-pwrctrl-pwrseq.c
> @@ -68,13 +68,6 @@ static int pwrseq_pwrctrl_power_off(struct pci_pwrctrl *pwrctrl)
> return pwrseq_power_off(pwrseq->pwrseq);
> }
>
> -static void devm_pwrseq_pwrctrl_power_off(void *data)
> -{
> - struct pwrseq_pwrctrl *pwrseq = data;
> -
> - pwrseq_pwrctrl_power_off(&pwrseq->pwrctrl);
> -}
> -
> static int pwrseq_pwrctrl_probe(struct platform_device *pdev)
> {
> const struct pwrseq_pwrctrl_pdata *pdata;
> @@ -101,11 +94,6 @@ static int pwrseq_pwrctrl_probe(struct platform_device *pdev)
> return dev_err_probe(dev, PTR_ERR(pwrseq->pwrseq),
> "Failed to get the power sequencer\n");
>
> - ret = devm_add_action_or_reset(dev, devm_pwrseq_pwrctrl_power_off,
> - pwrseq);
> - if (ret)
> - return ret;
> -
> pwrseq->pwrctrl.power_on = pwrseq_pwrctrl_power_on;
> pwrseq->pwrctrl.power_off = pwrseq_pwrctrl_power_off;
>
> diff --git a/drivers/pci/pwrctrl/slot.c b/drivers/pci/pwrctrl/slot.c
> index 082af81efe25..b87639253ae2 100644
> --- a/drivers/pci/pwrctrl/slot.c
> +++ b/drivers/pci/pwrctrl/slot.c
> @@ -63,7 +63,6 @@ static void devm_slot_pwrctrl_release(void *data)
> {
> struct slot_pwrctrl *slot = data;
>
> - slot_pwrctrl_power_off(&slot->pwrctrl);
> regulator_bulk_free(slot->num_supplies, slot->supplies);
> }
>
> --
> 2.53.0.414.gf7e9f6c205-goog
>
prev parent reply other threads:[~2026-03-23 16:28 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-02-26 9:22 [PATCH v2] PCI/pwrctrl: Do not power off on pwrctrl device removal Chen-Yu Tsai
2026-02-26 9:30 ` Manivannan Sadhasivam
2026-03-23 11:41 ` Chen-Yu Tsai
2026-03-23 11:44 ` Manivannan Sadhasivam
2026-03-23 16:28 ` Bjorn Helgaas [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260323162810.GA826479@bhelgaas \
--to=helgaas@kernel.org \
--cc=bartosz.golaszewski@oss.qualcomm.com \
--cc=bhelgaas@google.com \
--cc=brgl@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=mani@kernel.org \
--cc=manivannan.sadhasivam@oss.qualcomm.com \
--cc=wenst@chromium.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox