[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <Z88rtGH39C-S8phk@ryzen>
Date: Mon, 10 Mar 2025 19:13:08 +0100
From: Niklas Cassel <cassel@...nel.org>
To: Hans de Goede <hdegoede@...hat.com>
Cc: Eric <eric.4.debian@...batoulnz.fr>,
Salvatore Bonaccorso <carnil@...ian.org>,
Mario Limonciello <mario.limonciello@....com>,
Christoph Hellwig <hch@...radead.org>,
Mika Westerberg <mika.westerberg@...ux.intel.com>,
Damien Le Moal <dlemoal@...nel.org>,
Jian-Hong Pan <jhp@...lessos.org>, regressions@...ts.linux.dev,
linux-kernel@...r.kernel.org, stable@...r.kernel.org,
linux-ide@...r.kernel.org,
Dieter Mummenschanz <dmummenschanz@....de>
Subject: Re: Regression from 7627a0edef54 ("ata: ahci: Drop low power policy
board type") on reboot (but not cold boot)
Hello Hans,
On Mon, Mar 10, 2025 at 10:34:13AM +0100, Hans de Goede wrote:
>
> I think that the port-mask register is only read-only from an OS pov,
> the BIOS/UEFI/firmware can likely set it to e.g. exclude ports which are
> not enabled on the motherboard (e.g. an M2 slot which can do both pci-e +
> ata and is used in pci-e mode, so the sata port on that slot should be
> ignored).
>
> What we seem to be hitting here is a bug where the UEFI can not detect
> the SATA SSD after reboot if it ALPM was used by the OS before reboot and
> the UEFI's SATA driver responds to the not detecting by clearing the bit
> in the port-mask register.
>
> The UEFI not detecting the disk after reboot when ALPM was in use also
> matches with not being able to boot from the disk after reboot.
If we look at dmesg:
ahci 0000:00:11.0: AHCI vers 0001.0200, 32 command slots, 6 Gbps, SATA mode
ahci 0000:00:11.0: 3/3 ports implemented (port mask 0x38)
ahci 0000:00:11.0: flags: 64bit ncq sntf ilck pm led clo pmp pio slum part
We can see that the controller supports slumber, partial,
and aggressive link power management ("pm").
A COMRESET is supposed to take the device out of partial or slumber.
Now, we do not know if the BIOS code sends a COMRESET, but it definitely
should.
Anyway, it is stated in AHCI 1.3.1 "10.1 Software Initialization of HBA",
"To aid system software during runtime, the BIOS shall ensure that the
following registers are initialized to values that are reflective of the
capabilities supported by the platform."
"-PI (ports implemented)"
>
> I think what would be worth a try would be to disable ALPM on reboot
> from a driver shutdown hook. IIRC the ALPM level can be changed at runtime
> from a sysfs file, so we should be able to do the same at shutdown ?
>
> Its been a while since I last touched the AHCI code, so I hope someone else
> can write a proof of concept patch with the shutdown handler disabling ALPM
> on reboot ?
I mean, that would be a quirk, and if such a quirk is created, it should
only be applied for buggy BIOS versions.
(Since BIOS is supposed to initialize the PI register properly.)
If
ahci.mobile_lpm_policy=1
or
ahci.mobile_lpm_policy=2
works around your buggy BIOS, then I suggest you keep that
until your BIOS vendor manages to release a new BIOS version.
Kind regards,
Niklas
Powered by blists - more mailing lists