uartlite_tty.c 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. /*
  2. * Xilinx UARTLITE bootloader driver
  3. *
  4. * Copyright (c) 2007 Secret Lab Technologies Ltd.
  5. *
  6. * This program is free software; you can redistribute it and/or modify it
  7. * under the terms of the GNU General Public License as published by the
  8. * Free Software Foundation; either version 2 of the License, or (at your
  9. * option) any later version.
  10. */
  11. #include <linux/types.h>
  12. #include <asm/serial.h>
  13. #include <asm/io.h>
  14. #include <platforms/4xx/xparameters/xparameters.h>
  15. #define UARTLITE_BASEADDR ((void*)(XPAR_UARTLITE_0_BASEADDR))
  16. unsigned long
  17. serial_init(int chan, void *ignored)
  18. {
  19. /* Clear the RX FIFO */
  20. out_be32(UARTLITE_BASEADDR + 0x0C, 0x2);
  21. return 0;
  22. }
  23. void
  24. serial_putc(unsigned long com_port, unsigned char c)
  25. {
  26. while ((in_be32(UARTLITE_BASEADDR + 0x8) & 0x08) != 0); /* spin */
  27. out_be32(UARTLITE_BASEADDR + 0x4, c);
  28. }
  29. unsigned char
  30. serial_getc(unsigned long com_port)
  31. {
  32. while ((in_be32(UARTLITE_BASEADDR + 0x8) & 0x01) == 0); /* spin */
  33. return in_be32(UARTLITE_BASEADDR);
  34. }
  35. int
  36. serial_tstc(unsigned long com_port)
  37. {
  38. return ((in_be32(UARTLITE_BASEADDR + 0x8) & 0x01) != 0);
  39. }