Re: [PATCH V1] PCI/ASPM: Save/restore L1SS Capability for suspend/resume

From: Vidya Sagar
Date: Tue Feb 01 2022 - 14:25:03 EST


Hi Kenneth,
Thanks for sharing the files.
BTW, I see that the ASPM L1SS capability is supported by only two endpoints viz. KIOXIA's NVMe drive and Realtek's Card reader. None of the root ports seem to have the support. So, I'm wondering how was it even getting enabled in the first place earlier?
(OR)
was it the case that L1SS sub-states were never enabled earlier also and the issue was occurring without having ASPM L1SS enabled? (but with only L0s and L1 enabled??)

Also, I see that from 'before' and 'after' logs that for both NVMe and Card reader and their corresponding root ports, none of the ASPM states are enabled (not even L0s or L1).
Did you set the policy to 'powersupersave' before hibernating the system?

On 2/2/2022 12:23 AM, Kenneth R. Crudup wrote:
External email: Use caution opening links or attachments


On Tue, 1 Feb 2022, Vidya Sagar wrote:

Kenneth R. Crudup <kenny@xxxxxxxxx>
Could you please try this patch on top of linux-next and collect more info?
- 'sudo lspci -vvvv' output before and after hibernation

See attached. Added a diff file, too.

- could you please confirm the working of this patch for non NVMe devices that
support L1 Sub-States?

It seems to work, I'm on it now. I saw a "GPU Hang" from the i915 driver, but
it doesn't seem to be affecting the GPU any.

- Could you please try "NVME_QUIRK_NO_DEEPEST_PS" and "NVME_QUIRK_SIMPLE_SUSPEND"
quirks (one at a time) in check_vendor_combination_bug() API and see if it
makes any difference?

Do you still need me to do that, since this appears to work?

I will try another hibernate attempt just to be sure, too.

-Kenny

--
Kenneth R. Crudup / Sr. SW Engineer, Scott County Consulting, Orange County CA