| /* |
| * OMAP4 Save Restore source file |
| * |
| * Copyright (C) 2010 Texas Instruments, Inc. |
| * Written by Santosh Shilimkar <[email protected]> |
| * |
| * 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); |