aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-omap2/serial.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/mach-omap2/serial.c')
-rw-r--r--arch/arm/mach-omap2/serial.c70
1 files changed, 55 insertions, 15 deletions
diff --git a/arch/arm/mach-omap2/serial.c b/arch/arm/mach-omap2/serial.c
index 2e17b57f5b23..6278fe585c05 100644
--- a/arch/arm/mach-omap2/serial.c
+++ b/arch/arm/mach-omap2/serial.c
@@ -631,24 +631,64 @@ void __init omap_serial_early_init(void)
631 } 631 }
632} 632}
633 633
634void __init omap_serial_init(void) 634/**
635 * omap_serial_init_port() - initialize single serial port
636 * @port: serial port number (0-3)
637 *
638 * This function initialies serial driver for given @port only.
639 * Platforms can call this function instead of omap_serial_init()
640 * if they don't plan to use all available UARTs as serial ports.
641 *
642 * Don't mix calls to omap_serial_init_port() and omap_serial_init(),
643 * use only one of the two.
644 */
645void __init omap_serial_init_port(int port)
635{ 646{
636 int i; 647 struct omap_uart_state *uart;
648 struct platform_device *pdev;
649 struct device *dev;
637 650
638 for (i = 0; i < ARRAY_SIZE(omap_uart); i++) { 651 BUG_ON(port < 0);
639 struct omap_uart_state *uart = &omap_uart[i]; 652 BUG_ON(port >= ARRAY_SIZE(omap_uart));
640 struct platform_device *pdev = &uart->pdev;
641 struct device *dev = &pdev->dev;
642 653
643 omap_uart_reset(uart); 654 uart = &omap_uart[port];
644 omap_uart_idle_init(uart); 655 pdev = &uart->pdev;
656 dev = &pdev->dev;
645 657
646 if (WARN_ON(platform_device_register(pdev))) 658 omap_uart_reset(uart);
647 continue; 659 omap_uart_idle_init(uart);
648 if ((cpu_is_omap34xx() && uart->padconf) || 660
649 (uart->wk_en && uart->wk_mask)) { 661 if (WARN_ON(platform_device_register(pdev)))
650 device_init_wakeup(dev, true); 662 return;
651 DEV_CREATE_FILE(dev, &dev_attr_sleep_timeout); 663
652 } 664 if ((cpu_is_omap34xx() && uart->padconf) ||
665 (uart->wk_en && uart->wk_mask)) {
666 device_init_wakeup(dev, true);
667 DEV_CREATE_FILE(dev, &dev_attr_sleep_timeout);
653 } 668 }
669
670 /* omap44xx: Never read empty UART fifo
671 * omap3xxx: Never read empty UART fifo on UARTs
672 * with IP rev >=0x52
673 */
674 if (cpu_is_omap44xx())
675 uart->p->serial_in = serial_in_override;
676 else if ((serial_read_reg(uart->p, UART_OMAP_MVER) & 0xFF)
677 >= UART_OMAP_NO_EMPTY_FIFO_READ_IP_REV)
678 uart->p->serial_in = serial_in_override;
679}
680
681/**
682 * omap_serial_init() - intialize all supported serial ports
683 *
684 * Initializes all available UARTs as serial ports. Platforms
685 * can call this function when they want to have default behaviour
686 * for serial ports (e.g initialize them all as serial ports).
687 */
688void __init omap_serial_init(void)
689{
690 int i;
691
692 for (i = 0; i < ARRAY_SIZE(omap_uart); i++)
693 omap_serial_init_port(i);
654} 694}