diff options
author | Mike Frysinger <michael.frysinger@analog.com> | 2007-11-21 03:12:12 -0500 |
---|---|---|
committer | Bryan Wu <bryan.wu@analog.com> | 2007-11-21 03:12:12 -0500 |
commit | c3a9f435ae1b1969736a6ca695dfbc508b917b65 (patch) | |
tree | dcd03b47fd0c6ba43e9f9304b343369d7cdd8c15 /arch/blackfin/kernel | |
parent | 81a487a59f246a9eba24c3622e4c964e3347239d (diff) |
Blackfin arch: cplb and map header file cleanup
- remove duplicated defines for the BF561
- generalize L2 support (so that it works for BF54x) and mark it executable
- add support for reading/executing the Boot ROM sections
(since it has data/functions we may need at runtime)
- and fixup names for each map
Signed-off-by: Mike Frysinger <michael.frysinger@analog.com>
Signed-off-by: Bryan Wu <bryan.wu@analog.com>
Diffstat (limited to 'arch/blackfin/kernel')
-rw-r--r-- | arch/blackfin/kernel/cplbinit.c | 42 |
1 files changed, 26 insertions, 16 deletions
diff --git a/arch/blackfin/kernel/cplbinit.c b/arch/blackfin/kernel/cplbinit.c index 959b510c5ffb..6320bc45fbba 100644 --- a/arch/blackfin/kernel/cplbinit.c +++ b/arch/blackfin/kernel/cplbinit.c | |||
@@ -64,7 +64,7 @@ static struct cplb_desc cplb_data[] = { | |||
64 | #else | 64 | #else |
65 | .valid = 0, | 65 | .valid = 0, |
66 | #endif | 66 | #endif |
67 | .name = "ZERO Pointer Saveguard", | 67 | .name = "Zero Pointer Guard Page", |
68 | }, | 68 | }, |
69 | { | 69 | { |
70 | .start = L1_CODE_START, | 70 | .start = L1_CODE_START, |
@@ -95,20 +95,20 @@ static struct cplb_desc cplb_data[] = { | |||
95 | .end = 0, /* dynamic */ | 95 | .end = 0, /* dynamic */ |
96 | .psize = 0, | 96 | .psize = 0, |
97 | .attr = INITIAL_T | SWITCH_T | I_CPLB | D_CPLB, | 97 | .attr = INITIAL_T | SWITCH_T | I_CPLB | D_CPLB, |
98 | .i_conf = SDRAM_IGENERIC, | 98 | .i_conf = SDRAM_IGENERIC, |
99 | .d_conf = SDRAM_DGENERIC, | 99 | .d_conf = SDRAM_DGENERIC, |
100 | .valid = 1, | 100 | .valid = 1, |
101 | .name = "SDRAM Kernel", | 101 | .name = "Kernel Memory", |
102 | }, | 102 | }, |
103 | { | 103 | { |
104 | .start = 0, /* dynamic */ | 104 | .start = 0, /* dynamic */ |
105 | .end = 0, /* dynamic */ | 105 | .end = 0, /* dynamic */ |
106 | .psize = 0, | 106 | .psize = 0, |
107 | .attr = INITIAL_T | SWITCH_T | D_CPLB, | 107 | .attr = INITIAL_T | SWITCH_T | D_CPLB, |
108 | .i_conf = SDRAM_IGENERIC, | 108 | .i_conf = SDRAM_IGENERIC, |
109 | .d_conf = SDRAM_DNON_CHBL, | 109 | .d_conf = SDRAM_DNON_CHBL, |
110 | .valid = 1, | 110 | .valid = 1, |
111 | .name = "SDRAM RAM MTD", | 111 | .name = "uClinux MTD Memory", |
112 | }, | 112 | }, |
113 | { | 113 | { |
114 | .start = 0, /* dynamic */ | 114 | .start = 0, /* dynamic */ |
@@ -117,7 +117,7 @@ static struct cplb_desc cplb_data[] = { | |||
117 | .attr = INITIAL_T | SWITCH_T | D_CPLB, | 117 | .attr = INITIAL_T | SWITCH_T | D_CPLB, |
118 | .d_conf = SDRAM_DNON_CHBL, | 118 | .d_conf = SDRAM_DNON_CHBL, |
119 | .valid = 1, | 119 | .valid = 1, |
120 | .name = "SDRAM Uncached DMA ZONE", | 120 | .name = "Uncached DMA Zone", |
121 | }, | 121 | }, |
122 | { | 122 | { |
123 | .start = 0, /* dynamic */ | 123 | .start = 0, /* dynamic */ |
@@ -127,7 +127,7 @@ static struct cplb_desc cplb_data[] = { | |||
127 | .i_conf = 0, /* dynamic */ | 127 | .i_conf = 0, /* dynamic */ |
128 | .d_conf = 0, /* dynamic */ | 128 | .d_conf = 0, /* dynamic */ |
129 | .valid = 1, | 129 | .valid = 1, |
130 | .name = "SDRAM Reserved Memory", | 130 | .name = "Reserved Memory", |
131 | }, | 131 | }, |
132 | { | 132 | { |
133 | .start = ASYNC_BANK0_BASE, | 133 | .start = ASYNC_BANK0_BASE, |
@@ -136,14 +136,14 @@ static struct cplb_desc cplb_data[] = { | |||
136 | .attr = SWITCH_T | D_CPLB, | 136 | .attr = SWITCH_T | D_CPLB, |
137 | .d_conf = SDRAM_EBIU, | 137 | .d_conf = SDRAM_EBIU, |
138 | .valid = 1, | 138 | .valid = 1, |
139 | .name = "ASYNC Memory", | 139 | .name = "Asynchronous Memory Banks", |
140 | }, | 140 | }, |
141 | { | 141 | { |
142 | #if defined(CONFIG_BF561) | 142 | #ifdef L2_START |
143 | .start = L2_SRAM, | 143 | .start = L2_START, |
144 | .end = L2_SRAM_END, | 144 | .end = L2_START + L2_LENGTH, |
145 | .psize = SIZE_1M, | 145 | .psize = SIZE_1M, |
146 | .attr = SWITCH_T | D_CPLB, | 146 | .attr = SWITCH_T | I_CPLB | D_CPLB, |
147 | .i_conf = L2_MEMORY, | 147 | .i_conf = L2_MEMORY, |
148 | .d_conf = L2_MEMORY, | 148 | .d_conf = L2_MEMORY, |
149 | .valid = 1, | 149 | .valid = 1, |
@@ -151,7 +151,17 @@ static struct cplb_desc cplb_data[] = { | |||
151 | .valid = 0, | 151 | .valid = 0, |
152 | #endif | 152 | #endif |
153 | .name = "L2 Memory", | 153 | .name = "L2 Memory", |
154 | } | 154 | }, |
155 | { | ||
156 | .start = BOOT_ROM_START, | ||
157 | .end = BOOT_ROM_START + BOOT_ROM_LENGTH, | ||
158 | .psize = SIZE_1M, | ||
159 | .attr = SWITCH_T | I_CPLB | D_CPLB, | ||
160 | .i_conf = SDRAM_IGENERIC, | ||
161 | .d_conf = SDRAM_DGENERIC, | ||
162 | .valid = 1, | ||
163 | .name = "On-Chip BootROM", | ||
164 | }, | ||
155 | }; | 165 | }; |
156 | 166 | ||
157 | static u16 __init lock_kernel_check(u32 start, u32 end) | 167 | static u16 __init lock_kernel_check(u32 start, u32 end) |
@@ -343,7 +353,7 @@ void __init generate_cpl_tables(void) | |||
343 | else | 353 | else |
344 | cplb_data[RES_MEM].i_conf = SDRAM_INON_CHBL; | 354 | cplb_data[RES_MEM].i_conf = SDRAM_INON_CHBL; |
345 | 355 | ||
346 | for (i = ZERO_P; i <= L2_MEM; i++) { | 356 | for (i = ZERO_P; i < ARRAY_SIZE(cplb_data); ++i) { |
347 | if (!cplb_data[i].valid) | 357 | if (!cplb_data[i].valid) |
348 | continue; | 358 | continue; |
349 | 359 | ||