blob: f92b20a0983d7e6001cb5e8a548a09e8966fbddb [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
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
13#define L1_CACHE_SHIFT 5
14
15#define CCR 0xff00001c /* Address of Cache Control Register */
16#define CCR_CACHE_OCE 0x0001 /* Operand Cache Enable */
17#define CCR_CACHE_WT 0x0002 /* Write-Through (for P0,U0,P3) (else writeback)*/
18#define CCR_CACHE_CB 0x0004 /* Copy-Back (for P1) (else writethrough) */
19#define CCR_CACHE_OCI 0x0008 /* OC Invalidate */
20#define CCR_CACHE_ORA 0x0020 /* OC RAM Mode */
21#define CCR_CACHE_OIX 0x0080 /* OC Index Enable */
22#define CCR_CACHE_ICE 0x0100 /* Instruction Cache Enable */
23#define CCR_CACHE_ICI 0x0800 /* IC Invalidate */
24#define CCR_CACHE_IIX 0x8000 /* IC Index Enable */
Paul Mundt41504c32006-12-11 20:28:03 +090025#ifndef CONFIG_CPU_SH4A
Linus Torvalds1da177e2005-04-16 15:20:36 -070026#define CCR_CACHE_EMODE 0x80000000 /* EMODE Enable */
Paul Mundt5b19c902006-09-27 14:31:40 +090027#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070028
29/* Default CCR setup: 8k+16k-byte cache,P1-wb,enable */
30#define CCR_CACHE_ENABLE (CCR_CACHE_OCE|CCR_CACHE_ICE)
31#define CCR_CACHE_INVALIDATE (CCR_CACHE_OCI|CCR_CACHE_ICI)
32
33#define CACHE_IC_ADDRESS_ARRAY 0xf0000000
34#define CACHE_OC_ADDRESS_ARRAY 0xf4000000
35
36#endif /* __ASM_CPU_SH4_CACHE_H */
37