writel(val, MSDC_INT);                  \
        } while (0)
 
-#define msdc_clr_fifo() \
-       do {                                                            \
-               int retry = 3, cnt = 1000;                              \
-               sdr_set_bits(MSDC_FIFOCS, MSDC_FIFOCS_CLR);             \
-               msdc_retry(readl(MSDC_FIFOCS) & MSDC_FIFOCS_CLR, retry, cnt); \
-       } while (0)
+static void msdc_clr_fifo(struct msdc_host *host)
+{
+       void __iomem *base = host->base;
+
+       sdr_set_bits(MSDC_FIFOCS, MSDC_FIFOCS_CLR);
+       while (readl(MSDC_FIFOCS) & MSDC_FIFOCS_CLR)
+               cpu_relax();
+}
 
 #define msdc_irq_save(val) \
        do {                                    \
        ERR_MSG("Need to Abort.");
 
        msdc_reset_hw(host);
-       msdc_clr_fifo();
+       msdc_clr_fifo(host);
        msdc_clr_int();
 
        // need to check FIFO count 0 ?
                } else {
                        /* do basic: reset*/
                        msdc_reset_hw(host);
-                       msdc_clr_fifo();
+                       msdc_clr_fifo(host);
                        msdc_clr_int();
                }
                cmd->error = msdc_tune_cmdrsp(host, cmd);
                }
 
                writel(data->blocks, SDC_BLK_NUM);
-               //msdc_clr_fifo();  /* no need */
+               //msdc_clr_fifo(host);  /* no need */
 
                msdc_dma_on();  /* enable DMA mode first!! */
                init_completion(&host->xfer_done);
                        data->error = -ETIMEDOUT;
 
                        msdc_reset_hw(host);
-                       msdc_clr_fifo();
+                       msdc_clr_fifo(host);
                        msdc_clr_int();
                }
                spin_lock(&host->lock);
                if (intsts & datsts) {
                        /* do basic reset, or stop command will sdc_busy */
                        msdc_reset_hw(host);
-                       msdc_clr_fifo();
+                       msdc_clr_fifo(host);
                        msdc_clr_int();
 
                        if (intsts & MSDC_INT_DATTMO) {
                                IRQ_MSG("XXX CMD<%d> MSDC_INT_CMDTMO", cmd->opcode);
                        cmd->error = -ETIMEDOUT;
                        msdc_reset_hw(host);
-                       msdc_clr_fifo();
+                       msdc_clr_fifo(host);
                        msdc_clr_int();
                }
                complete(&host->cmd_done);
 
        /* Reset */
        msdc_reset_hw(host);
-       msdc_clr_fifo();
+       msdc_clr_fifo(host);
 
        /* Disable card detection */
        sdr_clr_bits(MSDC_PS, MSDC_PS_CDEN);