#define IMX21_UTS 0xb4 /* UART Test Register on all other i.mx*/
 
 /* UART Control Register Bit Fields.*/
+#define URXD_DUMMY_READ (1<<16)
 #define URXD_CHARRDY   (1<<15)
 #define URXD_ERR       (1<<14)
 #define URXD_OVRRUN    (1<<13)
 #endif
                }
 
+               if (sport->port.ignore_status_mask & URXD_DUMMY_READ)
+                       goto out;
+
                tty_insert_flip_char(port, rx, flg);
        }
 
        dev_dbg(sport->port.dev, "We get %d bytes.\n", count);
 
        if (count) {
-               tty_insert_flip_string(port, sport->rx_buf, count);
+               if (!(sport->port.ignore_status_mask & URXD_DUMMY_READ))
+                       tty_insert_flip_string(port, sport->rx_buf, count);
                tty_flip_buffer_push(port);
 
                start_rx_dma(sport);
                        sport->port.ignore_status_mask |= URXD_OVRRUN;
        }
 
+       if ((termios->c_cflag & CREAD) == 0)
+               sport->port.ignore_status_mask |= URXD_DUMMY_READ;
+
        /*
         * Update the per-port timeout.
         */