/* * Copyright (C) 2007 Google, Inc. * Copyright (c) 2008-2011, The Linux Foundation. All rights reserved. * Author: Brian Swetland * * This software is licensed under the terms of the GNU General Public * License version 2, as published by the Free Software Foundation, and * may be copied, distributed, and modified under those terms. * * 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. * * * The MSM peripherals are spread all over across 768MB of physical * space, which makes just having a simple IO_ADDRESS macro to slide * them into the right virtual location rough. Instead, we will * provide a master phys->virt mapping for peripherals here. * */ #ifndef __ASM_ARCH_MSM_IOMAP_8960_H #define __ASM_ARCH_MSM_IOMAP_8960_H /* Physical base address and size of peripherals. * Ordered by the virtual base addresses they will be mapped at. * * If you add or remove entries here, you'll want to edit the * msm_io_desc array in arch/arm/mach-msm/io.c to reflect your * changes. * */ #define MSM8960_TMR_PHYS 0x0200A000 #define MSM8960_TMR_SIZE SZ_4K #define MSM8960_TMR0_PHYS 0x0208A000 #define MSM8960_TMR0_SIZE SZ_4K #define MSM8960_RPM_PHYS 0x00108000 #define MSM8960_RPM_SIZE SZ_4K #define MSM8960_RPM_MPM_PHYS 0x00200000 #define MSM8960_RPM_MPM_SIZE SZ_4K #define MSM8960_TCSR_PHYS 0x1A400000 #define MSM8960_TCSR_SIZE SZ_4K #define MSM8960_APCS_GCC_PHYS 0x02011000 #define MSM8960_APCS_GCC_SIZE SZ_4K #define MSM8960_SAW_L2_PHYS 0x02012000 #define MSM8960_SAW_L2_SIZE SZ_4K #define MSM8960_SAW0_PHYS 0x02089000 #define MSM8960_SAW0_SIZE SZ_4K #define MSM8960_SAW1_PHYS 0x02099000 #define MSM8960_SAW1_SIZE SZ_4K #define MSM8960_IMEM_PHYS 0x2A03F000 #define MSM8960_IMEM_SIZE SZ_4K #define MSM8960_ACC0_PHYS 0x02088000 #define MSM8960_ACC0_SIZE SZ_4K #define MSM8960_ACC1_PHYS 0x02098000 #define MSM8960_ACC1_SIZE SZ_4K #define MSM8960_QGIC_DIST_PHYS 0x02000000 #define MSM8960_QGIC_DIST_SIZE SZ_4K #define MSM8960_QGIC_CPU_PHYS 0x02002000 #define MSM8960_QGIC_CPU_SIZE SZ_4K #define MSM8960_CLK_CTL_PHYS 0x00900000 #define MSM8960_CLK_CTL_SIZE SZ_16K #define MSM8960_MMSS_CLK_CTL_PHYS 0x04000000 #define MSM8960_MMSS_CLK_CTL_SIZE SZ_4K #define MSM8960_LPASS_CLK_CTL_PHYS 0x28000000 #define MSM8960_LPASS_CLK_CTL_SIZE SZ_4K #define MSM8960_HFPLL_PHYS 0x00903000 #define MSM8960_HFPLL_SIZE SZ_4K #define MSM8960_TLMM_PHYS 0x00800000 #define MSM8960_TLMM_SIZE SZ_16K #define MSM8960_SIC_NON_SECURE_PHYS 0x12100000 #define MSM8960_SIC_NON_SECURE_SIZE SZ_64K #define MSM_GPT_BASE (MSM_TMR_BASE + 0x4) #define MSM_DGT_BASE (MSM_TMR_BASE + 0x24) #define MSM8960_HDMI_PHYS 0x04A00000 #define MSM8960_HDMI_SIZE SZ_4K #ifdef CONFIG_DEBUG_MSM8960_UART #define MSM_DEBUG_UART_BASE IOMEM(0xFA740000) #define MSM_DEBUG_UART_PHYS 0x16440000 #endif #define MSM8960_QFPROM_PHYS 0x00700000 #define MSM8960_QFPROM_SIZE SZ_4K #ifndef __ASSEMBLY__ extern void msm_map_msm8960_io(void); #endif #endif