summaryrefslogtreecommitdiffstats
path: root/include/cmake.mk
diff options
context:
space:
mode:
authorLuke McKee <hojuruku@gmail.com>2016-07-24 02:00:24 +0700
committerFelix Fietkau <nbd@nbd.name>2016-07-29 20:27:34 +0200
commiteadf5fb7f8313d78fa503665e96457d080e6e3f9 (patch)
tree22697a856c3d56963786b557eeb38389d10b0549 /include/cmake.mk
parent009d6d602496947877766df6f152c713056201de (diff)
downloadmaster-31e0f0ae-eadf5fb7f8313d78fa503665e96457d080e6e3f9.tar.gz
master-31e0f0ae-eadf5fb7f8313d78fa503665e96457d080e6e3f9.tar.bz2
master-31e0f0ae-eadf5fb7f8313d78fa503665e96457d080e6e3f9.zip
cmake: include/cmake.mk add CMAKE_BINARY_SUBDIR to allow out of source tree builds
Some packages need out of source tree building with cmake, for example when building kernel modules. See an example here: https://sourceforge.net/p/accel-ppp/code/ci/master/tree/README Signed-off-by: Luke McKee <hojuruku@gmail.com> Signed-off-by: Felix Fietkau <nbd@nbd.name> [cleanup, rework]
Diffstat (limited to 'include/cmake.mk')
-rw-r--r--include/cmake.mk7
1 files changed, 5 insertions, 2 deletions
diff --git a/include/cmake.mk b/include/cmake.mk
index 009c6c2772..fac2bc0227 100644
--- a/include/cmake.mk
+++ b/include/cmake.mk
@@ -6,7 +6,9 @@ ifneq ($(findstring c,$(OPENWRT_VERBOSE)),)
MAKE_FLAGS+=VERBOSE=1
endif
-CMAKE_SOURCE_DIR:=.
+CMAKE_BINARY_DIR = $(PKG_BUILD_DIR)$(if $(CMAKE_BINARY_SUBDIR),/$(CMAKE_BINARY_SUBDIR))
+CMAKE_SOURCE_DIR = $(PKG_BUILD_DIR)
+MAKE_PATH = $(firstword $(CMAKE_BINARY_SUBDIR) .)
ifeq ($(CONFIG_EXTERNAL_TOOLCHAIN),)
cmake_tool=$(TOOLCHAIN_DIR)/bin/$(1)
@@ -35,7 +37,8 @@ CMAKE_HOST_FIND_ROOT_PATH:=$(STAGING_DIR)/host;$(STAGING_DIR_HOST)
CMAKE_SHARED_LDFLAGS:=-Wl,-Bsymbolic-functions
define Build/Configure/Default
- (cd $(PKG_BUILD_DIR); \
+ mkdir -p $(CMAKE_BINARY_DIR)
+ (cd $(CMAKE_BINARY_DIR); \
CFLAGS="$(TARGET_CFLAGS) $(EXTRA_CFLAGS)" \
CXXFLAGS="$(TARGET_CFLAGS) $(EXTRA_CFLAGS)" \
LDFLAGS="$(TARGET_LDFLAGS) $(EXTRA_LDFLAGS)" \