8250.S 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /*
  2. * arch/arm/include/debug/8250.S
  3. *
  4. * Copyright (C) 1994-2013 Russell King
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. */
  10. #include <linux/serial_reg.h>
  11. .macro addruart, rp, rv, tmp
  12. ldr \rp, =CONFIG_DEBUG_UART_PHYS
  13. ldr \rv, =CONFIG_DEBUG_UART_VIRT
  14. .endm
  15. #ifdef CONFIG_DEBUG_UART_8250_WORD
  16. .macro store, rd, rx:vararg
  17. ARM_BE8(rev \rd, \rd)
  18. str \rd, \rx
  19. ARM_BE8(rev \rd, \rd)
  20. .endm
  21. .macro load, rd, rx:vararg
  22. ldr \rd, \rx
  23. ARM_BE8(rev \rd, \rd)
  24. .endm
  25. #else
  26. .macro store, rd, rx:vararg
  27. strb \rd, \rx
  28. .endm
  29. .macro load, rd, rx:vararg
  30. ldrb \rd, \rx
  31. .endm
  32. #endif
  33. #define UART_SHIFT CONFIG_DEBUG_UART_8250_SHIFT
  34. .macro senduart,rd,rx
  35. store \rd, [\rx, #UART_TX << UART_SHIFT]
  36. .endm
  37. .macro busyuart,rd,rx
  38. 1002: load \rd, [\rx, #UART_LSR << UART_SHIFT]
  39. and \rd, \rd, #UART_LSR_TEMT | UART_LSR_THRE
  40. teq \rd, #UART_LSR_TEMT | UART_LSR_THRE
  41. bne 1002b
  42. .endm
  43. .macro waituart,rd,rx
  44. #ifdef CONFIG_DEBUG_UART_8250_FLOW_CONTROL
  45. 1001: load \rd, [\rx, #UART_MSR << UART_SHIFT]
  46. tst \rd, #UART_MSR_CTS
  47. beq 1001b
  48. #endif
  49. .endm