blob: e66aa6c94c84060125643379bf97f4058f515e9d [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.
Pirama Arumuga Nainar2d5a50e2015-07-09 12:37:19 -070010 CLANG_CONFIG_arm_EXTRA_CFLAGS += -mcpu=krait -mfpu=neon-vfpv4
Ian Rogerse2708732014-10-28 15:50:02 -070011endif
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,\
Bernhard Rosenkränzera24a9a82015-03-25 16:59:46 +010038 $(1)))
Ying Wang1f982832014-02-06 18:08:44 -080039endef