8250.S 1.0 KB

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