| /* |
| * Copyright (C) 2009 ST-Ericsson. |
| * |
| * U8500 hardware definitions |
| * |
| * This file is licensed under the terms of the GNU General Public |
| * License version 2. This program is licensed "as is" without any |
| * warranty of any kind, whether express or implied. |
| */ |
| #ifndef __MACH_HARDWARE_H |
| #define __MACH_HARDWARE_H |
| |
| /* |
| * Macros to get at IO space when running virtually |
| * We dont map all the peripherals, let ioremap do |
| * this for us. We map only very basic peripherals here. |
| */ |
| #define U8500_IO_VIRTUAL 0xf0000000 |
| #define U8500_IO_PHYSICAL 0xa0000000 |
| /* This is where we map in the ROM to check ASIC IDs */ |
| #define UX500_VIRT_ROM 0xf0000000 |
| |
| /* This macro is used in assembly, so no cast */ |
| #define IO_ADDRESS(x) \ |
| (((x) & 0x0fffffff) + (((x) >> 4) & 0x0f000000) + U8500_IO_VIRTUAL) |
| |
| /* typesafe io address */ |
| #define __io_address(n) IOMEM(IO_ADDRESS(n)) |
| |
| /* Used by some plat-nomadik code */ |
| #define io_p2v(n) __io_address(n) |
| |
| #include <mach/db8500-regs.h> |
| |
| #define MSP_TX_RX_REG_OFFSET 0 |
| #define CRYP1_RX_REG_OFFSET 0x10 |
| #define CRYP1_TX_REG_OFFSET 0x8 |
| #define HASH1_TX_REG_OFFSET 0x4 |
| |
| #ifndef __ASSEMBLY__ |
| |
| extern void __iomem *_PRCMU_BASE; |
| |
| #define ARRAY_AND_SIZE(x) (x), ARRAY_SIZE(x) |
| |
| #endif /* __ASSEMBLY__ */ |
| #endif /* __MACH_HARDWARE_H */ |