1 /*
2  *  Atheros AR231x/AR531x SoC specific CPU feature overrides
3  *
4  *  Copyright (C) 2008 Gabor Juhos <juhosg@openwrt.org>
5  *
6  *  This file was derived from: include/asm-mips/cpu-features.h
7  *	Copyright (C) 2003, 2004 Ralf Baechle
8  *	Copyright (C) 2004 Maciej W. Rozycki
9  *
10  *  This program is free software; you can redistribute it and/or modify it
11  *  under the terms of the GNU General Public License version 2 as published
12  *  by the Free Software Foundation.
13  *
14  */
15 #ifndef __ASM_MACH_ATH25_CPU_FEATURE_OVERRIDES_H
16 #define __ASM_MACH_ATH25_CPU_FEATURE_OVERRIDES_H
17 
18 /*
19  * The Atheros AR531x/AR231x SoCs have MIPS 4Kc/4KEc core.
20  */
21 #define cpu_has_tlb			1
22 #define cpu_has_4kex			1
23 #define cpu_has_3k_cache		0
24 #define cpu_has_4k_cache		1
25 #define cpu_has_tx39_cache		0
26 #define cpu_has_sb1_cache		0
27 #define cpu_has_fpu			0
28 #define cpu_has_32fpr			0
29 #define cpu_has_counter			1
30 #define cpu_has_ejtag			1
31 
32 #if !defined(CONFIG_SOC_AR5312)
33 #  define cpu_has_llsc			1
34 #else
35 /*
36  * The MIPS 4Kc V0.9 core in the AR5312/AR2312 have problems with the
37  * ll/sc instructions.
38  */
39 #  define cpu_has_llsc			0
40 #endif
41 
42 #define cpu_has_mips16			0
43 #define cpu_has_mdmx			0
44 #define cpu_has_mips3d			0
45 #define cpu_has_smartmips		0
46 
47 #define cpu_has_mips32r1		1
48 
49 #if !defined(CONFIG_SOC_AR5312)
50 #  define cpu_has_mips32r2		1
51 #endif
52 
53 #define cpu_has_mips64r1		0
54 #define cpu_has_mips64r2		0
55 
56 #define cpu_has_dsp			0
57 #define cpu_has_mipsmt			0
58 
59 #define cpu_has_64bits			0
60 #define cpu_has_64bit_zero_reg		0
61 #define cpu_has_64bit_gp_regs		0
62 #define cpu_has_64bit_addresses		0
63 
64 #endif /* __ASM_MACH_ATH25_CPU_FEATURE_OVERRIDES_H */
65