Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 1 | # |
| 2 | # Copyright (C) 2013 The Android Open Source Project |
| 3 | # |
| 4 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | # you may not use this file except in compliance with the License. |
| 6 | # You may obtain a copy of the License at |
| 7 | # |
| 8 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | # |
| 10 | # Unless required by applicable law or agreed to in writing, software |
| 11 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | # See the License for the specific language governing permissions and |
| 14 | # limitations under the License. |
| 15 | # |
| 16 | |
| 17 | # Configuration for Linux on MIPS64. |
| 18 | # Included by combo/select.mk |
| 19 | |
| 20 | # You can set TARGET_ARCH_VARIANT to use an arch version other |
Duane Sand | 1a07487 | 2014-11-08 15:25:18 -0800 | [diff] [blame] | 21 | # than mips64r6. Each value should correspond to a file named |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 22 | # $(BUILD_COMBOS)/arch/<name>.mk which must contain |
Elliott Hughes | 4314611 | 2015-08-28 10:31:28 -0700 | [diff] [blame] | 23 | # makefile variable definitions. Their |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 24 | # purpose is to allow module Android.mk files to selectively compile |
| 25 | # different versions of code based upon the funtionality and |
| 26 | # instructions available in a given architecture version. |
| 27 | # |
| 28 | # The blocks also define specific arch_variant_cflags, which |
| 29 | # include defines, and compiler settings for the given architecture |
| 30 | # version. |
| 31 | # |
| 32 | ifeq ($(strip $(TARGET_ARCH_VARIANT)),) |
Raghu Gandham | 10326b3 | 2014-09-02 16:30:00 -0700 | [diff] [blame] | 33 | TARGET_ARCH_VARIANT := mips64r6 |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 34 | endif |
| 35 | |
Ben Cheng | 4de6fa4 | 2014-04-10 22:46:26 -0700 | [diff] [blame] | 36 | # Decouple NDK library selection with platform compiler version |
Duane Sand | 1a07487 | 2014-11-08 15:25:18 -0800 | [diff] [blame] | 37 | TARGET_NDK_GCC_VERSION := 4.9 |
Ben Cheng | 4de6fa4 | 2014-04-10 22:46:26 -0700 | [diff] [blame] | 38 | |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 39 | ifeq ($(strip $(TARGET_GCC_VERSION_EXP)),) |
Duane Sand | 6670e24 | 2014-07-22 14:34:00 -0700 | [diff] [blame] | 40 | TARGET_GCC_VERSION := 4.9 |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 41 | else |
| 42 | TARGET_GCC_VERSION := $(TARGET_GCC_VERSION_EXP) |
| 43 | endif |
| 44 | |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 45 | TARGET_ARCH_SPECIFIC_MAKEFILE := $(BUILD_COMBOS)/arch/$(TARGET_ARCH)/$(TARGET_ARCH_VARIANT).mk |
| 46 | ifeq ($(strip $(wildcard $(TARGET_ARCH_SPECIFIC_MAKEFILE))),) |
| 47 | $(error Unknown MIPS architecture variant: $(TARGET_ARCH_VARIANT)) |
| 48 | endif |
| 49 | |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 50 | include $(TARGET_ARCH_SPECIFIC_MAKEFILE) |
Dehao Chen | 7092c79 | 2014-07-23 14:28:58 -0700 | [diff] [blame] | 51 | include $(BUILD_SYSTEM)/combo/fdo.mk |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 52 | |
| 53 | # You can set TARGET_TOOLS_PREFIX to get gcc from somewhere else |
| 54 | ifeq ($(strip $(TARGET_TOOLS_PREFIX)),) |
| 55 | TARGET_TOOLCHAIN_ROOT := prebuilts/gcc/$(HOST_PREBUILT_TAG)/mips/mips64el-linux-android-$(TARGET_GCC_VERSION) |
| 56 | TARGET_TOOLS_PREFIX := $(TARGET_TOOLCHAIN_ROOT)/bin/mips64el-linux-android- |
| 57 | endif |
| 58 | |
Dan Albert | 216ecac | 2015-05-04 12:44:44 -0700 | [diff] [blame] | 59 | TARGET_CC := $(TARGET_TOOLS_PREFIX)gcc |
| 60 | TARGET_CXX := $(TARGET_TOOLS_PREFIX)g++ |
| 61 | TARGET_AR := $(TARGET_TOOLS_PREFIX)ar |
| 62 | TARGET_OBJCOPY := $(TARGET_TOOLS_PREFIX)objcopy |
| 63 | TARGET_LD := $(TARGET_TOOLS_PREFIX)ld |
| 64 | TARGET_READELF := $(TARGET_TOOLS_PREFIX)readelf |
| 65 | TARGET_STRIP := $(TARGET_TOOLS_PREFIX)strip |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 66 | |
| 67 | TARGET_NO_UNDEFINED_LDFLAGS := -Wl,--no-undefined |
| 68 | |
| 69 | TARGET_mips_CFLAGS := -O2 \ |
| 70 | -fomit-frame-pointer \ |
| 71 | -fno-strict-aliasing \ |
| 72 | -funswitch-loops |
| 73 | |
| 74 | # Set FORCE_MIPS_DEBUGGING to "true" in your buildspec.mk |
| 75 | # or in your environment to gdb debugging easier. |
| 76 | # Don't forget to do a clean build. |
| 77 | ifeq ($(FORCE_MIPS_DEBUGGING),true) |
| 78 | TARGET_mips_CFLAGS += -fno-omit-frame-pointer |
| 79 | endif |
| 80 | |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 81 | TARGET_GLOBAL_CFLAGS += \ |
| 82 | $(TARGET_mips_CFLAGS) \ |
Elliott Hughes | 1acd8b0 | 2014-04-23 23:24:36 -0700 | [diff] [blame] | 83 | -U__unix -U__unix__ -Umips \ |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 84 | -ffunction-sections \ |
| 85 | -fdata-sections \ |
| 86 | -funwind-tables \ |
| 87 | -Wa,--noexecstack \ |
| 88 | -Werror=format-security \ |
| 89 | -D_FORTIFY_SOURCE=2 \ |
Andrew Hsieh | 48f239c | 2014-05-09 14:13:13 +0800 | [diff] [blame] | 90 | -no-canonical-prefixes \ |
| 91 | -fno-canonical-system-headers \ |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 92 | $(arch_variant_cflags) \ |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 93 | |
Elliott Hughes | d1ea5fb | 2015-02-24 16:04:31 -0800 | [diff] [blame] | 94 | # Help catch common 32/64-bit errors. |
| 95 | TARGET_GLOBAL_CFLAGS += \ |
| 96 | -Werror=pointer-to-int-cast \ |
| 97 | -Werror=int-to-pointer-cast \ |
| 98 | -Werror=implicit-function-declaration \ |
| 99 | |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 100 | ifneq ($(ARCH_MIPS_PAGE_SHIFT),) |
| 101 | TARGET_GLOBAL_CFLAGS += -DPAGE_SHIFT=$(ARCH_MIPS_PAGE_SHIFT) |
| 102 | endif |
| 103 | |
| 104 | TARGET_GLOBAL_LDFLAGS += \ |
| 105 | -Wl,-z,noexecstack \ |
| 106 | -Wl,-z,relro \ |
| 107 | -Wl,-z,now \ |
Dehao Chen | 734de7a | 2015-01-14 11:21:22 -0800 | [diff] [blame] | 108 | -Wl,--build-id=md5 \ |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 109 | -Wl,--warn-shared-textrel \ |
| 110 | -Wl,--fatal-warnings \ |
| 111 | $(arch_variant_ldflags) |
| 112 | |
Dan Albert | 46ed1e8 | 2015-08-06 14:17:40 -0700 | [diff] [blame] | 113 | # Disable transitive dependency library symbol resolving. |
| 114 | TARGET_GLOBAL_LDFLAGS += -Wl,--allow-shlib-undefined |
| 115 | |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 116 | TARGET_GLOBAL_CPPFLAGS += -fvisibility-inlines-hidden |
| 117 | |
| 118 | # More flags/options can be added here |
| 119 | TARGET_RELEASE_CFLAGS := \ |
| 120 | -DNDEBUG \ |
| 121 | -g \ |
| 122 | -Wstrict-aliasing=2 \ |
| 123 | -fgcse-after-reload \ |
| 124 | -frerun-cse-after-loop \ |
| 125 | -frename-registers |
| 126 | |
| 127 | libc_root := bionic/libc |
| 128 | libm_root := bionic/libm |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 129 | |
| 130 | |
| 131 | ## on some hosts, the target cross-compiler is not available so do not run this command |
| 132 | ifneq ($(wildcard $(TARGET_CC)),) |
| 133 | # We compile with the global cflags to ensure that |
| 134 | # any flags which affect libgcc are correctly taken |
| 135 | # into account. |
| 136 | TARGET_LIBGCC := \ |
| 137 | $(shell $(TARGET_CC) $(TARGET_GLOBAL_CFLAGS) -print-file-name=libgcc.a) |
Andrew Hsieh | 4c952d7 | 2014-05-29 02:47:27 -0700 | [diff] [blame] | 138 | TARGET_LIBATOMIC := \ |
| 139 | $(shell $(TARGET_CC) $(TARGET_GLOBAL_CFLAGS) -print-file-name=libatomic.a) |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 140 | LIBGCC_EH := $(shell $(TARGET_CC) $(TARGET_GLOBAL_CFLAGS) -print-file-name=libgcc_eh.a) |
| 141 | ifneq ($(LIBGCC_EH),libgcc_eh.a) |
| 142 | TARGET_LIBGCC += $(LIBGCC_EH) |
| 143 | endif |
Dan Albert | 4bbc6c7 | 2014-09-19 14:25:57 -0700 | [diff] [blame] | 144 | TARGET_LIBGCOV := $(shell $(TARGET_CC) $(TARGET_GLOBAL_CFLAGS) \ |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 145 | --print-file-name=libgcov.a) |
| 146 | endif |
| 147 | |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 148 | KERNEL_HEADERS_COMMON := $(libc_root)/kernel/uapi |
Christopher Ferris | 6a2f285 | 2015-09-16 11:09:04 -0700 | [diff] [blame] | 149 | KERNEL_HEADERS_COMMON += $(libc_root)/kernel/common |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 150 | KERNEL_HEADERS_ARCH := $(libc_root)/kernel/uapi/asm-mips |
| 151 | # TODO: perhaps use $(libc_root)/kernel/uapi/asm-$(TARGET_ARCH) instead of asm-mips ? |
| 152 | KERNEL_HEADERS := $(KERNEL_HEADERS_COMMON) $(KERNEL_HEADERS_ARCH) |
| 153 | |
| 154 | TARGET_C_INCLUDES := \ |
| 155 | $(libc_root)/arch-mips64/include \ |
| 156 | $(libc_root)/include \ |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 157 | $(KERNEL_HEADERS) \ |
| 158 | $(libm_root)/include \ |
| 159 | $(libm_root)/include/mips \ |
Elliott Hughes | c09eaa7 | 2015-06-16 15:22:52 -0700 | [diff] [blame] | 160 | |
Chris Dearman | 1efd9e4 | 2014-02-03 15:01:24 -0800 | [diff] [blame] | 161 | # TODO: perhaps use $(libm_root)/include/mips64 instead of mips ? |
| 162 | |
| 163 | TARGET_CRTBEGIN_STATIC_O := $(TARGET_OUT_INTERMEDIATE_LIBRARIES)/crtbegin_static.o |
| 164 | TARGET_CRTBEGIN_DYNAMIC_O := $(TARGET_OUT_INTERMEDIATE_LIBRARIES)/crtbegin_dynamic.o |
| 165 | TARGET_CRTEND_O := $(TARGET_OUT_INTERMEDIATE_LIBRARIES)/crtend_android.o |
| 166 | |
| 167 | TARGET_CRTBEGIN_SO_O := $(TARGET_OUT_INTERMEDIATE_LIBRARIES)/crtbegin_so.o |
| 168 | TARGET_CRTEND_SO_O := $(TARGET_OUT_INTERMEDIATE_LIBRARIES)/crtend_so.o |
| 169 | |
Dmitriy Ivanov | 8387d99 | 2015-04-29 15:34:21 -0700 | [diff] [blame] | 170 | TARGET_PACK_MODULE_RELOCATIONS := true |
| 171 | |
Dan Albert | e088c0d | 2014-11-13 10:15:46 -0800 | [diff] [blame] | 172 | TARGET_LINKER := /system/bin/linker64 |