mirror of
https://github.com/immortalwrt/immortalwrt
synced 2025-01-08 12:08:13 +08:00
ccache: update to 4.1
Upstream switched to building with CMake. Adjust accordingly. Reapplied patch as upstream changed the file format. Added HOST_BUILD_PARALLEL for faster compilation. Added cmake tool dependency and removed circular dependencies as a result. Adjusted dependent tools to use NOCACHE as they are needed to build ccache. Signed-off-by: Rosen Penev <rosenp@gmail.com>
This commit is contained in:
parent
f3e45c45cb
commit
31554e50d2
@ -80,8 +80,9 @@ ifneq ($(HOST_OS),Linux)
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq ($(CONFIG_CCACHE)$(CONFIG_SDK),)
|
ifneq ($(CONFIG_CCACHE)$(CONFIG_SDK),)
|
||||||
$(foreach tool, $(filter-out xz patch,$(tools-y)), $(eval $(curdir)/$(tool)/compile += $(curdir)/ccache/compile))
|
$(foreach tool, $(filter-out xz zstd patch pkgconf libressl cmake,$(tools-y)), $(eval $(curdir)/$(tool)/compile += $(curdir)/ccache/compile))
|
||||||
tools-y += ccache
|
tools-y += ccache
|
||||||
|
$(curdir)/ccache/compile := $(curdir)/cmake/compile $(curdir)/zstd/compile
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# in case there is no patch tool on the host we need to make patch tool a
|
# in case there is no patch tool on the host we need to make patch tool a
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#
|
#
|
||||||
# Copyright (C) 2006-2015 OpenWrt.org
|
# Copyright (C) 2006-2015 OpenWrt.org
|
||||||
#
|
#
|
||||||
# This is free software, licensed under the GNU General Public License v2.
|
# This is free software, licensed under the GNU General Public License v2.
|
||||||
@ -8,25 +8,26 @@ include $(TOPDIR)/rules.mk
|
|||||||
include $(INCLUDE_DIR)/target.mk
|
include $(INCLUDE_DIR)/target.mk
|
||||||
|
|
||||||
PKG_NAME:=ccache
|
PKG_NAME:=ccache
|
||||||
PKG_VERSION:=3.7.11
|
PKG_VERSION:=4.1
|
||||||
|
|
||||||
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz
|
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz
|
||||||
PKG_SOURCE_URL:=https://github.com/ccache/ccache/releases/download/v$(PKG_VERSION)
|
PKG_SOURCE_URL:=https://github.com/ccache/ccache/releases/download/v$(PKG_VERSION)
|
||||||
PKG_HASH:=8d450208099a4d202bd7df87caaec81baee20ce9dd62da91e9ea7b95a9072f68
|
PKG_HASH:=5fdc804056632d722a1182e15386696f0ea6c59cb4ab4d65a54f0b269ae86f99
|
||||||
|
|
||||||
|
HOST_BUILD_PARALLEL:=1
|
||||||
|
|
||||||
include $(INCLUDE_DIR)/host-build.mk
|
include $(INCLUDE_DIR)/host-build.mk
|
||||||
|
include $(INCLUDE_DIR)/cmake.mk
|
||||||
|
|
||||||
HOST_CONFIGURE_VARS += CC="$(HOSTCC_NOCACHE)"
|
CMAKE_HOST_OPTIONS += \
|
||||||
|
-DCMAKE_C_COMPILER_LAUNCHER="" \
|
||||||
|
-DCMAKE_CXX_COMPILER_LAUNCHER=""
|
||||||
|
|
||||||
define Host/Install/ccache
|
define Host/Install/ccache
|
||||||
$(INSTALL_DIR) $(STAGING_DIR_HOST)/bin/
|
$(INSTALL_DIR) $(STAGING_DIR_HOST)/bin/
|
||||||
$(CP) ./files/* $(STAGING_DIR_HOST)/bin/
|
$(CP) ./files/* $(STAGING_DIR_HOST)/bin/
|
||||||
endef
|
endef
|
||||||
|
|
||||||
define Host/Clean
|
|
||||||
-$(MAKE) -C $(HOST_BUILD_DIR) uninstall
|
|
||||||
$(call Host/Clean/Default)
|
|
||||||
endef
|
|
||||||
define Host/Install
|
define Host/Install
|
||||||
$(call Host/Install/Default)
|
$(call Host/Install/Default)
|
||||||
$(call Host/Install/ccache)
|
$(call Host/Install/ccache)
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
--- a/src/ccache.c
|
--- a/src/ccache.cpp
|
||||||
+++ b/src/ccache.c
|
+++ b/src/ccache.cpp
|
||||||
@@ -2277,6 +2277,7 @@ calculate_object_hash(struct args *args,
|
@@ -1654,6 +1654,7 @@ calculate_result_name(Context& ctx,
|
||||||
"CPLUS_INCLUDE_PATH",
|
"CPLUS_INCLUDE_PATH",
|
||||||
"OBJC_INCLUDE_PATH",
|
"OBJC_INCLUDE_PATH",
|
||||||
"OBJCPLUS_INCLUDE_PATH", // clang
|
"OBJCPLUS_INCLUDE_PATH", // clang
|
||||||
+ "GCC_HONOUR_COPTS",
|
+ "GCC_HONOUR_COPTS",
|
||||||
NULL
|
nullptr};
|
||||||
};
|
for (const char** p = envvars; *p; ++p) {
|
||||||
for (const char **p = envvars; *p; ++p) {
|
const char* v = getenv(*p);
|
||||||
|
@ -23,6 +23,7 @@ HOST_BUILD_PARALLEL:=1
|
|||||||
|
|
||||||
include $(INCLUDE_DIR)/host-build.mk
|
include $(INCLUDE_DIR)/host-build.mk
|
||||||
|
|
||||||
|
HOSTCC := $(HOSTCC_NOCACHE)
|
||||||
HOST_CONFIGURE_ARGS += --enable-static --disable-shared --disable-tests
|
HOST_CONFIGURE_ARGS += --enable-static --disable-shared --disable-tests
|
||||||
HOST_CFLAGS += $(FPIC)
|
HOST_CFLAGS += $(FPIC)
|
||||||
|
|
||||||
|
@ -19,6 +19,8 @@ include $(INCLUDE_DIR)/host-build.mk
|
|||||||
|
|
||||||
unexport PKG_CONFIG
|
unexport PKG_CONFIG
|
||||||
|
|
||||||
|
HOSTCC := $(HOSTCC_NOCACHE)
|
||||||
|
|
||||||
define Host/Install
|
define Host/Install
|
||||||
$(MAKE) -C $(HOST_BUILD_DIR) install
|
$(MAKE) -C $(HOST_BUILD_DIR) install
|
||||||
mv $(STAGING_DIR_HOST)/bin/pkgconf $(STAGING_DIR_HOST)/bin/pkg-config.real
|
mv $(STAGING_DIR_HOST)/bin/pkgconf $(STAGING_DIR_HOST)/bin/pkg-config.real
|
||||||
|
@ -15,6 +15,7 @@ HOST_BUILD_PARALLEL:=1
|
|||||||
|
|
||||||
include $(INCLUDE_DIR)/host-build.mk
|
include $(INCLUDE_DIR)/host-build.mk
|
||||||
|
|
||||||
|
HOSTCC := $(HOSTCC_NOCACHE)
|
||||||
HOST_MAKE_FLAGS = PREFIX=$(HOST_BUILD_PREFIX) HAVE_ZLIB=0 HAVE_LZMA=0 HAVE_LZ4=0
|
HOST_MAKE_FLAGS = PREFIX=$(HOST_BUILD_PREFIX) HAVE_ZLIB=0 HAVE_LZMA=0 HAVE_LZ4=0
|
||||||
|
|
||||||
$(eval $(call HostBuild))
|
$(eval $(call HostBuild))
|
||||||
|
Loading…
Reference in New Issue
Block a user