我正在尝试使用cmake交叉编译gRPC。
我实际上设法做到了。不幸的是,我的方法涉及修补CMakeLists.txt。
问题是,当我试图编译gRPC时,它正在使用他刚刚编译的protobuffer。它无法在x86机器上运行ARM编译的可执行文件。
我设法通过在gRPCs主CMakeLists.txt中手动指定protoc和grpc_cpp_plugin的路径来编译它。它很脏,因为我想将gRPC作为子模块包含在内,我需要干净的方法来完成它。
有没有人设法使用cmake交叉编译gRPC?
这种方式应该工作:
-D
可执行文件的cmake
选项):
gRPC_PROTOBUF_PROVIDER:包
gRPC_PROTOBUF_PACKAGE_TYPE:MODULE
Protobuf_PROTOC_EXECUTABLE:<主机protoc
可执行文件的路径>将参数gRPC_PROTOBUF_PROVIDER
设置为“package”会告诉gRPC不要构建自己的Protobuf,而是使用已经安装的变体。这个变种由find_package(Protobuf)
搜索。
将参数gRPC_PROTOBUF_PACKAGE_TYPE
设置为“MODULE”会告诉gRPC不要使用Protobuf安装提供的“Config”文件来检测Protobuf事物(库和可执行文件)。配置文件包含无法在外部调整的硬编码路径。相反,FindProtobuf.cmake脚本用于查找Protobuf。
设置参数Protobuf_PROTOC_EXECUTABLE
告诉FindProtobuf.cmake
脚本不搜索Protobuf可执行文件,但从参数中获取它。