diff options
author | Andrea Bastoni <bastoni@cs.unc.edu> | 2010-05-30 19:16:45 -0400 |
---|---|---|
committer | Andrea Bastoni <bastoni@cs.unc.edu> | 2010-05-30 19:16:45 -0400 |
commit | ada47b5fe13d89735805b566185f4885f5a3f750 (patch) | |
tree | 644b88f8a71896307d71438e9b3af49126ffb22b /arch/arm/mm/proc-arm940.S | |
parent | 43e98717ad40a4ae64545b5ba047c7b86aa44f4f (diff) | |
parent | 3280f21d43ee541f97f8cda5792150d2dbec20d5 (diff) |
Merge branch 'wip-2.6.34' into old-private-masterarchived-private-master
Diffstat (limited to 'arch/arm/mm/proc-arm940.S')
-rw-r--r-- | arch/arm/mm/proc-arm940.S | 41 |
1 files changed, 33 insertions, 8 deletions
diff --git a/arch/arm/mm/proc-arm940.S b/arch/arm/mm/proc-arm940.S index 5b0f8464c8f2..1af1657819eb 100644 --- a/arch/arm/mm/proc-arm940.S +++ b/arch/arm/mm/proc-arm940.S | |||
@@ -141,14 +141,15 @@ ENTRY(arm940_coherent_user_range) | |||
141 | /* FALLTHROUGH */ | 141 | /* FALLTHROUGH */ |
142 | 142 | ||
143 | /* | 143 | /* |
144 | * flush_kern_dcache_page(void *page) | 144 | * flush_kern_dcache_area(void *addr, size_t size) |
145 | * | 145 | * |
146 | * Ensure no D cache aliasing occurs, either with itself or | 146 | * Ensure no D cache aliasing occurs, either with itself or |
147 | * the I cache | 147 | * the I cache |
148 | * | 148 | * |
149 | * - addr - page aligned address | 149 | * - addr - kernel address |
150 | * - size - region size | ||
150 | */ | 151 | */ |
151 | ENTRY(arm940_flush_kern_dcache_page) | 152 | ENTRY(arm940_flush_kern_dcache_area) |
152 | mov ip, #0 | 153 | mov ip, #0 |
153 | mov r1, #(CACHE_DSEGMENTS - 1) << 4 @ 4 segments | 154 | mov r1, #(CACHE_DSEGMENTS - 1) << 4 @ 4 segments |
154 | 1: orr r3, r1, #(CACHE_DENTRIES - 1) << 26 @ 64 entries | 155 | 1: orr r3, r1, #(CACHE_DENTRIES - 1) << 26 @ 64 entries |
@@ -170,7 +171,7 @@ ENTRY(arm940_flush_kern_dcache_page) | |||
170 | * - start - virtual start address | 171 | * - start - virtual start address |
171 | * - end - virtual end address | 172 | * - end - virtual end address |
172 | */ | 173 | */ |
173 | ENTRY(arm940_dma_inv_range) | 174 | arm940_dma_inv_range: |
174 | mov ip, #0 | 175 | mov ip, #0 |
175 | mov r1, #(CACHE_DSEGMENTS - 1) << 4 @ 4 segments | 176 | mov r1, #(CACHE_DSEGMENTS - 1) << 4 @ 4 segments |
176 | 1: orr r3, r1, #(CACHE_DENTRIES - 1) << 26 @ 64 entries | 177 | 1: orr r3, r1, #(CACHE_DENTRIES - 1) << 26 @ 64 entries |
@@ -191,7 +192,7 @@ ENTRY(arm940_dma_inv_range) | |||
191 | * - start - virtual start address | 192 | * - start - virtual start address |
192 | * - end - virtual end address | 193 | * - end - virtual end address |
193 | */ | 194 | */ |
194 | ENTRY(arm940_dma_clean_range) | 195 | arm940_dma_clean_range: |
195 | ENTRY(cpu_arm940_dcache_clean_area) | 196 | ENTRY(cpu_arm940_dcache_clean_area) |
196 | mov ip, #0 | 197 | mov ip, #0 |
197 | #ifndef CONFIG_CPU_DCACHE_WRITETHROUGH | 198 | #ifndef CONFIG_CPU_DCACHE_WRITETHROUGH |
@@ -232,15 +233,39 @@ ENTRY(arm940_dma_flush_range) | |||
232 | mcr p15, 0, ip, c7, c10, 4 @ drain WB | 233 | mcr p15, 0, ip, c7, c10, 4 @ drain WB |
233 | mov pc, lr | 234 | mov pc, lr |
234 | 235 | ||
236 | /* | ||
237 | * dma_map_area(start, size, dir) | ||
238 | * - start - kernel virtual start address | ||
239 | * - size - size of region | ||
240 | * - dir - DMA direction | ||
241 | */ | ||
242 | ENTRY(arm940_dma_map_area) | ||
243 | add r1, r1, r0 | ||
244 | cmp r2, #DMA_TO_DEVICE | ||
245 | beq arm940_dma_clean_range | ||
246 | bcs arm940_dma_inv_range | ||
247 | b arm940_dma_flush_range | ||
248 | ENDPROC(arm940_dma_map_area) | ||
249 | |||
250 | /* | ||
251 | * dma_unmap_area(start, size, dir) | ||
252 | * - start - kernel virtual start address | ||
253 | * - size - size of region | ||
254 | * - dir - DMA direction | ||
255 | */ | ||
256 | ENTRY(arm940_dma_unmap_area) | ||
257 | mov pc, lr | ||
258 | ENDPROC(arm940_dma_unmap_area) | ||
259 | |||
235 | ENTRY(arm940_cache_fns) | 260 | ENTRY(arm940_cache_fns) |
236 | .long arm940_flush_kern_cache_all | 261 | .long arm940_flush_kern_cache_all |
237 | .long arm940_flush_user_cache_all | 262 | .long arm940_flush_user_cache_all |
238 | .long arm940_flush_user_cache_range | 263 | .long arm940_flush_user_cache_range |
239 | .long arm940_coherent_kern_range | 264 | .long arm940_coherent_kern_range |
240 | .long arm940_coherent_user_range | 265 | .long arm940_coherent_user_range |
241 | .long arm940_flush_kern_dcache_page | 266 | .long arm940_flush_kern_dcache_area |
242 | .long arm940_dma_inv_range | 267 | .long arm940_dma_map_area |
243 | .long arm940_dma_clean_range | 268 | .long arm940_dma_unmap_area |
244 | .long arm940_dma_flush_range | 269 | .long arm940_dma_flush_range |
245 | 270 | ||
246 | __INIT | 271 | __INIT |