mxs_auart_modem_status() did't detect gpio's state change
because s->mctrl_prev was modified before by mctrl_gpio_get().
The patch introduces mctrl_temp variable to fix the bug.
Signed-off-by: Janusz Uzycki <j.uzycki@elproma.com.pl>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
 {
        u32 istat;
        struct mxs_auart_port *s = context;
+       u32 mctrl_temp = s->mctrl_prev;
        u32 stat = readl(s->port.membase + AUART_STAT);
 
        istat = readl(s->port.membase + AUART_INTR);
            irq == s->gpio_irq[UART_GPIO_DSR] ||
            irq == s->gpio_irq[UART_GPIO_RI])
                mxs_auart_modem_status(s,
-                               mctrl_gpio_get(s->gpios, &s->mctrl_prev));
+                               mctrl_gpio_get(s->gpios, &mctrl_temp));
 
        if (istat & AUART_INTR_CTSMIS) {
                if (CTS_AT_AUART() && s->ms_irq_enabled)