/* * Copyright 2008 Freescale Semiconductor, Inc. All Rights Reserved. * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. */ /* * The code contained herein is licensed under the GNU General Public * License. You may obtain a copy of the GNU General Public License * Version 2 or later at the following locations: * * http://www.opensource.org/licenses/gpl-license.html * http://www.gnu.org/copyleft/gpl.html */ #ifndef __ASM_PLAT_PLATFORM_H #define __ASM_PLAT_PLATFORM_H #ifndef __ASSEMBLER__ #include <linux/io.h> #endif #include <asm/sizes.h> /* Virtual address where registers are mapped */ #define STMP3XXX_REGS_PHBASE 0x80000000 #ifdef __ASSEMBLER__ #define STMP3XXX_REGS_BASE 0xF0000000 #else #define STMP3XXX_REGS_BASE (void __iomem *)0xF0000000 #endif #define STMP3XXX_REGS_SIZE SZ_1M /* Virtual address where OCRAM is mapped */ #define STMP3XXX_OCRAM_PHBASE 0x00000000 #ifdef __ASSEMBLER__ #define STMP3XXX_OCRAM_BASE 0xf1000000 #else #define STMP3XXX_OCRAM_BASE (void __iomem *)0xf1000000 #endif #define STMP3XXX_OCRAM_SIZE (32 * SZ_1K) #ifdef CONFIG_ARCH_STMP37XX #define IRQ_PRIORITY_REG_RD HW_ICOLL_PRIORITYn_RD #define IRQ_PRIORITY_REG_WR HW_ICOLL_PRIORITYn_WR #endif #ifdef CONFIG_ARCH_STMP378X #define IRQ_PRIORITY_REG_RD HW_ICOLL_INTERRUPTn_RD #define IRQ_PRIORITY_REG_WR HW_ICOLL_INTERRUPTn_WR #endif #define HW_STMP3XXX_SET 0x04 #define HW_STMP3XXX_CLR 0x08 #define HW_STMP3XXX_TOG 0x0c #ifndef __ASSEMBLER__ static inline void stmp3xxx_clearl(u32 v, void __iomem *r) { __raw_writel(v, r + HW_STMP3XXX_CLR); } static inline void stmp3xxx_setl(u32 v, void __iomem *r) { __raw_writel(v, r + HW_STMP3XXX_SET); } #endif #define BF(value, field) (((value) << BP_##field) & BM_##field) #endif /* __ASM_ARCH_PLATFORM_H */