diff options
| author | Clément Péron <peron.clem@gmail.com> | 2023-09-27 10:42:39 +0200 | 
|---|---|---|
| committer | Armin Kuster <akuster808@gmail.com> | 2023-10-04 07:52:48 -0700 | 
| commit | 5afd2adfd5f1f55b216fe7b55a07d803b3d8787d (patch) | |
| tree | 998bb218127e40643fc06c8d37599a078f55f8ae | |
| parent | 3e987a3955dfcd48082bb267e89f519f83d08d47 (diff) | |
| download | meta-openembedded-5afd2adfd5f1f55b216fe7b55a07d803b3d8787d.tar.gz | |
etcd-cpp-apiv3: fix build when gRPC is cross compiled
Signed-off-by: Clément Péron <peron.clem@gmail.com>
Signed-off-by: Khem Raj <raj.khem@gmail.com>
(cherry picked from commit 23d6505d0bf0bbd5887292658ee98e806c7128de)
Signed-off-by: Armin Kuster <akuster808@gmail.com>
| -rw-r--r-- | meta-oe/recipes-extended/etcd/etcd-cpp-apiv3/0001-cmake-fix-when-cross-compiling.patch | 66 | ||||
| -rw-r--r-- | meta-oe/recipes-extended/etcd/etcd-cpp-apiv3_0.15.3.bb | 6 | 
2 files changed, 71 insertions, 1 deletions
| diff --git a/meta-oe/recipes-extended/etcd/etcd-cpp-apiv3/0001-cmake-fix-when-cross-compiling.patch b/meta-oe/recipes-extended/etcd/etcd-cpp-apiv3/0001-cmake-fix-when-cross-compiling.patch new file mode 100644 index 0000000000..d1126aa05b --- /dev/null +++ b/meta-oe/recipes-extended/etcd/etcd-cpp-apiv3/0001-cmake-fix-when-cross-compiling.patch | |||
| @@ -0,0 +1,66 @@ | |||
| 1 | From cb79329010d73e36ce64830914005f1c17f8f53c Mon Sep 17 00:00:00 2001 | ||
| 2 | From: =?UTF-8?q?Cl=C3=A9ment=20P=C3=A9ron?= <peron.clem@gmail.com> | ||
| 3 | Date: Sat, 23 Sep 2023 11:32:18 +0200 | ||
| 4 | Subject: [PATCH] cmake: fix when cross compiling | ||
| 5 | MIME-Version: 1.0 | ||
| 6 | Content-Type: text/plain; charset=UTF-8 | ||
| 7 | Content-Transfer-Encoding: 8bit | ||
| 8 | |||
| 9 | In order to generate protobuf files CMake need to use the protoc | ||
| 10 | and grpc-cpp-plugin compiled for the host architecture. | ||
| 11 | |||
| 12 | Unfortunately, the protoc and grpc-cpp-plugin in the gRPC CMake | ||
| 13 | configuration file are the one for the target architecture. | ||
| 14 | |||
| 15 | Fix this by properly finding the correct executable when | ||
| 16 | CMake is cross compiling. | ||
| 17 | |||
| 18 | Signed-off-by: Clément Péron <peron.clem@gmail.com> | ||
| 19 | --- | ||
| 20 | CMakeLists.txt | 28 ++++++++++++++++++++++++++-- | ||
| 21 | 1 file changed, 26 insertions(+), 2 deletions(-) | ||
| 22 | |||
| 23 | diff --git a/CMakeLists.txt b/CMakeLists.txt | ||
| 24 | index 5aa1310..80ebad2 100644 | ||
| 25 | --- a/CMakeLists.txt | ||
| 26 | +++ b/CMakeLists.txt | ||
| 27 | @@ -120,10 +120,34 @@ if(Protobuf_PROTOC_EXECUTABLE) | ||
| 28 | endif() | ||
| 29 | endif() | ||
| 30 | |||
| 31 | +# When cross compiling we look for the native protoc compiler | ||
| 32 | +# overwrite protobuf::protoc with the proper protoc | ||
| 33 | +if(CMAKE_CROSSCOMPILING) | ||
| 34 | + find_program(Protobuf_PROTOC_EXECUTABLE REQUIRED NAMES protoc) | ||
| 35 | + if(NOT TARGET protobuf::protoc) | ||
| 36 | + add_executable(protobuf::protoc IMPORTED) | ||
| 37 | + endif() | ||
| 38 | + set_target_properties(protobuf::protoc PROPERTIES | ||
| 39 | + IMPORTED_LOCATION "${Protobuf_PROTOC_EXECUTABLE}") | ||
| 40 | +endif() | ||
| 41 | + | ||
| 42 | find_package(gRPC QUIET) | ||
| 43 | -if(gRPC_FOUND AND TARGET gRPC::grpc AND TARGET gRPC::grpc_cpp_plugin) | ||
| 44 | +if(gRPC_FOUND AND TARGET gRPC::grpc) | ||
| 45 | + # When cross compiling we look for the native grpc_cpp_plugin | ||
| 46 | + if(CMAKE_CROSSCOMPILING) | ||
| 47 | + find_program(GRPC_CPP_PLUGIN REQUIRED NAMES grpc_cpp_plugin) | ||
| 48 | + if(NOT TARGET gRPC::grpc_cpp_plugin) | ||
| 49 | + add_executable(gRPC::grpc_cpp_plugin IMPORTED) | ||
| 50 | + endif() | ||
| 51 | + set_target_properties(gRPC::grpc_cpp_plugin PROPERTIES | ||
| 52 | + IMPORTED_LOCATION "${GRPC_CPP_PLUGIN}") | ||
| 53 | + elseif(TARGET gRPC::grpc_cpp_plugin) | ||
| 54 | + get_target_property(GRPC_CPP_PLUGIN gRPC::grpc_cpp_plugin LOCATION) | ||
| 55 | + else() | ||
| 56 | + message(FATAL_ERROR "Found gRPC but no gRPC CPP plugin defined") | ||
| 57 | + endif() | ||
| 58 | + | ||
| 59 | set(GRPC_LIBRARIES gRPC::gpr gRPC::grpc gRPC::grpc++) | ||
| 60 | - get_target_property(GRPC_CPP_PLUGIN gRPC::grpc_cpp_plugin LOCATION) | ||
| 61 | get_target_property(GRPC_INCLUDE_DIR gRPC::grpc INTERFACE_INCLUDE_DIRECTORIES) | ||
| 62 | else() | ||
| 63 | include(${CMAKE_CURRENT_SOURCE_DIR}/cmake/FindGRPC.cmake) | ||
| 64 | -- | ||
| 65 | 2.39.3 (Apple Git-145) | ||
| 66 | |||
| diff --git a/meta-oe/recipes-extended/etcd/etcd-cpp-apiv3_0.15.3.bb b/meta-oe/recipes-extended/etcd/etcd-cpp-apiv3_0.15.3.bb index d724abc3c9..e8299bab5f 100644 --- a/meta-oe/recipes-extended/etcd/etcd-cpp-apiv3_0.15.3.bb +++ b/meta-oe/recipes-extended/etcd/etcd-cpp-apiv3_0.15.3.bb | |||
| @@ -4,7 +4,11 @@ HOMEPAGE = "https://github.com/etcd-cpp-apiv3/etcd-cpp-apiv3" | |||
| 4 | LICENSE = "BSD-3-Clause" | 4 | LICENSE = "BSD-3-Clause" | 
| 5 | LIC_FILES_CHKSUM = "file://LICENSE.txt;md5=eae7da6a2cd1788a5cf8a9f838cf6450" | 5 | LIC_FILES_CHKSUM = "file://LICENSE.txt;md5=eae7da6a2cd1788a5cf8a9f838cf6450" | 
| 6 | 6 | ||
| 7 | SRC_URI += "git://github.com/etcd-cpp-apiv3/etcd-cpp-apiv3.git;branch=master;protocol=https" | 7 | SRC_URI = " \ | 
| 8 | git://github.com/etcd-cpp-apiv3/etcd-cpp-apiv3.git;branch=master;protocol=https \ | ||
| 9 | file://0001-cmake-fix-when-cross-compiling.patch \ | ||
| 10 | " | ||
| 11 | |||
| 8 | SRCREV = "e31ac4d4caa55fa662e207150ba40f8151b7ad96" | 12 | SRCREV = "e31ac4d4caa55fa662e207150ba40f8151b7ad96" | 
| 9 | 13 | ||
| 10 | inherit cmake | 14 | inherit cmake | 
