From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from smtp45.i.mail.ru (smtp45.i.mail.ru [94.100.177.105]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dev.tarantool.org (Postfix) with ESMTPS id 1AC1E43D679 for ; Sat, 26 Oct 2019 04:02:30 +0300 (MSK) From: Alexander Turenko Date: Sat, 26 Oct 2019 04:01:59 +0300 Message-Id: <434bf54dd0197a89680ddf18b3fc95b6f1c5df28.1572050052.git.alexander.turenko@tarantool.org> In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Subject: [Tarantool-patches] [PATCH v2 2/2] build: pass path to toolchain for luajit and curl List-Id: Tarantool development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Igor Munkin Cc: tarantool-patches@freelists.org, tarantool-patches@dev.tarantool.org This allows to overcome problems when CMake chooses one toolchain to build tarantool, but a library (libluajit.a or libcurl.a) is built using another (incompatible) toolchain. Fixes #4587. --- cmake/BuildLibCURL.cmake | 12 ++++++++++++ cmake/luajit.cmake | 12 ++++++++++++ 2 files changed, 24 insertions(+) diff --git a/cmake/BuildLibCURL.cmake b/cmake/BuildLibCURL.cmake index dc1b40750..12062ec8b 100644 --- a/cmake/BuildLibCURL.cmake +++ b/cmake/BuildLibCURL.cmake @@ -45,9 +45,21 @@ macro(curl_build) CONFIGURE_COMMAND cd && ./buildconf && cd && /configure + # Pass the same toolchain as is used to build + # tarantool itself, because they can be + # incompatible. CC=${CMAKE_C_COMPILER} + LD=${CMAKE_LINKER} + AR=${CMAKE_AR} + RANLIB=${CMAKE_RANLIB} + NM=${CMAKE_NM} + STRIP=${CMAKE_STRIP} + + # Pass -isysroot= option on Mac OS, see + # above. CPPFLAGS=${LIBCURL_CPPFLAGS} CFLAGS=${LIBCURL_CFLAGS} + --prefix --enable-static --enable-shared diff --git a/cmake/luajit.cmake b/cmake/luajit.cmake index eca2bf36b..10df633d5 100644 --- a/cmake/luajit.cmake +++ b/cmake/luajit.cmake @@ -223,12 +223,24 @@ macro(luajit_build) foreach(def ${defs}) set(luajit_xcflags ${luajit_xcflags} -D${def}) endforeach() + + # Pass the same toolchain that is used for building of + # tarantool itself, because tools from different toolchains + # can be incompatible. A compiler and a linker are already set + # above. + set (luajit_ld ${CMAKE_LINKER}) + set (luajit_ar ${CMAKE_AR} rcus) + set (luajit_strip ${CMAKE_STRIP}) + set (luajit_buildoptions BUILDMODE=static HOST_CC="${luajit_hostcc}" TARGET_CC="${luajit_cc}" TARGET_CFLAGS="${luajit_cflags}" + TARGET_LD="${luajit_ld}" TARGET_LDFLAGS="${luajit_ldflags}" + TARGET_AR="${luajit_ar}" + TARGET_STRIP="${luajit_strip}" TARGET_SYS="${CMAKE_SYSTEM_NAME}" CCOPT="${luajit_ccopt}" CCDEBUG="${luajit_ccdebug}" -- 2.22.0