cacheflush.h 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  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_cache_sigtramp(unsigned long addr);
  31. void flush_icache_user_range(struct vm_area_struct *vma, struct page *page,
  32. unsigned long addr, int len);
  33. #define flush_icache_page(vma,pg) do { } while (0)
  34. /* Initialization of P3 area for copy_user_page */
  35. void p3_cache_init(void);
  36. #define PG_mapped PG_arch_1
  37. #endif /* __ASM_CPU_SH4_CACHEFLUSH_H */