#define TX_FIFO_LVL(v, i) (((v) >> 6) & FIFO_LVL_MASK(i))
 #define RX_FIFO_LVL(v, i) (((v) >> (i)->port_conf->rx_lvl_offset) & \
                                        FIFO_LVL_MASK(i))
+#define FIFO_DEPTH(i) ((FIFO_LVL_MASK(i) >> 1) + 1)
 
 #define S3C64XX_SPI_MAX_TRAILCNT       0x3ff
 #define S3C64XX_SPI_TRAILCNT_OFF       19
        struct s3c64xx_spi_driver_data *sdd = spi_controller_get_devdata(host);
 
        if (sdd->rx_dma.ch && sdd->tx_dma.ch) {
-               return xfer->len > (FIFO_LVL_MASK(sdd) >> 1) + 1;
+               return xfer->len > FIFO_DEPTH(sdd);
        } else {
                return false;
        }
        void __iomem *regs = sdd->regs;
        unsigned long val = 1;
        u32 status;
-
-       /* max fifo depth available */
-       u32 max_fifo = (FIFO_LVL_MASK(sdd) >> 1) + 1;
+       u32 max_fifo = FIFO_DEPTH(sdd);
 
        if (timeout_ms)
                val = msecs_to_loops(timeout_ms);
         * For any size less than the fifo size the below code is
         * executed atleast once.
         */
-       loops = xfer->len / ((FIFO_LVL_MASK(sdd) >> 1) + 1);
+       loops = xfer->len / FIFO_DEPTH(sdd);
        buf = xfer->rx_buf;
        do {
                /* wait for data to be received in the fifo */
                                    struct spi_transfer *xfer)
 {
        struct s3c64xx_spi_driver_data *sdd = spi_controller_get_devdata(host);
-       const unsigned int fifo_len = (FIFO_LVL_MASK(sdd) >> 1) + 1;
+       const unsigned int fifo_len = FIFO_DEPTH(sdd);
        const void *tx_buf = NULL;
        void *rx_buf = NULL;
        int target_len = 0, origin_len = 0;
        dev_dbg(&pdev->dev, "Samsung SoC SPI Driver loaded for Bus SPI-%d with %d Targets attached\n",
                                        sdd->port_id, host->num_chipselect);
        dev_dbg(&pdev->dev, "\tIOmem=[%pR]\tFIFO %dbytes\n",
-                                       mem_res, (FIFO_LVL_MASK(sdd) >> 1) + 1);
+                                       mem_res, FIFO_DEPTH(sdd));
 
        pm_runtime_mark_last_busy(&pdev->dev);
        pm_runtime_put_autosuspend(&pdev->dev);