diff options
author | Trent Piepho <tpiepho@freescale.com> | 2008-12-08 22:34:57 -0500 |
---|---|---|
committer | Kumar Gala <galak@kernel.crashing.org> | 2009-01-28 19:16:51 -0500 |
commit | f88747e7f68866f2f82cef1363c5b8e7aa13b0a3 (patch) | |
tree | 7adcbb1a619477de38eb12fcea2556dc609a0854 /arch/powerpc/mm | |
parent | 105c31df6fc5a424b480321763b5598cf3817821 (diff) |
powerpc/fsl-booke: Remove code duplication in lowmem mapping
The code to map lowmem uses three CAM aka TLB[1] entries to cover it. The
size of each is stored in three globals named __cam0, __cam1, and __cam2.
All the code that uses them is duplicated three times for each of the three
variables.
We have these things called arrays and loops....
Once converted to use an array, it will be easier to make the number of
CAMs configurable.
Signed-off-by: Trent Piepho <tpiepho@freescale.com>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/mm')
-rw-r--r-- | arch/powerpc/mm/fsl_booke_mmu.c | 79 |
1 files changed, 31 insertions, 48 deletions
diff --git a/arch/powerpc/mm/fsl_booke_mmu.c b/arch/powerpc/mm/fsl_booke_mmu.c index 1971e4ee3d6e..1dabe1a1751b 100644 --- a/arch/powerpc/mm/fsl_booke_mmu.c +++ b/arch/powerpc/mm/fsl_booke_mmu.c | |||
@@ -56,7 +56,7 @@ | |||
56 | 56 | ||
57 | extern void loadcam_entry(unsigned int index); | 57 | extern void loadcam_entry(unsigned int index); |
58 | unsigned int tlbcam_index; | 58 | unsigned int tlbcam_index; |
59 | static unsigned long __cam0, __cam1, __cam2; | 59 | static unsigned long cam[3]; |
60 | 60 | ||
61 | #define NUM_TLBCAMS (16) | 61 | #define NUM_TLBCAMS (16) |
62 | 62 | ||
@@ -152,19 +152,19 @@ void invalidate_tlbcam_entry(int index) | |||
152 | loadcam_entry(index); | 152 | loadcam_entry(index); |
153 | } | 153 | } |
154 | 154 | ||
155 | void __init cam_mapin_ram(unsigned long cam0, unsigned long cam1, | 155 | unsigned long __init mmu_mapin_ram(void) |
156 | unsigned long cam2) | ||
157 | { | 156 | { |
158 | settlbcam(0, PAGE_OFFSET, memstart_addr, cam0, _PAGE_KERNEL, 0); | 157 | unsigned long virt = PAGE_OFFSET; |
159 | tlbcam_index++; | 158 | phys_addr_t phys = memstart_addr; |
160 | if (cam1) { | 159 | |
161 | tlbcam_index++; | 160 | while (cam[tlbcam_index] && tlbcam_index < ARRAY_SIZE(cam)) { |
162 | settlbcam(1, PAGE_OFFSET+cam0, memstart_addr+cam0, cam1, _PAGE_KERNEL, 0); | 161 | settlbcam(tlbcam_index, virt, phys, cam[tlbcam_index], _PAGE_KERNEL, 0); |
163 | } | 162 | virt += cam[tlbcam_index]; |
164 | if (cam2) { | 163 | phys += cam[tlbcam_index]; |
165 | tlbcam_index++; | 164 | tlbcam_index++; |
166 | settlbcam(2, PAGE_OFFSET+cam0+cam1, memstart_addr+cam0+cam1, cam2, _PAGE_KERNEL, 0); | ||
167 | } | 165 | } |
166 | |||
167 | return virt - PAGE_OFFSET; | ||
168 | } | 168 | } |
169 | 169 | ||
170 | /* | 170 | /* |
@@ -175,51 +175,34 @@ void __init MMU_init_hw(void) | |||
175 | flush_instruction_cache(); | 175 | flush_instruction_cache(); |
176 | } | 176 | } |
177 | 177 | ||
178 | unsigned long __init mmu_mapin_ram(void) | ||
179 | { | ||
180 | cam_mapin_ram(__cam0, __cam1, __cam2); | ||
181 | |||
182 | return __cam0 + __cam1 + __cam2; | ||
183 | } | ||
184 | |||
185 | |||
186 | void __init | 178 | void __init |
187 | adjust_total_lowmem(void) | 179 | adjust_total_lowmem(void) |
188 | { | 180 | { |
189 | phys_addr_t max_lowmem_size = __max_low_memory; | ||
190 | phys_addr_t cam_max_size = 0x10000000; | ||
191 | phys_addr_t ram; | 181 | phys_addr_t ram; |
182 | unsigned int max_cam = 28; /* 2^28 = 256 Mb */ | ||
183 | char buf[ARRAY_SIZE(cam) * 5 + 1], *p = buf; | ||
184 | int i; | ||
192 | 185 | ||
193 | /* adjust CAM size to max_lowmem_size */ | 186 | /* adjust lowmem size to __max_low_memory */ |
194 | if (max_lowmem_size < cam_max_size) | 187 | ram = min((phys_addr_t)__max_low_memory, (phys_addr_t)total_lowmem); |
195 | cam_max_size = max_lowmem_size; | ||
196 | |||
197 | /* adjust lowmem size to max_lowmem_size */ | ||
198 | ram = min(max_lowmem_size, total_lowmem); | ||
199 | 188 | ||
200 | /* Calculate CAM values */ | 189 | /* Calculate CAM values */ |
201 | __cam0 = 1UL << 2 * (__ilog2(ram) / 2); | 190 | __max_low_memory = 0; |
202 | if (__cam0 > cam_max_size) | 191 | for (i = 0; ram && i < ARRAY_SIZE(cam); i++) { |
203 | __cam0 = cam_max_size; | 192 | unsigned int camsize = __ilog2(ram) & ~1U; |
204 | ram -= __cam0; | 193 | if (camsize > max_cam) |
205 | if (ram) { | 194 | camsize = max_cam; |
206 | __cam1 = 1UL << 2 * (__ilog2(ram) / 2); | 195 | cam[i] = 1UL << camsize; |
207 | if (__cam1 > cam_max_size) | 196 | ram -= cam[i]; |
208 | __cam1 = cam_max_size; | 197 | __max_low_memory += cam[i]; |
209 | ram -= __cam1; | 198 | |
210 | } | 199 | p += sprintf(p, "%lu/", cam[i] >> 20); |
211 | if (ram) { | ||
212 | __cam2 = 1UL << 2 * (__ilog2(ram) / 2); | ||
213 | if (__cam2 > cam_max_size) | ||
214 | __cam2 = cam_max_size; | ||
215 | ram -= __cam2; | ||
216 | } | 200 | } |
201 | for (; i < ARRAY_SIZE(cam); i++) | ||
202 | p += sprintf(p, "0/"); | ||
203 | p[-1] = '\0'; | ||
217 | 204 | ||
218 | printk(KERN_INFO "Memory CAM mapping: CAM0=%ldMb, CAM1=%ldMb," | 205 | pr_info("Memory CAM mapping: %s Mb, residual: %ldMb\n", buf, |
219 | " CAM2=%ldMb residual: %ldMb\n", | 206 | (total_lowmem - __max_low_memory) >> 20); |
220 | __cam0 >> 20, __cam1 >> 20, __cam2 >> 20, | ||
221 | (long int)((total_lowmem - __cam0 - __cam1 - __cam2) | ||
222 | >> 20)); | ||
223 | __max_low_memory = __cam0 + __cam1 + __cam2; | ||
224 | __initial_memory_limit_addr = memstart_addr + __max_low_memory; | 207 | __initial_memory_limit_addr = memstart_addr + __max_low_memory; |
225 | } | 208 | } |