diff options
Diffstat (limited to 'arch/arm/mach-omap2/serial.c')
-rw-r--r-- | arch/arm/mach-omap2/serial.c | 70 |
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 | ||
634 | void __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 | */ | ||
645 | void __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 | */ | ||
688 | void __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 | } |