2  * File:         drivers/serial/bfin_5xx.c
 
   3  * Based on:     Based on drivers/serial/sa1100.c
 
   4  * Author:       Aubrey Li <aubrey.li@analog.com>
 
   7  * Description:  Driver for blackfin 5xx serial ports
 
  10  *               Copyright 2006 Analog Devices Inc.
 
  12  * Bugs:         Enter bugs at http://blackfin.uclinux.org/
 
  14  * This program is free software; you can redistribute it and/or modify
 
  15  * it under the terms of the GNU General Public License as published by
 
  16  * the Free Software Foundation; either version 2 of the License, or
 
  17  * (at your option) any later version.
 
  19  * This program is distributed in the hope that it will be useful,
 
  20  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  21  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  22  * GNU General Public License for more details.
 
  24  * You should have received a copy of the GNU General Public License
 
  25  * along with this program; if not, see the file COPYING, or write
 
  26  * to the Free Software Foundation, Inc.,
 
  27  * 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
  30 #if defined(CONFIG_SERIAL_BFIN_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>
 
  44 #ifdef CONFIG_KGDB_UART
 
  45 #include <linux/kgdb.h>
 
  46 #include <asm/irq_regs.h>
 
  50 #include <asm/mach/bfin_serial_5xx.h>
 
  52 #ifdef CONFIG_SERIAL_BFIN_DMA
 
  53 #include <linux/dma-mapping.h>
 
  56 #include <asm/cacheflush.h>
 
  59 /* UART name and device definitions */
 
  60 #define BFIN_SERIAL_NAME        "ttyBF"
 
  61 #define BFIN_SERIAL_MAJOR       204
 
  62 #define BFIN_SERIAL_MINOR       64
 
  65  * Setup for console. Argument comes from the menuconfig
 
  67 #define DMA_RX_XCOUNT           512
 
  68 #define DMA_RX_YCOUNT           (PAGE_SIZE / DMA_RX_XCOUNT)
 
  70 #define DMA_RX_FLUSH_JIFFIES    5
 
  72 #ifdef CONFIG_SERIAL_BFIN_DMA
 
  73 static void bfin_serial_dma_tx_chars(struct bfin_serial_port *uart);
 
  75 static void bfin_serial_do_work(struct work_struct *work);
 
  76 static void bfin_serial_tx_chars(struct bfin_serial_port *uart);
 
  77 static void local_put_char(struct bfin_serial_port *uart, char ch);
 
  80 static void bfin_serial_mctrl_check(struct bfin_serial_port *uart);
 
  83  * interrupts are disabled on entry
 
  85 static void bfin_serial_stop_tx(struct uart_port *port)
 
  87         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
  89         while (!(UART_GET_LSR(uart) & TEMT))
 
  92 #ifdef CONFIG_SERIAL_BFIN_DMA
 
  93         disable_dma(uart->tx_dma_channel);
 
  96         /* Waiting for Transmission Finished */
 
  97         while (!(UART_GET_LSR(uart) & TFI))
 
 100         UART_PUT_LSR(uart, TFI);
 
 101         UART_CLEAR_IER(uart, ETBEI);
 
 105         ier = UART_GET_IER(uart);
 
 107         UART_PUT_IER(uart, ier);
 
 113  * port is locked and interrupts are disabled
 
 115 static void bfin_serial_start_tx(struct uart_port *port)
 
 117         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 119 #ifdef CONFIG_SERIAL_BFIN_DMA
 
 120         bfin_serial_dma_tx_chars(uart);
 
 123         UART_SET_IER(uart, ETBEI);
 
 126         ier = UART_GET_IER(uart);
 
 128         UART_PUT_IER(uart, ier);
 
 130         bfin_serial_tx_chars(uart);
 
 135  * Interrupts are enabled
 
 137 static void bfin_serial_stop_rx(struct uart_port *port)
 
 139         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 140 #ifdef  CONFIG_KGDB_UART
 
 141         if (uart->port.line != CONFIG_KGDB_UART_PORT) {
 
 144         UART_CLEAR_IER(uart, ERBFI);
 
 148         ier = UART_GET_IER(uart);
 
 150         UART_PUT_IER(uart, ier);
 
 152 #ifdef  CONFIG_KGDB_UART
 
 158  * Set the modem control timer to fire immediately.
 
 160 static void bfin_serial_enable_ms(struct uart_port *port)
 
 164 #ifdef CONFIG_KGDB_UART
 
 165 static int kgdb_entry_state;
 
 167 void kgdb_put_debug_char(int chr)
 
 169         struct bfin_serial_port *uart;
 
 171         if (CONFIG_KGDB_UART_PORT<0 || CONFIG_KGDB_UART_PORT>=NR_PORTS)
 
 172                 uart = &bfin_serial_ports[0];
 
 174                 uart = &bfin_serial_ports[CONFIG_KGDB_UART_PORT];
 
 176         while (!(UART_GET_LSR(uart) & THRE)) {
 
 181         UART_PUT_LCR(uart, UART_GET_LCR(uart)&(~DLAB));
 
 184         UART_PUT_CHAR(uart, (unsigned char)chr);
 
 188 int kgdb_get_debug_char(void)
 
 190         struct bfin_serial_port *uart;
 
 193         if (CONFIG_KGDB_UART_PORT<0 || CONFIG_KGDB_UART_PORT>=NR_PORTS)
 
 194                 uart = &bfin_serial_ports[0];
 
 196                 uart = &bfin_serial_ports[CONFIG_KGDB_UART_PORT];
 
 198         while(!(UART_GET_LSR(uart) & DR)) {
 
 202         UART_PUT_LCR(uart, UART_GET_LCR(uart)&(~DLAB));
 
 205         chr = UART_GET_CHAR(uart);
 
 212 #ifdef CONFIG_SERIAL_BFIN_PIO
 
 213 static void local_put_char(struct bfin_serial_port *uart, char ch)
 
 215         unsigned short status;
 
 218         spin_lock_irqsave(&uart->port.lock, flags);
 
 221                 status = UART_GET_LSR(uart);
 
 222         } while (!(status & THRE));
 
 224         UART_PUT_CHAR(uart, ch);
 
 227         spin_unlock_irqrestore(&uart->port.lock, flags);
 
 230 static void bfin_serial_rx_chars(struct bfin_serial_port *uart)
 
 232         struct tty_struct *tty = uart->port.info->tty;
 
 233         unsigned int status, ch, flg;
 
 234         static int in_break = 0;
 
 235 #ifdef CONFIG_KGDB_UART
 
 236         struct pt_regs *regs = get_irq_regs();
 
 239         status = UART_GET_LSR(uart);
 
 240         ch = UART_GET_CHAR(uart);
 
 241         uart->port.icount.rx++;
 
 243 #ifdef CONFIG_KGDB_UART
 
 244         if (uart->port.line == CONFIG_KGDB_UART_PORT) {
 
 245                 if (uart->port.cons->index == CONFIG_KGDB_UART_PORT && ch == 0x1) { /* Ctrl + A */
 
 246                         kgdb_breakkey_pressed(regs);
 
 248                 } else if (kgdb_entry_state == 0 && ch == '$') {/* connection from KGDB */
 
 249                         kgdb_entry_state = 1;
 
 250                 } else if (kgdb_entry_state == 1 && ch == 'q') {
 
 251                         kgdb_entry_state = 0;
 
 252                         kgdb_breakkey_pressed(regs);
 
 254                 } else if (ch == 0x3) {/* Ctrl + C */
 
 255                         kgdb_entry_state = 0;
 
 256                         kgdb_breakkey_pressed(regs);
 
 259                         kgdb_entry_state = 0;
 
 264         if (ANOMALY_05000230) {
 
 265                 /* The BF533 family of processors have a nice misbehavior where
 
 266                  * they continuously generate characters for a "single" break.
 
 267                  * We have to basically ignore this flood until the "next" valid
 
 268                  * character comes across.  All other Blackfin families operate
 
 270                  * Note: While Anomaly 05000230 does not directly address this,
 
 271                  *       the changes that went in for it also fixed this issue.
 
 276                                 ch = UART_GET_CHAR(uart);
 
 277                                 if (bfin_revid() < 5)
 
 285                 if (ANOMALY_05000230)
 
 287                 uart->port.icount.brk++;
 
 288                 if (uart_handle_break(&uart->port))
 
 290                 status &= ~(PE | FE);
 
 293                 uart->port.icount.parity++;
 
 295                 uart->port.icount.overrun++;
 
 297                 uart->port.icount.frame++;
 
 299         status &= uart->port.read_status_mask;
 
 303         else if (status & PE)
 
 305         else if (status & FE)
 
 310         if (uart_handle_sysrq_char(&uart->port, ch))
 
 313         uart_insert_char(&uart->port, status, OE, ch, flg);
 
 316         tty_flip_buffer_push(tty);
 
 319 static void bfin_serial_tx_chars(struct bfin_serial_port *uart)
 
 321         struct circ_buf *xmit = &uart->port.info->xmit;
 
 323         if (uart->port.x_char) {
 
 324                 UART_PUT_CHAR(uart, uart->port.x_char);
 
 325                 uart->port.icount.tx++;
 
 326                 uart->port.x_char = 0;
 
 330          * Check the modem control lines before
 
 331          * transmitting anything.
 
 333         bfin_serial_mctrl_check(uart);
 
 335         if (uart_circ_empty(xmit) || uart_tx_stopped(&uart->port)) {
 
 336                 bfin_serial_stop_tx(&uart->port);
 
 340         local_put_char(uart, xmit->buf[xmit->tail]);
 
 341         xmit->tail = (xmit->tail + 1) & (UART_XMIT_SIZE - 1);
 
 342         uart->port.icount.tx++;
 
 344         if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)
 
 345                 uart_write_wakeup(&uart->port);
 
 347         if (uart_circ_empty(xmit))
 
 348                 bfin_serial_stop_tx(&uart->port);
 
 351 static irqreturn_t bfin_serial_rx_int(int irq, void *dev_id)
 
 353         struct bfin_serial_port *uart = dev_id;
 
 356         unsigned short status;
 
 357         spin_lock(&uart->port.lock);
 
 358         status = UART_GET_LSR(uart);
 
 359         while ((UART_GET_IER(uart) & ERBFI) && (status & DR)) {
 
 360                 bfin_serial_rx_chars(uart);
 
 361                 status = UART_GET_LSR(uart);
 
 363         spin_unlock(&uart->port.lock);
 
 365         spin_lock(&uart->port.lock);
 
 366         while ((UART_GET_IIR(uart) & IIR_STATUS) == IIR_RX_READY)
 
 367                 bfin_serial_rx_chars(uart);
 
 368         spin_unlock(&uart->port.lock);
 
 373 static irqreturn_t bfin_serial_tx_int(int irq, void *dev_id)
 
 375         struct bfin_serial_port *uart = dev_id;
 
 378         unsigned short status;
 
 379         spin_lock(&uart->port.lock);
 
 380         status = UART_GET_LSR(uart);
 
 381         while ((UART_GET_IER(uart) & ETBEI) && (status & THRE)) {
 
 382                 bfin_serial_tx_chars(uart);
 
 383                 status = UART_GET_LSR(uart);
 
 385         spin_unlock(&uart->port.lock);
 
 387         spin_lock(&uart->port.lock);
 
 388         while ((UART_GET_IIR(uart) & IIR_STATUS) == IIR_TX_READY)
 
 389                 bfin_serial_tx_chars(uart);
 
 390         spin_unlock(&uart->port.lock);
 
 396 static void bfin_serial_do_work(struct work_struct *work)
 
 398         struct bfin_serial_port *uart = container_of(work, struct bfin_serial_port, cts_workqueue);
 
 400         bfin_serial_mctrl_check(uart);
 
 404 #ifdef CONFIG_SERIAL_BFIN_DMA
 
 405 static void bfin_serial_dma_tx_chars(struct bfin_serial_port *uart)
 
 407         struct circ_buf *xmit = &uart->port.info->xmit;
 
 416         if (uart->port.x_char) {
 
 417                 UART_PUT_CHAR(uart, uart->port.x_char);
 
 418                 uart->port.icount.tx++;
 
 419                 uart->port.x_char = 0;
 
 424          * Check the modem control lines before
 
 425          * transmitting anything.
 
 427         bfin_serial_mctrl_check(uart);
 
 429         if (uart_circ_empty(xmit) || uart_tx_stopped(&uart->port)) {
 
 430                 bfin_serial_stop_tx(&uart->port);
 
 435         spin_lock_irqsave(&uart->port.lock, flags);
 
 436         uart->tx_count = CIRC_CNT(xmit->head, xmit->tail, UART_XMIT_SIZE);
 
 437         if (uart->tx_count > (UART_XMIT_SIZE - xmit->tail))
 
 438                 uart->tx_count = UART_XMIT_SIZE - xmit->tail;
 
 439         blackfin_dcache_flush_range((unsigned long)(xmit->buf+xmit->tail),
 
 440                                         (unsigned long)(xmit->buf+xmit->tail+uart->tx_count));
 
 441         set_dma_config(uart->tx_dma_channel,
 
 442                 set_bfin_dma_config(DIR_READ, DMA_FLOW_STOP,
 
 446         set_dma_start_addr(uart->tx_dma_channel, (unsigned long)(xmit->buf+xmit->tail));
 
 447         set_dma_x_count(uart->tx_dma_channel, uart->tx_count);
 
 448         set_dma_x_modify(uart->tx_dma_channel, 1);
 
 449         enable_dma(uart->tx_dma_channel);
 
 451         UART_SET_IER(uart, ETBEI);
 
 453         ier = UART_GET_IER(uart);
 
 455         UART_PUT_IER(uart, ier);
 
 457         spin_unlock_irqrestore(&uart->port.lock, flags);
 
 460 static void bfin_serial_dma_rx_chars(struct bfin_serial_port *uart)
 
 462         struct tty_struct *tty = uart->port.info->tty;
 
 465         status = UART_GET_LSR(uart);
 
 466         uart->port.icount.rx += CIRC_CNT(uart->rx_dma_buf.head, uart->rx_dma_buf.tail, UART_XMIT_SIZE);;
 
 469                 uart->port.icount.brk++;
 
 470                 if (uart_handle_break(&uart->port))
 
 471                         goto dma_ignore_char;
 
 472                 status &= ~(PE | FE);
 
 475                 uart->port.icount.parity++;
 
 477                 uart->port.icount.overrun++;
 
 479                 uart->port.icount.frame++;
 
 481         status &= uart->port.read_status_mask;
 
 485         else if (status & PE)
 
 487         else if (status & FE)
 
 492         for (i = uart->rx_dma_buf.head; i < uart->rx_dma_buf.tail; i++) {
 
 493                 if (uart_handle_sysrq_char(&uart->port, uart->rx_dma_buf.buf[i]))
 
 494                         goto dma_ignore_char;
 
 495                 uart_insert_char(&uart->port, status, OE, uart->rx_dma_buf.buf[i], flg);
 
 499         tty_flip_buffer_push(tty);
 
 502 void bfin_serial_rx_dma_timeout(struct bfin_serial_port *uart)
 
 507         bfin_serial_dma_tx_chars(uart);
 
 509         spin_lock_irqsave(&uart->port.lock, flags);
 
 510         x_pos = DMA_RX_XCOUNT - get_dma_curr_xcount(uart->rx_dma_channel);
 
 511         if (x_pos == DMA_RX_XCOUNT)
 
 514         pos = uart->rx_dma_nrows * DMA_RX_XCOUNT + x_pos;
 
 516         if (pos>uart->rx_dma_buf.tail) {
 
 517                 uart->rx_dma_buf.tail = pos;
 
 518                 bfin_serial_dma_rx_chars(uart);
 
 519                 uart->rx_dma_buf.head = uart->rx_dma_buf.tail;
 
 521         spin_unlock_irqrestore(&uart->port.lock, flags);
 
 522         uart->rx_dma_timer.expires = jiffies + DMA_RX_FLUSH_JIFFIES;
 
 523         add_timer(&(uart->rx_dma_timer));
 
 526 static irqreturn_t bfin_serial_dma_tx_int(int irq, void *dev_id)
 
 528         struct bfin_serial_port *uart = dev_id;
 
 529         struct circ_buf *xmit = &uart->port.info->xmit;
 
 532         spin_lock(&uart->port.lock);
 
 533         if (!(get_dma_curr_irqstat(uart->tx_dma_channel)&DMA_RUN)) {
 
 534                 clear_dma_irqstat(uart->tx_dma_channel);
 
 535                 disable_dma(uart->tx_dma_channel);
 
 537                 UART_CLEAR_IER(uart, ETBEI);
 
 539                 ier = UART_GET_IER(uart);
 
 541                 UART_PUT_IER(uart, ier);
 
 543                 xmit->tail = (xmit->tail+uart->tx_count) &(UART_XMIT_SIZE -1);
 
 544                 uart->port.icount.tx+=uart->tx_count;
 
 546                 if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)
 
 547                         uart_write_wakeup(&uart->port);
 
 549                 if (uart_circ_empty(xmit))
 
 550                         bfin_serial_stop_tx(&uart->port);
 
 554         spin_unlock(&uart->port.lock);
 
 558 static irqreturn_t bfin_serial_dma_rx_int(int irq, void *dev_id)
 
 560         struct bfin_serial_port *uart = dev_id;
 
 561         unsigned short irqstat;
 
 563         uart->rx_dma_nrows++;
 
 564         if (uart->rx_dma_nrows == DMA_RX_YCOUNT) {
 
 565                 uart->rx_dma_nrows = 0;
 
 566                 uart->rx_dma_buf.tail = DMA_RX_XCOUNT*DMA_RX_YCOUNT;
 
 567                 bfin_serial_dma_rx_chars(uart);
 
 568                 uart->rx_dma_buf.head = uart->rx_dma_buf.tail = 0;
 
 570         spin_lock(&uart->port.lock);
 
 571         irqstat = get_dma_curr_irqstat(uart->rx_dma_channel);
 
 572         clear_dma_irqstat(uart->rx_dma_channel);
 
 574         spin_unlock(&uart->port.lock);
 
 580  * Return TIOCSER_TEMT when transmitter is not busy.
 
 582 static unsigned int bfin_serial_tx_empty(struct uart_port *port)
 
 584         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 587         lsr = UART_GET_LSR(uart);
 
 594 static unsigned int bfin_serial_get_mctrl(struct uart_port *port)
 
 596 #ifdef CONFIG_SERIAL_BFIN_CTSRTS
 
 597         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 598         if (uart->cts_pin < 0)
 
 599                 return TIOCM_CTS | TIOCM_DSR | TIOCM_CAR;
 
 601         if (gpio_get_value(uart->cts_pin))
 
 602                 return TIOCM_DSR | TIOCM_CAR;
 
 605                 return TIOCM_CTS | TIOCM_DSR | TIOCM_CAR;
 
 608 static void bfin_serial_set_mctrl(struct uart_port *port, unsigned int mctrl)
 
 610 #ifdef CONFIG_SERIAL_BFIN_CTSRTS
 
 611         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 612         if (uart->rts_pin < 0)
 
 615         if (mctrl & TIOCM_RTS)
 
 616                 gpio_set_value(uart->rts_pin, 0);
 
 618                 gpio_set_value(uart->rts_pin, 1);
 
 623  * Handle any change of modem status signal since we were last called.
 
 625 static void bfin_serial_mctrl_check(struct bfin_serial_port *uart)
 
 627 #ifdef CONFIG_SERIAL_BFIN_CTSRTS
 
 629 # ifdef CONFIG_SERIAL_BFIN_DMA
 
 630         struct uart_info *info = uart->port.info;
 
 631         struct tty_struct *tty = info->tty;
 
 633         status = bfin_serial_get_mctrl(&uart->port);
 
 634         if (!(status & TIOCM_CTS)) {
 
 640         status = bfin_serial_get_mctrl(&uart->port);
 
 641         uart_handle_cts_change(&uart->port, status & TIOCM_CTS);
 
 642         if (!(status & TIOCM_CTS))
 
 643                 schedule_work(&uart->cts_workqueue);
 
 649  * Interrupts are always disabled.
 
 651 static void bfin_serial_break_ctl(struct uart_port *port, int break_state)
 
 653         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 654         u16 lcr = UART_GET_LCR(uart);
 
 659         UART_PUT_LCR(uart, lcr);
 
 663 static int bfin_serial_startup(struct uart_port *port)
 
 665         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 667 #ifdef CONFIG_SERIAL_BFIN_DMA
 
 668         dma_addr_t dma_handle;
 
 670         if (request_dma(uart->rx_dma_channel, "BFIN_UART_RX") < 0) {
 
 671                 printk(KERN_NOTICE "Unable to attach Blackfin UART RX DMA channel\n");
 
 675         if (request_dma(uart->tx_dma_channel, "BFIN_UART_TX") < 0) {
 
 676                 printk(KERN_NOTICE "Unable to attach Blackfin UART TX DMA channel\n");
 
 677                 free_dma(uart->rx_dma_channel);
 
 681         set_dma_callback(uart->rx_dma_channel, bfin_serial_dma_rx_int, uart);
 
 682         set_dma_callback(uart->tx_dma_channel, bfin_serial_dma_tx_int, uart);
 
 684         uart->rx_dma_buf.buf = (unsigned char *)dma_alloc_coherent(NULL, PAGE_SIZE, &dma_handle, GFP_DMA);
 
 685         uart->rx_dma_buf.head = 0;
 
 686         uart->rx_dma_buf.tail = 0;
 
 687         uart->rx_dma_nrows = 0;
 
 689         set_dma_config(uart->rx_dma_channel,
 
 690                 set_bfin_dma_config(DIR_WRITE, DMA_FLOW_AUTO,
 
 691                                 INTR_ON_ROW, DIMENSION_2D,
 
 693         set_dma_x_count(uart->rx_dma_channel, DMA_RX_XCOUNT);
 
 694         set_dma_x_modify(uart->rx_dma_channel, 1);
 
 695         set_dma_y_count(uart->rx_dma_channel, DMA_RX_YCOUNT);
 
 696         set_dma_y_modify(uart->rx_dma_channel, 1);
 
 697         set_dma_start_addr(uart->rx_dma_channel, (unsigned long)uart->rx_dma_buf.buf);
 
 698         enable_dma(uart->rx_dma_channel);
 
 700         uart->rx_dma_timer.data = (unsigned long)(uart);
 
 701         uart->rx_dma_timer.function = (void *)bfin_serial_rx_dma_timeout;
 
 702         uart->rx_dma_timer.expires = jiffies + DMA_RX_FLUSH_JIFFIES;
 
 703         add_timer(&(uart->rx_dma_timer));
 
 705         if (request_irq(uart->port.irq, bfin_serial_rx_int, IRQF_DISABLED,
 
 706              "BFIN_UART_RX", uart)) {
 
 707 # ifdef CONFIG_KGDB_UART
 
 708                 if (uart->port.line != CONFIG_KGDB_UART_PORT) {
 
 710                 printk(KERN_NOTICE "Unable to attach BlackFin UART RX interrupt\n");
 
 712 # ifdef CONFIG_KGDB_UART
 
 719             (uart->port.irq+1, bfin_serial_tx_int, IRQF_DISABLED,
 
 720              "BFIN_UART_TX", uart)) {
 
 721                 printk(KERN_NOTICE "Unable to attach BlackFin UART TX interrupt\n");
 
 722                 free_irq(uart->port.irq, uart);
 
 727         UART_SET_IER(uart, ERBFI);
 
 729         UART_PUT_IER(uart, UART_GET_IER(uart) | ERBFI);
 
 734 static void bfin_serial_shutdown(struct uart_port *port)
 
 736         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 738 #ifdef CONFIG_SERIAL_BFIN_DMA
 
 739         disable_dma(uart->tx_dma_channel);
 
 740         free_dma(uart->tx_dma_channel);
 
 741         disable_dma(uart->rx_dma_channel);
 
 742         free_dma(uart->rx_dma_channel);
 
 743         del_timer(&(uart->rx_dma_timer));
 
 745 #ifdef  CONFIG_KGDB_UART
 
 746         if (uart->port.line != CONFIG_KGDB_UART_PORT)
 
 748         free_irq(uart->port.irq, uart);
 
 749         free_irq(uart->port.irq+1, uart);
 
 754 bfin_serial_set_termios(struct uart_port *port, struct ktermios *termios,
 
 755                    struct ktermios *old)
 
 757         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 759         unsigned int baud, quot;
 
 760         unsigned short val, ier, lsr, lcr = 0;
 
 762         switch (termios->c_cflag & CSIZE) {
 
 776                 printk(KERN_ERR "%s: word lengh not supported\n",
 
 780         if (termios->c_cflag & CSTOPB)
 
 782         if (termios->c_cflag & PARENB)
 
 784         if (!(termios->c_cflag & PARODD))
 
 786         if (termios->c_cflag & CMSPAR)
 
 789         port->read_status_mask = OE;
 
 790         if (termios->c_iflag & INPCK)
 
 791                 port->read_status_mask |= (FE | PE);
 
 792         if (termios->c_iflag & (BRKINT | PARMRK))
 
 793                 port->read_status_mask |= BI;
 
 796          * Characters to ignore
 
 798         port->ignore_status_mask = 0;
 
 799         if (termios->c_iflag & IGNPAR)
 
 800                 port->ignore_status_mask |= FE | PE;
 
 801         if (termios->c_iflag & IGNBRK) {
 
 802                 port->ignore_status_mask |= BI;
 
 804                  * If we're ignoring parity and break indicators,
 
 805                  * ignore overruns too (for real raw support).
 
 807                 if (termios->c_iflag & IGNPAR)
 
 808                         port->ignore_status_mask |= OE;
 
 811         baud = uart_get_baud_rate(port, termios, old, 0, port->uartclk/16);
 
 812         quot = uart_get_divisor(port, baud);
 
 813         spin_lock_irqsave(&uart->port.lock, flags);
 
 816                 lsr = UART_GET_LSR(uart);
 
 817         } while (!(lsr & TEMT));
 
 820         ier = UART_GET_IER(uart);
 
 822         UART_CLEAR_IER(uart, 0xF);
 
 824         UART_PUT_IER(uart, 0);
 
 828         /* Set DLAB in LCR to Access DLL and DLH */
 
 829         val = UART_GET_LCR(uart);
 
 831         UART_PUT_LCR(uart, val);
 
 835         UART_PUT_DLL(uart, quot & 0xFF);
 
 837         UART_PUT_DLH(uart, (quot >> 8) & 0xFF);
 
 841         /* Clear DLAB in LCR to Access THR RBR IER */
 
 842         val = UART_GET_LCR(uart);
 
 844         UART_PUT_LCR(uart, val);
 
 848         UART_PUT_LCR(uart, lcr);
 
 852         UART_SET_IER(uart, ier);
 
 854         UART_PUT_IER(uart, ier);
 
 857         val = UART_GET_GCTL(uart);
 
 859         UART_PUT_GCTL(uart, val);
 
 861         spin_unlock_irqrestore(&uart->port.lock, flags);
 
 864 static const char *bfin_serial_type(struct uart_port *port)
 
 866         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 868         return uart->port.type == PORT_BFIN ? "BFIN-UART" : NULL;
 
 872  * Release the memory region(s) being used by 'port'.
 
 874 static void bfin_serial_release_port(struct uart_port *port)
 
 879  * Request the memory region(s) being used by 'port'.
 
 881 static int bfin_serial_request_port(struct uart_port *port)
 
 887  * Configure/autoconfigure the port.
 
 889 static void bfin_serial_config_port(struct uart_port *port, int flags)
 
 891         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
 893         if (flags & UART_CONFIG_TYPE &&
 
 894             bfin_serial_request_port(&uart->port) == 0)
 
 895                 uart->port.type = PORT_BFIN;
 
 899  * Verify the new serial_struct (for TIOCSSERIAL).
 
 900  * The only change we allow are to the flags and type, and
 
 901  * even then only between PORT_BFIN and PORT_UNKNOWN
 
 904 bfin_serial_verify_port(struct uart_port *port, struct serial_struct *ser)
 
 909 static struct uart_ops bfin_serial_pops = {
 
 910         .tx_empty       = bfin_serial_tx_empty,
 
 911         .set_mctrl      = bfin_serial_set_mctrl,
 
 912         .get_mctrl      = bfin_serial_get_mctrl,
 
 913         .stop_tx        = bfin_serial_stop_tx,
 
 914         .start_tx       = bfin_serial_start_tx,
 
 915         .stop_rx        = bfin_serial_stop_rx,
 
 916         .enable_ms      = bfin_serial_enable_ms,
 
 917         .break_ctl      = bfin_serial_break_ctl,
 
 918         .startup        = bfin_serial_startup,
 
 919         .shutdown       = bfin_serial_shutdown,
 
 920         .set_termios    = bfin_serial_set_termios,
 
 921         .type           = bfin_serial_type,
 
 922         .release_port   = bfin_serial_release_port,
 
 923         .request_port   = bfin_serial_request_port,
 
 924         .config_port    = bfin_serial_config_port,
 
 925         .verify_port    = bfin_serial_verify_port,
 
 928 static void __init bfin_serial_init_ports(void)
 
 930         static int first = 1;
 
 937         for (i = 0; i < nr_ports; i++) {
 
 938                 bfin_serial_ports[i].port.uartclk   = get_sclk();
 
 939                 bfin_serial_ports[i].port.ops       = &bfin_serial_pops;
 
 940                 bfin_serial_ports[i].port.line      = i;
 
 941                 bfin_serial_ports[i].port.iotype    = UPIO_MEM;
 
 942                 bfin_serial_ports[i].port.membase   =
 
 943                         (void __iomem *)bfin_serial_resource[i].uart_base_addr;
 
 944                 bfin_serial_ports[i].port.mapbase   =
 
 945                         bfin_serial_resource[i].uart_base_addr;
 
 946                 bfin_serial_ports[i].port.irq       =
 
 947                         bfin_serial_resource[i].uart_irq;
 
 948                 bfin_serial_ports[i].port.flags     = UPF_BOOT_AUTOCONF;
 
 949 #ifdef CONFIG_SERIAL_BFIN_DMA
 
 950                 bfin_serial_ports[i].tx_done        = 1;
 
 951                 bfin_serial_ports[i].tx_count       = 0;
 
 952                 bfin_serial_ports[i].tx_dma_channel =
 
 953                         bfin_serial_resource[i].uart_tx_dma_channel;
 
 954                 bfin_serial_ports[i].rx_dma_channel =
 
 955                         bfin_serial_resource[i].uart_rx_dma_channel;
 
 956                 init_timer(&(bfin_serial_ports[i].rx_dma_timer));
 
 958                 INIT_WORK(&bfin_serial_ports[i].cts_workqueue, bfin_serial_do_work);
 
 960 #ifdef CONFIG_SERIAL_BFIN_CTSRTS
 
 961                 bfin_serial_ports[i].cts_pin        =
 
 962                         bfin_serial_resource[i].uart_cts_pin;
 
 963                 bfin_serial_ports[i].rts_pin        =
 
 964                         bfin_serial_resource[i].uart_rts_pin;
 
 966                 bfin_serial_hw_init(&bfin_serial_ports[i]);
 
 971 #ifdef CONFIG_SERIAL_BFIN_CONSOLE
 
 973  * If the port was already initialised (eg, by a boot loader),
 
 974  * try to determine the current setup.
 
 977 bfin_serial_console_get_options(struct bfin_serial_port *uart, int *baud,
 
 978                            int *parity, int *bits)
 
 980         unsigned short status;
 
 982         status = UART_GET_IER(uart) & (ERBFI | ETBEI);
 
 983         if (status == (ERBFI | ETBEI)) {
 
 984                 /* ok, the port was enabled */
 
 985                 unsigned short lcr, val;
 
 986                 unsigned short dlh, dll;
 
 988                 lcr = UART_GET_LCR(uart);
 
 997                 switch (lcr & 0x03) {
 
 998                         case 0: *bits = 5; break;
 
 999                         case 1: *bits = 6; break;
 
1000                         case 2: *bits = 7; break;
 
1001                         case 3: *bits = 8; break;
 
1003 #ifndef CONFIG_BF54x
 
1004                 /* Set DLAB in LCR to Access DLL and DLH */
 
1005                 val = UART_GET_LCR(uart);
 
1007                 UART_PUT_LCR(uart, val);
 
1010                 dll = UART_GET_DLL(uart);
 
1011                 dlh = UART_GET_DLH(uart);
 
1013 #ifndef CONFIG_BF54x
 
1014                 /* Clear DLAB in LCR to Access THR RBR IER */
 
1015                 val = UART_GET_LCR(uart);
 
1017                 UART_PUT_LCR(uart, val);
 
1020                 *baud = get_sclk() / (16*(dll | dlh << 8));
 
1022         pr_debug("%s:baud = %d, parity = %c, bits= %d\n", __FUNCTION__, *baud, *parity, *bits);
 
1026 #if defined(CONFIG_SERIAL_BFIN_CONSOLE) || defined(CONFIG_EARLY_PRINTK)
 
1027 static struct uart_driver bfin_serial_reg;
 
1030 bfin_serial_console_setup(struct console *co, char *options)
 
1032         struct bfin_serial_port *uart;
 
1033 # ifdef CONFIG_SERIAL_BFIN_CONSOLE
 
1037 #  ifdef CONFIG_SERIAL_BFIN_CTSRTS
 
1045          * Check whether an invalid uart number has been specified, and
 
1046          * if so, search for the first available port that does have
 
1049         if (co->index == -1 || co->index >= nr_ports)
 
1051         uart = &bfin_serial_ports[co->index];
 
1053 # ifdef CONFIG_SERIAL_BFIN_CONSOLE
 
1055                 uart_parse_options(options, &baud, &parity, &bits, &flow);
 
1057                 bfin_serial_console_get_options(uart, &baud, &parity, &bits);
 
1059         return uart_set_options(&uart->port, co, baud, parity, bits, flow);
 
1064 #endif /* defined (CONFIG_SERIAL_BFIN_CONSOLE) ||
 
1065                                  defined (CONFIG_EARLY_PRINTK) */
 
1067 #ifdef CONFIG_SERIAL_BFIN_CONSOLE
 
1068 static void bfin_serial_console_putchar(struct uart_port *port, int ch)
 
1070         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
1071         while (!(UART_GET_LSR(uart) & THRE))
 
1073         UART_PUT_CHAR(uart, ch);
 
1078  * Interrupts are disabled on entering
 
1081 bfin_serial_console_write(struct console *co, const char *s, unsigned int count)
 
1083         struct bfin_serial_port *uart = &bfin_serial_ports[co->index];
 
1086         spin_lock_irqsave(&uart->port.lock, flags);
 
1087         uart_console_write(&uart->port, s, count, bfin_serial_console_putchar);
 
1088         spin_unlock_irqrestore(&uart->port.lock, flags);
 
1092 static struct console bfin_serial_console = {
 
1093         .name           = BFIN_SERIAL_NAME,
 
1094         .write          = bfin_serial_console_write,
 
1095         .device         = uart_console_device,
 
1096         .setup          = bfin_serial_console_setup,
 
1097         .flags          = CON_PRINTBUFFER,
 
1099         .data           = &bfin_serial_reg,
 
1102 static int __init bfin_serial_rs_console_init(void)
 
1104         bfin_serial_init_ports();
 
1105         register_console(&bfin_serial_console);
 
1106 #ifdef CONFIG_KGDB_UART
 
1107         kgdb_entry_state = 0;
 
1112 console_initcall(bfin_serial_rs_console_init);
 
1114 #define BFIN_SERIAL_CONSOLE     &bfin_serial_console
 
1116 #define BFIN_SERIAL_CONSOLE     NULL
 
1117 #endif /* CONFIG_SERIAL_BFIN_CONSOLE */
 
1120 #ifdef CONFIG_EARLY_PRINTK
 
1121 static __init void early_serial_putc(struct uart_port *port, int ch)
 
1123         unsigned timeout = 0xffff;
 
1124         struct bfin_serial_port *uart = (struct bfin_serial_port *)port;
 
1126         while ((!(UART_GET_LSR(uart) & THRE)) && --timeout)
 
1128         UART_PUT_CHAR(uart, ch);
 
1131 static __init void early_serial_write(struct console *con, const char *s,
 
1134         struct bfin_serial_port *uart = &bfin_serial_ports[con->index];
 
1137         for (i = 0; i < n; i++, s++) {
 
1139                         early_serial_putc(&uart->port, '\r');
 
1140                 early_serial_putc(&uart->port, *s);
 
1144 static struct __init console bfin_early_serial_console = {
 
1145         .name = "early_BFuart",
 
1146         .write = early_serial_write,
 
1147         .device = uart_console_device,
 
1148         .flags = CON_PRINTBUFFER,
 
1149         .setup = bfin_serial_console_setup,
 
1151         .data  = &bfin_serial_reg,
 
1154 struct console __init *bfin_earlyserial_init(unsigned int port,
 
1157         struct bfin_serial_port *uart;
 
1160         if (port == -1 || port >= nr_ports)
 
1162         bfin_serial_init_ports();
 
1163         bfin_early_serial_console.index = port;
 
1164         uart = &bfin_serial_ports[port];
 
1170         bfin_serial_set_termios(&uart->port, &t, &t);
 
1171         return &bfin_early_serial_console;
 
1174 #endif /* CONFIG_SERIAL_BFIN_CONSOLE */
 
1176 static struct uart_driver bfin_serial_reg = {
 
1177         .owner                  = THIS_MODULE,
 
1178         .driver_name            = "bfin-uart",
 
1179         .dev_name               = BFIN_SERIAL_NAME,
 
1180         .major                  = BFIN_SERIAL_MAJOR,
 
1181         .minor                  = BFIN_SERIAL_MINOR,
 
1183         .cons                   = BFIN_SERIAL_CONSOLE,
 
1186 static int bfin_serial_suspend(struct platform_device *dev, pm_message_t state)
 
1188         struct bfin_serial_port *uart = platform_get_drvdata(dev);
 
1191                 uart_suspend_port(&bfin_serial_reg, &uart->port);
 
1196 static int bfin_serial_resume(struct platform_device *dev)
 
1198         struct bfin_serial_port *uart = platform_get_drvdata(dev);
 
1201                 uart_resume_port(&bfin_serial_reg, &uart->port);
 
1206 static int bfin_serial_probe(struct platform_device *dev)
 
1208         struct resource *res = dev->resource;
 
1211         for (i = 0; i < dev->num_resources; i++, res++)
 
1212                 if (res->flags & IORESOURCE_MEM)
 
1215         if (i < dev->num_resources) {
 
1216                 for (i = 0; i < nr_ports; i++, res++) {
 
1217                         if (bfin_serial_ports[i].port.mapbase != res->start)
 
1219                         bfin_serial_ports[i].port.dev = &dev->dev;
 
1220                         uart_add_one_port(&bfin_serial_reg, &bfin_serial_ports[i].port);
 
1221                         platform_set_drvdata(dev, &bfin_serial_ports[i]);
 
1228 static int bfin_serial_remove(struct platform_device *pdev)
 
1230         struct bfin_serial_port *uart = platform_get_drvdata(pdev);
 
1233 #ifdef CONFIG_SERIAL_BFIN_CTSRTS
 
1234         gpio_free(uart->cts_pin);
 
1235         gpio_free(uart->rts_pin);
 
1238         platform_set_drvdata(pdev, NULL);
 
1241                 uart_remove_one_port(&bfin_serial_reg, &uart->port);
 
1246 static struct platform_driver bfin_serial_driver = {
 
1247         .probe          = bfin_serial_probe,
 
1248         .remove         = bfin_serial_remove,
 
1249         .suspend        = bfin_serial_suspend,
 
1250         .resume         = bfin_serial_resume,
 
1252                 .name   = "bfin-uart",
 
1256 static int __init bfin_serial_init(void)
 
1259 #ifdef CONFIG_KGDB_UART
 
1260         struct bfin_serial_port *uart = &bfin_serial_ports[CONFIG_KGDB_UART_PORT];
 
1264         pr_info("Serial: Blackfin serial driver\n");
 
1266         bfin_serial_init_ports();
 
1268         ret = uart_register_driver(&bfin_serial_reg);
 
1270                 ret = platform_driver_register(&bfin_serial_driver);
 
1272                         pr_debug("uart register failed\n");
 
1273                         uart_unregister_driver(&bfin_serial_reg);
 
1276 #ifdef CONFIG_KGDB_UART
 
1277         if (uart->port.cons->index != CONFIG_KGDB_UART_PORT) {
 
1278                 request_irq(uart->port.irq, bfin_serial_rx_int,
 
1279                         IRQF_DISABLED, "BFIN_UART_RX", uart);
 
1280                 pr_info("Request irq for kgdb uart port\n");
 
1282                 UART_SET_IER(uart, ERBFI);
 
1284                 UART_PUT_IER(uart, UART_GET_IER(uart) | ERBFI);
 
1287                 t.c_cflag = CS8|B57600;
 
1291                 t.c_line = CONFIG_KGDB_UART_PORT;
 
1292                 bfin_serial_set_termios(&uart->port, &t, &t);
 
1298 static void __exit bfin_serial_exit(void)
 
1300         platform_driver_unregister(&bfin_serial_driver);
 
1301         uart_unregister_driver(&bfin_serial_reg);
 
1304 module_init(bfin_serial_init);
 
1305 module_exit(bfin_serial_exit);
 
1307 MODULE_AUTHOR("Aubrey.Li <aubrey.li@analog.com>");
 
1308 MODULE_DESCRIPTION("Blackfin generic serial port driver");
 
1309 MODULE_LICENSE("GPL");
 
1310 MODULE_ALIAS_CHARDEV_MAJOR(BFIN_SERIAL_MAJOR);