2  *  linux/arch/arm/mm/cache-v3.S
 
   4  *  Copyright (C) 1997-2002 Russell king
 
   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.
 
  10 #include <linux/linkage.h>
 
  11 #include <linux/init.h>
 
  13 #include "proc-macros.S"
 
  16  *      flush_user_cache_all()
 
  18  *      Invalidate all cache entries in a particular address
 
  21  *      - mm    - mm_struct describing address space
 
  23 ENTRY(v3_flush_user_cache_all)
 
  26  *      flush_kern_cache_all()
 
  28  *      Clean and invalidate the entire cache.
 
  30 ENTRY(v3_flush_kern_cache_all)
 
  34  *      flush_user_cache_range(start, end, flags)
 
  36  *      Invalidate a range of cache entries in the specified
 
  39  *      - start - start address (may not be aligned)
 
  40  *      - end   - end address (exclusive, may not be aligned)
 
  41  *      - flags - vma_area_struct flags describing address space
 
  43 ENTRY(v3_flush_user_cache_range)
 
  45         mcreq   p15, 0, ip, c7, c0, 0           @ flush ID cache
 
  49  *      coherent_kern_range(start, end)
 
  51  *      Ensure coherency between the Icache and the Dcache in the
 
  52  *      region described by start.  If you have non-snooping
 
  53  *      Harvard caches, you need to implement this function.
 
  55  *      - start  - virtual start address
 
  56  *      - end    - virtual end address
 
  58 ENTRY(v3_coherent_kern_range)
 
  62  *      coherent_user_range(start, end)
 
  64  *      Ensure coherency between the Icache and the Dcache in the
 
  65  *      region described by start.  If you have non-snooping
 
  66  *      Harvard caches, you need to implement this function.
 
  68  *      - start  - virtual start address
 
  69  *      - end    - virtual end address
 
  71 ENTRY(v3_coherent_user_range)
 
  75  *      flush_kern_dcache_page(void *page)
 
  77  *      Ensure no D cache aliasing occurs, either with itself or
 
  80  *      - addr  - page aligned address
 
  82 ENTRY(v3_flush_kern_dcache_page)
 
  86  *      dma_inv_range(start, end)
 
  88  *      Invalidate (discard) the specified virtual address range.
 
  89  *      May not write back any entries.  If 'start' or 'end'
 
  90  *      are not cache line aligned, those lines must be written
 
  93  *      - start  - virtual start address
 
  94  *      - end    - virtual end address
 
  96 ENTRY(v3_dma_inv_range)
 
 100  *      dma_flush_range(start, end)
 
 102  *      Clean and invalidate the specified virtual address range.
 
 104  *      - start  - virtual start address
 
 105  *      - end    - virtual end address
 
 107 ENTRY(v3_dma_flush_range)
 
 109         mcr     p15, 0, r0, c7, c0, 0           @ flush ID cache
 
 113  *      dma_clean_range(start, end)
 
 115  *      Clean (write back) the specified virtual address range.
 
 117  *      - start  - virtual start address
 
 118  *      - end    - virtual end address
 
 120 ENTRY(v3_dma_clean_range)
 
 125         .type   v3_cache_fns, #object
 
 127         .long   v3_flush_kern_cache_all
 
 128         .long   v3_flush_user_cache_all
 
 129         .long   v3_flush_user_cache_range
 
 130         .long   v3_coherent_kern_range
 
 131         .long   v3_coherent_user_range
 
 132         .long   v3_flush_kern_dcache_page
 
 133         .long   v3_dma_inv_range
 
 134         .long   v3_dma_clean_range
 
 135         .long   v3_dma_flush_range
 
 136         .size   v3_cache_fns, . - v3_cache_fns