Commit 6de7435e authored by Adrian Hunter's avatar Adrian Hunter Committed by Martin K. Petersen
Browse files

scsi: ufs: ufs-pci: Fix default runtime and system PM levels



Intel MTL-like host controllers support auto-hibernate.  Using
auto-hibernate with manual (driver initiated) hibernate produces more
complex operation.  For example, the host controller will have to exit
auto-hibernate simply to allow the driver to enter hibernate state
manually.  That is not recommended.

The default rpm_lvl and spm_lvl is 3, which includes manual hibernate.

Change the default values to 2, which does not.

Note, to be simpler to backport to stable kernels, utilize the UFS PCI
driver's ->late_init() call back.  Recent commits have made it possible
to set up a controller-specific default in the regular ->init() call
back, but not all stable kernels have those changes.

Fixes: 4049f7ac ("scsi: ufs: ufs-pci: Add support for Intel MTL")
Cc: stable@vger.kernel.org
Signed-off-by: default avatarAdrian Hunter <adrian.hunter@intel.com>
Link: https://lore.kernel.org/r/20250723165856.145750-3-adrian.hunter@intel.com


Reviewed-by: default avatarBart Van Assche <bvanassche@acm.org>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 4428ddea
Loading
Loading
Loading
Loading
+14 −1
Original line number Diff line number Diff line
@@ -468,10 +468,23 @@ static int ufs_intel_adl_init(struct ufs_hba *hba)
	return ufs_intel_common_init(hba);
}

static void ufs_intel_mtl_late_init(struct ufs_hba *hba)
{
	hba->rpm_lvl = UFS_PM_LVL_2;
	hba->spm_lvl = UFS_PM_LVL_2;
}

static int ufs_intel_mtl_init(struct ufs_hba *hba)
{
	struct ufs_host *ufs_host;
	int err;

	hba->caps |= UFSHCD_CAP_CRYPTO | UFSHCD_CAP_WB_EN;
	return ufs_intel_common_init(hba);
	err = ufs_intel_common_init(hba);
	/* Get variant after it is set in ufs_intel_common_init() */
	ufs_host = ufshcd_get_variant(hba);
	ufs_host->late_init = ufs_intel_mtl_late_init;
	return err;
}

static int ufs_qemu_get_hba_mac(struct ufs_hba *hba)