/* SPDX-License-Identifier: GPL-2.0-only */1/*2* Debugging macro include header3*4* Copyright (C) 2011 Xilinx5*/6#define UART_CR_OFFSET 0x00 /* Control Register [8:0] */7#define UART_SR_OFFSET 0x2C /* Channel Status [11:0] */8#define UART_FIFO_OFFSET 0x30 /* FIFO [15:0] or [7:0] */910#define UART_SR_TXFULL 0x00000010 /* TX FIFO full */11#define UART_SR_TXEMPTY 0x00000008 /* TX FIFO empty */1213#define UART0_PHYS 0xE000000014#define UART0_VIRT 0xF080000015#define UART1_PHYS 0xE000100016#define UART1_VIRT 0xF08010001718#if IS_ENABLED(CONFIG_DEBUG_ZYNQ_UART1)19# define LL_UART_PADDR UART1_PHYS20# define LL_UART_VADDR UART1_VIRT21#else22# define LL_UART_PADDR UART0_PHYS23# define LL_UART_VADDR UART0_VIRT24#endif2526.macro addruart, rp, rv, tmp27ldr \rp, =LL_UART_PADDR @ physical28ldr \rv, =LL_UART_VADDR @ virtual29.endm3031.macro senduart,rd,rx32strb \rd, [\rx, #UART_FIFO_OFFSET] @ TXDATA33.endm3435.macro waituartcts,rd,rx36.endm3738.macro waituarttxrdy,rd,rx391001: ldr \rd, [\rx, #UART_SR_OFFSET]40ARM_BE8( rev \rd, \rd )41tst \rd, #UART_SR_TXEMPTY42beq 1001b43.endm4445.macro busyuart,rd,rx461002: ldr \rd, [\rx, #UART_SR_OFFSET] @ get status register47ARM_BE8( rev \rd, \rd )48tst \rd, #UART_SR_TXFULL @49bne 1002b @ wait if FIFO is full50.endm515253