133 lines
2.8 KiB
C
133 lines
2.8 KiB
C
/*
|
|
* OMAP4XXX L3 Interconnect error handling driver header
|
|
*
|
|
* Copyright (C) 2011 Texas Corporation
|
|
* Santosh Shilimkar <santosh.shilimkar@ti.com>
|
|
* sricharan <r.sricharan@ti.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
* USA
|
|
*/
|
|
#ifndef __ARCH_ARM_MACH_OMAP2_L3_INTERCONNECT_3XXX_H
|
|
#define __ARCH_ARM_MACH_OMAP2_L3_INTERCONNECT_3XXX_H
|
|
|
|
/*
|
|
* L3 register offsets
|
|
*/
|
|
#define L3_MODULES 3
|
|
#define CLEAR_STDERR_LOG (1 << 31)
|
|
#define CUSTOM_ERROR 0x2
|
|
#define STANDARD_ERROR 0x0
|
|
#define INBAND_ERROR 0x0
|
|
#define EMIF_KERRLOG_OFFSET 0x10
|
|
#define L3_SLAVE_ADDRESS_OFFSET 0x14
|
|
#define LOGICAL_ADDR_ERRORLOG 0x4
|
|
#define L3_APPLICATION_ERROR 0x0
|
|
#define L3_DEBUG_ERROR 0x1
|
|
|
|
u32 l3_flagmux[L3_MODULES] = {
|
|
0x50C,
|
|
0x100C,
|
|
0X020C
|
|
};
|
|
|
|
/*
|
|
* L3 Target standard Error register offsets
|
|
*/
|
|
u32 l3_targ_stderrlog_main_clk1[] = {
|
|
0x148, /* DMM1 */
|
|
0x248, /* DMM2 */
|
|
0x348, /* ABE */
|
|
0x448, /* L4CFG */
|
|
0x648 /* CLK2 PWR DISC */
|
|
};
|
|
|
|
u32 l3_targ_stderrlog_main_clk2[] = {
|
|
0x548, /* CORTEX M3 */
|
|
0x348, /* DSS */
|
|
0x148, /* GPMC */
|
|
0x448, /* ISS */
|
|
0x748, /* IVAHD */
|
|
0xD48, /* missing in TRM corresponds to AES1*/
|
|
0x948, /* L4 PER0*/
|
|
0x248, /* OCMRAM */
|
|
0x148, /* missing in TRM corresponds to GPMC sERROR*/
|
|
0x648, /* SGX */
|
|
0x848, /* SL2 */
|
|
0x1648, /* C2C */
|
|
0x1148, /* missing in TRM corresponds PWR DISC CLK1*/
|
|
0xF48, /* missing in TRM corrsponds to SHA1*/
|
|
0xE48, /* missing in TRM corresponds to AES2*/
|
|
0xC48, /* L4 PER3 */
|
|
0xA48, /* L4 PER1*/
|
|
0xB48 /* L4 PER2*/
|
|
};
|
|
|
|
u32 l3_targ_stderrlog_main_clk3[] = {
|
|
0x0148 /* EMUSS */
|
|
};
|
|
|
|
char *l3_targ_stderrlog_main_name[L3_MODULES][18] = {
|
|
{
|
|
"DMM1",
|
|
"DMM2",
|
|
"ABE",
|
|
"L4CFG",
|
|
"CLK2 PWR DISC",
|
|
},
|
|
{
|
|
"CORTEX M3" ,
|
|
"DSS ",
|
|
"GPMC ",
|
|
"ISS ",
|
|
"IVAHD ",
|
|
"AES1",
|
|
"L4 PER0",
|
|
"OCMRAM ",
|
|
"GPMC sERROR",
|
|
"SGX ",
|
|
"SL2 ",
|
|
"C2C ",
|
|
"PWR DISC CLK1",
|
|
"SHA1",
|
|
"AES2",
|
|
"L4 PER3",
|
|
"L4 PER1",
|
|
"L4 PER2",
|
|
},
|
|
{
|
|
"EMUSS",
|
|
},
|
|
};
|
|
|
|
u32 *l3_targ[L3_MODULES] = {
|
|
l3_targ_stderrlog_main_clk1,
|
|
l3_targ_stderrlog_main_clk2,
|
|
l3_targ_stderrlog_main_clk3,
|
|
};
|
|
|
|
struct omap4_l3 {
|
|
struct device *dev;
|
|
struct clk *ick;
|
|
|
|
/* memory base */
|
|
void __iomem *l3_base[4];
|
|
|
|
int debug_irq;
|
|
int app_irq;
|
|
};
|
|
|
|
#endif
|