cacheflush.h 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. /*
  2. * include/asm-sh/cpu-sh4/cacheflush.h
  3. *
  4. * Copyright (C) 1999 Niibe Yutaka
  5. * Copyright (C) 2003 Paul Mundt
  6. *
  7. * This file is subject to the terms and conditions of the GNU General Public
  8. * License. See the file "COPYING" in the main directory of this archive
  9. * for more details.
  10. */
  11. #ifndef __ASM_CPU_SH4_CACHEFLUSH_H
  12. #define __ASM_CPU_SH4_CACHEFLUSH_H
  13. /*
  14. * Caches are broken on SH-4 (unless we use write-through
  15. * caching; in which case they're only semi-broken),
  16. * so we need them.
  17. */
  18. void flush_cache_all(void);
  19. void flush_dcache_all(void);
  20. void flush_cache_mm(struct mm_struct *mm);
  21. #define flush_cache_dup_mm(mm) flush_cache_mm(mm)
  22. void flush_cache_range(struct vm_area_struct *vma, unsigned long start,
  23. unsigned long end);
  24. void flush_cache_page(struct vm_area_struct *vma, unsigned long addr,
  25. unsigned long pfn);
  26. void flush_dcache_page(struct page *pg);
  27. #define flush_dcache_mmap_lock(mapping) do { } while (0)
  28. #define flush_dcache_mmap_unlock(mapping) do { } while (0)
  29. void flush_icache_range(unsigned long start, unsigned long end);
  30. void flush_icache_user_range(struct vm_area_struct *vma, struct page *page,
  31. unsigned long addr, int len);
  32. #define flush_icache_page(vma,pg) do { } while (0)
  33. /* Initialization of P3 area for copy_user_page */
  34. void p3_cache_init(void);
  35. #define PG_mapped PG_arch_1
  36. #endif /* __ASM_CPU_SH4_CACHEFLUSH_H */