8250.S 1002 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * arch/arm/include/debug/8250.S
  3. *
  4. * Copyright (C) 1994-2013 Russell King
  5. *
  6. * SPDX-License-Identifier: GPL-2.0+
  7. */
  8. #include <linux/serial_reg.h>
  9. .macro addruart, rp, rv, tmp
  10. ldr \rp, =CONFIG_DEBUG_UART_PHYS
  11. ldr \rv, =CONFIG_DEBUG_UART_VIRT
  12. .endm
  13. #ifdef CONFIG_DEBUG_UART_8250_WORD
  14. .macro store, rd, rx:vararg
  15. str \rd, \rx
  16. .endm
  17. .macro load, rd, rx:vararg
  18. ldr \rd, \rx
  19. .endm
  20. #else
  21. .macro store, rd, rx:vararg
  22. strb \rd, \rx
  23. .endm
  24. .macro load, rd, rx:vararg
  25. ldrb \rd, \rx
  26. .endm
  27. #endif
  28. #define UART_SHIFT CONFIG_DEBUG_UART_8250_SHIFT
  29. .macro senduart,rd,rx
  30. store \rd, [\rx, #UART_TX << UART_SHIFT]
  31. .endm
  32. .macro busyuart,rd,rx
  33. 1002: load \rd, [\rx, #UART_LSR << UART_SHIFT]
  34. and \rd, \rd, #UART_LSR_TEMT | UART_LSR_THRE
  35. teq \rd, #UART_LSR_TEMT | UART_LSR_THRE
  36. bne 1002b
  37. .endm
  38. .macro waituart,rd,rx
  39. #ifdef CONFIG_DEBUG_UART_8250_FLOW_CONTROL
  40. 1001: load \rd, [\rx, #UART_MSR << UART_SHIFT]
  41. tst \rd, #UART_MSR_CTS
  42. beq 1001b
  43. #endif
  44. .endm