]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ata: ahci: Disable DIPM if host lacks support
authorDamien Le Moal <dlemoal@kernel.org>
Tue, 1 Jul 2025 12:53:17 +0000 (21:53 +0900)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 20 Aug 2025 16:40:55 +0000 (18:40 +0200)
[ Upstream commit f7870e8d345cdabfb94bcbdcba6a07e050f8705e ]

The AHCI specification version 1.3.1 section 8.3.1.4 (Software
Requirements and Precedence) states that:

If CAP.SSC or CAP.PSC is cleared to ‘0’, software should disable
device-initiated power management by issuing the appropriate SET
FEATURES command to the device.

To satisfy this constraint and force ata_dev_configure to disable the
device DIPM feature, modify ahci_update_initial_lpm_policy() to set the
ATA_FLAG_NO_DIPM flag on ports that have a host with either the
ATA_HOST_NO_PART flag set or the ATA_HOST_NO_SSC flag set.

Signed-off-by: Damien Le Moal <dlemoal@kernel.org>
Reviewed-by: Niklas Cassel <cassel@kernel.org>
Reviewed-by: Hannes Reinecke <hare@suse.de>
Reviewed-by: Hannes Reinecke <hare@suse.de.>
Link: https://lore.kernel.org/r/20250701125321.69496-7-dlemoal@kernel.org
Signed-off-by: Niklas Cassel <cassel@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/ata/ahci.c

index 04c9b601cac14e516eefa493f5ab77f2b0e4ac4f..4f69da480e8669673ca7faa0bcbad3db72ca85b0 100644 (file)
@@ -1778,6 +1778,13 @@ static void ahci_update_initial_lpm_policy(struct ata_port *ap)
                return;
        }
 
+       /* If no Partial or no Slumber, we cannot support DIPM. */
+       if ((ap->host->flags & ATA_HOST_NO_PART) ||
+           (ap->host->flags & ATA_HOST_NO_SSC)) {
+               ata_port_dbg(ap, "Host does not support DIPM\n");
+               ap->flags |= ATA_FLAG_NO_DIPM;
+       }
+
        /* If no LPM states are supported by the HBA, do not bother with LPM */
        if ((ap->host->flags & ATA_HOST_NO_PART) &&
            (ap->host->flags & ATA_HOST_NO_SSC) &&