summaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-lpc32xx/include/mach/hardware.h
diff options
context:
space:
mode:
authorKevin Wells <wellsk40@gmail.com>2010-02-27 00:53:38 +0100
committerKevin Wells <wellsk40@gmail.com>2010-07-27 12:08:08 +0200
commit437db5903653f6a8a736e77ad5c21a296d74299b (patch)
treebe1a44710420d6260db04b23876d650c54df838b /arch/arm/mach-lpc32xx/include/mach/hardware.h
parentMerge branch 'urgent' of git://git.kernel.org/pub/scm/linux/kernel/git/paulus... (diff)
downloadlinux-437db5903653f6a8a736e77ad5c21a296d74299b.tar.xz
linux-437db5903653f6a8a736e77ad5c21a296d74299b.zip
ARM: LPC32XX: Initial arch header files
Header files for the LPC32xx arch Signed-off-by: Kevin Wells <wellsk40@gmail.com> Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Diffstat (limited to 'arch/arm/mach-lpc32xx/include/mach/hardware.h')
-rw-r--r--arch/arm/mach-lpc32xx/include/mach/hardware.h34
1 files changed, 34 insertions, 0 deletions
diff --git a/arch/arm/mach-lpc32xx/include/mach/hardware.h b/arch/arm/mach-lpc32xx/include/mach/hardware.h
new file mode 100644
index 000000000000..33e1dde37bd9
--- /dev/null
+++ b/arch/arm/mach-lpc32xx/include/mach/hardware.h
@@ -0,0 +1,34 @@
+/*
+ * arch/arm/mach-lpc32xx/include/mach/hardware.h
+ *
+ * Copyright (c) 2005 MontaVista Software, Inc. <source@mvista.com>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ */
+
+#ifndef __ASM_ARCH_HARDWARE_H
+#define __ASM_ARCH_HARDWARE_H
+
+/*
+ * Start of virtual addresses for IO devices
+ */
+#define IO_BASE 0xF0000000
+
+/*
+ * This macro relies on fact that for all HW i/o addresses bits 20-23 are 0
+ */
+#define IO_ADDRESS(x) (((((x) & 0xff000000) >> 4) | ((x) & 0xfffff)) |\
+ IO_BASE)
+
+#define io_p2v(x) ((void __iomem *) (unsigned long) IO_ADDRESS(x))
+#define io_v2p(x) ((((x) & 0x0ff00000) << 4) | ((x) & 0x000fffff))
+
+#endif