config SCSI_UFSHCD_PLATFORM
        tristate "Platform bus based UFS Controller support"
        depends on SCSI_UFSHCD
+       depends on HAS_IOMEM
        help
 -      This selects the UFS host controller support. Select this if
 -      you have an UFS controller on Platform bus.
 +        This selects the UFS host controller support. Select this if
 +        you have an UFS controller on Platform bus.
  
 -      If you have a controller with this interface, say Y or M here.
 +        If you have a controller with this interface, say Y or M here.
  
          If unsure, say N.
  
 
        spin_unlock_irqrestore(hba->host->host_lock, flags);
        ufshcd_scsi_unblock_requests(hba);
        ufshcd_err_handling_unprepare(hba);
 -      up(&hba->eh_sem);
 +      up(&hba->host_sem);
+ 
+       if (!err && needs_reset)
+               ufshcd_clear_ua_wluns(hba);
  }
  
  /**
         */
        if (ret) {
                pm_runtime_put_sync(hba->dev);
 -              ufshcd_exit_clk_scaling(hba);
                ufshcd_hba_exit(hba);
-       } else {
-               ufshcd_clear_ua_wluns(hba);
        }
  }
  
        if (!ufshcd_set_dev_pwr_mode(hba, UFS_ACTIVE_PWR_MODE))
                ufshcd_disable_auto_bkops(hba);
  enable_gating:
 -      if (hba->clk_scaling.is_allowed)
 -              ufshcd_resume_clkscaling(hba);
 +      if (ufshcd_is_clkscaling_supported(hba))
 +              ufshcd_clk_scaling_suspend(hba, false);
 +
        hba->clk_gating.is_suspended = false;
        hba->dev_info.b_rpm_dev_flush_capable = false;
+       ufshcd_clear_ua_wluns(hba);
        ufshcd_release(hba);
  out:
        if (hba->dev_info.b_rpm_dev_flush_capable) {