return 0;
 }
 
+/*
+ * To stop accepting input, we disable the receive line status interrupts, and
+ * tell the interrupt driver to stop checking the data ready bit in the line
+ * status register.
+ */
+static void mxser_stop_rx(struct mxser_port *info)
+{
+       info->IER &= ~UART_IER_RLSI;
+       if (info->board->must_hwid)
+               info->IER &= ~MOXA_MUST_RECV_ISR;
+
+       outb(info->IER, info->ioaddr + UART_IER);
+}
+
 /*
  * This routine will shutdown a serial port
  */
 
        spin_lock_irqsave(&info->slock, flags);
 
+       mxser_stop_rx(info);
+
        /*
         * clear delta_msr_wait queue to avoid mem leaks: we may free the irq
         * here so the queue might never be waken up
        tty_wakeup(tty);
 }
 
-/*
- * To stop accepting input, we disable the receive line status interrupts, and
- * tell the interrupt driver to stop checking the data ready bit in the line
- * status register.
- */
-static void mxser_stop_rx(struct mxser_port *info)
-{
-       info->IER &= ~UART_IER_RLSI;
-       if (info->board->must_hwid)
-               info->IER &= ~MOXA_MUST_RECV_ISR;
-
-       outb(info->IER, info->ioaddr + UART_IER);
-}
-
 /*
  * This routine is called when the serial port gets closed.  First, we
  * wait for the last remaining data to be sent.  Then, we unlink its
        if (tty_port_close_start(port, tty, filp) == 0)
                return;
        mutex_lock(&port->mutex);
-       mxser_stop_rx(info);
        mxser_flush_buffer(tty);
        if (tty_port_initialized(port) && C_HUPCL(tty))
                tty_port_lower_dtr_rts(port);