mcfuart.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. /*
  2. * (C) Copyright 2004-2007 Freescale Semiconductor, Inc.
  3. * TsiChung Liew, Tsi-Chung.Liew@freescale.com.
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. /*
  8. * Minimal serial functions needed to use one of the uart ports
  9. * as serial console interface.
  10. */
  11. #include <common.h>
  12. #include <serial.h>
  13. #include <linux/compiler.h>
  14. #include <asm/immap.h>
  15. #include <asm/uart.h>
  16. DECLARE_GLOBAL_DATA_PTR;
  17. extern void uart_port_conf(int port);
  18. static int mcf_serial_init(void)
  19. {
  20. volatile uart_t *uart;
  21. u32 counter;
  22. uart = (volatile uart_t *)(CONFIG_SYS_UART_BASE);
  23. uart_port_conf(CONFIG_SYS_UART_PORT);
  24. /* write to SICR: SIM2 = uart mode,dcd does not affect rx */
  25. uart->ucr = UART_UCR_RESET_RX;
  26. uart->ucr = UART_UCR_RESET_TX;
  27. uart->ucr = UART_UCR_RESET_ERROR;
  28. uart->ucr = UART_UCR_RESET_MR;
  29. __asm__("nop");
  30. uart->uimr = 0;
  31. /* write to CSR: RX/TX baud rate from timers */
  32. uart->ucsr = (UART_UCSR_RCS_SYS_CLK | UART_UCSR_TCS_SYS_CLK);
  33. uart->umr = (UART_UMR_BC_8 | UART_UMR_PM_NONE);
  34. uart->umr = UART_UMR_SB_STOP_BITS_1;
  35. /* Setting up BaudRate */
  36. counter = (u32) ((gd->bus_clk / 32) + (gd->baudrate / 2));
  37. counter = counter / gd->baudrate;
  38. /* write to CTUR: divide counter upper byte */
  39. uart->ubg1 = (u8) ((counter & 0xff00) >> 8);
  40. /* write to CTLR: divide counter lower byte */
  41. uart->ubg2 = (u8) (counter & 0x00ff);
  42. uart->ucr = (UART_UCR_RX_ENABLED | UART_UCR_TX_ENABLED);
  43. return (0);
  44. }
  45. static void mcf_serial_putc(const char c)
  46. {
  47. volatile uart_t *uart = (volatile uart_t *)(CONFIG_SYS_UART_BASE);
  48. if (c == '\n')
  49. serial_putc('\r');
  50. /* Wait for last character to go. */
  51. while (!(uart->usr & UART_USR_TXRDY)) ;
  52. uart->utb = c;
  53. }
  54. static int mcf_serial_getc(void)
  55. {
  56. volatile uart_t *uart = (volatile uart_t *)(CONFIG_SYS_UART_BASE);
  57. /* Wait for a character to arrive. */
  58. while (!(uart->usr & UART_USR_RXRDY)) ;
  59. return uart->urb;
  60. }
  61. static int mcf_serial_tstc(void)
  62. {
  63. volatile uart_t *uart = (volatile uart_t *)(CONFIG_SYS_UART_BASE);
  64. return (uart->usr & UART_USR_RXRDY);
  65. }
  66. static void mcf_serial_setbrg(void)
  67. {
  68. volatile uart_t *uart = (volatile uart_t *)(CONFIG_SYS_UART_BASE);
  69. u32 counter;
  70. /* Setting up BaudRate */
  71. counter = (u32) ((gd->bus_clk / 32) + (gd->baudrate / 2));
  72. counter = counter / gd->baudrate;
  73. /* write to CTUR: divide counter upper byte */
  74. uart->ubg1 = ((counter & 0xff00) >> 8);
  75. /* write to CTLR: divide counter lower byte */
  76. uart->ubg2 = (counter & 0x00ff);
  77. uart->ucr = UART_UCR_RESET_RX;
  78. uart->ucr = UART_UCR_RESET_TX;
  79. uart->ucr = UART_UCR_RX_ENABLED | UART_UCR_TX_ENABLED;
  80. }
  81. static struct serial_device mcf_serial_drv = {
  82. .name = "mcf_serial",
  83. .start = mcf_serial_init,
  84. .stop = NULL,
  85. .setbrg = mcf_serial_setbrg,
  86. .putc = mcf_serial_putc,
  87. .puts = default_serial_puts,
  88. .getc = mcf_serial_getc,
  89. .tstc = mcf_serial_tstc,
  90. };
  91. void mcf_serial_initialize(void)
  92. {
  93. serial_register(&mcf_serial_drv);
  94. }
  95. __weak struct serial_device *default_serial_console(void)
  96. {
  97. return &mcf_serial_drv;
  98. }