~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/arm/include/debug/imx.S

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0-only */
  2 /* arch/arm/mach-imx/include/mach/debug-macro.S
  3  *
  4  * Debugging macro include header
  5  *
  6  *  Copyright (C) 1994-1999 Russell King
  7  *  Moved from linux/arch/arm/kernel/debug.S by Ben Dooks
  8  */
  9 
 10 #include <asm/assembler.h>
 11 #include "imx-uart.h"
 12 
 13 /*
 14  * FIXME: This is a copy of IMX_IO_P2V in hardware.h, and needs to
 15  * stay sync with that.  It's hard to maintain, and should be fixed
 16  * globally for multi-platform build to use a fixed virtual address
 17  * for low-level debug uart port across platforms.
 18  */
 19 #define IMX_IO_P2V(x)   (                                               \
 20                         (((x) & 0x80000000) >> 7) |                     \
 21                         (0xf4000000 +                                   \
 22                         (((x) & 0x50000000) >> 6) +                     \
 23                         (((x) & 0x0b000000) >> 4) +                     \
 24                         (((x) & 0x000fffff))))
 25 
 26 #define UART_VADDR      IMX_IO_P2V(UART_PADDR)
 27 
 28                 .macro  addruart, rp, rv, tmp
 29                 ldr     \rp, =UART_PADDR        @ physical
 30                 ldr     \rv, =UART_VADDR        @ virtual
 31                 .endm
 32 
 33                 .macro  senduart,rd,rx
 34                 ARM_BE8(rev \rd, \rd)
 35                 str     \rd, [\rx, #0x40]       @ TXDATA
 36                 .endm
 37 
 38                 .macro  waituartcts,rd,rx
 39                 .endm
 40 
 41                 .macro  waituarttxrdy,rd,rx
 42                 .endm
 43 
 44                 .macro  busyuart,rd,rx
 45 1002:           ldr     \rd, [\rx, #0x98]       @ SR2
 46                 ARM_BE8(rev \rd, \rd)
 47                 tst     \rd, #1 << 3            @ TXDC
 48                 beq     1002b                   @ wait until transmit done
 49                 .endm

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php