[PATCH 2/3] PCI: dwc: qcom: Set suspend_poweroff flag for SC7280
Bjorn Helgaas
helgaas at kernel.org
Wed May 18 09:50:17 PDT 2022
On Wed, May 18, 2022 at 09:22:11AM +0530, Manivannan Sadhasivam wrote:
> On Tue, May 17, 2022 at 12:18:57PM -0500, Bjorn Helgaas wrote:
> > [+cc Prasad, Andy, Rob, Krzysztof, Rajat, Saheed, Rama, Stephen,
> > Dmitry, Kalle for connection to https://lore.kernel.org/lkml/CAE-0n53ho2DX2rqQMvvKAuDCfsWW62TceTaNPzv5Mn_NQ-U6dA@mail.gmail.com/T/]
> >
> > Subject line convention for this file is "PCI: qcom:" (not "PCI: dwc:
> > qcom:").
> >
> > Find this from "git log --oneline drivers/pci/controller/dwc/pcie-qcom.c".
> >
> > On Tue, May 17, 2022 at 08:41:34PM +0530, Manivannan Sadhasivam wrote:
> > > On Mon, May 16, 2022 at 03:19:50PM -0500, Bjorn Helgaas wrote:
> > > > On Fri, May 13, 2022 at 04:30:26PM +0530, Manivannan Sadhasivam wrote:
> > > > > For aggressive power saving on SC7280 SoCs, the power for the
> > > > > PCI devices will be taken off during system suspend. Hence,
> > > > > notify the same to the PCI device drivers using
> > > > > "suspend_poweroff" flag so that the drivers can prepare the PCI
> > > > > devices to handle the poweroff and recover them during resume.
> > > >
> > > > No doubt "power ... will be taken off during system suspend" is
> > > > true, but this isn't very informative. Is this a property of
> > > > SC7280? A choice made by the SC7280 driver? Why is this not
> > > > applicable to other systems?
> > >
> > > The SC7280's RPMh firmware is cutting off the PCIe power domain
> > > during system suspend. And as I explained in previous patch, the RC
> > > driver itself may put the devices in D3cold conditionally on this
> > > platform. The reason is to save power as this chipset is being used
> > > in Chromebooks.
> >
> > It looks like this should be squashed into the patch you mentioned:
> > https://lore.kernel.org/lkml/CAE-0n53ho2DX2rqQMvvKAuDCfsWW62TceTaNPzv5Mn_NQ-U6dA@mail.gmail.com/T/
> >
> > If Prasad's patch is applied without this, devices will be powered
> > off, but nvme will not be prepared for it. Apparently something would
> > be broken in that case?
> >
>
> Yes, but Prasad's patch is not yet reviewed so likely not get merged until
> further respins.
Ok. Please work with Prasad to squash these as needed so there are no
regressions along the way.
> > Also, I think this patch should be reordered so the nvme driver is
> > prepared for suspend_poweroff before the qcom driver starts setting
> > it. Otherwise there's a window where qcom sets suspend_poweroff and
> > powers off devices, but nvme doesn't know about it, and I assume
> > something will be broken in that case?
>
> As per my understanding, patches in a series should not have build dependency
> but they may depend on each other for functionality.
Yes. But if qcom starts powering off devices when nvme isn't
expecting it, it sounds like nvme will regress until the patch that
adds nvme support. That temporary regression is what I want to avoid.
Bjorn
More information about the Linux-nvme
mailing list