1/* 2 * linux/arch/arm/mm/cache-v4.S 3 * 4 * Copyright (C) 1997-2002 Russell king 5 * 6 * This program is free software; you can redistribute it and/or modify 7 * it under the terms of the GNU General Public License version 2 as 8 * published by the Free Software Foundation. 9 */ 10#include <linux/linkage.h> 11#include <linux/init.h> 12#include <asm/page.h> 13#include "proc-macros.S" 14 15/* 16 * flush_icache_all() 17 * 18 * Unconditionally clean and invalidate the entire icache. 19 */ 20ENTRY(v4_flush_icache_all) 21 mov pc, lr 22ENDPROC(v4_flush_icache_all) 23 24/* 25 * flush_user_cache_all() 26 * 27 * Invalidate all cache entries in a particular address 28 * space. 29 * 30 * - mm - mm_struct describing address space 31 */ 32ENTRY(v4_flush_user_cache_all) 33 /* FALLTHROUGH */ 34/* 35 * flush_kern_cache_all() 36 * 37 * Clean and invalidate the entire cache. 38 */ 39ENTRY(v4_flush_kern_cache_all) 40#ifdef CONFIG_CPU_CP15 41 mov r0, #0 42 mcr p15, 0, r0, c7, c7, 0 @ flush ID cache 43 mov pc, lr 44#else 45 /* FALLTHROUGH */ 46#endif 47 48/* 49 * flush_user_cache_range(start, end, flags) 50 * 51 * Invalidate a range of cache entries in the specified 52 * address space. 53 * 54 * - start - start address (may not be aligned) 55 * - end - end address (exclusive, may not be aligned) 56 * - flags - vma_area_struct flags describing address space 57 */ 58ENTRY(v4_flush_user_cache_range) 59#ifdef CONFIG_CPU_CP15 60 mov ip, #0 61 mcreq p15, 0, ip, c7, c7, 0 @ flush ID cache 62 mov pc, lr 63#else 64 /* FALLTHROUGH */ 65#endif 66 67/* 68 * coherent_kern_range(start, end) 69 * 70 * Ensure coherency between the Icache and the Dcache in the 71 * region described by start. If you have non-snooping 72 * Harvard caches, you need to implement this function. 73 * 74 * - start - virtual start address 75 * - end - virtual end address 76 */ 77ENTRY(v4_coherent_kern_range) 78 /* FALLTHROUGH */ 79 80/* 81 * coherent_user_range(start, end) 82 * 83 * Ensure coherency between the Icache and the Dcache in the 84 * region described by start. If you have non-snooping 85 * Harvard caches, you need to implement this function. 86 * 87 * - start - virtual start address 88 * - end - virtual end address 89 */ 90ENTRY(v4_coherent_user_range) 91 mov pc, lr 92 93/* 94 * flush_kern_dcache_area(void *addr, size_t size) 95 * 96 * Ensure no D cache aliasing occurs, either with itself or 97 * the I cache 98 * 99 * - addr - kernel address 100 * - size - region size 101 */ 102ENTRY(v4_flush_kern_dcache_area) 103 /* FALLTHROUGH */ 104 105/* 106 * dma_flush_range(start, end) 107 * 108 * Clean and invalidate the specified virtual address range. 109 * 110 * - start - virtual start address 111 * - end - virtual end address 112 */ 113ENTRY(v4_dma_flush_range) 114#ifdef CONFIG_CPU_CP15 115 mov r0, #0 116 mcr p15, 0, r0, c7, c7, 0 @ flush ID cache 117#endif 118 mov pc, lr 119 120/* 121 * dma_unmap_area(start, size, dir) 122 * - start - kernel virtual start address 123 * - size - size of region 124 * - dir - DMA direction 125 */ 126ENTRY(v4_dma_unmap_area) 127 teq r2, #DMA_TO_DEVICE 128 bne v4_dma_flush_range 129 /* FALLTHROUGH */ 130 131/* 132 * dma_map_area(start, size, dir) 133 * - start - kernel virtual start address 134 * - size - size of region 135 * - dir - DMA direction 136 */ 137ENTRY(v4_dma_map_area) 138 mov pc, lr 139ENDPROC(v4_dma_unmap_area) 140ENDPROC(v4_dma_map_area) 141 142 __INITDATA 143 144 .type v4_cache_fns, #object 145ENTRY(v4_cache_fns) 146 .long v4_flush_icache_all 147 .long v4_flush_kern_cache_all 148 .long v4_flush_user_cache_all 149 .long v4_flush_user_cache_range 150 .long v4_coherent_kern_range 151 .long v4_coherent_user_range 152 .long v4_flush_kern_dcache_area 153 .long v4_dma_map_area 154 .long v4_dma_unmap_area 155 .long v4_dma_flush_range 156 .size v4_cache_fns, . - v4_cache_fns 157