cache.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. /*
  2. * include/asm-sh/cpu-sh4/cache.h
  3. *
  4. * Copyright (C) 1999 Niibe Yutaka
  5. *
  6. * This file is subject to the terms and conditions of the GNU General Public
  7. * License. See the file "COPYING" in the main directory of this archive
  8. * for more details.
  9. */
  10. #ifndef __ASM_CPU_SH4_CACHE_H
  11. #define __ASM_CPU_SH4_CACHE_H
  12. #define L1_CACHE_SHIFT 5
  13. #define SH_CACHE_VALID 1
  14. #define SH_CACHE_UPDATED 2
  15. #define SH_CACHE_COMBINED 4
  16. #define SH_CACHE_ASSOC 8
  17. #define SH_CCR 0xff00001c /* Address of Cache Control Register */
  18. #define CCR_CACHE_OCE 0x0001 /* Operand Cache Enable */
  19. #define CCR_CACHE_WT 0x0002 /* Write-Through (for P0,U0,P3) (else writeback)*/
  20. #define CCR_CACHE_CB 0x0004 /* Copy-Back (for P1) (else writethrough) */
  21. #define CCR_CACHE_OCI 0x0008 /* OC Invalidate */
  22. #define CCR_CACHE_ORA 0x0020 /* OC RAM Mode */
  23. #define CCR_CACHE_OIX 0x0080 /* OC Index Enable */
  24. #define CCR_CACHE_ICE 0x0100 /* Instruction Cache Enable */
  25. #define CCR_CACHE_ICI 0x0800 /* IC Invalidate */
  26. #define CCR_CACHE_IIX 0x8000 /* IC Index Enable */
  27. #ifndef CONFIG_CPU_SH4A
  28. #define CCR_CACHE_EMODE 0x80000000 /* EMODE Enable */
  29. #endif
  30. /* Default CCR setup: 8k+16k-byte cache,P1-wb,enable */
  31. #define CCR_CACHE_ENABLE (CCR_CACHE_OCE|CCR_CACHE_ICE)
  32. #define CCR_CACHE_INVALIDATE (CCR_CACHE_OCI|CCR_CACHE_ICI)
  33. #define CACHE_IC_ADDRESS_ARRAY 0xf0000000
  34. #define CACHE_OC_ADDRESS_ARRAY 0xf4000000
  35. #define RAMCR 0xFF000074
  36. #endif /* __ASM_CPU_SH4_CACHE_H */