diff options
Diffstat (limited to 'arch/blackfin/mach-common/cache-c.c')
-rw-r--r-- | arch/blackfin/mach-common/cache-c.c | 44 |
1 files changed, 43 insertions, 1 deletions
diff --git a/arch/blackfin/mach-common/cache-c.c b/arch/blackfin/mach-common/cache-c.c index b59ce3cb3807..4ebbd78db3a4 100644 --- a/arch/blackfin/mach-common/cache-c.c +++ b/arch/blackfin/mach-common/cache-c.c | |||
@@ -1,14 +1,16 @@ | |||
1 | /* | 1 | /* |
2 | * Blackfin cache control code (simpler control-style functions) | 2 | * Blackfin cache control code (simpler control-style functions) |
3 | * | 3 | * |
4 | * Copyright 2004-2008 Analog Devices Inc. | 4 | * Copyright 2004-2009 Analog Devices Inc. |
5 | * | 5 | * |
6 | * Enter bugs at http://blackfin.uclinux.org/ | 6 | * Enter bugs at http://blackfin.uclinux.org/ |
7 | * | 7 | * |
8 | * Licensed under the GPL-2 or later. | 8 | * Licensed under the GPL-2 or later. |
9 | */ | 9 | */ |
10 | 10 | ||
11 | #include <linux/init.h> | ||
11 | #include <asm/blackfin.h> | 12 | #include <asm/blackfin.h> |
13 | #include <asm/cplbinit.h> | ||
12 | 14 | ||
13 | /* Invalidate the Entire Data cache by | 15 | /* Invalidate the Entire Data cache by |
14 | * clearing DMC[1:0] bits | 16 | * clearing DMC[1:0] bits |
@@ -34,3 +36,43 @@ void blackfin_invalidate_entire_icache(void) | |||
34 | SSYNC(); | 36 | SSYNC(); |
35 | } | 37 | } |
36 | 38 | ||
39 | #if defined(CONFIG_BFIN_ICACHE) || defined(CONFIG_BFIN_DCACHE) | ||
40 | |||
41 | static void | ||
42 | bfin_cache_init(struct cplb_entry *cplb_tbl, unsigned long cplb_addr, | ||
43 | unsigned long cplb_data, unsigned long mem_control, | ||
44 | unsigned long mem_mask) | ||
45 | { | ||
46 | int i; | ||
47 | |||
48 | for (i = 0; i < MAX_CPLBS; i++) { | ||
49 | bfin_write32(cplb_addr + i * 4, cplb_tbl[i].addr); | ||
50 | bfin_write32(cplb_data + i * 4, cplb_tbl[i].data); | ||
51 | } | ||
52 | |||
53 | _enable_cplb(mem_control, mem_mask); | ||
54 | } | ||
55 | |||
56 | #ifdef CONFIG_BFIN_ICACHE | ||
57 | void __cpuinit bfin_icache_init(struct cplb_entry *icplb_tbl) | ||
58 | { | ||
59 | bfin_cache_init(icplb_tbl, ICPLB_ADDR0, ICPLB_DATA0, IMEM_CONTROL, | ||
60 | (IMC | ENICPLB)); | ||
61 | } | ||
62 | #endif | ||
63 | |||
64 | #ifdef CONFIG_BFIN_DCACHE | ||
65 | void __cpuinit bfin_dcache_init(struct cplb_entry *dcplb_tbl) | ||
66 | { | ||
67 | /* | ||
68 | * Anomaly notes: | ||
69 | * 05000287 - We implement workaround #2 - Change the DMEM_CONTROL | ||
70 | * register, so that the port preferences for DAG0 and DAG1 are set | ||
71 | * to port B | ||
72 | */ | ||
73 | bfin_cache_init(dcplb_tbl, DCPLB_ADDR0, DCPLB_DATA0, DMEM_CONTROL, | ||
74 | (DMEM_CNTR | PORT_PREF0 | (ANOMALY_05000287 ? PORT_PREF1 : 0))); | ||
75 | } | ||
76 | #endif | ||
77 | |||
78 | #endif | ||