Skip to content

Commit

Permalink
arm: compile all thumb with -mthumb-interwork and cleanup -O3
Browse files Browse the repository at this point in the history
To enable this option use ENABLE_ARM_THUMB_INTERWORK := true

This may slightly increase binary size but will include more arm
instructions for increased performance.

https://gcc.gnu.org/onlinedocs/gcc/ARM-Options.html

Change-Id: I0ba0a2d34b84e34309c20ce0cbb85ea3ee6dda15
Signed-off-by: Paul Beeler <pbeeler80@gmail.com>
  • Loading branch information
pbeeler committed Feb 20, 2015
1 parent 37fb144 commit ae59641
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 25 deletions.
33 changes: 8 additions & 25 deletions core/O3.mk
Original file line number Diff line number Diff line change
Expand Up @@ -14,32 +14,15 @@
#

ifneq (1,$(words $(filter $(LOCAL_DISABLE_O3),$(LOCAL_MODULE))))
LOCAL_ARM_MODE := $(strip $(LOCAL_ARM_MODE))
ifeq (arm,$(TARGET_$(LOCAL_2ND_ARCH_VAR_PREFIX)ARCH))
arm_objects_mode := $(if $(LOCAL_ARM_MODE),$(LOCAL_ARM_MODE),arm)
normal_objects_mode := $(if $(LOCAL_ARM_MODE),$(LOCAL_ARM_MODE),thumb)

# Read the values from something like TARGET_arm_CFLAGS or
# TARGET_thumb_CFLAGS. HOST_(arm|thumb)_CFLAGS values aren't
# actually used (although they are usually empty).
arm_objects_cflags := $($(LOCAL_2ND_ARCH_VAR_PREFIX)$(my_prefix)$(arm_objects_mode)_CFLAGS)
normal_objects_cflags := $($(LOCAL_2ND_ARCH_VAR_PREFIX)$(my_prefix)$(normal_objects_mode)_CFLAGS)
ifdef LOCAL_CONLYFLAGS
LOCAL_CONLYFLAGS += $(O3_FLAGS)
else
arm_objects_mode :=
normal_objects_mode :=
arm_objects_cflags :=
normal_objects_cflags :=
LOCAL_CONLYFLAGS := $(O3_FLAGS)
endif
ifeq ($(filter $(LOCAL_DISABLE_O3_CFLAGS),$(arm_objects_cflags)$(normal_objects_cflags)),)
ifdef LOCAL_CONLYFLAGS
LOCAL_CONLYFLAGS += $(O3_FLAGS)
else
LOCAL_CONLYFLAGS := $(O3_FLAGS)
endif
ifdef LOCAL_CPPFLAGS
LOCAL_CPPFLAGS += $(O3_FLAGS)
else
LOCAL_CPPFLAGS := $(O3_FLAGS)
endif
ifdef LOCAL_CPPFLAGS
LOCAL_CPPFLAGS += $(O3_FLAGS)
else
LOCAL_CPPFLAGS := $(O3_FLAGS)
endif
endif
endif
7 changes: 7 additions & 0 deletions core/binary.mk
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,13 @@ endif

# Include custom gcc flags. Seperate them so they can be easily managed.

# arm thumb
ifeq ($(strip $(ENABLE_ARM_THUMB_INTERWORK)),true)
ifneq ($(strip $(LOCAL_IS_HOST_MODULE)),true)
include $(BUILD_SYSTEM)/thumb_interwork.mk
endif
endif

# O3
ifeq ($(strip $(O3_OPTIMIZATIONS)),true)
include $(BUILD_SYSTEM)/O3.mk
Expand Down
41 changes: 41 additions & 0 deletions core/thumb_interwork.mk
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
# Copyright (C) 2014-2015 The SaberMod Project
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#

# Copyright (C) 2014-2015 The SaberMod Project
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#

ifeq ($(strip (TARGET_ARCH)),arm)
ifneq (1,$(words $(filter $(LOCAL_DISABLE_THUMB_INTERWORK),$(LOCAL_MODULE))))
ifdef LOCAL_CFLAGS
LOCAL_CFLAGS += \
-mthumb-interwork
else
LOCAL_CFLAGS := \
-mthumb-interwork
endif
endif
endif

0 comments on commit ae59641

Please sign in to comment.