case MMC_BUSY_ERASE:
                err = R1_STATUS(status) ? -EIO : 0;
                break;
+       case MMC_BUSY_HPI:
+               break;
        default:
                err = -EINVAL;
        }
 
 static int mmc_send_hpi_cmd(struct mmc_card *card)
 {
+       unsigned int busy_timeout_ms = card->ext_csd.out_of_int_time;
        struct mmc_command cmd = {};
        unsigned int opcode;
        int err;
                return err;
        }
 
-       return 0;
+       /* Let's poll to find out when the HPI request completes. */
+       return mmc_poll_for_busy(card, busy_timeout_ms, MMC_BUSY_HPI);
 }
 
 /**
 {
        int err;
        u32 status;
-       unsigned long prg_wait;
 
        if (!card->ext_csd.hpi_en) {
                pr_info("%s: HPI enable bit unset\n", mmc_hostname(card->host));
        }
 
        err = mmc_send_hpi_cmd(card);
-       if (err)
-               goto out;
-
-       prg_wait = jiffies + msecs_to_jiffies(card->ext_csd.out_of_int_time);
-       do {
-               err = mmc_send_status(card, &status);
-
-               if (!err && R1_CURRENT_STATE(status) == R1_STATE_TRAN)
-                       break;
-               if (time_after(jiffies, prg_wait))
-                       err = -ETIMEDOUT;
-       } while (!err);
-
 out:
        return err;
 }