am b71677b1: Merge "Extend x86 to have different arch variants"
* commit 'b71677b17cc0100caf16209bfcd1eee529e2eb5a': Extend x86 to have different arch variants
This commit is contained in:
commit
70190a2b02
|
@ -131,7 +131,8 @@ TARGET_GLOBAL_CFLAGS += \
|
|||
-fstrict-aliasing \
|
||||
-funswitch-loops \
|
||||
-funwind-tables \
|
||||
-fstack-protector
|
||||
-fstack-protector \
|
||||
-m32
|
||||
|
||||
android_config_h := $(call select-android-config-h,target_linux-x86)
|
||||
TARGET_ANDROID_CONFIG_CFLAGS := -include $(android_config_h) -I $(dir $(android_config_h))
|
||||
|
@ -141,23 +142,37 @@ TARGET_GLOBAL_CFLAGS += $(TARGET_ANDROID_CONFIG_CFLAGS)
|
|||
TARGET_GLOBAL_CPPFLAGS += \
|
||||
-fno-use-cxa-atexit
|
||||
|
||||
# XXX: Our toolchain is normally configured to always set these flags by default
|
||||
# however, there have been reports that this is sometimes not the case. So make
|
||||
# them explicit here unless we have the time to carefully check it
|
||||
#
|
||||
TARGET_GLOBAL_CFLAGS += -mstackrealign -msse3 -mfpmath=sse -m32
|
||||
TARGET_GLOBAL_CFLAGS += $(arch_variant_cflags)
|
||||
|
||||
# XXX: These flags should not be defined here anymore. Instead, the Android.mk
|
||||
# of the modules that depend on these features should instead check the
|
||||
# corresponding macros (e.g. ARCH_X86_HAVE_SSE2 and ARCH_X86_HAVE_SSSE3)
|
||||
# Keep them here until this is all cleared up.
|
||||
#
|
||||
ifeq ($(ARCH_X86_HAVE_SSE2),true)
|
||||
TARGET_GLOBAL_CFLAGS += -DUSE_SSE2
|
||||
ifeq ($(ARCH_X86_HAVE_MMX),true)
|
||||
TARGET_GLOBAL_CFLAGS += -DUSE_MMX -mmmx
|
||||
endif
|
||||
ifeq ($(ARCH_X86_HAVE_SSE),true)
|
||||
TARGET_GLOBAL_CFLAGS += -DUSE_SSE -msse
|
||||
endif
|
||||
ifeq ($(ARCH_X86_HAVE_SSE2),true)
|
||||
TARGET_GLOBAL_CFLAGS += -DUSE_SSE2 -msse2
|
||||
endif
|
||||
ifeq ($(ARCH_X86_HAVE_SSE3),true)
|
||||
TARGET_GLOBAL_CFLAGS += -DUSE_SSE3 -msse3
|
||||
endif
|
||||
|
||||
ifeq ($(ARCH_X86_HAVE_SSSE3),true) # yes, really SSSE3, not SSE3!
|
||||
TARGET_GLOBAL_CFLAGS += -DUSE_SSSE3
|
||||
TARGET_GLOBAL_CFLAGS += -DUSE_SSSE3 -mssse3
|
||||
endif
|
||||
ifeq ($(ARCH_X86_HAVE_SSE4),true)
|
||||
TARGET_GLOBAL_CFLAGS += -msse4
|
||||
endif
|
||||
ifeq ($(ARCH_X86_HAVE_SSE4_1),true)
|
||||
TARGET_GLOBAL_CFLAGS += -msse4.1
|
||||
endif
|
||||
ifeq ($(ARCH_X86_HAVE_SSE4_2),true)
|
||||
TARGET_GLOBAL_CFLAGS += -msse4.2
|
||||
endif
|
||||
ifeq ($(ARCH_X86_HAVE_AVX),true)
|
||||
TARGET_GLOBAL_CFLAGS += -mavx
|
||||
endif
|
||||
ifeq ($(ARCH_X86_HAVE_AES_NI),true)
|
||||
TARGET_GLOBAL_CFLAGS += -maes
|
||||
endif
|
||||
|
||||
# XXX: This flag is probably redundant. I believe our toolchain always sets
|
||||
|
|
|
@ -0,0 +1,20 @@
|
|||
# Configuration for Linux on x86.
|
||||
# Generating binaries for Haswell processors.
|
||||
#
|
||||
ARCH_X86_HAVE_MMX := true
|
||||
ARCH_X86_HAVE_SSE := true
|
||||
ARCH_X86_HAVE_SSE2 := true
|
||||
ARCH_X86_HAVE_SSE3 := true
|
||||
ARCH_X86_HAVE_SSSE3 := true
|
||||
ARCH_X86_HAVE_SSE4 := true
|
||||
ARCH_X86_HAVE_SSE4_1 := true
|
||||
ARCH_X86_HAVE_SSE4_2 := true
|
||||
ARCH_X86_HAVE_AES_NI := true
|
||||
ARCH_X86_HAVE_AVX := true
|
||||
|
||||
# CFLAGS for this arch
|
||||
arch_variant_cflags := \
|
||||
-march=core-avx2 \
|
||||
-mstackrealign \
|
||||
-mfpmath=sse \
|
||||
|
|
@ -0,0 +1,20 @@
|
|||
# Configuration for Linux on x86.
|
||||
# Generating binaries for Ivy Bridge processors.
|
||||
#
|
||||
ARCH_X86_HAVE_MMX := true
|
||||
ARCH_X86_HAVE_SSE := true
|
||||
ARCH_X86_HAVE_SSE2 := true
|
||||
ARCH_X86_HAVE_SSE3 := true
|
||||
ARCH_X86_HAVE_SSSE3 := true
|
||||
ARCH_X86_HAVE_SSE4 := true
|
||||
ARCH_X86_HAVE_SSE4_1 := true
|
||||
ARCH_X86_HAVE_SSE4_2 := true
|
||||
ARCH_X86_HAVE_AES_NI := true
|
||||
ARCH_X86_HAVE_AVX := true
|
||||
|
||||
# CFLAGS for this arch
|
||||
arch_variant_cflags := \
|
||||
-march=core-avx-i \
|
||||
-mstackrealign \
|
||||
-mfpmath=sse \
|
||||
|
|
@ -0,0 +1,18 @@
|
|||
# Configuration for Linux on x86.
|
||||
# Generating binaries for SandyBridge processors.
|
||||
#
|
||||
ARCH_X86_HAVE_MMX := true
|
||||
ARCH_X86_HAVE_SSE := true
|
||||
ARCH_X86_HAVE_SSE2 := true
|
||||
ARCH_X86_HAVE_SSE3 := true
|
||||
ARCH_X86_HAVE_SSSE3 := true
|
||||
ARCH_X86_HAVE_SSE4_1 := true
|
||||
ARCH_X86_HAVE_SSE4_2 := true
|
||||
ARCH_X86_HAVE_AVX := true
|
||||
|
||||
# CFLAGS for this arch
|
||||
arch_variant_cflags := \
|
||||
-march=corei7-avx \
|
||||
-mstackrealign \
|
||||
-mfpmath=sse \
|
||||
|
|
@ -8,11 +8,13 @@ ARCH_X86_HAVE_MMX := true
|
|||
ARCH_X86_HAVE_SSE := true
|
||||
ARCH_X86_HAVE_SSE2 := true
|
||||
ARCH_X86_HAVE_SSE3 := true
|
||||
|
||||
ARCH_X86_HAVE_SSSE3 := true
|
||||
ARCH_X86_HAVE_MOVBE := true
|
||||
ARCH_X86_HAVE_POPCNT := false # popcnt is not supported by current Atom CPUs
|
||||
|
||||
# This flag is used to enabled Atom-specific optimizations with our toolchain
|
||||
#
|
||||
TARGET_GLOBAL_CFLAGS += -march=atom
|
||||
# CFLAGS for this arch
|
||||
arch_variant_cflags := \
|
||||
-march=atom \
|
||||
-mstackrealign \
|
||||
-mfpmath=sse \
|
||||
|
||||
|
|
|
@ -32,4 +32,6 @@ ARCH_X86_HAVE_POPCNT := false
|
|||
# not always work as intended, so keep it unless we have the time to check
|
||||
# everything properly.
|
||||
|
||||
TARGET_GLOBAL_CFLAGS += -march=i686
|
||||
arch_variant_cflags := \
|
||||
-march=i686 \
|
||||
|
||||
|
|
Loading…
Reference in New Issue