blob: ceb4a5a038bb4699511c09e0d235b66a11e1b55f [file] [log] [blame]
Ying Wang1f982832014-02-06 18:08:44 -08001# Clang flags for arm arch, target or host.
2
Chih-Hung Hsieh57c8a152014-10-22 09:21:53 -07003CLANG_CONFIG_arm_EXTRA_ASFLAGS :=
Ying Wang1f982832014-02-06 18:08:44 -08004
Chih-Hung Hsieh57c8a152014-10-22 09:21:53 -07005CLANG_CONFIG_arm_EXTRA_CFLAGS :=
Ying Wang1f982832014-02-06 18:08:44 -08006
Ian Rogerse2708732014-10-28 15:50:02 -07007ifneq (,$(filter krait,$(TARGET_$(combo_2nd_arch_prefix)CPU_VARIANT)))
8 # Android's clang support's krait as a CPU whereas GCC doesn't. Specify
9 # -mcpu here rather than the more normal core/combo/arch/arm/armv7-a-neon.mk.
10 CLANG_CONFIG_arm_EXTRA_CFLAGS += -mcpu=krait
11endif
12
Chih-Hung Hsieh57c8a152014-10-22 09:21:53 -070013CLANG_CONFIG_arm_EXTRA_CPPFLAGS :=
Tim Murray43d5e1b2014-04-03 16:06:59 -070014
Chih-Hung Hsieh57c8a152014-10-22 09:21:53 -070015CLANG_CONFIG_arm_EXTRA_LDFLAGS :=
Ying Wang1f982832014-02-06 18:08:44 -080016
17# Include common unknown flags
18CLANG_CONFIG_arm_UNKNOWN_CFLAGS := \
19 $(CLANG_CONFIG_UNKNOWN_CFLAGS) \
20 -mthumb-interwork \
21 -fgcse-after-reload \
22 -frerun-cse-after-loop \
23 -frename-registers \
Ying Wang1f982832014-02-06 18:08:44 -080024 -fno-align-jumps \
Chih-Hung Hsieh02781742014-08-25 13:57:57 -070025 -fno-builtin-sin \
26 -fno-caller-saves \
27 -fno-early-inlining \
28 -fno-move-loop-invariants \
29 -fno-partial-inlining \
30 -fno-strict-volatile-bitfields \
31 -fno-tree-copy-prop \
32 -fno-tree-loop-optimize \
Ying Wang1f982832014-02-06 18:08:44 -080033 -Wa,--noexecstack
34
35define subst-clang-incompatible-arm-flags
36 $(subst -march=armv5te,-march=armv5t,\
37 $(subst -march=armv5e,-march=armv5,\
38 $(subst -mcpu=cortex-a15,-march=armv7-a,\
39 $(1))))
40endef