diff options
Diffstat (limited to 'arch/arm/mach-omap2/omap4-sar.c')
-rw-r--r-- | arch/arm/mach-omap2/omap4-sar.c | 1054 |
1 files changed, 1054 insertions, 0 deletions
diff --git a/arch/arm/mach-omap2/omap4-sar.c b/arch/arm/mach-omap2/omap4-sar.c new file mode 100644 index 0000000..85b5fe9 --- /dev/null +++ b/arch/arm/mach-omap2/omap4-sar.c @@ -0,0 +1,1054 @@ +/* + * OMAP4 Save Restore source file + * + * Copyright (C) 2010 Texas Instruments, Inc. + * Written by Santosh Shilimkar <santosh.shilimkar@ti.com> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ + +#include <linux/kernel.h> +#include <linux/init.h> +#include <linux/io.h> +#include <linux/platform_device.h> +#include <linux/clk.h> + +#include <mach/omap4-common.h> +#include <mach/ctrl_module_wkup_44xx.h> + +#include "clockdomain.h" +#include "omap4-sar-layout.h" +#include "cm-regbits-44xx.h" +#include "prcm44xx.h" +#include "cminst44xx.h" + +/* + * These SECURE control registers are used to work-around + * DDR corruption on the second chip select on OMAP443x. + */ +#define OMAP4_CTRL_SECURE_EMIF1_SDRAM_CONFIG2_REG 0x0114 +#define OMAP4_CTRL_SECURE_EMIF2_SDRAM_CONFIG2_REG 0x011c + +static void __iomem *sar_ram_base; +static void __iomem *omap4_sar_modules[MAX_SAR_MODULES]; +static struct powerdomain *l3init_pwrdm; + static struct clockdomain *l3init_clkdm; +static struct clk *usb_host_ck, *usb_tll_ck; + +/* + * SAR_RAM1 register layout consist of EMIF1, EMIF2, CM1, CM2, + * CONTROL_CORE efuse, DMM and USB TLL registers. + * The layout is arranged is a two dimentional array like + * below, + * const u32 sar_ramX_layout[nb_regs_sets][4] = { + * {module_index, reg_offset, size, sar_ram_offset}, + * } + */ +static const u32 omap443x_sar_ram1_layout[][4] = { + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_CONFIG, 1, 0x00000000}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_CONFIG_2, 1, 0x00000004}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_REF_CTRL, 1, 0x00000008}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_REF_CTRL_SHDW, 1, 0x0000000C}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_1, 1, 0x00000010}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_1_SHDW, 1, 0x00000014}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_2, 1, 0x00000018}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_2_SHDW, 1, 0x0000001C}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_3, 1, 0x00000020}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_3_SHDW, 1, 0x00000024}, + {EMIF1_INDEX, OMAP44XX_EMIF_LPDDR2_NVM_TIM, 1, 0x00000028}, + {EMIF1_INDEX, OMAP44XX_EMIF_LPDDR2_NVM_TIM_SHDW, 1, 0x0000002C}, + {EMIF1_INDEX, OMAP44XX_EMIF_PWR_MGMT_CTRL, 1, 0x00000030}, + {EMIF1_INDEX, OMAP44XX_EMIF_PWR_MGMT_CTRL_SHDW, 1, 0x00000034}, + {EMIF1_INDEX, OMAP44XX_EMIF_OCP_CONFIG, 1, 0x00000038}, + {EMIF1_INDEX, OMAP44XX_EMIF_PERF_CNT_CFG, 1, 0x0000003C}, + {EMIF1_INDEX, OMAP44XX_EMIF_PERF_CNT_SEL, 1, 0x00000040}, + {EMIF1_INDEX, OMAP44XX_EMIF_READ_IDLE_CTRL, 1, 0x00000044}, + {EMIF1_INDEX, OMAP44XX_EMIF_READ_IDLE_CTRL_SHDW, 1, 0x00000048}, + {EMIF1_INDEX, OMAP44XX_EMIF_IRQENABLE_SET_SYS, 1, 0x0000004C}, + {EMIF1_INDEX, OMAP44XX_EMIF_IRQENABLE_SET_LL, 1, 0x00000050}, + {EMIF1_INDEX, OMAP44XX_EMIF_ZQ_CONFIG, 1, 0x00000054}, + {EMIF1_INDEX, OMAP44XX_EMIF_TEMP_ALERT_CONFIG, 1, 0x00000058}, + {EMIF1_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_1, 1, 0x0000005C}, + {EMIF1_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_1_SHDW, 1, 0x00000060}, + {EMIF1_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_2, 1, 0x00000064}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_CONFIG, 1, 0x00000068}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_CONFIG_2, 1, 0x0000006C}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_REF_CTRL, 1, 0x00000070}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_REF_CTRL_SHDW, 1, 0x00000074}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_1, 1, 0x00000078}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_1_SHDW, 1, 0x0000007C}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_2, 1, 0x00000080}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_2_SHDW, 1, 0x00000084}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_3, 1, 0x00000088}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_3_SHDW, 1, 0x0000008C}, + {EMIF2_INDEX, OMAP44XX_EMIF_LPDDR2_NVM_TIM, 1, 0x00000090}, + {EMIF2_INDEX, OMAP44XX_EMIF_LPDDR2_NVM_TIM_SHDW, 1, 0x00000094}, + {EMIF2_INDEX, OMAP44XX_EMIF_PWR_MGMT_CTRL, 1, 0x00000098}, + {EMIF2_INDEX, OMAP44XX_EMIF_PWR_MGMT_CTRL_SHDW, 1, 0x0000009C}, + {EMIF2_INDEX, OMAP44XX_EMIF_OCP_CONFIG, 1, 0x000000A0}, + {EMIF2_INDEX, OMAP44XX_EMIF_PERF_CNT_CFG, 1, 0x000000A4}, + {EMIF2_INDEX, OMAP44XX_EMIF_PERF_CNT_SEL, 1, 0x000000A8}, + {EMIF2_INDEX, OMAP44XX_EMIF_READ_IDLE_CTRL, 1, 0x000000AC}, + {EMIF2_INDEX, OMAP44XX_EMIF_READ_IDLE_CTRL_SHDW, 1, 0x000000B0}, + {EMIF2_INDEX, OMAP44XX_EMIF_IRQENABLE_SET_SYS, 1, 0x000000B4}, + {EMIF2_INDEX, OMAP44XX_EMIF_IRQENABLE_SET_LL, 1, 0x000000B8}, + {EMIF2_INDEX, OMAP44XX_EMIF_ZQ_CONFIG, 1, 0x000000BC}, + {EMIF2_INDEX, OMAP44XX_EMIF_TEMP_ALERT_CONFIG, 1, 0x000000C0}, + {EMIF2_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_1, 1, 0x000000C4}, + {EMIF2_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_1_SHDW, 1, 0x000000C8}, + {EMIF2_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_2, 1, 0x000000CC}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_MEMIF_CLKSTCTRL_RESTORE_OFFSET, 1, 0x000000D0}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_CLKSEL_CORE_RESTORE_OFFSET, 1, 0x000000D4}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M2_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000D8}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M3_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000DC}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M4_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000E0}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M5_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000E4}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M6_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000E8}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M7_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000EC}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_CLKSEL_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000F0}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_SSC_DELTAMSTEP_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000F4}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_SSC_MODFREQDIV_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000F8}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_CLKMODE_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000FC}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_SHADOW_FREQ_CONFIG2_RESTORE_OFFSET, 1, 0x00000100}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_SHADOW_FREQ_CONFIG1_RESTORE_OFFSET, 1, 0x00000104}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_AUTOIDLE_DPLL_CORE_RESTORE_OFFSET, 1, 0x00000108}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_MPU_CLKSTCTRL_RESTORE_OFFSET, 1, 0x0000010C}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_CM1_PROFILING_CLKCTRL_RESTORE_OFFSET, 1, 0x00000110}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DYN_DEP_PRESCAL_RESTORE_OFFSET, 1, 0x00000114}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3_1_CLKSTCTRL_RESTORE_OFFSET, 1, 0x00000118}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3_2_CLKSTCTRL_RESTORE_OFFSET, 1, 0x0000011C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L4CFG_CLKSTCTRL_RESTORE_OFFSET, 1, 0x00000120}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_MEMIF_CLKSTCTRL_RESTORE_OFFSET, 1, 0x00000124}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L4PER_CLKSTCTRL_RESTORE_OFFSET, 1, 0x00000128}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_CLKSTCTRL_RESTORE_OFFSET, 1, 0x0000012C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INSTR_L3_3_CLKCTRL_RESTORE_OFFSET, 1, 0x00000130}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INSTR_L3_INSTR_CLKCTRL_RESTORE_OFFSET, 1, 0x00000134}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INSTR_OCP_WP1_CLKCTRL_RESTORE_OFFSET, 1, 0x00000138}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_CM2_PROFILING_CLKCTRL_RESTORE_OFFSET, 1, 0x0000013C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_D2D_STATICDEP_RESTORE_OFFSET, 1, 0x00000140}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3_1_DYNAMICDEP_RESTORE_OFFSET, 1, 0x00000144}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3_2_DYNAMICDEP_RESTORE_OFFSET, 1, 0x00000148}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_D2D_DYNAMICDEP_RESTORE_OFFSET, 1, 0x0000014C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L4CFG_DYNAMICDEP_RESTORE_OFFSET, 1, 0x00000150}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L4PER_DYNAMICDEP_RESTORE_OFFSET, 1, 0x00000154}, + {C2C_INDEX, 0x0C, 1, 0x00000158}, + {C2C_INDEX, 0x10, 1, 0x0000015C}, + {C2C_INDEX, 0x28, 1, 0x00000160}, + {C2C_INDEX, 0x40, 1, 0x00000164}, + {C2C_INDEX, 0x44, 1, 0x00000168}, + {C2C_INDEX, 0x70, 1, 0x0000016C}, + {C2C_INDEX, 0x74, 1, 0x00000170}, + {C2C_INDEX, 0x84, 1, 0x00000174}, + {C2C_INDEX, 0x88, 1, 0x00000178}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_PADCONF_GLOBAL, 15, 0x0000017C}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_PBIASLITE, 14, 0x000001B8}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_LPDDR2IO1_0, 8, 0x000001F0}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_BUS_HOLD, 1, 0x00000210}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_C2C, 1, 0x00000214}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_EFUSE_1, 1, 0x00000218}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_EFUSE_2, 1, 0x0000021C}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_EFUSE_4, 1, 0x00000220}, + {DMM_INDEX, OMAP44XX_DMM_LISA_MAP, 4, 0x000000224}, + {DMM_INDEX, OMAP44XX_DMM_LISA_LOCK, 1, 0x00000234}, + {DMM_INDEX, OMAP44XX_DMM_TILER_OR, 2, 0x00000238}, + {DMM_INDEX, OMAP44XX_DMM_PAT_VIEW, 2, 0x00000240}, + {DMM_INDEX, OMAP44XX_DMM_PAT_VIEW_MAP, 4, 0x00000248}, + {DMM_INDEX, OMAP44XX_DMM_PAT_VIEW_MAP_BASE, 1, 0x00000258}, + {DMM_INDEX, OMAP44XX_DMM_PAT_IRQENABLE_SET, 1, 0x0000025C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DESCR, 1, 0x00000260}, + {DMM_INDEX, OMAP44XX_DMM_PAT_AREA, 1, 0x00000264}, + {DMM_INDEX, OMAP44XX_DMM_PAT_CTRL, 1, 0x00000268}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DATA, 1, 0x0000026C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DESCR + 0x10, 1, 0x00000270}, + {DMM_INDEX, OMAP44XX_DMM_PAT_AREA + 0x10, 1, 0x00000274}, + {DMM_INDEX, OMAP44XX_DMM_PAT_CTRL + 0x10, 1, 0x00000278}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DATA + 0x10, 1, 0x0000027C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DESCR + 0x20, 1, 0x00000280}, + {DMM_INDEX, OMAP44XX_DMM_PAT_AREA + 0x20, 1, 0x00000284}, + {DMM_INDEX, OMAP44XX_DMM_PAT_CTRL + 0x20, 1, 0x00000288}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DATA + 0x20, 1, 0x0000028C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DESCR + 0x30, 1, 0x00000290}, + {DMM_INDEX, OMAP44XX_DMM_PAT_AREA + 0x30, 1, 0x00000294}, + {DMM_INDEX, OMAP44XX_DMM_PAT_CTRL + 0x30, 1, 0x00000298}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DATA + 0x30, 1, 0x0000029C}, + {DMM_INDEX, OMAP44XX_DMM_PEG_PRIO, 2, 0x000002A0}, + {DMM_INDEX, OMAP44XX_DMM_PEG_PRIO_PAT, 1, 0x000002A8}, + {L3_CLK1_INDEX, 0x508, 1, 0x000002AC}, + {L3_CLK1_INDEX, 0x510, 1, 0x000002B0}, + {L3_CLK1_INDEX, 0x708, 1, 0x000002B4}, + {L3_CLK1_INDEX, 0x70C, 1, 0x000002B8}, + {L3_CLK1_INDEX, 0x808, 1, 0x000002BC}, + {L3_CLK2_INDEX, 0x1008, 1, 0x000002C0}, + {L3_CLK2_INDEX, 0x1010, 1, 0x000002C4}, + {L3_CLK2_INDEX, 0x1208, 1, 0x000002C8}, + {L3_CLK2_INDEX, 0x1308, 1, 0x000002CC}, + {L3_CLK2_INDEX, 0x130C, 1, 0x000002D0}, + {L3_CLK2_INDEX, 0x1408, 1, 0x000002D4}, + {L3_CLK2_INDEX, 0x140C, 1, 0x000002D8}, + {L3_CLK2_INDEX, 0x1508, 1, 0x000002DC}, + {L3_CLK2_INDEX, 0x150C, 1, 0x000002E0}, + {L3_CLK3_INDEX, 0x208, 1, 0x000002E4}, + {L3_CLK3_INDEX, 0x210, 1, 0x000002E8}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_USB_HOST_CLKCTRL_RESTORE_OFFSET, 1, 0x000002EC}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_USB_TLL_CLKCTRL_RESTORE_OFFSET, 1, 0x000002F0}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_SDMA_STATICDEP_RESTORE_OFFSET, 1, 0x000002F4}, + {USBTLL_INDEX, 0x400, 7, 0x000002F8}, + {UHH_INDEX, 0x10, 1, 0x00000314}, + {UHH_INDEX, 0x40, 1, 0x00000318}, + {UHH_INDEX, 0x100, 384, 0x0000031C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_USB_HOST_CLKCTRL_RESTORE_OFFSET, 1, 0x0000091C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_USB_TLL_CLKCTRL_RESTORE_OFFSET, 1, 0x00000920}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_SDMA_STATICDEP_RESTORE_OFFSET, 1, 0x00000924}, +}; + +/* + * SAR_RAM2 register layout consist of SYSCTRL_PADCONF_CORE regsiters + */ +static const u32 omap443x_sar_ram2_layout[][4] = { + {CTRL_MODULE_PAD_CORE_INDEX, 0x40, 102, 0x00000000}, +}; + +/* + * SAR_RAM3 and SAR_RAM4 layout is not listed since moslty it's handle by + * secure software. + */ +static const u32 omap443x_sar_ram3_layout[][4] = { + {L4CORE_INDEX, 0x2140, 1, 0x00000000}, + {L4CORE_INDEX, 0x2104, 1, 0x00000004}, + {L4CORE_INDEX, 0x2100, 1, 0x00000008}, + {L4CORE_INDEX, 0x2108, 1, 0x0000000C}, + {L4CORE_INDEX, 0x210C, 1, 0x00000010}, + {L4CORE_INDEX, 0x2110, 1, 0x00000014}, + {L4CORE_INDEX, 0x2114, 1, 0x00000018}, + {L4CORE_INDEX, 0x204088, 14, 0x0000001C}, + {L4CORE_INDEX, 0x206088, 2, 0x00000054}, + {L4CORE_INDEX, 0x20C088, 30, 0x0000005C}, + {L4CORE_INDEX, 0x210088, 30, 0x000000D4}, + {L4CORE_INDEX, 0x212088, 38, 0x0000014C}, + {L4CORE_INDEX, 0x214088, 2, 0x000001E4}, + {L4CORE_INDEX, 0x216088, 2, 0x000001EC}, + {L4CORE_INDEX, 0x218088, 2, 0x000001F4}, + {L4CORE_INDEX, 0x21C088, 2, 0x000001FC}, + {L4CORE_INDEX, 0x21E088, 2, 0x00000204}, + {L4CORE_INDEX, 0x220088, 2, 0x0000020C}, + {L4CORE_INDEX, 0x226088, 6, 0x00000214}, + {L4CORE_INDEX, 0x228088, 2, 0x0000022C}, + {L4CORE_INDEX, 0x22A088, 14, 0x00000234}, + {L4PER_INDEX, 0x218, 1, 0x0000026C}, + {L4PER_INDEX, 0x220, 1, 0x00000270}, + {L4PER_INDEX, 0x228, 1, 0x00000274}, + {L4PER_INDEX, 0x230, 1, 0x00000278}, + {L4PER_INDEX, 0x238, 1, 0x0000027C}, + {L4PER_INDEX, 0x298, 2, 0x00000280}, + {L4PER_INDEX, 0x2A0, 2, 0x00000288}, + {L4PER_INDEX, 0x2A8, 2, 0x00000290}, + {L4PER_INDEX, 0x2B0, 2, 0x00000298}, + {L4PER_INDEX, 0x2B8, 2, 0x000002A0}, + {L4PER_INDEX, 0x304, 1, 0x000002A8}, + {L4PER_INDEX, 0x31C, 1, 0x000002AC}, + {L4PER_INDEX, 0x32C, 1, 0x000002B0}, + {L4PER_INDEX, 0x33C, 1, 0x000002B4}, + {L4PER_INDEX, 0x34C, 1, 0x000002B8}, + {L4PER_INDEX, 0x35C, 1, 0x000002BC}, + {L4PER_INDEX, 0x36C, 1, 0x000002C0}, + {L4PER_INDEX, 0x37C, 1, 0x000002C4}, + {L4PER_INDEX, 0x38C, 1, 0x000002C8}, + {L4PER_INDEX, 0x39C, 1, 0x000002CC}, + {L4PER_INDEX, 0x3AC, 1, 0x000002D0}, + {L4PER_INDEX, 0x3BC, 1, 0x000002D4}, + {L4PER_INDEX, 0x3CC, 1, 0x000002D8}, + {L4PER_INDEX, 0x3D4, 1, 0x000002DC}, + {L4PER_INDEX, 0x3E4, 1, 0x000002E0}, + {L4PER_INDEX, 0x3F4, 1, 0x000002E4}, + {L4PER_INDEX, 0x404, 1, 0x000002E8}, + {L4PER_INDEX, 0x414, 1, 0x000002EC}, + {L4PER_INDEX, 0x42C, 1, 0x000002F0}, + {L4PER_INDEX, 0x43C, 1, 0x000002F4}, + {L4PER_INDEX, 0x44C, 1, 0x000002F8}, + {L4PER_INDEX, 0x45C, 1, 0x000002FC}, + {L4PER_INDEX, 0x46C, 1, 0x00000300}, + {L4PER_INDEX, 0x47C, 1, 0x00000304}, + {L4PER_INDEX, 0x48C, 1, 0x00000308}, + {L4PER_INDEX, 0x49C, 1, 0x0000030C}, + {L4PER_INDEX, 0x4AC, 1, 0x00000310}, + {L4PER_INDEX, 0x4BC, 1, 0x00000314}, + {L4PER_INDEX, 0x4CC, 1, 0x00000318}, + {L4PER_INDEX, 0x4DC, 1, 0x0000031C}, + {L4PER_INDEX, 0x4EC, 1, 0x00000320}, + {L4PER_INDEX, 0x4FC, 1, 0x00000324}, + {L4PER_INDEX, 0x50C, 1, 0x00000328}, + {L4PER_INDEX, 0x51C, 1, 0x0000032C}, + {L4PER_INDEX, 0x52C, 1, 0x00000330}, + {L4PER_INDEX, 0x53C, 1, 0x00000334}, + {L4PER_INDEX, 0x54C, 1, 0x00000338}, + {L4PER_INDEX, 0x55C, 1, 0x0000033C}, + {L4PER_INDEX, 0x56C, 1, 0x00000340}, + {L4PER_INDEX, 0x57C, 1, 0x00000344}, + {L4PER_INDEX, 0x5A4, 1, 0x00000348}, + {L4CORE_INDEX, 0x230, 1, 0x0000034C}, + {L4CORE_INDEX, 0x238, 1, 0x00000350}, + {L4CORE_INDEX, 0x2B0, 2, 0x00000354}, + {L4CORE_INDEX, 0x2B8, 2, 0x0000035C}, + {L4CORE_INDEX, 0x304, 1, 0x00000364}, + {L4CORE_INDEX, 0x31C, 1, 0x00000368}, + {L4CORE_INDEX, 0x32C, 1, 0x0000036C}, + {L4CORE_INDEX, 0x33C, 1, 0x00000370}, + {L4CORE_INDEX, 0x354, 1, 0x00000374}, + {L4CORE_INDEX, 0x35C, 1, 0x00000378}, + {L4CORE_INDEX, 0x36C, 1, 0x0000037C}, + {L4CORE_INDEX, 0x37C, 1, 0x00000380}, + {L4CORE_INDEX, 0x38C, 1, 0x00000384}, + {L4CORE_INDEX, 0x3AC, 1, 0x00000388}, + {L4CORE_INDEX, 0x3BC, 1, 0x0000038C}, + {L4CORE_INDEX, 0x3CC, 1, 0x00000390}, + {L4CORE_INDEX, 0x3DC, 1, 0x00000394}, + {L4CORE_INDEX, 0x3EC, 1, 0x00000398}, + {L4CORE_INDEX, 0x3FC, 1, 0x0000039C}, + {L4CORE_INDEX, 0x40C, 1, 0x000003A0}, + {L4CORE_INDEX, 0x41C, 1, 0x000003A4}, + {L4CORE_INDEX, 0x42C, 1, 0x000003A8}, + {L4CORE_INDEX, 0x43C, 1, 0x000003AC}, + {L4CORE_INDEX, 0x44C, 1, 0x000003B0}, + {L4CORE_INDEX, 0x45C, 1, 0x000003B4}, + {L4CORE_INDEX, 0x46C, 1, 0x000003B8}, + {L4CORE_INDEX, 0x47C, 1, 0x000003BC}, + {L4CORE_INDEX, 0x48C, 1, 0x000003C0}, + {L4CORE_INDEX, 0x49C, 1, 0x000003C4}, + {L4CORE_INDEX, 0x4AC, 1, 0x000003C8}, + {L4CORE_INDEX, 0x4BC, 1, 0x000003CC}, + {L4CORE_INDEX, 0x4CC, 1, 0x000003D0}, + {L4CORE_INDEX, 0x4DC, 1, 0x000003D4}, + {L4CORE_INDEX, 0x4EC, 1, 0x000003D8}, + {L4CORE_INDEX, 0x4FC, 1, 0x000003DC}, + {L4CORE_INDEX, 0x50C, 1, 0x000003E0}, + {L4CORE_INDEX, 0x51C, 1, 0x000003E4}, + {L4CORE_INDEX, 0x52C, 1, 0x000003E8}, + {L4CORE_INDEX, 0x53C, 1, 0x000003EC}, + {L4CORE_INDEX, 0x54C, 1, 0x000003F0}, + {L4CORE_INDEX, 0x55C, 1, 0x000003F4}, + {L4CORE_INDEX, 0x56C, 1, 0x000003F8}, + {L4CORE_INDEX, 0x574, 1, 0x000003FC}, + {L4CORE_INDEX, 0x584, 1, 0x00000400}, + {L4CORE_INDEX, 0x594, 1, 0x00000404}, + {L4CORE_INDEX, 0x5A4, 1, 0x00000408}, + {L4CORE_INDEX, 0x5B4, 1, 0x0000040C}, + {L4CORE_INDEX, 0x5C4, 1, 0x00000410}, + {L4CORE_INDEX, 0x5D4, 1, 0x00000414}, + {L4CORE_INDEX, 0x5DC, 1, 0x00000418}, +}; + + +static const u32 omap446x_sar_ram1_layout[][4] = { + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_CONFIG_2, 1, 0x00000000}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_CONFIG, 1, 0x00000004}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_REF_CTRL, 1, 0x00000008}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_REF_CTRL_SHDW, 1, 0x0000000C}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_1, 1, 0x00000010}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_1_SHDW, 1, 0x00000014}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_2, 1, 0x00000018}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_2_SHDW, 1, 0x0000001C}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_3, 1, 0x00000020}, + {EMIF1_INDEX, OMAP44XX_EMIF_SDRAM_TIM_3_SHDW, 1, 0x00000024}, + {EMIF1_INDEX, OMAP44XX_EMIF_LPDDR2_NVM_TIM, 1, 0x00000028}, + {EMIF1_INDEX, OMAP44XX_EMIF_LPDDR2_NVM_TIM_SHDW, 1, 0x0000002C}, + {EMIF1_INDEX, OMAP44XX_EMIF_PWR_MGMT_CTRL, 1, 0x00000030}, + {EMIF1_INDEX, OMAP44XX_EMIF_PWR_MGMT_CTRL_SHDW, 1, 0x00000034}, + {EMIF1_INDEX, OMAP44XX_EMIF_OCP_CONFIG, 1, 0x00000038}, + {EMIF1_INDEX, OMAP44XX_EMIF_PERF_CNT_CFG, 1, 0x0000003C}, + {EMIF1_INDEX, OMAP44XX_EMIF_PERF_CNT_SEL, 1, 0x00000040}, + {EMIF1_INDEX, OMAP44XX_EMIF_READ_IDLE_CTRL, 1, 0x00000044}, + {EMIF1_INDEX, OMAP44XX_EMIF_READ_IDLE_CTRL_SHDW, 1, 0x00000048}, + {EMIF1_INDEX, OMAP44XX_EMIF_IRQENABLE_SET_SYS, 1, 0x0000004C}, + {EMIF1_INDEX, OMAP44XX_EMIF_IRQENABLE_SET_LL, 1, 0x00000050}, + {EMIF1_INDEX, OMAP44XX_EMIF_ZQ_CONFIG, 1, 0x00000054}, + {EMIF1_INDEX, OMAP44XX_EMIF_TEMP_ALERT_CONFIG, 1, 0x00000058}, + {EMIF1_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_1, 1, 0x0000005C}, + {EMIF1_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_1_SHDW, 1, 0x00000060}, + {EMIF1_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_2, 1, 0x00000064}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_CONFIG_2, 1, 0x00000068}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_CONFIG, 1, 0x0000006C}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_REF_CTRL, 1, 0x00000070}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_REF_CTRL_SHDW, 1, 0x00000074}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_1, 1, 0x00000078}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_1_SHDW, 1, 0x0000007C}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_2, 1, 0x00000080}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_2_SHDW, 1, 0x00000084}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_3, 1, 0x00000088}, + {EMIF2_INDEX, OMAP44XX_EMIF_SDRAM_TIM_3_SHDW, 1, 0x0000008C}, + {EMIF2_INDEX, OMAP44XX_EMIF_LPDDR2_NVM_TIM, 1, 0x00000090}, + {EMIF2_INDEX, OMAP44XX_EMIF_LPDDR2_NVM_TIM_SHDW, 1, 0x00000094}, + {EMIF2_INDEX, OMAP44XX_EMIF_PWR_MGMT_CTRL, 1, 0x00000098}, + {EMIF2_INDEX, OMAP44XX_EMIF_PWR_MGMT_CTRL_SHDW, 1, 0x0000009C}, + {EMIF2_INDEX, OMAP44XX_EMIF_OCP_CONFIG, 1, 0x000000A0}, + {EMIF2_INDEX, OMAP44XX_EMIF_PERF_CNT_CFG, 1, 0x000000A4}, + {EMIF2_INDEX, OMAP44XX_EMIF_PERF_CNT_SEL, 1, 0x000000A8}, + {EMIF2_INDEX, OMAP44XX_EMIF_READ_IDLE_CTRL, 1, 0x000000AC}, + {EMIF2_INDEX, OMAP44XX_EMIF_READ_IDLE_CTRL_SHDW, 1, 0x000000B0}, + {EMIF2_INDEX, OMAP44XX_EMIF_IRQENABLE_SET_SYS, 1, 0x000000B4}, + {EMIF2_INDEX, OMAP44XX_EMIF_IRQENABLE_SET_LL, 1, 0x000000B8}, + {EMIF2_INDEX, OMAP44XX_EMIF_ZQ_CONFIG, 1, 0x000000BC}, + {EMIF2_INDEX, OMAP44XX_EMIF_TEMP_ALERT_CONFIG, 1, 0x000000C0}, + {EMIF2_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_1, 1, 0x000000C4}, + {EMIF2_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_1_SHDW, 1, 0x000000C8}, + {EMIF2_INDEX, OMAP44XX_EMIF_DDR_PHY_CTRL_2, 1, 0x000000CC}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_MEMIF_CLKSTCTRL_RESTORE_OFFSET, 1, 0x000000D0}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_CLKSEL_CORE_RESTORE_OFFSET, 1, 0x000000D4}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M2_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000D8}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M3_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000DC}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M4_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000E0}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M5_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000E4}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M6_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000E8}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DIV_M7_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000EC}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_CLKSEL_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000F0}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_SSC_DELTAMSTEP_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000F4}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_SSC_MODFREQDIV_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000F8}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_CLKMODE_DPLL_CORE_RESTORE_OFFSET, 1, 0x000000FC}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_SHADOW_FREQ_CONFIG2_RESTORE_OFFSET, 1, 0x00000100}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_SHADOW_FREQ_CONFIG1_RESTORE_OFFSET, 1, 0x00000104}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_AUTOIDLE_DPLL_CORE_RESTORE_OFFSET, 1, 0x00000108}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_MPU_CLKSTCTRL_RESTORE_OFFSET, 1, 0x0000010C}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_CM1_PROFILING_CLKCTRL_RESTORE_OFFSET, 1, 0x00000110}, + {CM1_INDEX, OMAP4430_CM1_RESTORE_INST + + OMAP4_CM_DYN_DEP_PRESCAL_RESTORE_OFFSET, 1, 0x00000114}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3_1_CLKSTCTRL_RESTORE_OFFSET, 1, 0x00000118}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3_2_CLKSTCTRL_RESTORE_OFFSET, 1, 0x0000011C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L4CFG_CLKSTCTRL_RESTORE_OFFSET, 1, 0x00000120}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_MEMIF_CLKSTCTRL_RESTORE_OFFSET, 1, 0x00000124}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L4PER_CLKSTCTRL_RESTORE_OFFSET, 1, 0x00000128}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_CLKSTCTRL_RESTORE_OFFSET, 1, 0x0000012C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INSTR_L3_3_CLKCTRL_RESTORE_OFFSET, 1, 0x00000130}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INSTR_L3_INSTR_CLKCTRL_RESTORE_OFFSET, 1, 0x00000134}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INSTR_OCP_WP1_CLKCTRL_RESTORE_OFFSET, 1, 0x00000138}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_CM2_PROFILING_CLKCTRL_RESTORE_OFFSET, 1, 0x0000013C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_D2D_STATICDEP_RESTORE_OFFSET, 1, 0x00000140}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3_1_DYNAMICDEP_RESTORE_OFFSET, 1, 0x00000144}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3_2_DYNAMICDEP_RESTORE_OFFSET, 1, 0x00000148}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_D2D_DYNAMICDEP_RESTORE_OFFSET, 1, 0x0000014C}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L4CFG_DYNAMICDEP_RESTORE_OFFSET, 1, 0x00000150}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L4PER_DYNAMICDEP_RESTORE_OFFSET, 1, 0x00000154}, + {C2C_INDEX, 0x0C, 1, 0x00000158}, + {C2C_INDEX, 0x10, 1, 0x0000015C}, + {C2C_INDEX, 0x28, 1, 0x00000160}, + {C2C_INDEX, 0x40, 1, 0x00000164}, + {C2C_INDEX, 0x44, 1, 0x00000168}, + {C2C_INDEX, 0x70, 1, 0x0000016C}, + {C2C_INDEX, 0x74, 1, 0x00000170}, + {C2C_INDEX, 0x84, 1, 0x00000174}, + {C2C_INDEX, 0x88, 1, 0x00000178}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_PADCONF_GLOBAL, 15, 0x0000017C}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_PBIASLITE, 14, 0x000001B8}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_LPDDR2IO1_0, 8, 0x000001F0}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_BUS_HOLD, 1, 0x00000210}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_C2C, 1, 0x00000214}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_EFUSE_1, 1, 0x00000218}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_EFUSE_2, 1, 0x0000021C}, + {CTRL_MODULE_PAD_CORE_INDEX, + OMAP4_CTRL_MODULE_PAD_CORE_CONTROL_EFUSE_4, 1, 0x00000220}, + {L4CORE_INDEX, 0x2350, 1, 0x00000224}, + {DMM_INDEX, OMAP44XX_DMM_LISA_MAP, 4, 0x000000228}, + {DMM_INDEX, OMAP44XX_DMM_LISA_LOCK, 1, 0x00000238}, + {DMM_INDEX, OMAP44XX_DMM_TILER_OR, 2, 0x0000023C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_VIEW, 2, 0x00000244}, + {DMM_INDEX, OMAP44XX_DMM_PAT_VIEW_MAP, 4, 0x0000024C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_VIEW_MAP_BASE, 1, 0x0000025C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_IRQENABLE_SET, 1, 0x00000260}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DESCR, 1, 0x00000264}, + {DMM_INDEX, OMAP44XX_DMM_PAT_AREA, 1, 0x00000268}, + {DMM_INDEX, OMAP44XX_DMM_PAT_CTRL, 1, 0x0000026C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DATA, 1, 0x00000270}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DESCR + 0x10, 1, 0x00000274}, + {DMM_INDEX, OMAP44XX_DMM_PAT_AREA + 0x10, 1, 0x00000278}, + {DMM_INDEX, OMAP44XX_DMM_PAT_CTRL + 0x10, 1, 0x0000027C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DATA + 0x10, 1, 0x00000280}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DESCR + 0x20, 1, 0x00000284}, + {DMM_INDEX, OMAP44XX_DMM_PAT_AREA + 0x20, 1, 0x00000288}, + {DMM_INDEX, OMAP44XX_DMM_PAT_CTRL + 0x20, 1, 0x0000028C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DATA + 0x20, 1, 0x00000290}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DESCR + 0x30, 1, 0x00000294}, + {DMM_INDEX, OMAP44XX_DMM_PAT_AREA + 0x30, 1, 0x00000298}, + {DMM_INDEX, OMAP44XX_DMM_PAT_CTRL + 0x30, 1, 0x0000029C}, + {DMM_INDEX, OMAP44XX_DMM_PAT_DATA + 0x30, 1, 0x000002A0}, + {DMM_INDEX, OMAP44XX_DMM_PEG_PRIO, 2, 0x000002A4}, + {DMM_INDEX, OMAP44XX_DMM_PEG_PRIO_PAT, 1, 0x000002AC}, + {L3_CLK1_INDEX, 0x508, 1, 0x000002B0}, + {L3_CLK1_INDEX, 0x510, 1, 0x000002B4}, + {L3_CLK1_INDEX, 0x708, 1, 0x000002B8}, + {L3_CLK1_INDEX, 0x70C, 1, 0x000002BC}, + {L3_CLK1_INDEX, 0x808, 1, 0x000002C0}, + {L3_CLK2_INDEX, 0x1008, 1, 0x000002C4}, + {L3_CLK2_INDEX, 0x1010, 1, 0x000002C8}, + {L3_CLK2_INDEX, 0x1208, 1, 0x000002CC}, + {L3_CLK2_INDEX, 0x1308, 1, 0x000002D0}, + {L3_CLK2_INDEX, 0x130C, 1, 0x000002D4}, + {L3_CLK2_INDEX, 0x1408, 1, 0x000002D8}, + {L3_CLK2_INDEX, 0x140C, 1, 0x000002DC}, + {L3_CLK2_INDEX, 0x1508, 1, 0x000002E0}, + {L3_CLK2_INDEX, 0x150C, 1, 0x000002E4}, + {L3_CLK3_INDEX, 0x208, 1, 0x000002E8}, + {L3_CLK3_INDEX, 0x210, 1, 0x000002EC}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_USB_HOST_CLKCTRL_RESTORE_OFFSET, 1, 0x000002F0}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_USB_TLL_CLKCTRL_RESTORE_OFFSET, 1, 0x000002F4}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_SDMA_STATICDEP_RESTORE_OFFSET, 1, 0x000002F8}, + {USBTLL_INDEX, 0x400, 7, 0x000002FC}, + {UHH_INDEX, 0x10, 1, 0x00000318}, + {UHH_INDEX, 0x40, 1, 0x0000031C}, + {UHH_INDEX, 0x100, 384, 0x00000320}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_USB_HOST_CLKCTRL_RESTORE_OFFSET, 1, 0x00000920}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_L3INIT_USB_TLL_CLKCTRL_RESTORE_OFFSET, 1, 0x00000924}, + {CM2_INDEX, OMAP4430_CM2_RESTORE_INST + + OMAP4_CM_SDMA_STATICDEP_RESTORE_OFFSET, 1, 0x00000928}, +}; + +/* + * SAR_RAM2 register layout consist of SYSCTRL_PADCONF_CORE regsiters + */ +static const u32 omap446x_sar_ram2_layout[][4] = { + {CTRL_MODULE_PAD_CORE_INDEX, 0x40, 102, 0x00000000}, + {CTRL_MODULE_PAD_CORE_INDEX, 0x1f4, 1, 0x00000198}, +}; + +/* + * SAR_RAM3 and SAR_RAM4 layout is not listed since moslty it's handle by + * secure software. + */ +static const u32 omap446x_sar_ram3_layout[][4] = { + {L4CORE_INDEX, 0x2140, 1, 0x00000000}, + {L4CORE_INDEX, 0x2104, 1, 0x00000004}, + {L4CORE_INDEX, 0x2100, 1, 0x00000008}, + {L4CORE_INDEX, 0x2108, 1, 0x0000000C}, + {L4CORE_INDEX, 0x210C, 1, 0x00000010}, + {L4CORE_INDEX, 0x2110, 1, 0x00000014}, + {L4CORE_INDEX, 0x2114, 1, 0x00000018}, + {L4CORE_INDEX, 0x204088, 14, 0x0000001C}, + {L4CORE_INDEX, 0x206088, 2, 0x00000054}, + {L4CORE_INDEX, 0x20C088, 30, 0x0000005C}, + {L4CORE_INDEX, 0x210088, 30, 0x000000D4}, + {L4CORE_INDEX, 0x212088, 38, 0x0000014C}, + {L4CORE_INDEX, 0x214088, 2, 0x000001E4}, + {L4CORE_INDEX, 0x216088, 2, 0x000001EC}, + {L4CORE_INDEX, 0x218088, 2, 0x000001F4}, + {L4CORE_INDEX, 0x21C088, 2, 0x000001FC}, + {L4CORE_INDEX, 0x21E088, 2, 0x00000204}, + {L4CORE_INDEX, 0x220088, 2, 0x0000020C}, + {L4CORE_INDEX, 0x226088, 6, 0x00000214}, + {L4CORE_INDEX, 0x228088, 2, 0x0000022C}, + {L4CORE_INDEX, 0x22A088, 14, 0x00000234}, + {L4CORE_INDEX, 0x20A088, 30, 0x0000026C}, + {L4PER_INDEX, 0x218, 1, 0x000002E4}, + {L4PER_INDEX, 0x220, 1, 0x000002E8}, + {L4PER_INDEX, 0x228, 1, 0x000002EC}, + {L4PER_INDEX, 0x230, 1, 0x000002F0}, + {L4PER_INDEX, 0x238, 1, 0x000002F4}, + {L4PER_INDEX, 0x298, 2, 0x000002F8}, + {L4PER_INDEX, 0x2A0, 2, 0x00000300}, + {L4PER_INDEX, 0x2A8, 2, 0x00000308}, + {L4PER_INDEX, 0x2B0, 2, 0x00000310}, + {L4PER_INDEX, 0x2B8, 2, 0x00000318}, + {L4PER_INDEX, 0x304, 1, 0x00000320}, + {L4PER_INDEX, 0x31C, 1, 0x00000324}, + {L4PER_INDEX, 0x32C, 1, 0x00000328}, + {L4PER_INDEX, 0x33C, 1, 0x0000032C}, + {L4PER_INDEX, 0x34C, 1, 0x00000330}, + {L4PER_INDEX, 0x35C, 1, 0x00000334}, + {L4PER_INDEX, 0x36C, 1, 0x00000338}, + {L4PER_INDEX, 0x37C, 1, 0x0000033C}, + {L4PER_INDEX, 0x38C, 1, 0x00000340}, + {L4PER_INDEX, 0x39C, 1, 0x00000344}, + {L4PER_INDEX, 0x3AC, 1, 0x00000348}, + {L4PER_INDEX, 0x3BC, 1, 0x0000034C}, + {L4PER_INDEX, 0x3CC, 1, 0x00000350}, + {L4PER_INDEX, 0x3D4, 1, 0x00000354}, + {L4PER_INDEX, 0x3E4, 1, 0x00000358}, + {L4PER_INDEX, 0x3F4, 1, 0x0000035C}, + {L4PER_INDEX, 0x404, 1, 0x00000360}, + {L4PER_INDEX, 0x414, 1, 0x00000364}, + {L4PER_INDEX, 0x42C, 1, 0x00000368}, + {L4PER_INDEX, 0x43C, 1, 0x0000036C}, + {L4PER_INDEX, 0x44C, 1, 0x00000370}, + {L4PER_INDEX, 0x45C, 1, 0x00000374}, + {L4PER_INDEX, 0x46C, 1, 0x00000378}, + {L4PER_INDEX, 0x47C, 1, 0x0000037C}, + {L4PER_INDEX, 0x48C, 1, 0x00000380}, + {L4PER_INDEX, 0x49C, 1, 0x00000384}, + {L4PER_INDEX, 0x4AC, 1, 0x00000388}, + {L4PER_INDEX, 0x4BC, 1, 0x0000038C}, + {L4PER_INDEX, 0x4CC, 1, 0x00000390}, + {L4PER_INDEX, 0x4DC, 1, 0x00000394}, + {L4PER_INDEX, 0x4EC, 1, 0x00000398}, + {L4PER_INDEX, 0x4FC, 1, 0x0000039C}, + {L4PER_INDEX, 0x50C, 1, 0x000003A0}, + {L4PER_INDEX, 0x51C, 1, 0x000003A4}, + {L4PER_INDEX, 0x52C, 1, 0x000003A8}, + {L4PER_INDEX, 0x53C, 1, 0x000003AC}, + {L4PER_INDEX, 0x54C, 1, 0x000003B0}, + {L4PER_INDEX, 0x55C, 1, 0x000003B4}, + {L4PER_INDEX, 0x56C, 1, 0x000003B8}, + {L4PER_INDEX, 0x57C, 1, 0x000003BC}, + {L4PER_INDEX, 0x5A4, 1, 0x000003C0}, + {L4CORE_INDEX, 0x230, 1, 0x000003C4}, + {L4CORE_INDEX, 0x238, 1, 0x000003C8}, + {L4CORE_INDEX, 0x2B0, 2, 0x000003CC}, + {L4CORE_INDEX, 0x2B8, 2, 0x000003D4}, + {L4CORE_INDEX, 0x304, 1, 0x000003DC}, + {L4CORE_INDEX, 0x31C, 1, 0x000003E0}, + {L4CORE_INDEX, 0x32C, 1, 0x000003E4}, + {L4CORE_INDEX, 0x33C, 1, 0x000003E8}, + {L4CORE_INDEX, 0x354, 1, 0x000003EC}, + {L4CORE_INDEX, 0x35C, 1, 0x000003F0}, + {L4CORE_INDEX, 0x36C, 1, 0x000003F4}, + {L4CORE_INDEX, 0x37C, 1, 0x000003F8}, + {L4CORE_INDEX, 0x38C, 1, 0x000003FC}, + {L4CORE_INDEX, 0x3AC, 1, 0x00000400}, + {L4CORE_INDEX, 0x3BC, 1, 0x00000404}, + {L4CORE_INDEX, 0x3CC, 1, 0x00000408}, + {L4CORE_INDEX, 0x3DC, 1, 0x0000040C}, + {L4CORE_INDEX, 0x3EC, 1, 0x00000410}, + {L4CORE_INDEX, 0x3FC, 1, 0x00000414}, + {L4CORE_INDEX, 0x40C, 1, 0x00000418}, + {L4CORE_INDEX, 0x41C, 1, 0x0000041C}, + {L4CORE_INDEX, 0x42C, 1, 0x00000420}, + {L4CORE_INDEX, 0x43C, 1, 0x00000424}, + {L4CORE_INDEX, 0x44C, 1, 0x00000428}, + {L4CORE_INDEX, 0x45C, 1, 0x0000042C}, + {L4CORE_INDEX, 0x46C, 1, 0x00000430}, + {L4CORE_INDEX, 0x47C, 1, 0x00000434}, + {L4CORE_INDEX, 0x48C, 1, 0x00000438}, + {L4CORE_INDEX, 0x49C, 1, 0x0000043C}, + {L4CORE_INDEX, 0x4AC, 1, 0x00000440}, + {L4CORE_INDEX, 0x4BC, 1, 0x00000444}, + {L4CORE_INDEX, 0x4CC, 1, 0x00000448}, + {L4CORE_INDEX, 0x4DC, 1, 0x0000044C}, + {L4CORE_INDEX, 0x4EC, 1, 0x00000450}, + {L4CORE_INDEX, 0x4FC, 1, 0x00000454}, + {L4CORE_INDEX, 0x50C, 1, 0x00000458}, + {L4CORE_INDEX, 0x51C, 1, 0x0000045C}, + {L4CORE_INDEX, 0x52C, 1, 0x00000460}, + {L4CORE_INDEX, 0x53C, 1, 0x00000464}, + {L4CORE_INDEX, 0x54C, 1, 0x00000468}, + {L4CORE_INDEX, 0x55C, 1, 0x0000046C}, + {L4CORE_INDEX, 0x56C, 1, 0x00000470}, + {L4CORE_INDEX, 0x574, 1, 0x00000474}, + {L4CORE_INDEX, 0x584, 1, 0x00000478}, + {L4CORE_INDEX, 0x594, 1, 0x0000047C}, + {L4CORE_INDEX, 0x5A4, 1, 0x00000480}, + {L4CORE_INDEX, 0x5B4, 1, 0x00000484}, + {L4CORE_INDEX, 0x5C4, 1, 0x00000488}, + {L4CORE_INDEX, 0x5D4, 1, 0x0000048C}, + {L4CORE_INDEX, 0x5DC, 1, 0x00000490}, + {L4CORE_INDEX, 0x5E4, 1, 0x00000494}, + {L4CORE_INDEX, 0x5EC, 1, 0x00000498}, + {L4CORE_INDEX, 0x5F4, 1, 0x0000049C}, + {L4CORE_INDEX, 0x5FC, 1, 0x000004A0}, +}; + +/* + * omap_sar_save : + * common routine to save the registers to SAR RAM with the + * given parameters + * @nb_regs - Number of registers to saved + * @sar_bank_offset - where to backup + * @sar_layout - constant table containing the backup info + */ +static void sar_save(u32 nb_regs, u32 sar_bank, const u32 sar_layout_table[][4]) +{ + u32 reg_val, size, i, j; + void __iomem *reg_read_addr, *sar_wr_addr; + + for (i = 0; i < nb_regs; i++) { + if (omap4_sar_modules[(sar_layout_table[i][MODULE_ADDR_IDX])]) { + size = sar_layout_table[i][MODULE_NB_REGS_IDX]; + reg_read_addr = + omap4_sar_modules[sar_layout_table[i] + [MODULE_ADDR_IDX]] + + sar_layout_table[i][MODULE_OFFSET_IDX]; + sar_wr_addr = sar_ram_base + sar_bank + + sar_layout_table[i][SAR_RAM_OFFSET_IDX]; + for (j = 0; j < size; j++) { + reg_val = __raw_readl(reg_read_addr + j * 4); + __raw_writel(reg_val, sar_wr_addr + j * 4); + } + } + } +} + +static void save_sar_bank3(void) +{ + struct clockdomain *l4_secure_clkdm; + + /* + * Not supported on ES1.0 silicon + */ + if (omap_rev() == OMAP4430_REV_ES1_0) { + WARN_ONCE(1, "omap4: SAR backup not supported on ES1.0 ..\n"); + return; + } + + l4_secure_clkdm = clkdm_lookup("l4_secure_clkdm"); + clkdm_wakeup(l4_secure_clkdm); + + if (cpu_is_omap446x()) + sar_save(ARRAY_SIZE(omap446x_sar_ram3_layout), SAR_BANK3_OFFSET, + omap446x_sar_ram3_layout); + else + sar_save(ARRAY_SIZE(omap443x_sar_ram3_layout), SAR_BANK3_OFFSET, + omap443x_sar_ram3_layout); + + clkdm_allow_idle(l4_secure_clkdm); +} + +static int omap4_sar_not_accessible(void) +{ + u32 usbhost_state, usbtll_state; + + /* + * Make sure that USB host and TLL modules are not + * enabled before attempting to save the context + * registers, otherwise this will trigger an exception. + */ + usbhost_state = omap4_cminst_read_inst_reg(OMAP4430_CM2_PARTITION, + OMAP4430_CM2_L3INIT_INST, + OMAP4_CM_L3INIT_USB_HOST_CLKCTRL_OFFSET) + & (OMAP4430_STBYST_MASK | OMAP4430_IDLEST_MASK); + + usbtll_state = omap4_cminst_read_inst_reg(OMAP4430_CM2_PARTITION, + OMAP4430_CM2_L3INIT_INST, + OMAP4_CM_L3INIT_USB_TLL_CLKCTRL_OFFSET) + & OMAP4430_IDLEST_MASK; + + if ((usbhost_state == (OMAP4430_STBYST_MASK | OMAP4430_IDLEST_MASK)) && + (usbtll_state == (OMAP4430_IDLEST_MASK))) + return 0; + else + return -EBUSY; +} + + /* + * omap4_sar_save - + * Save the context to SAR_RAM1 and SAR_RAM2 as per + * omap4xxx_sar_ram1_layout and omap4xxx_sar_ram2_layout for the device OFF + * mode + */ +int omap4_sar_save(void) +{ + /* + * Not supported on ES1.0 silicon + */ + if (omap_rev() == OMAP4430_REV_ES1_0) { + WARN_ONCE(1, "omap4: SAR backup not supported on ES1.0 ..\n"); + return -ENODEV; + } + + if (omap4_sar_not_accessible()) { + pr_debug("%s: USB SAR CNTX registers are not accessible!\n", + __func__); + return -EBUSY; + } + + /* + * SAR bits and clocks needs to be enabled + */ + clkdm_wakeup(l3init_clkdm); + pwrdm_enable_hdwr_sar(l3init_pwrdm); + clk_enable(usb_host_ck); + clk_enable(usb_tll_ck); + + /* Save SAR BANK1 */ + if (cpu_is_omap446x()) + sar_save(ARRAY_SIZE(omap446x_sar_ram1_layout), SAR_BANK1_OFFSET, + omap446x_sar_ram1_layout); + else + sar_save(ARRAY_SIZE(omap443x_sar_ram1_layout), SAR_BANK1_OFFSET, + omap443x_sar_ram1_layout); + + clk_disable(usb_host_ck); + clk_disable(usb_tll_ck); + pwrdm_disable_hdwr_sar(l3init_pwrdm); + clkdm_allow_idle(l3init_clkdm); + + /* Save SAR BANK2 */ + if (cpu_is_omap446x()) + sar_save(ARRAY_SIZE(omap446x_sar_ram2_layout), SAR_BANK2_OFFSET, + omap446x_sar_ram2_layout); + else + sar_save(ARRAY_SIZE(omap443x_sar_ram2_layout), SAR_BANK2_OFFSET, + omap443x_sar_ram2_layout); + + return 0; +} + +/** + * omap4_sar_overwrite : + * This API overwrite some of the SAR locations as a special cases + * The register content to be saved can be the register value before + * going into OFF-mode or a value that is required on wake up. This means + * that the restored register value can be different from the last value + * of the register before going into OFF-mode + * - CM1 and CM2 configuration + * Bits 0 of the CM_SHADOW_FREQ_CONFIG1 regiser and the + * CM_SHADOW_FREQ_CONFIG2 register are self-clearing and must + * be set at restore time. Thus, these data must always be + * overwritten in the SAR RAM. + * - Because USBHOSTHS and USBTLL restore needs a particular + * sequencing, the software must overwrite data read from + * the following registers implied in phase2a and phase 2b + */ +void omap4_sar_overwrite(void) +{ + u32 val = 0; + u32 offset = 0; + + if (cpu_is_omap446x()) + offset = 0x04; + + /* Overwriting Phase1 data to be restored */ + /* CM2 MEMIF_CLKTRCTRL = SW_WKUP, before FREQ UPDATE */ + __raw_writel(0x2, sar_ram_base + SAR_BANK1_OFFSET + 0xd0); + /* CM1 CM_SHADOW_FREQ_CONFIG2, Enable FREQ UPDATE */ + val = __raw_readl(OMAP4430_CM_SHADOW_FREQ_CONFIG2); + /* + * FIXME: Implement FREQ UPDATE for L#/M5 before enabling this + * val |= 1 << OMAP4430_FREQ_UPDATE_SHIFT; + */ + __raw_writel(val, sar_ram_base + SAR_BANK1_OFFSET + 0x100); + /* CM1 CM_SHADOW_FREQ_CONFIG1, Enable FREQ UPDATE */ + val = __raw_readl(OMAP4430_CM_SHADOW_FREQ_CONFIG1); + val |= 1 << OMAP4430_FREQ_UPDATE_SHIFT; + val &= ~OMAP4430_DLL_OVERRIDE_MASK; + __raw_writel(val, sar_ram_base + SAR_BANK1_OFFSET + 0x104); + /* CM2 MEMIF_CLKTRCTRL = HW_AUTO, after FREQ UPDATE */ + __raw_writel(0x3, sar_ram_base + SAR_BANK1_OFFSET + 0x124); + + /* Overwriting Phase2a data to be restored */ + /* CM_L3INIT_USB_HOST_CLKCTRL: SAR_MODE = 1, MODULEMODE = 2 */ + __raw_writel(0x00000012, + sar_ram_base + SAR_BANK1_OFFSET + 0x2ec + offset); + /* CM_L3INIT_USB_TLL_CLKCTRL: SAR_MODE = 1, MODULEMODE = 1 */ + __raw_writel(0x00000011, + sar_ram_base + SAR_BANK1_OFFSET + 0x2f0 + offset); + /* CM2 CM_SDMA_STATICDEP : Enable static depedency for SAR modules */ + __raw_writel(0x000090e8, + sar_ram_base + SAR_BANK1_OFFSET + 0x2f4 + offset); + + /* Overwriting Phase2b data to be restored */ + /* CM_L3INIT_USB_HOST_CLKCTRL: SAR_MODE = 0, MODULEMODE = 0 */ + val = __raw_readl(OMAP4430_CM_L3INIT_USB_HOST_CLKCTRL); + val &= (OMAP4430_CLKSEL_UTMI_P1_MASK | OMAP4430_CLKSEL_UTMI_P2_MASK); + __raw_writel(val, sar_ram_base + SAR_BANK1_OFFSET + 0x91c + offset); + /* CM_L3INIT_USB_TLL_CLKCTRL: SAR_MODE = 0, MODULEMODE = 0 */ + __raw_writel(0x0000000, + sar_ram_base + SAR_BANK1_OFFSET + 0x920 + offset); + /* CM2 CM_SDMA_STATICDEP : Clear the static depedency */ + __raw_writel(0x00000040, + sar_ram_base + SAR_BANK1_OFFSET + 0x924 + offset); + + /* readback to ensure data reaches to SAR RAM */ + barrier(); + val = __raw_readl(sar_ram_base + SAR_BANK1_OFFSET + 0x924 + offset); +} + +void __iomem *omap4_get_sar_ram_base(void) +{ + return sar_ram_base; +} + +/* + * SAR RAM used to save and restore the HW + * context in low power modes + */ +static int __init omap4_sar_ram_init(void) +{ + /* + * To avoid code running on other OMAPs in + * multi-omap builds + */ + if (!cpu_is_omap44xx()) + return -ENODEV; + + /* + * Static mapping, never released Actual SAR area used is 8K it's + * spaced over 16K address with some part is reserved. + */ + sar_ram_base = ioremap(OMAP44XX_SAR_RAM_BASE, SZ_16K); + BUG_ON(!sar_ram_base); + + /* + * All these are static mappings so ioremap() will + * just return with mapped VA + */ + omap4_sar_modules[EMIF1_INDEX] = ioremap(OMAP44XX_EMIF1, SZ_1M); + BUG_ON(!omap4_sar_modules[EMIF1_INDEX]); + omap4_sar_modules[EMIF2_INDEX] = ioremap(OMAP44XX_EMIF2, SZ_1M); + BUG_ON(!omap4_sar_modules[EMIF2_INDEX]); + omap4_sar_modules[DMM_INDEX] = ioremap(OMAP44XX_DMM_BASE, SZ_1M); + BUG_ON(!omap4_sar_modules[DMM_INDEX]); + omap4_sar_modules[CM1_INDEX] = ioremap(OMAP4430_CM1_BASE, SZ_8K); + BUG_ON(!omap4_sar_modules[CM1_INDEX]); + omap4_sar_modules[CM2_INDEX] = ioremap(OMAP4430_CM2_BASE, SZ_8K); + BUG_ON(!omap4_sar_modules[CM2_INDEX]); + omap4_sar_modules[C2C_INDEX] = ioremap(OMAP44XX_C2C_BASE, SZ_1M); + BUG_ON(!omap4_sar_modules[C2C_INDEX]); + omap4_sar_modules[CTRL_MODULE_PAD_CORE_INDEX] = + ioremap(OMAP443X_CTRL_BASE, SZ_4K); + BUG_ON(!omap4_sar_modules[CTRL_MODULE_PAD_CORE_INDEX]); + omap4_sar_modules[L3_CLK1_INDEX] = ioremap(L3_44XX_BASE_CLK1, SZ_1M); + BUG_ON(!omap4_sar_modules[L3_CLK1_INDEX]); + omap4_sar_modules[L3_CLK2_INDEX] = ioremap(L3_44XX_BASE_CLK2, SZ_1M); + BUG_ON(!omap4_sar_modules[L3_CLK2_INDEX]); + omap4_sar_modules[L3_CLK3_INDEX] = ioremap(L3_44XX_BASE_CLK3, SZ_1M); + BUG_ON(!omap4_sar_modules[L3_CLK3_INDEX]); + omap4_sar_modules[USBTLL_INDEX] = ioremap(OMAP44XX_USBTLL_BASE, SZ_1M); + BUG_ON(!omap4_sar_modules[USBTLL_INDEX]); + omap4_sar_modules[UHH_INDEX] = ioremap(OMAP44XX_UHH_CONFIG_BASE, SZ_1M); + BUG_ON(!omap4_sar_modules[UHH_INDEX]); + omap4_sar_modules[L4CORE_INDEX] = ioremap(L4_44XX_PHYS, SZ_4M); + BUG_ON(!omap4_sar_modules[L4CORE_INDEX]); + omap4_sar_modules[L4PER_INDEX] = ioremap(L4_PER_44XX_PHYS, SZ_4M); + BUG_ON(!omap4_sar_modules[L4PER_INDEX]); + + /* + * SAR BANK3 contains all firewall settings and it's saved through + * secure API on HS device. On GP device these registers are + * meaningless but still needs to be saved. Otherwise Auto-restore + * phase DMA takes an abort. Hence save these conents only once + * in init to avoid the issue while waking up from device OFF + */ + if (omap_type() == OMAP2_DEVICE_TYPE_GP) + save_sar_bank3(); + /* + * Work around for OMAP443x Errata i632: "LPDDR2 Corruption After OFF + * Mode Transition When CS1 Is Used On EMIF": + * Overwrite EMIF1/EMIF2 + * SECURE_EMIF1_SDRAM_CONFIG2_REG + * SECURE_EMIF2_SDRAM_CONFIG2_REG + */ + if (cpu_is_omap443x()) { + void __iomem *secure_ctrl_mod; + + secure_ctrl_mod = ioremap(OMAP4_CTRL_MODULE_WKUP, SZ_4K); + BUG_ON(!secure_ctrl_mod); + + __raw_writel(0x10, secure_ctrl_mod + + OMAP4_CTRL_SECURE_EMIF1_SDRAM_CONFIG2_REG); + __raw_writel(0x10, secure_ctrl_mod + + OMAP4_CTRL_SECURE_EMIF2_SDRAM_CONFIG2_REG); + wmb(); + iounmap(secure_ctrl_mod); + } + + /* + * L3INIT PD and clocks are needed for SAR save phase + */ + l3init_pwrdm = pwrdm_lookup("l3init_pwrdm"); + if (!l3init_pwrdm) + pr_err("Failed to get l3init_pwrdm\n"); + + l3init_clkdm = clkdm_lookup("l3_init_clkdm"); + if (!l3init_clkdm) + pr_err("Failed to get l3_init_clkdm\n"); + + usb_host_ck = clk_get(NULL, "usb_host_hs_fck"); + if (!usb_host_ck) + pr_err("Could not get usb_host_ck\n"); + + usb_tll_ck = clk_get(NULL, "usb_tll_hs_ick"); + if (!usb_tll_ck) + pr_err("Could not get usb_tll_ck\n"); + + return 0; +} +early_initcall(omap4_sar_ram_init); |