scsi: ufshcd: Allow specifying an Auto-Hibernate Timer value of zero
authorBao D. Nguyen <nguyenb@codeaurora.org>
Sat, 29 Aug 2020 01:05:13 +0000 (18:05 -0700)
committerMartin K. Petersen <martin.petersen@oracle.com>
Wed, 9 Sep 2020 01:26:15 +0000 (21:26 -0400)
Setting the Auto-Hibernate Timer to zero is a valid setting which indicates
the Auto-Hibernate feature being disabled. Correctly support this setting.

In addition, when the timer value is queried from sysfs, read from the host
controller's register and return that value instead of using the RAM value.

Link: https://lore.kernel.org/r/b141cfcd7998b8933635828b56fbb64f8ad4d175.1598661071.git.nguyenb@codeaurora.org
Acked-by: Stanley Chu <stanley.chu@mediatek.com>
Signed-off-by: Bao D. Nguyen <nguyenb@codeaurora.org>
Signed-off-by: Asutosh Das <asutoshd@codeaurora.org>
Signed-off-by: Can Guo <cang@codeaurora.org>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/ufs/ufs-sysfs.c
drivers/scsi/ufs/ufshcd.c

index 02d379f00727fecb8a84e1e6204704dbb25f61c2..bdcd27faa0547e02ce2ca36228f469e014354269 100644 (file)
@@ -146,12 +146,19 @@ static u32 ufshcd_us_to_ahit(unsigned int timer)
 static ssize_t auto_hibern8_show(struct device *dev,
                                 struct device_attribute *attr, char *buf)
 {
+       u32 ahit;
        struct ufs_hba *hba = dev_get_drvdata(dev);
 
        if (!ufshcd_is_auto_hibern8_supported(hba))
                return -EOPNOTSUPP;
 
-       return snprintf(buf, PAGE_SIZE, "%d\n", ufshcd_ahit_to_us(hba->ahit));
+       pm_runtime_get_sync(hba->dev);
+       ufshcd_hold(hba, false);
+       ahit = ufshcd_readl(hba, REG_AUTO_HIBERNATE_IDLE_TIMER);
+       ufshcd_release(hba);
+       pm_runtime_put_sync(hba->dev);
+
+       return scnprintf(buf, PAGE_SIZE, "%d\n", ufshcd_ahit_to_us(ahit));
 }
 
 static ssize_t auto_hibern8_store(struct device *dev,
index 05716f62febeff0d935607cebe97a01c9a475d1a..ef210f8405f3b989eb7266b7ac5a1de4a821c557 100644 (file)
@@ -3980,7 +3980,7 @@ void ufshcd_auto_hibern8_enable(struct ufs_hba *hba)
 {
        unsigned long flags;
 
-       if (!ufshcd_is_auto_hibern8_supported(hba) || !hba->ahit)
+       if (!ufshcd_is_auto_hibern8_supported(hba))
                return;
 
        spin_lock_irqsave(hba->host->host_lock, flags);