|
1 | 1 | NDK_ROOT := $(shell dirname $(CC))/../../../../..
|
2 | 2 |
|
3 |
| -ifeq "$(findstring 64, $(ARCH))" "64" |
4 |
| - # lowest 64-bit API level |
5 |
| - API_LEVEL := 21 |
6 |
| -else ifeq "$(ARCH)" "i386" |
7 |
| - # clone(2) declaration is present only since this api level |
8 |
| - API_LEVEL := 17 |
| 3 | +ifeq "$(HOST_OS)" "Linux" |
| 4 | + HOST_TAG := linux-x86_64 |
| 5 | +else ifeq "$(HOST_OS)" "Darwin" |
| 6 | + HOST_TAG := darwin-x86_64 |
9 | 7 | else
|
10 |
| - # lowest supported 32-bit API level |
11 |
| - API_LEVEL := 16 |
| 8 | + HOST_TAG := windows-x86_64 |
| 9 | +endif |
| 10 | + |
| 11 | +TOOLCHAIN_ROOT := $(NDK_ROOT)/toolchains/llvm/prebuilt/$(HOST_TAG) |
| 12 | +TOOLCHAIN_SYSROOT := $(TOOLCHAIN_ROOT)/sysroot |
| 13 | + |
| 14 | +OBJCOPY ?= $(TOOLCHAIN_ROOT)/bin/llvm-objcopy |
| 15 | +ARCHIVER ?= $(TOOLCHAIN_ROOT)/bin/llvm-ar |
| 16 | + |
| 17 | +ifeq "$(wildcard $(TOOLCHAIN_SYSROOT)/.)" "" |
| 18 | +# Compiling test inferiors for Android requires an NDK with the unified |
| 19 | +# toolchain introduced in version r19. |
| 20 | +$(error "No unified toolchain sysroot found in $(NDK_ROOT). NDK must be r19 or later.") |
12 | 21 | endif
|
13 | 22 |
|
14 | 23 | ifeq "$(ARCH)" "arm"
|
15 |
| - SYSROOT_ARCH := arm |
16 |
| - STL_ARCH := armeabi-v7a |
17 | 24 | TRIPLE := armv7-none-linux-androideabi
|
18 | 25 | ARCH_CFLAGS += -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -marm
|
19 | 26 | else ifeq "$(ARCH)" "aarch64"
|
20 |
| - SYSROOT_ARCH := arm64 |
21 |
| - STL_ARCH := arm64-v8a |
22 | 27 | TRIPLE := aarch64-none-linux-android
|
23 | 28 | else ifeq "$(ARCH)" "i386"
|
24 |
| - SYSROOT_ARCH := x86 |
25 |
| - STL_ARCH := x86 |
26 | 29 | TRIPLE := i686-none-linux-android
|
27 | 30 | else
|
28 |
| - SYSROOT_ARCH := $(ARCH) |
29 |
| - STL_ARCH := $(ARCH) |
30 | 31 | TRIPLE := $(ARCH)-none-linux-android
|
31 | 32 | endif
|
32 | 33 |
|
33 |
| -ifeq "$(findstring 86,$(ARCH))" "86" |
34 |
| - TOOLCHAIN_DIR := $(STL_ARCH)-4.9 |
35 |
| -else ifeq "$(ARCH)" "arm" |
36 |
| - TOOLCHAIN_DIR := arm-linux-androideabi-4.9 |
37 |
| -else |
38 |
| - TOOLCHAIN_DIR := $(subst -none,,$(TRIPLE))-4.9 |
39 |
| -endif |
| 34 | +# lowest 64-bit API level |
| 35 | +API_LEVEL := 21 |
40 | 36 |
|
41 | 37 | ifeq "$(ARCH)" "arm"
|
42 |
| - TOOL_PREFIX := arm-linux-androideabi |
| 38 | + ARCH_DIR := arm-linux-androideabi |
43 | 39 | else
|
44 |
| - TOOL_PREFIX := $(subst -none,,$(TRIPLE)) |
| 40 | + ARCH_DIR := $(subst -none,,$(TRIPLE)) |
45 | 41 | endif
|
46 | 42 |
|
47 |
| -ifeq "$(HOST_OS)" "Linux" |
48 |
| - HOST_TAG := linux-x86_64 |
49 |
| -else ifeq "$(HOST_OS)" "Darwin" |
50 |
| - HOST_TAG := darwin-x86_64 |
51 |
| -else |
52 |
| - HOST_TAG := windows-x86_64 |
53 |
| -endif |
54 |
| - |
55 |
| -GCC_TOOLCHAIN = $(NDK_ROOT)/toolchains/$(TOOLCHAIN_DIR)/prebuilt/$(HOST_TAG) |
56 |
| - |
57 |
| -OBJCOPY ?= $(GCC_TOOLCHAIN)/bin/$(TOOL_PREFIX)-objcopy |
58 |
| -ARCHIVER ?= $(GCC_TOOLCHAIN)/bin/$(TOOL_PREFIX)-ar |
59 |
| - |
60 |
| -ifeq "$(findstring clang,$(CC))" "clang" |
61 |
| - ARCH_CFLAGS += -target $(TRIPLE) --gcc-toolchain=$(GCC_TOOLCHAIN) |
62 |
| - ARCH_LDFLAGS += -target $(TRIPLE) --gcc-toolchain=$(GCC_TOOLCHAIN) |
63 |
| -endif |
64 |
| - |
65 |
| -ARCH_CFLAGS += --sysroot=$(NDK_ROOT)/sysroot \ |
66 |
| - -isystem $(NDK_ROOT)/sysroot/usr/include/$(TOOL_PREFIX) \ |
67 |
| - -D__ANDROID_API__=$(API_LEVEL) \ |
68 |
| - -isystem $(NDK_ROOT)/platforms/android-$(API_LEVEL)/arch-$(SYSROOT_ARCH)/usr/include |
69 |
| - |
70 |
| -ARCH_LDFLAGS += --sysroot=$(NDK_ROOT)/platforms/android-$(API_LEVEL)/arch-$(SYSROOT_ARCH) -lm |
| 43 | +ARCH_CFLAGS += \ |
| 44 | + --target=$(TRIPLE) \ |
| 45 | + --sysroot=$(TOOLCHAIN_SYSROOT) \ |
| 46 | + -D__ANDROID_API__=$(API_LEVEL) |
71 | 47 |
|
72 | 48 | ARCH_CXXFLAGS += \
|
73 |
| - -isystem $(NDK_ROOT)/sources/cxx-stl/llvm-libc++/include \ |
74 |
| - -isystem $(NDK_ROOT)/sources/android/support/include \ |
75 |
| - -isystem $(NDK_ROOT)/sources/cxx-stl/llvm-libc++abi/include |
| 49 | + -isystem $(TOOLCHAIN_SYSROOT)/usr/include/c++/v1 |
76 | 50 |
|
77 | 51 | ARCH_LDFLAGS += \
|
78 |
| - -L$(NDK_ROOT)/sources/cxx-stl/llvm-libc++/libs/$(STL_ARCH) \ |
79 |
| - $(NDK_ROOT)/sources/cxx-stl/llvm-libc++/libs/$(STL_ARCH)/libc++_static.a \ |
| 52 | + --target=$(TRIPLE) \ |
| 53 | + --sysroot=$(TOOLCHAIN_SYSROOT) \ |
| 54 | + --prefix=$(TOOLCHAIN_SYSROOT)/usr/lib/$(ARCH_DIR)/$(API_LEVEL) \ |
| 55 | + -L$(TOOLCHAIN_SYSROOT)/usr/lib/$(ARCH_DIR)/$(API_LEVEL) \ |
| 56 | + $(TOOLCHAIN_SYSROOT)/usr/lib/$(ARCH_DIR)/libc++_static.a \ |
| 57 | + -lm \ |
80 | 58 | -lc++abi \
|
81 | 59 | -nostdlib++
|
0 commit comments