Currently a 1 ms delay is applied before polling CONTROLLER_ENABLE
bit. This delay may not be required or can be changed in different
controllers. Make the delay as a changeable value in struct ufs_hba to
allow it customized by vendors.
Link: https://lore.kernel.org/r/20200318104016.28049-6-stanley.chu@mediatek.com
Reviewed-by: Avri Altman <avri.altman@wdc.com>
Reviewed-by: Can Guo <cang@codeaurora.org>
Signed-off-by: Stanley Chu <stanley.chu@mediatek.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
         * instruction might be read back.
         * This delay can be changed based on the controller.
         */
-       usleep_range(1000, 1100);
+       ufshcd_delay_us(hba->hba_enable_delay_us, 100);
 
        /* wait for the host controller to complete initialization */
        retry = 10;
 
        hba->mmio_base = mmio_base;
        hba->irq = irq;
+       hba->hba_enable_delay_us = 1000;
 
        err = ufshcd_hba_init(hba);
        if (err)
 
        u32 eh_flags;
        u32 intr_mask;
        u16 ee_ctrl_mask;
+       u16 hba_enable_delay_us;
        bool is_powered;
        struct ufs_init_prefetch init_prefetch_data;