blob: 85b5fe9e2ff851c34ed396a9c8364245ff1d68a4 [file] [log] [blame] [edit]
/*
* 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);