1 /* arch/arm/plat-samsung/include/plat/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 <linux/serial_s3c.h>
14 /* The S5PV210/S5PC110 implementations are as belows. */
16 .macro fifo_level_s5pv210 rd, rx
17 ldr \rd, [\rx, # S3C2410_UFSTAT]
19 and \rd, \rd, #S5PV210_UFSTAT_TXMASK
22 .macro fifo_full_s5pv210 rd, rx
23 ldr \rd, [\rx, # S3C2410_UFSTAT]
25 tst \rd, #S5PV210_UFSTAT_TXFULL
28 /* The S3C2440 implementations are used by default as they are the
29 * most widely re-used */
31 .macro fifo_level_s3c2440 rd, rx
32 ldr \rd, [\rx, # S3C2410_UFSTAT]
34 and \rd, \rd, #S3C2440_UFSTAT_TXMASK
38 #define fifo_level fifo_level_s3c2440
41 .macro fifo_full_s3c2440 rd, rx
42 ldr \rd, [\rx, # S3C2410_UFSTAT]
44 tst \rd, #S3C2440_UFSTAT_TXFULL
48 #define fifo_full fifo_full_s3c2440
52 strb \rd, [\rx, # S3C2410_UTXH]
55 .macro busyuart, rd, rx
56 ldr \rd, [\rx, # S3C2410_UFCON]
58 tst \rd, #S3C2410_UFCON_FIFOMODE @ fifo enabled?
67 @ busy waiting for non fifo
68 ldr \rd, [\rx, # S3C2410_UTRSTAT]
70 tst \rd, #S3C2410_UTRSTAT_TXFE
77 ldr \rd, [\rx, # S3C2410_UFCON]
79 tst \rd, #S3C2410_UFCON_FIFOMODE @ fifo enabled?
88 @ idle waiting for non fifo
89 ldr \rd, [\rx, # S3C2410_UTRSTAT]
91 tst \rd, #S3C2410_UTRSTAT_TXFE