mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-27 01:04:03 +00:00
b980f22877
The `--disable-jemalloc` configure option has a failure mode where it will create a distribution that is not compatible with other compilers. For example the nightly for Linux will assume that it will link to jemalloc by default as an allocator for executable crates. If, however, a standard library is used which was built via `./configure --disable-jemalloc` then this will fail because the jemalloc crate wasn't built. While this seems somewhat reasonable as a niche situation, the same mechanism is used for disabling jemalloc for platforms that just don't support it. For example if the rumprun target is compiled then the sibiling Linux target *also* doesn't have jemalloc. This is currently a problem for our cross-build nightlies which build many targets. If rumprun is also built, it will disable jemalloc for all targets, which isn't desired. This commit moves the platform-specific disabling of jemalloc as hardcoded logic into the makefiles that is scoped per-platform. This way when configuring multiple targets **without the `--disable-jemalloc` option specified** all targets will get jemalloc as they should.
138 lines
4.7 KiB
Makefile
138 lines
4.7 KiB
Makefile
# Copyright 2012 The Rust Project Developers. See the COPYRIGHT
|
|
# file at the top-level directory of this distribution and at
|
|
# http://rust-lang.org/COPYRIGHT.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
# http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
# <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
# option. This file may not be copied, modified, or distributed
|
|
# except according to those terms.
|
|
|
|
RUN_INSTALLER = cd tmp/empty_dir && \
|
|
sh ../../tmp/dist/$(1)/install.sh \
|
|
--prefix="$(DESTDIR)$(CFG_PREFIX)" \
|
|
--libdir="$(DESTDIR)$(CFG_LIBDIR)" \
|
|
--mandir="$(DESTDIR)$(CFG_MANDIR)"
|
|
|
|
install:
|
|
ifeq (root user, $(USER) $(patsubst %,user,$(SUDO_USER)))
|
|
# Build the dist as the original user
|
|
$(Q)sudo -u "$$SUDO_USER" $(MAKE) prepare_install
|
|
else
|
|
$(Q)$(MAKE) prepare_install
|
|
endif
|
|
ifeq ($(CFG_DISABLE_DOCS),)
|
|
$(Q)$(call RUN_INSTALLER,$(DOC_PKG_NAME)-$(CFG_BUILD)) --disable-ldconfig
|
|
endif
|
|
$(Q)$(foreach target,$(CFG_TARGET),\
|
|
($(call RUN_INSTALLER,$(STD_PKG_NAME)-$(target)) --disable-ldconfig);)
|
|
$(Q)$(call RUN_INSTALLER,$(PKG_NAME)-$(CFG_BUILD))
|
|
# Remove tmp files because it's a decent amount of disk space
|
|
$(Q)rm -R tmp/dist
|
|
|
|
prepare_install: dist-tar-bins | tmp/empty_dir
|
|
|
|
uninstall:
|
|
ifeq (root user, $(USER) $(patsubst %,user,$(SUDO_USER)))
|
|
# Build the dist as the original user
|
|
$(Q)sudo -u "$$SUDO_USER" $(MAKE) prepare_uninstall
|
|
else
|
|
$(Q)$(MAKE) prepare_uninstall
|
|
endif
|
|
ifeq ($(CFG_DISABLE_DOCS),)
|
|
$(Q)$(call RUN_INSTALLER,$(DOC_PKG_NAME)-$(CFG_BUILD)) --uninstall
|
|
endif
|
|
$(Q)$(call RUN_INSTALLER,$(PKG_NAME)-$(CFG_BUILD)) --uninstall
|
|
$(Q)$(foreach target,$(CFG_TARGET),\
|
|
($(call RUN_INSTALLER,$(STD_PKG_NAME)-$(target)) --uninstall);)
|
|
# Remove tmp files because it's a decent amount of disk space
|
|
$(Q)rm -R tmp/dist
|
|
|
|
prepare_uninstall: dist-tar-bins | tmp/empty_dir
|
|
|
|
.PHONY: install prepare_install uninstall prepare_uninstall
|
|
|
|
tmp/empty_dir:
|
|
mkdir -p $@
|
|
|
|
######################################################################
|
|
# Android remote installation
|
|
######################################################################
|
|
|
|
# Android runtime setup
|
|
# FIXME: This probably belongs somewhere else
|
|
|
|
# target platform specific variables for android
|
|
define DEF_ADB_DEVICE_STATUS
|
|
CFG_ADB_DEVICE_STATUS=$(1)
|
|
endef
|
|
|
|
$(foreach target,$(CFG_TARGET), \
|
|
$(if $(findstring android, $(target)), \
|
|
$(if $(findstring adb,$(CFG_ADB)), \
|
|
$(if $(findstring device,$(shell $(CFG_ADB) devices 2>/dev/null | grep -E '^[_A-Za-z0-9-]+[[:blank:]]+device')), \
|
|
$(info install: install-runtime-target for $(target) enabled \
|
|
$(info install: android device attached) \
|
|
$(eval $(call DEF_ADB_DEVICE_STATUS, true))), \
|
|
$(info install: install-runtime-target for $(target) disabled \
|
|
$(info install: android device not attached) \
|
|
$(eval $(call DEF_ADB_DEVICE_STATUS, false))) \
|
|
), \
|
|
$(info install: install-runtime-target for $(target) disabled \
|
|
$(info install: adb not found) \
|
|
$(eval $(call DEF_ADB_DEVICE_STATUS, false))) \
|
|
), \
|
|
) \
|
|
)
|
|
|
|
ifeq (install-runtime-target,$(firstword $(MAKECMDGOALS)))
|
|
$(eval $(wordlist 2,$(words $(MAKECMDGOALS)),$(MAKECMDGOALS)):;@:)
|
|
L_TOKEN := $(word 2,$(MAKECMDGOALS))
|
|
ifeq ($(L_TOKEN),)
|
|
CFG_RUNTIME_PUSH_DIR=/system/lib
|
|
else
|
|
CFG_RUNTIME_PUSH_DIR=$(L_TOKEN)
|
|
endif
|
|
|
|
ifeq ($(CFG_ADB_DEVICE_STATUS),true)
|
|
ifdef VERBOSE
|
|
ADB = adb $(1)
|
|
ADB_PUSH = adb push $(1) $(2)
|
|
ADB_SHELL = adb shell $(1) $(2)
|
|
else
|
|
ADB = $(Q)$(call E, adb $(1)) && adb $(1) 1>/dev/null
|
|
ADB_PUSH = $(Q)$(call E, adb push $(1)) && adb push $(1) $(2) 1>/dev/null
|
|
ADB_SHELL = $(Q)$(call E, adb shell $(1) $(2)) && adb shell $(1) $(2) 1>/dev/null
|
|
endif
|
|
|
|
define INSTALL_RUNTIME_TARGET_N
|
|
install-runtime-target-$(1)-host-$(2): $$(TSREQ$$(ISTAGE)_T_$(1)_H_$(2)) $$(SREQ$$(ISTAGE)_T_$(1)_H_$(2))
|
|
$$(Q)$$(call ADB_SHELL,mkdir,$(CFG_RUNTIME_PUSH_DIR))
|
|
$$(Q)$$(foreach crate,$$(TARGET_CRATES_$(1)), \
|
|
$$(call ADB_PUSH,$$(TL$(1)$(2))/$$(call CFG_LIB_GLOB_$(1),$$(crate)), \
|
|
$$(CFG_RUNTIME_PUSH_DIR));)
|
|
endef
|
|
|
|
define INSTALL_RUNTIME_TARGET_CLEANUP_N
|
|
install-runtime-target-$(1)-cleanup:
|
|
$$(Q)$$(call ADB,remount)
|
|
$$(Q)$$(foreach crate,$$(TARGET_CRATES_$(1)), \
|
|
$$(call ADB_SHELL,rm,$$(CFG_RUNTIME_PUSH_DIR)/$$(call CFG_LIB_GLOB_$(1),$$(crate)));)
|
|
endef
|
|
|
|
$(foreach target,$(CFG_TARGET), \
|
|
$(if $(findstring $(CFG_ADB_DEVICE_STATUS),"true"), \
|
|
$(eval $(call INSTALL_RUNTIME_TARGET_N,$(taget),$(CFG_BUILD))) \
|
|
$(eval $(call INSTALL_RUNTIME_TARGET_CLEANUP_N,$(target))) \
|
|
))
|
|
|
|
install-runtime-target: \
|
|
install-runtime-target-arm-linux-androideabi-cleanup \
|
|
install-runtime-target-arm-linux-androideabi-host-$(CFG_BUILD)
|
|
else
|
|
install-runtime-target:
|
|
@echo "No device to install runtime library"
|
|
@echo
|
|
endif
|
|
endif
|