blob: 420380dab1cb8c2628ba15f7a3e95cec9a60b2ae [file] [log] [blame]
Mike Frysingerd4d77302008-02-04 19:26:55 -05001/*
2 * cplb.h - defines for managing CPLB tables
Wolfgang Denk6cb142f2006-03-12 02:12:27 +01003 *
Mike Frysingerd4d77302008-02-04 19:26:55 -05004 * Copyright (c) 2002-2007 Analog Devices Inc.
Wolfgang Denk6cb142f2006-03-12 02:12:27 +01005 *
Mike Frysingerd4d77302008-02-04 19:26:55 -05006 * Licensed under the GPL-2 or later.
7 */
Wolfgang Denk6cb142f2006-03-12 02:12:27 +01008
Mike Frysingerd4d77302008-02-04 19:26:55 -05009#ifndef __ASM_BLACKFIN_CPLB_H__
10#define __ASM_BLACKFIN_CPLB_H__
Wolfgang Denk6cb142f2006-03-12 02:12:27 +010011
Mike Frysingerd4d77302008-02-04 19:26:55 -050012#include <asm/mach-common/bits/mpu.h>
Aubrey.Li3f0606a2007-03-09 13:38:44 +080013
Wolfgang Denk6cb142f2006-03-12 02:12:27 +010014#define CPLB_ENABLE_ICACHE_P 0
15#define CPLB_ENABLE_DCACHE_P 1
16#define CPLB_ENABLE_DCACHE2_P 2
Aubrey.Li3f0606a2007-03-09 13:38:44 +080017#define CPLB_ENABLE_CPLBS_P 3 /* Deprecated! */
Wolfgang Denk6cb142f2006-03-12 02:12:27 +010018#define CPLB_ENABLE_ICPLBS_P 4
19#define CPLB_ENABLE_DCPLBS_P 5
20
21#define CPLB_ENABLE_ICACHE (1<<CPLB_ENABLE_ICACHE_P)
22#define CPLB_ENABLE_DCACHE (1<<CPLB_ENABLE_DCACHE_P)
23#define CPLB_ENABLE_DCACHE2 (1<<CPLB_ENABLE_DCACHE2_P)
24#define CPLB_ENABLE_CPLBS (1<<CPLB_ENABLE_CPLBS_P)
25#define CPLB_ENABLE_ICPLBS (1<<CPLB_ENABLE_ICPLBS_P)
26#define CPLB_ENABLE_DCPLBS (1<<CPLB_ENABLE_DCPLBS_P)
27#define CPLB_ENABLE_ANY_CPLBS CPLB_ENABLE_CPLBS | \
28 CPLB_ENABLE_ICPLBS | \
29 CPLB_ENABLE_DCPLBS
30
31#define CPLB_RELOADED 0x0000
32#define CPLB_NO_UNLOCKED 0x0001
33#define CPLB_NO_ADDR_MATCH 0x0002
34#define CPLB_PROT_VIOL 0x0003
35
36#define CPLB_DEF_CACHE CPLB_L1_CHBL | CPLB_WT
37#define CPLB_CACHE_ENABLED CPLB_L1_CHBL | CPLB_DIRTY
38
39#define CPLB_ALL_ACCESS CPLB_SUPV_WR | CPLB_USER_RD | CPLB_USER_WR
40
41#define CPLB_I_PAGE_MGMT CPLB_LOCK | CPLB_VALID
42#define CPLB_D_PAGE_MGMT CPLB_LOCK | CPLB_ALL_ACCESS | CPLB_VALID
43#define CPLB_DNOCACHE CPLB_ALL_ACCESS | CPLB_VALID
44#define CPLB_DDOCACHE CPLB_DNOCACHE | CPLB_DEF_CACHE
Wolfgang Denk53677ef2008-05-20 16:00:29 +020045#define CPLB_INOCACHE CPLB_USER_RD | CPLB_VALID
46#define CPLB_IDOCACHE CPLB_INOCACHE | CPLB_L1_CHBL
Wolfgang Denk6cb142f2006-03-12 02:12:27 +010047
Aubrey.Li3f0606a2007-03-09 13:38:44 +080048/* Data Attibutes*/
Bob Liu7677d652011-10-25 18:07:58 +080049#if defined(__ADSPBF60x__)
50#define SDRAM_IGENERIC (PAGE_SIZE_16MB | CPLB_L1_CHBL | \
51 CPLB_USER_RD | CPLB_VALID)
52#else
53#define SDRAM_IGENERIC (PAGE_SIZE_4MB | CPLB_L1_CHBL | \
54 CPLB_USER_RD | CPLB_VALID)
55#endif
Aubrey.Li3f0606a2007-03-09 13:38:44 +080056#define SDRAM_IKERNEL (PAGE_SIZE_4MB | CPLB_L1_CHBL | CPLB_USER_RD | CPLB_VALID | CPLB_LOCK)
Aubrey Li7b7e30a2007-04-05 18:33:04 +080057#define L1_IMEMORY (PAGE_SIZE_1MB | CPLB_USER_RD | CPLB_VALID | CPLB_LOCK)
Aubrey.Li3f0606a2007-03-09 13:38:44 +080058#define SDRAM_INON_CHBL (PAGE_SIZE_4MB | CPLB_USER_RD | CPLB_VALID)
59
Mike Frysingerd4d77302008-02-04 19:26:55 -050060#if ANOMALY_05000158
61# define ANOMALY_05000158_WORKAROUND 0x200
62#else
63# define ANOMALY_05000158_WORKAROUND 0
64#endif
Aubrey.Li3f0606a2007-03-09 13:38:44 +080065
Mike Frysingerd4d77302008-02-04 19:26:55 -050066#ifdef CONFIG_DCACHE_WB /*Write Back Policy */
Bob Liu7677d652011-10-25 18:07:58 +080067#if defined(__ADSPBF60x__)
68#define SDRAM_DGENERIC (PAGE_SIZE_16MB | CPLB_L1_CHBL | CPLB_DIRTY | \
69 CPLB_SUPV_WR | CPLB_USER_WR | CPLB_USER_RD | \
70 CPLB_VALID | ANOMALY_05000158_WORKAROUND)
71#else
72#define SDRAM_DGENERIC (PAGE_SIZE_4MB | CPLB_L1_CHBL | CPLB_DIRTY | \
73 CPLB_SUPV_WR | CPLB_USER_WR | CPLB_USER_RD | \
74 CPLB_VALID | ANOMALY_05000158_WORKAROUND)
75#endif
Mike Frysingerd4d77302008-02-04 19:26:55 -050076#define SDRAM_DNON_CHBL (PAGE_SIZE_4MB | CPLB_DIRTY | CPLB_SUPV_WR | CPLB_USER_RD | CPLB_USER_WR | CPLB_VALID | ANOMALY_05000158_WORKAROUND)
77#define SDRAM_DKERNEL (PAGE_SIZE_4MB | CPLB_L1_CHBL | CPLB_USER_RD | CPLB_USER_WR | CPLB_DIRTY | CPLB_SUPV_WR | CPLB_VALID | CPLB_LOCK | ANOMALY_05000158_WORKAROUND)
78#define L1_DMEMORY (PAGE_SIZE_4MB | CPLB_SUPV_WR | CPLB_USER_WR | CPLB_USER_RD | CPLB_VALID | ANOMALY_05000158_WORKAROUND)
79#define SDRAM_EBIU (PAGE_SIZE_4MB | CPLB_DIRTY | CPLB_USER_RD | CPLB_USER_WR | CPLB_SUPV_WR | CPLB_VALID | ANOMALY_05000158_WORKAROUND)
Aubrey.Li3f0606a2007-03-09 13:38:44 +080080
81#else /*Write Through */
Bob Liu7677d652011-10-25 18:07:58 +080082#if defined(__ADSPBF60x__)
83#define SDRAM_DGENERIC (PAGE_SIZE_16MB | CPLB_L1_CHBL | CPLB_WT | \
84 CPLB_L1_AOW | CPLB_SUPV_WR | CPLB_USER_RD | \
85 CPLB_USER_WR | CPLB_VALID | \
86 ANOMALY_05000158_WORKAROUND)
87#else
88#define SDRAM_DGENERIC (PAGE_SIZE_4MB | CPLB_L1_CHBL | CPLB_WT | \
89 CPLB_L1_AOW | CPLB_SUPV_WR | CPLB_USER_RD | \
90 CPLB_USER_WR | CPLB_VALID | \
91 ANOMALY_05000158_WORKAROUND)
92#endif
Mike Frysingerd4d77302008-02-04 19:26:55 -050093#define SDRAM_DNON_CHBL (PAGE_SIZE_4MB | CPLB_WT | CPLB_L1_AOW | CPLB_SUPV_WR | CPLB_USER_WR | CPLB_USER_RD | CPLB_VALID | ANOMALY_05000158_WORKAROUND)
94#define SDRAM_DKERNEL (PAGE_SIZE_4MB | CPLB_L1_CHBL | CPLB_WT | CPLB_L1_AOW | CPLB_USER_RD | CPLB_SUPV_WR | CPLB_USER_WR | CPLB_VALID | CPLB_LOCK | ANOMALY_05000158_WORKAROUND)
95#define L1_DMEMORY (PAGE_SIZE_4MB | CPLB_SUPV_WR | CPLB_USER_WR | CPLB_VALID | ANOMALY_05000158_WORKAROUND)
96#define SDRAM_EBIU (PAGE_SIZE_4MB | CPLB_WT | CPLB_L1_AOW | CPLB_USER_RD | CPLB_USER_WR | CPLB_SUPV_WR | CPLB_VALID | ANOMALY_05000158_WORKAROUND)
Aubrey.Li3f0606a2007-03-09 13:38:44 +080097#endif
98
Aubrey.Li3f0606a2007-03-09 13:38:44 +080099#endif /* _CPLB_H */