cacheflush.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  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_cache_mm(struct mm_struct *mm);
  20. void flush_cache_range(struct vm_area_struct *vma, unsigned long start,
  21. unsigned long end);
  22. void flush_cache_page(struct vm_area_struct *vma, unsigned long addr,
  23. unsigned long pfn);
  24. void flush_dcache_page(struct page *pg);
  25. #define flush_dcache_mmap_lock(mapping) do { } while (0)
  26. #define flush_dcache_mmap_unlock(mapping) do { } while (0)
  27. void flush_icache_range(unsigned long start, unsigned long end);
  28. void flush_cache_sigtramp(unsigned long addr);
  29. void flush_icache_user_range(struct vm_area_struct *vma, struct page *page,
  30. unsigned long addr, int len);
  31. #define flush_icache_page(vma,pg) do { } while (0)
  32. /* Initialization of P3 area for copy_user_page */
  33. void p3_cache_init(void);
  34. #define PG_mapped PG_arch_1
  35. #ifdef CONFIG_MMU
  36. extern int remap_area_pages(unsigned long addr, unsigned long phys_addr,
  37. unsigned long size, unsigned long flags);
  38. #else /* CONFIG_MMU */
  39. static inline int remap_area_pages(unsigned long addr, unsigned long phys_addr,
  40. unsigned long size, unsigned long flags)
  41. {
  42. return 0;
  43. }
  44. #endif /* CONFIG_MMU */
  45. #endif /* __ASM_CPU_SH4_CACHEFLUSH_H */