meson.S 771 B

1234567891011121314151617181920212223242526272829303132333435
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (C) 2014 Carlo Caione
  4. * Carlo Caione <[email protected]>
  5. */
  6. #define MESON_AO_UART_WFIFO 0x0
  7. #define MESON_AO_UART_STATUS 0xc
  8. #define MESON_AO_UART_TX_FIFO_EMPTY (1 << 22)
  9. #define MESON_AO_UART_TX_FIFO_FULL (1 << 21)
  10. .macro addruart, rp, rv, tmp
  11. ldr \rp, =(CONFIG_DEBUG_UART_PHYS) @ physical
  12. ldr \rv, =(CONFIG_DEBUG_UART_VIRT) @ virtual
  13. .endm
  14. .macro senduart,rd,rx
  15. str \rd, [\rx, #MESON_AO_UART_WFIFO]
  16. .endm
  17. .macro busyuart,rd,rx
  18. 1002: ldr \rd, [\rx, #MESON_AO_UART_STATUS]
  19. tst \rd, #MESON_AO_UART_TX_FIFO_EMPTY
  20. beq 1002b
  21. .endm
  22. .macro waituartcts,rd,rx
  23. .endm
  24. .macro waituarttxrdy,rd,rx
  25. 1001: ldr \rd, [\rx, #MESON_AO_UART_STATUS]
  26. tst \rd, #MESON_AO_UART_TX_FIFO_FULL
  27. bne 1001b
  28. .endm