1 /* linux/include/asm-arm/plat-s3c/debug-macro.S
 
   3  * Copyright 2005, 2007 Simtec Electronics
 
   4  *      http://armlinux.simtec.co.uk/
 
   5  *      Ben Dooks <ben@simtec.co.uk>
 
   7  * This program is free software; you can redistribute it and/or modify
 
   8  * it under the terms of the GNU General Public License version 2 as
 
   9  * published by the Free Software Foundation.
 
  12 #include <asm/plat-s3c/regs-serial.h>
 
  14 /* The S3C2440 implementations are used by default as they are the
 
  15  * most widely re-used */
 
  17         .macro fifo_level_s3c2440 rd, rx
 
  18                 ldr     \rd, [ \rx, # S3C2410_UFSTAT ]
 
  19                 and     \rd, \rd, #S3C2440_UFSTAT_TXMASK
 
  23 #define fifo_level fifo_level_s3c2410
 
  26         .macro  fifo_full_s3c2440 rd, rx
 
  27                 ldr     \rd, [ \rx, # S3C2410_UFSTAT ]
 
  28                 tst     \rd, #S3C2440_UFSTAT_TXFULL
 
  32 #define fifo_full fifo_full_s3c2440
 
  36                 strb    \rd, [\rx, # S3C2410_UTXH ]
 
  39         .macro  busyuart, rd, rx
 
  40                 ldr     \rd, [ \rx, # S3C2410_UFCON ]
 
  41                 tst     \rd, #S3C2410_UFCON_FIFOMODE    @ fifo enabled?
 
  50                 @ busy waiting for non fifo
 
  51                 ldr     \rd, [ \rx, # S3C2410_UTRSTAT ]
 
  52                 tst     \rd, #S3C2410_UTRSTAT_TXFE
 
  59                 ldr     \rd, [ \rx, # S3C2410_UFCON ]
 
  60                 tst     \rd, #S3C2410_UFCON_FIFOMODE    @ fifo enabled?
 
  69                 @ idle waiting for non fifo
 
  70                 ldr     \rd, [ \rx, # S3C2410_UTRSTAT ]
 
  71                 tst     \rd, #S3C2410_UTRSTAT_TXFE