|
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