2  *  linux/drivers/serial/imx.c
 
   4  *  Driver for Motorola IMX serial ports
 
   6  *  Based on drivers/char/serial.c, by Linus Torvalds, Theodore Ts'o.
 
   8  *  Author: Sascha Hauer <sascha@saschahauer.de>
 
   9  *  Copyright (C) 2004 Pengutronix
 
  11  * This program is free software; you can redistribute it and/or modify
 
  12  * it under the terms of the GNU General Public License as published by
 
  13  * the Free Software Foundation; either version 2 of the License, or
 
  14  * (at your option) any later version.
 
  16  * This program is distributed in the hope that it will be useful,
 
  17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  19  * GNU General Public License for more details.
 
  21  * You should have received a copy of the GNU General Public License
 
  22  * along with this program; if not, write to the Free Software
 
  23  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
  25  * [29-Mar-2005] Mike Lee
 
  26  * Added hardware handshake
 
  28 #include <linux/config.h>
 
  30 #if defined(CONFIG_SERIAL_IMX_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
 
  34 #include <linux/module.h>
 
  35 #include <linux/ioport.h>
 
  36 #include <linux/init.h>
 
  37 #include <linux/console.h>
 
  38 #include <linux/sysrq.h>
 
  39 #include <linux/platform_device.h>
 
  40 #include <linux/tty.h>
 
  41 #include <linux/tty_flip.h>
 
  42 #include <linux/serial_core.h>
 
  43 #include <linux/serial.h>
 
  47 #include <asm/hardware.h>
 
  49 /* We've been assigned a range on the "Low-density serial ports" major */
 
  50 #define SERIAL_IMX_MAJOR        204
 
  51 #define MINOR_START             41
 
  55 #define IMX_ISR_PASS_LIMIT      256
 
  58  * This is the size of our serial port register set.
 
  60 #define UART_PORT_SIZE  0x100
 
  63  * This determines how often we check the modem status signals
 
  64  * for any change.  They generally aren't connected to an IRQ
 
  65  * so we have to poll them.  We also check immediately before
 
  66  * filling the TX fifo incase CTS has been dropped.
 
  68 #define MCTRL_TIMEOUT   (250*HZ/1000)
 
  70 #define DRIVER_NAME "IMX-uart"
 
  73         struct uart_port        port;
 
  74         struct timer_list       timer;
 
  75         unsigned int            old_status;
 
  76         int txirq,rxirq,rtsirq;
 
  80  * Handle any change of modem status signal since we were last called.
 
  82 static void imx_mctrl_check(struct imx_port *sport)
 
  84         unsigned int status, changed;
 
  86         status = sport->port.ops->get_mctrl(&sport->port);
 
  87         changed = status ^ sport->old_status;
 
  92         sport->old_status = status;
 
  94         if (changed & TIOCM_RI)
 
  95                 sport->port.icount.rng++;
 
  96         if (changed & TIOCM_DSR)
 
  97                 sport->port.icount.dsr++;
 
  98         if (changed & TIOCM_CAR)
 
  99                 uart_handle_dcd_change(&sport->port, status & TIOCM_CAR);
 
 100         if (changed & TIOCM_CTS)
 
 101                 uart_handle_cts_change(&sport->port, status & TIOCM_CTS);
 
 103         wake_up_interruptible(&sport->port.info->delta_msr_wait);
 
 107  * This is our per-port timeout handler, for checking the
 
 108  * modem status signals.
 
 110 static void imx_timeout(unsigned long data)
 
 112         struct imx_port *sport = (struct imx_port *)data;
 
 115         if (sport->port.info) {
 
 116                 spin_lock_irqsave(&sport->port.lock, flags);
 
 117                 imx_mctrl_check(sport);
 
 118                 spin_unlock_irqrestore(&sport->port.lock, flags);
 
 120                 mod_timer(&sport->timer, jiffies + MCTRL_TIMEOUT);
 
 125  * interrupts disabled on entry
 
 127 static void imx_stop_tx(struct uart_port *port)
 
 129         struct imx_port *sport = (struct imx_port *)port;
 
 130         UCR1((u32)sport->port.membase) &= ~UCR1_TXMPTYEN;
 
 134  * interrupts disabled on entry
 
 136 static void imx_stop_rx(struct uart_port *port)
 
 138         struct imx_port *sport = (struct imx_port *)port;
 
 139         UCR2((u32)sport->port.membase) &= ~UCR2_RXEN;
 
 143  * Set the modem control timer to fire immediately.
 
 145 static void imx_enable_ms(struct uart_port *port)
 
 147         struct imx_port *sport = (struct imx_port *)port;
 
 149         mod_timer(&sport->timer, jiffies);
 
 152 static inline void imx_transmit_buffer(struct imx_port *sport)
 
 154         struct circ_buf *xmit = &sport->port.info->xmit;
 
 157                 /* send xmit->buf[xmit->tail]
 
 158                  * out the port here */
 
 159                 URTX0((u32)sport->port.membase) = xmit->buf[xmit->tail];
 
 160                 xmit->tail = (xmit->tail + 1) &
 
 161                          (UART_XMIT_SIZE - 1);
 
 162                 sport->port.icount.tx++;
 
 163                 if (uart_circ_empty(xmit))
 
 165         } while (!(UTS((u32)sport->port.membase) & UTS_TXFULL));
 
 167         if (uart_circ_empty(xmit))
 
 168                 imx_stop_tx(&sport->port);
 
 172  * interrupts disabled on entry
 
 174 static void imx_start_tx(struct uart_port *port)
 
 176         struct imx_port *sport = (struct imx_port *)port;
 
 178         UCR1((u32)sport->port.membase) |= UCR1_TXMPTYEN;
 
 180         if(UTS((u32)sport->port.membase) & UTS_TXEMPTY)
 
 181                 imx_transmit_buffer(sport);
 
 184 static irqreturn_t imx_rtsint(int irq, void *dev_id, struct pt_regs *regs)
 
 186         struct imx_port *sport = (struct imx_port *)dev_id;
 
 187         unsigned int val = USR1((u32)sport->port.membase)&USR1_RTSS;
 
 190         spin_lock_irqsave(&sport->port.lock, flags);
 
 192         USR1((u32)sport->port.membase) = USR1_RTSD;
 
 193         uart_handle_cts_change(&sport->port, !!val);
 
 194         wake_up_interruptible(&sport->port.info->delta_msr_wait);
 
 196         spin_unlock_irqrestore(&sport->port.lock, flags);
 
 200 static irqreturn_t imx_txint(int irq, void *dev_id, struct pt_regs *regs)
 
 202         struct imx_port *sport = (struct imx_port *)dev_id;
 
 203         struct circ_buf *xmit = &sport->port.info->xmit;
 
 206         spin_lock_irqsave(&sport->port.lock,flags);
 
 207         if (sport->port.x_char)
 
 210                 URTX0((u32)sport->port.membase) = sport->port.x_char;
 
 214         if (uart_circ_empty(xmit) || uart_tx_stopped(&sport->port)) {
 
 215                 imx_stop_tx(&sport->port);
 
 219         imx_transmit_buffer(sport);
 
 221         if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)
 
 222                 uart_write_wakeup(&sport->port);
 
 225         spin_unlock_irqrestore(&sport->port.lock,flags);
 
 229 static irqreturn_t imx_rxint(int irq, void *dev_id, struct pt_regs *regs)
 
 231         struct imx_port *sport = dev_id;
 
 232         unsigned int rx,flg,ignored = 0;
 
 233         struct tty_struct *tty = sport->port.info->tty;
 
 236         rx = URXD0((u32)sport->port.membase);
 
 237         spin_lock_irqsave(&sport->port.lock,flags);
 
 241                 sport->port.icount.rx++;
 
 243                 if( USR2((u32)sport->port.membase) & USR2_BRCD ) {
 
 244                         USR2((u32)sport->port.membase) |= USR2_BRCD;
 
 245                         if(uart_handle_break(&sport->port))
 
 249                 if (uart_handle_sysrq_char
 
 250                             (&sport->port, (unsigned char)rx, regs))
 
 253                 if( rx & (URXD_PRERR | URXD_OVRRUN | URXD_FRMERR) )
 
 257                 tty_insert_flip_char(tty, rx, flg);
 
 260                 rx = URXD0((u32)sport->port.membase);
 
 261         } while(rx & URXD_CHARRDY);
 
 264         spin_unlock_irqrestore(&sport->port.lock,flags);
 
 265         tty_flip_buffer_push(tty);
 
 270                 sport->port.icount.parity++;
 
 271         else if (rx & URXD_FRMERR)
 
 272                 sport->port.icount.frame++;
 
 273         if (rx & URXD_OVRRUN)
 
 274                 sport->port.icount.overrun++;
 
 276         if (rx & sport->port.ignore_status_mask) {
 
 282         rx &= sport->port.read_status_mask;
 
 286         else if (rx & URXD_FRMERR)
 
 288         if (rx & URXD_OVRRUN)
 
 292         sport->port.sysrq = 0;
 
 298  * Return TIOCSER_TEMT when transmitter is not busy.
 
 300 static unsigned int imx_tx_empty(struct uart_port *port)
 
 302         struct imx_port *sport = (struct imx_port *)port;
 
 304         return USR2((u32)sport->port.membase) & USR2_TXDC ?  TIOCSER_TEMT : 0;
 
 308  * We have a modem side uart, so the meanings of RTS and CTS are inverted.
 
 310 static unsigned int imx_get_mctrl(struct uart_port *port)
 
 312         struct imx_port *sport = (struct imx_port *)port;
 
 313         unsigned int tmp = TIOCM_DSR | TIOCM_CAR;
 
 315         if (USR1((u32)sport->port.membase) & USR1_RTSS)
 
 318         if (UCR2((u32)sport->port.membase) & UCR2_CTS)
 
 324 static void imx_set_mctrl(struct uart_port *port, unsigned int mctrl)
 
 326         struct imx_port *sport = (struct imx_port *)port;
 
 328         if (mctrl & TIOCM_RTS)
 
 329                 UCR2((u32)sport->port.membase) |= UCR2_CTS;
 
 331                 UCR2((u32)sport->port.membase) &= ~UCR2_CTS;
 
 335  * Interrupts always disabled.
 
 337 static void imx_break_ctl(struct uart_port *port, int break_state)
 
 339         struct imx_port *sport = (struct imx_port *)port;
 
 342         spin_lock_irqsave(&sport->port.lock, flags);
 
 344         if ( break_state != 0 )
 
 345                 UCR1((u32)sport->port.membase) |= UCR1_SNDBRK;
 
 347                 UCR1((u32)sport->port.membase) &= ~UCR1_SNDBRK;
 
 349         spin_unlock_irqrestore(&sport->port.lock, flags);
 
 352 #define TXTL 2 /* reset default */
 
 353 #define RXTL 1 /* reset default */
 
 355 static int imx_setup_ufcr(struct imx_port *sport, unsigned int mode)
 
 358         unsigned int ufcr_rfdiv;
 
 360         /* set receiver / transmitter trigger level.
 
 361          * RFDIV is set such way to satisfy requested uartclk value
 
 363         val = TXTL<<10 | RXTL;
 
 364         ufcr_rfdiv = (imx_get_perclk1() + sport->port.uartclk / 2) / sport->port.uartclk;
 
 372                 ufcr_rfdiv = 6 - ufcr_rfdiv;
 
 374         val |= UFCR_RFDIV & (ufcr_rfdiv << 7);
 
 376         UFCR((u32)sport->port.membase) = val;
 
 381 static int imx_startup(struct uart_port *port)
 
 383         struct imx_port *sport = (struct imx_port *)port;
 
 387         imx_setup_ufcr(sport, 0);
 
 389         /* disable the DREN bit (Data Ready interrupt enable) before
 
 392         UCR4((u32)sport->port.membase) &= ~UCR4_DREN;
 
 397         retval = request_irq(sport->rxirq, imx_rxint, 0,
 
 399         if (retval) goto error_out1;
 
 401         retval = request_irq(sport->txirq, imx_txint, 0,
 
 403         if (retval) goto error_out2;
 
 405         retval = request_irq(sport->rtsirq, imx_rtsint,
 
 406                              SA_TRIGGER_FALLING | SA_TRIGGER_RISING,
 
 408         if (retval) goto error_out3;
 
 411          * Finally, clear and enable interrupts
 
 414         USR1((u32)sport->port.membase) = USR1_RTSD;
 
 415         UCR1((u32)sport->port.membase) |=
 
 416                          (UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN | UCR1_UARTEN);
 
 418         UCR2((u32)sport->port.membase) |= (UCR2_RXEN | UCR2_TXEN);
 
 420          * Enable modem status interrupts
 
 422         spin_lock_irqsave(&sport->port.lock,flags);
 
 423         imx_enable_ms(&sport->port);
 
 424         spin_unlock_irqrestore(&sport->port.lock,flags);
 
 429         free_irq(sport->txirq, sport);
 
 431         free_irq(sport->rxirq, sport);
 
 436 static void imx_shutdown(struct uart_port *port)
 
 438         struct imx_port *sport = (struct imx_port *)port;
 
 443         del_timer_sync(&sport->timer);
 
 446          * Free the interrupts
 
 448         free_irq(sport->rtsirq, sport);
 
 449         free_irq(sport->txirq, sport);
 
 450         free_irq(sport->rxirq, sport);
 
 453          * Disable all interrupts, port and break condition.
 
 456         UCR1((u32)sport->port.membase) &=
 
 457                          ~(UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN | UCR1_UARTEN);
 
 461 imx_set_termios(struct uart_port *port, struct termios *termios,
 
 464         struct imx_port *sport = (struct imx_port *)port;
 
 466         unsigned int ucr2, old_ucr1, old_txrxen, baud, quot;
 
 467         unsigned int old_csize = old ? old->c_cflag & CSIZE : CS8;
 
 470          * If we don't support modem control lines, don't allow
 
 474                 termios->c_cflag &= ~(HUPCL | CRTSCTS | CMSPAR);
 
 475                 termios->c_cflag |= CLOCAL;
 
 479          * We only support CS7 and CS8.
 
 481         while ((termios->c_cflag & CSIZE) != CS7 &&
 
 482                (termios->c_cflag & CSIZE) != CS8) {
 
 483                 termios->c_cflag &= ~CSIZE;
 
 484                 termios->c_cflag |= old_csize;
 
 488         if ((termios->c_cflag & CSIZE) == CS8)
 
 489                 ucr2 = UCR2_WS | UCR2_SRST | UCR2_IRTS;
 
 491                 ucr2 = UCR2_SRST | UCR2_IRTS;
 
 493         if (termios->c_cflag & CRTSCTS) {
 
 498         if (termios->c_cflag & CSTOPB)
 
 500         if (termios->c_cflag & PARENB) {
 
 502                 if (termios->c_cflag & PARODD)
 
 507          * Ask the core to calculate the divisor for us.
 
 509         baud = uart_get_baud_rate(port, termios, old, 0, port->uartclk/16);
 
 510         quot = uart_get_divisor(port, baud);
 
 512         spin_lock_irqsave(&sport->port.lock, flags);
 
 514         sport->port.read_status_mask = 0;
 
 515         if (termios->c_iflag & INPCK)
 
 516                 sport->port.read_status_mask |= (URXD_FRMERR | URXD_PRERR);
 
 517         if (termios->c_iflag & (BRKINT | PARMRK))
 
 518                 sport->port.read_status_mask |= URXD_BRK;
 
 521          * Characters to ignore
 
 523         sport->port.ignore_status_mask = 0;
 
 524         if (termios->c_iflag & IGNPAR)
 
 525                 sport->port.ignore_status_mask |= URXD_PRERR;
 
 526         if (termios->c_iflag & IGNBRK) {
 
 527                 sport->port.ignore_status_mask |= URXD_BRK;
 
 529                  * If we're ignoring parity and break indicators,
 
 530                  * ignore overruns too (for real raw support).
 
 532                 if (termios->c_iflag & IGNPAR)
 
 533                         sport->port.ignore_status_mask |= URXD_OVRRUN;
 
 536         del_timer_sync(&sport->timer);
 
 539          * Update the per-port timeout.
 
 541         uart_update_timeout(port, termios->c_cflag, baud);
 
 544          * disable interrupts and drain transmitter
 
 546         old_ucr1 = UCR1((u32)sport->port.membase);
 
 547         UCR1((u32)sport->port.membase) &= ~(UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN);
 
 549         while ( !(USR2((u32)sport->port.membase) & USR2_TXDC))
 
 552         /* then, disable everything */
 
 553         old_txrxen = UCR2((u32)sport->port.membase) & ( UCR2_TXEN | UCR2_RXEN );
 
 554         UCR2((u32)sport->port.membase) &= ~( UCR2_TXEN | UCR2_RXEN);
 
 556         /* set the parity, stop bits and data size */
 
 557         UCR2((u32)sport->port.membase) = ucr2;
 
 559         /* set the baud rate. We assume uartclk = 16 MHz
 
 562          * --------- = --------
 
 565         UBIR((u32)sport->port.membase) = (baud / 100) - 1;
 
 566         UBMR((u32)sport->port.membase) = 10000 - 1;
 
 568         UCR1((u32)sport->port.membase) = old_ucr1;
 
 569         UCR2((u32)sport->port.membase) |= old_txrxen;
 
 571         if (UART_ENABLE_MS(&sport->port, termios->c_cflag))
 
 572                 imx_enable_ms(&sport->port);
 
 574         spin_unlock_irqrestore(&sport->port.lock, flags);
 
 577 static const char *imx_type(struct uart_port *port)
 
 579         struct imx_port *sport = (struct imx_port *)port;
 
 581         return sport->port.type == PORT_IMX ? "IMX" : NULL;
 
 585  * Release the memory region(s) being used by 'port'.
 
 587 static void imx_release_port(struct uart_port *port)
 
 589         struct imx_port *sport = (struct imx_port *)port;
 
 591         release_mem_region(sport->port.mapbase, UART_PORT_SIZE);
 
 595  * Request the memory region(s) being used by 'port'.
 
 597 static int imx_request_port(struct uart_port *port)
 
 599         struct imx_port *sport = (struct imx_port *)port;
 
 601         return request_mem_region(sport->port.mapbase, UART_PORT_SIZE,
 
 602                         "imx-uart") != NULL ? 0 : -EBUSY;
 
 606  * Configure/autoconfigure the port.
 
 608 static void imx_config_port(struct uart_port *port, int flags)
 
 610         struct imx_port *sport = (struct imx_port *)port;
 
 612         if (flags & UART_CONFIG_TYPE &&
 
 613             imx_request_port(&sport->port) == 0)
 
 614                 sport->port.type = PORT_IMX;
 
 618  * Verify the new serial_struct (for TIOCSSERIAL).
 
 619  * The only change we allow are to the flags and type, and
 
 620  * even then only between PORT_IMX and PORT_UNKNOWN
 
 623 imx_verify_port(struct uart_port *port, struct serial_struct *ser)
 
 625         struct imx_port *sport = (struct imx_port *)port;
 
 628         if (ser->type != PORT_UNKNOWN && ser->type != PORT_IMX)
 
 630         if (sport->port.irq != ser->irq)
 
 632         if (ser->io_type != UPIO_MEM)
 
 634         if (sport->port.uartclk / 16 != ser->baud_base)
 
 636         if ((void *)sport->port.mapbase != ser->iomem_base)
 
 638         if (sport->port.iobase != ser->port)
 
 645 static struct uart_ops imx_pops = {
 
 646         .tx_empty       = imx_tx_empty,
 
 647         .set_mctrl      = imx_set_mctrl,
 
 648         .get_mctrl      = imx_get_mctrl,
 
 649         .stop_tx        = imx_stop_tx,
 
 650         .start_tx       = imx_start_tx,
 
 651         .stop_rx        = imx_stop_rx,
 
 652         .enable_ms      = imx_enable_ms,
 
 653         .break_ctl      = imx_break_ctl,
 
 654         .startup        = imx_startup,
 
 655         .shutdown       = imx_shutdown,
 
 656         .set_termios    = imx_set_termios,
 
 658         .release_port   = imx_release_port,
 
 659         .request_port   = imx_request_port,
 
 660         .config_port    = imx_config_port,
 
 661         .verify_port    = imx_verify_port,
 
 664 static struct imx_port imx_ports[] = {
 
 666         .txirq  = UART1_MINT_TX,
 
 667         .rxirq  = UART1_MINT_RX,
 
 668         .rtsirq = UART1_MINT_RTS,
 
 672                 .membase        = (void *)IMX_UART1_BASE,
 
 673                 .mapbase        = IMX_UART1_BASE, /* FIXME */
 
 674                 .irq            = UART1_MINT_RX,
 
 677                 .flags          = UPF_BOOT_AUTOCONF,
 
 682         .txirq  = UART2_MINT_TX,
 
 683         .rxirq  = UART2_MINT_RX,
 
 684         .rtsirq = UART2_MINT_RTS,
 
 688                 .membase        = (void *)IMX_UART2_BASE,
 
 689                 .mapbase        = IMX_UART2_BASE, /* FIXME */
 
 690                 .irq            = UART2_MINT_RX,
 
 693                 .flags          = UPF_BOOT_AUTOCONF,
 
 701  * Setup the IMX serial ports.
 
 702  * Note also that we support "console=ttySMXx" where "x" is either 0 or 1.
 
 703  * Which serial port this ends up being depends on the machine you're
 
 704  * running this kernel on.  I'm not convinced that this is a good idea,
 
 705  * but that's the way it traditionally works.
 
 708 static void __init imx_init_ports(void)
 
 710         static int first = 1;
 
 717         for (i = 0; i < ARRAY_SIZE(imx_ports); i++) {
 
 718                 init_timer(&imx_ports[i].timer);
 
 719                 imx_ports[i].timer.function = imx_timeout;
 
 720                 imx_ports[i].timer.data     = (unsigned long)&imx_ports[i];
 
 723         imx_gpio_mode(PC9_PF_UART1_CTS);
 
 724         imx_gpio_mode(PC10_PF_UART1_RTS);
 
 725         imx_gpio_mode(PC11_PF_UART1_TXD);
 
 726         imx_gpio_mode(PC12_PF_UART1_RXD);
 
 727         imx_gpio_mode(PB28_PF_UART2_CTS);
 
 728         imx_gpio_mode(PB29_PF_UART2_RTS);
 
 730         imx_gpio_mode(PB30_PF_UART2_TXD);
 
 731         imx_gpio_mode(PB31_PF_UART2_RXD);
 
 733 #if 0 /* We don't need these, on the mx1 the _modem_ side of the uart
 
 736         imx_gpio_mode(PD7_AF_UART2_DTR);
 
 737         imx_gpio_mode(PD8_AF_UART2_DCD);
 
 738         imx_gpio_mode(PD9_AF_UART2_RI);
 
 739         imx_gpio_mode(PD10_AF_UART2_DSR);
 
 745 #ifdef CONFIG_SERIAL_IMX_CONSOLE
 
 746 static void imx_console_putchar(struct uart_port *port, int ch)
 
 748         struct imx_port *sport = (struct imx_port *)port;
 
 749         while ((UTS((u32)sport->port.membase) & UTS_TXFULL))
 
 751         URTX0((u32)sport->port.membase) = ch;
 
 755  * Interrupts are disabled on entering
 
 758 imx_console_write(struct console *co, const char *s, unsigned int count)
 
 760         struct imx_port *sport = &imx_ports[co->index];
 
 761         unsigned int old_ucr1, old_ucr2;
 
 764          *      First, save UCR1/2 and then disable interrupts
 
 766         old_ucr1 = UCR1((u32)sport->port.membase);
 
 767         old_ucr2 = UCR2((u32)sport->port.membase);
 
 769         UCR1((u32)sport->port.membase) =
 
 770                            (old_ucr1 | UCR1_UARTCLKEN | UCR1_UARTEN)
 
 771                            & ~(UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN);
 
 772         UCR2((u32)sport->port.membase) = old_ucr2 | UCR2_TXEN;
 
 774         uart_console_write(&sport->port, s, count, imx_console_putchar);
 
 777          *      Finally, wait for transmitter to become empty
 
 780         while (!(USR2((u32)sport->port.membase) & USR2_TXDC));
 
 782         UCR1((u32)sport->port.membase) = old_ucr1;
 
 783         UCR2((u32)sport->port.membase) = old_ucr2;
 
 787  * If the port was already initialised (eg, by a boot loader),
 
 788  * try to determine the current setup.
 
 791 imx_console_get_options(struct imx_port *sport, int *baud,
 
 792                            int *parity, int *bits)
 
 795         if ( UCR1((u32)sport->port.membase) | UCR1_UARTEN ) {
 
 796                 /* ok, the port was enabled */
 
 797                 unsigned int ucr2, ubir,ubmr, uartclk;
 
 798                 unsigned int baud_raw;
 
 799                 unsigned int ucfr_rfdiv;
 
 801                 ucr2 = UCR2((u32)sport->port.membase);
 
 804                 if (ucr2 & UCR2_PREN) {
 
 805                         if (ucr2 & UCR2_PROE)
 
 816                 ubir = UBIR((u32)sport->port.membase) & 0xffff;
 
 817                 ubmr = UBMR((u32)sport->port.membase) & 0xffff;
 
 820                 ucfr_rfdiv = (UFCR((u32)sport->port.membase) & UFCR_RFDIV) >> 7;
 
 824                         ucfr_rfdiv = 6 - ucfr_rfdiv;
 
 826                 uartclk = imx_get_perclk1();
 
 827                 uartclk /= ucfr_rfdiv;
 
 830                          * The next code provides exact computation of
 
 831                          *   baud_raw = round(((uartclk/16) * (ubir + 1)) / (ubmr + 1))
 
 832                          * without need of float support or long long division,
 
 833                          * which would be required to prevent 32bit arithmetic overflow
 
 835                         unsigned int mul = ubir + 1;
 
 836                         unsigned int div = 16 * (ubmr + 1);
 
 837                         unsigned int rem = uartclk % div;
 
 839                         baud_raw = (uartclk / div) * mul;
 
 840                         baud_raw += (rem * mul + div / 2) / div;
 
 841                         *baud = (baud_raw + 50) / 100 * 100;
 
 844                 if(*baud != baud_raw)
 
 845                         printk(KERN_INFO "Serial: Console IMX rounded baud rate from %d to %d\n",
 
 851 imx_console_setup(struct console *co, char *options)
 
 853         struct imx_port *sport;
 
 860          * Check whether an invalid uart number has been specified, and
 
 861          * if so, search for the first available port that does have
 
 864         if (co->index == -1 || co->index >= ARRAY_SIZE(imx_ports))
 
 866         sport = &imx_ports[co->index];
 
 869                 uart_parse_options(options, &baud, &parity, &bits, &flow);
 
 871                 imx_console_get_options(sport, &baud, &parity, &bits);
 
 873         imx_setup_ufcr(sport, 0);
 
 875         return uart_set_options(&sport->port, co, baud, parity, bits, flow);
 
 878 static struct uart_driver imx_reg;
 
 879 static struct console imx_console = {
 
 881         .write          = imx_console_write,
 
 882         .device         = uart_console_device,
 
 883         .setup          = imx_console_setup,
 
 884         .flags          = CON_PRINTBUFFER,
 
 889 static int __init imx_rs_console_init(void)
 
 892         register_console(&imx_console);
 
 895 console_initcall(imx_rs_console_init);
 
 897 #define IMX_CONSOLE     &imx_console
 
 899 #define IMX_CONSOLE     NULL
 
 902 static struct uart_driver imx_reg = {
 
 903         .owner          = THIS_MODULE,
 
 904         .driver_name    = DRIVER_NAME,
 
 905         .dev_name       = "ttySMX",
 
 906         .devfs_name     = "ttsmx/",
 
 907         .major          = SERIAL_IMX_MAJOR,
 
 908         .minor          = MINOR_START,
 
 909         .nr             = ARRAY_SIZE(imx_ports),
 
 913 static int serial_imx_suspend(struct platform_device *dev, pm_message_t state)
 
 915         struct imx_port *sport = platform_get_drvdata(dev);
 
 918                 uart_suspend_port(&imx_reg, &sport->port);
 
 923 static int serial_imx_resume(struct platform_device *dev)
 
 925         struct imx_port *sport = platform_get_drvdata(dev);
 
 928                 uart_resume_port(&imx_reg, &sport->port);
 
 933 static int serial_imx_probe(struct platform_device *dev)
 
 935         imx_ports[dev->id].port.dev = &dev->dev;
 
 936         uart_add_one_port(&imx_reg, &imx_ports[dev->id].port);
 
 937         platform_set_drvdata(dev, &imx_ports[dev->id]);
 
 941 static int serial_imx_remove(struct platform_device *dev)
 
 943         struct imx_port *sport = platform_get_drvdata(dev);
 
 945         platform_set_drvdata(dev, NULL);
 
 948                 uart_remove_one_port(&imx_reg, &sport->port);
 
 953 static struct platform_driver serial_imx_driver = {
 
 954         .probe          = serial_imx_probe,
 
 955         .remove         = serial_imx_remove,
 
 957         .suspend        = serial_imx_suspend,
 
 958         .resume         = serial_imx_resume,
 
 964 static int __init imx_serial_init(void)
 
 968         printk(KERN_INFO "Serial: IMX driver\n");
 
 972         ret = uart_register_driver(&imx_reg);
 
 976         ret = platform_driver_register(&serial_imx_driver);
 
 978                 uart_unregister_driver(&imx_reg);
 
 983 static void __exit imx_serial_exit(void)
 
 985         uart_unregister_driver(&imx_reg);
 
 986         platform_driver_unregister(&serial_imx_driver);
 
 989 module_init(imx_serial_init);
 
 990 module_exit(imx_serial_exit);
 
 992 MODULE_AUTHOR("Sascha Hauer");
 
 993 MODULE_DESCRIPTION("IMX generic serial port driver");
 
 994 MODULE_LICENSE("GPL");