diff options
author | Gabor Juhos <juhosg@openwrt.org> | 2013-08-23 09:06:36 -0400 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2013-09-04 10:58:31 -0400 |
commit | 9852ba6a914f95db65e86fed85d02d5309a301da (patch) | |
tree | e2bce37be0c3e28fd614d619aabfb9e209226327 /arch/mips | |
parent | 0d4649684ca6cbc536fcc509e7aac0b34bb4146a (diff) |
MIPS: ralink: mt7620: Add cpu-feature-override header
Override certain CPU features to help GCC to optimize
the generated code. Saves about 150KB in the vmlinux
image with a generic configuration.
text data bss dec hex filename
3824158 134820 234192 4193170 3ffb92 vmlinux.no-override
3664054 138804 234192 4037050 3d99ba vmlinux.override
Signed-off-by: Gabor Juhos <juhosg@openwrt.org>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/5759/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips')
-rw-r--r-- | arch/mips/include/asm/mach-ralink/mt7620/cpu-feature-overrides.h | 57 | ||||
-rw-r--r-- | arch/mips/ralink/Platform | 1 |
2 files changed, 58 insertions, 0 deletions
diff --git a/arch/mips/include/asm/mach-ralink/mt7620/cpu-feature-overrides.h b/arch/mips/include/asm/mach-ralink/mt7620/cpu-feature-overrides.h new file mode 100644 index 000000000000..f7bb8cfc5eb1 --- /dev/null +++ b/arch/mips/include/asm/mach-ralink/mt7620/cpu-feature-overrides.h | |||
@@ -0,0 +1,57 @@ | |||
1 | /* | ||
2 | * Ralink MT7620 specific CPU feature overrides | ||
3 | * | ||
4 | * Copyright (C) 2008-2009 Gabor Juhos <juhosg@openwrt.org> | ||
5 | * Copyright (C) 2008 Imre Kaloz <kaloz@openwrt.org> | ||
6 | * | ||
7 | * This file was derived from: include/asm-mips/cpu-features.h | ||
8 | * Copyright (C) 2003, 2004 Ralf Baechle | ||
9 | * Copyright (C) 2004 Maciej W. Rozycki | ||
10 | * | ||
11 | * This program is free software; you can redistribute it and/or modify it | ||
12 | * under the terms of the GNU General Public License version 2 as published | ||
13 | * by the Free Software Foundation. | ||
14 | * | ||
15 | */ | ||
16 | #ifndef _MT7620_CPU_FEATURE_OVERRIDES_H | ||
17 | #define _MT7620_CPU_FEATURE_OVERRIDES_H | ||
18 | |||
19 | #define cpu_has_tlb 1 | ||
20 | #define cpu_has_4kex 1 | ||
21 | #define cpu_has_3k_cache 0 | ||
22 | #define cpu_has_4k_cache 1 | ||
23 | #define cpu_has_tx39_cache 0 | ||
24 | #define cpu_has_sb1_cache 0 | ||
25 | #define cpu_has_fpu 0 | ||
26 | #define cpu_has_32fpr 0 | ||
27 | #define cpu_has_counter 1 | ||
28 | #define cpu_has_watch 1 | ||
29 | #define cpu_has_divec 1 | ||
30 | |||
31 | #define cpu_has_prefetch 1 | ||
32 | #define cpu_has_ejtag 1 | ||
33 | #define cpu_has_llsc 1 | ||
34 | |||
35 | #define cpu_has_mips16 1 | ||
36 | #define cpu_has_mdmx 0 | ||
37 | #define cpu_has_mips3d 0 | ||
38 | #define cpu_has_smartmips 0 | ||
39 | |||
40 | #define cpu_has_mips32r1 1 | ||
41 | #define cpu_has_mips32r2 1 | ||
42 | #define cpu_has_mips64r1 0 | ||
43 | #define cpu_has_mips64r2 0 | ||
44 | |||
45 | #define cpu_has_dsp 1 | ||
46 | #define cpu_has_dsp2 0 | ||
47 | #define cpu_has_mipsmt 0 | ||
48 | |||
49 | #define cpu_has_64bits 0 | ||
50 | #define cpu_has_64bit_zero_reg 0 | ||
51 | #define cpu_has_64bit_gp_regs 0 | ||
52 | #define cpu_has_64bit_addresses 0 | ||
53 | |||
54 | #define cpu_dcache_line_size() 32 | ||
55 | #define cpu_icache_line_size() 32 | ||
56 | |||
57 | #endif /* _MT7620_CPU_FEATURE_OVERRIDES_H */ | ||
diff --git a/arch/mips/ralink/Platform b/arch/mips/ralink/Platform index cda4b6645c50..6d9c8c499f98 100644 --- a/arch/mips/ralink/Platform +++ b/arch/mips/ralink/Platform | |||
@@ -26,3 +26,4 @@ cflags-$(CONFIG_SOC_RT3883) += -I$(srctree)/arch/mips/include/asm/mach-ralink/rt | |||
26 | # Ralink MT7620 | 26 | # Ralink MT7620 |
27 | # | 27 | # |
28 | load-$(CONFIG_SOC_MT7620) += 0xffffffff80000000 | 28 | load-$(CONFIG_SOC_MT7620) += 0xffffffff80000000 |
29 | cflags-$(CONFIG_SOC_MT7620) += -I$(srctree)/arch/mips/include/asm/mach-ralink/mt7620 | ||