第八篇 交叉编译华为云Iot SDK到Orangepi3B

news2024/11/16 12:25:39

本篇主要内容:

      • 一、交叉编译华为云Iot SDK依赖
        • 1.宿主机安装交叉编译工具链
        • (1)选择下载交叉编译工具链
        • (2)解压、添加环境变量、重启
        • 2.交叉编译依赖库
        • (0) 准备工作
        • (1) 交叉编译openssl
        • (2) 交叉编译paho
        • (3) 交叉编译zlib
        • (4) 交叉编译华为安全函数库
        • (★5)交叉编译libssh
        • (★6)交叉编译libnopoll
      • 二、移植SDK测试用例到OrangePi 3B运行
        • (1)配置交叉编译华为云Iot SDK
        • (2)在华为云上创建"设备接入ioTDA"服务
        • (3)在Orangepi 3B上运行测试用例
      • 三、在cmake项目中使用SDK
        • (1)将SDK交叉编译成动态库
        • (2)在cmake中引入SDK动态库


一、交叉编译华为云Iot SDK依赖

🔖开发板: Orangepi 3B

🔖目标操作系统: Orangepi3b_1.0.0_ubuntu_jammy_desktop_xfce_linux6.6.0-rc5

🔖编译平台: ubuntu22.04_x86_64虚拟机

🔖交叉编译器: gcc-arm-11.2-2022.02-x86_64-aarch64-none-linux-gnu.tar.xz
(注意:这里要清楚开发板和编译平台/宿主机各自的操作系统架构,下面才能正确选择交叉编译器)

🔖说明: 这里参考了官方提供的文档,可能由于版本更迭,按照文档的步骤有报错,而且文档没有提供可参考的交叉编译的使用说明,出错的解决方法网上也比较少,个人感觉不太友好。在文档中,分别编译了openssl库、paho库、zlib库、华为安全函数boundscheck库、libssh库、libnopoll库。下面是交叉编译这6个库移植到OrangePi3B的步骤,其中带★的库可以省略跳过,如果需求只是连接到iot平台,上报数据、发布命令,实现远程控制的基本功能的话,只需要移植不带★的库即可,在官方论坛有看到仅编译openssl和paho即可,经过测试不适用,还需要zlib和boundscheck,可能sdk新旧版本的不同。

1.宿主机安装交叉编译工具链
(1)选择下载交叉编译工具链

交叉编译工具链官方下载地址(国外)
​交叉编译工具链清华开源镜像站下载地址(国内)

在这里插入图片描述

(2)解压、添加环境变量、重启
sudo tar -xvf arm-gnu-toolchain-13.2.rel1-x86_64-aarch64-none-linux-gnu.tar.xz -C /mnt
sudo vi /etc/environment  
# 添加路径:/mnt/arm-gnu-toolchain-13.2.Rel1-x86_64-aarch64-none-linux-gnu/bin

在这里插入图片描述

sudo reboot		#重启永久生效,也可以使用命令source /etc/environment,仅在当前会话生效

输入aarch按tab键能补全aarch64-none-linux-gnu-就可以了,也可以使用aarch64-none-linux-gnu-gcc -v查看版本

2.交叉编译依赖库
(0) 准备工作
sudo mkdir ~/mqtt_sdk && cd mqtt_sdk	# 在根目录下新建目录,存放以下编译过程库的源码和过程文件
sudo git clone https://github.com/huaweicloud/huaweicloud-iot-device-sdk-c.git  # 下载SDK源码

下面开始交叉编译sdk所需要的库,所有的库源码都下载到~/mqtt_sdk下

(1) 交叉编译openssl
sudo wget https://www.openssl.org/source/openssl-3.2.0.tar.gz	# 下载源码
sudo tar -zxvf openssl-3.2.0.tar.gz && sudo rm openssl-3.2.0.tar.gz && cd openssl-3.2.0/ # 解压
sudo ./config no-asm --prefix=$(pwd)/_install --cross-compile-prefix=/mnt/gcc-arm-11.2-2022.02-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu-  
#配置,没有生成Makefile需要检查这一步,注意 要使用绝对路径,no-asm表示不使用汇编代码
# 接着我们vi打开生成的Makefile,搜索-m64有的可能是-m32,将这些链接选项都删掉,下面编译才不会报错

在这里插入图片描述

sudo make depend && sudo make -j20	#添加依赖并开始编译
sudo make install -j20	# 安装

编译完成后已经在顶层目录生成交叉编译的库文件,个人感觉也可以不用安装,直接拷贝这些文件。安装完成后,在源码目录下的_install/openssl/lib64生成的库文件,我们可以通过file libssl.so.3查看是否是交叉编译生成的目标平台文件

在这里插入图片描述

# 最后,直接把_install/目录下我们需要的库文件和头文件拷贝到SDK源码里
sudo cp _install/lib64/lib* ../huaweicloud-iot-device-sdk-c/lib/	# 库文件
sudo cp -r _install/include/openssl/ ../huaweicloud-iot-device-sdk-c/include/	# 头文件
(2) 交叉编译paho
sudo git clone https://github.com/eclipse/paho.mqtt.c.git	# 获取源码

编译paho库需要使用到openssl库以及头文件,这里需要在Makefile中先指定好

cd paho.mqtt.c/ && sudo vi Makefile #打开Makefile,搜索DOXYGEN_COMMAND这个字段,在下面加入链接openssl的路径,再指定编译器
LDFLAGS += -L/home/$(shell logname)/mqtt_sdk/openssl-3.2.0/_install/lib64 -lrt
CFLAGS += -I/home/$(shell logname)/mqtt_sdk/openssl-3.2.0/_install/include

CC ::= /mnt/gcc-arm-11.2-2022.02-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu-gcc	# 如图所示

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

sudo make clean && sudo make -j20	# 开始编译,这里没有配置安装路径就不安装了
#编译完成后,可以在build/output/目录下看到生成的库和头文件,和前面一样,我们直接拷贝到桌面lib目录;
sudo cp build/output/libpaho-mqtt3* ../huaweicloud-iot-device-sdk-c/lib/	#拷贝库文件
sudo cp src/*.h ../huaweicloud-iot-device-sdk-c/include/base/  #头文件需要拷贝的sdk目录下include/base
(3) 交叉编译zlib
sudo wget https://github.com/madler/zlib/archive/v1.2.11.zip	# 下载源码
sudo unzip v1.2.11.zip	&& sudo rm v1.2.11.zip && cd zlib-1.2.11/	# 解压源码并删除压缩包
sudo CC=/mnt/gcc-arm-11.2-2022.02-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu-gcc ./configure --prefix=$(pwd)/_install --libdir=$(pwd)/_install/lib --includedir=$(pwd)/_install/include	#配置交叉编译工具、安装路径等
sudo make -j20 && sudo make install	# 编译、安装
sudo cp _install/lib/libz.* ../huaweicloud-iot-device-sdk-c/lib/    # 拷贝库
sudo cp -r _install/include/ ../huaweicloud-iot-device-sdk-c/include/zlib    # 拷贝头文件
(4) 交叉编译华为安全函数库
sudo git clone https://gitee.com/openeuler/libboundscheck.git && cd libboundscheck/  # 获取源码
# vi打开Makefile,直接将CC?=gcc改成下面这样,sudo make在lib目录下生成libboundscheck.so即可
CC::=/mnt/gcc-arm-11.2-2022.02-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu-gcc 
sudo make -j20	#编译
sudo cp lib/libboundscheck.so ../huaweicloud-iot-device-sdk-c/lib/       # 拷贝库文件

到这里就完成sdk依赖库的编译(对于只需要设备接入、上报数据和下发命令就足够了),以下是官方文档提到其它依赖库交叉编译


(★5)交叉编译libssh
sudo wget https://www.libssh.org/files/0.10/libssh-0.10.6.tar.xz	# 下载源码
sudo tar -xvf libssh-0.10.6.tar.xz && sudo rm libssh-0.10.6.tar.xz && cd libssh-0.10.6/	# 解压

libssh使用cmake构建项目,这里我们直接打开源码顶层目录的CMakeList.txt,在前面增加以下内容即可

# 指定交叉编译器
set(CROSS_COMPILE /mnt/gcc-arm-11.2-2022.02-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu-)
set(CMAKE_C_COMPILER ${CROSS_COMPILE}gcc)
set(CMAKE_CXX_COMPILER ${CROSS_COMPILE}g++)

# 指定INSTALL、README提到的几个选项
set(ZLIB_LIBRARY /home/zzk/mqtt_sdk/zlib-1.2.11/_install/lib)
set(ZLIB_INCLUDE_DIR /home/zzk/mqtt_sdk/zlib-1.2.11/_install/include)
set(OPENSSL_ROOT_DIR /home/zzk/mqtt_sdk/openssl-3.2.0)

# 指定最后链接ld库的选项
link_libraries("-L /home/zzk/mqtt_sdk/openssl-3.2.0/_install/lib64 -lcrypto")
link_libraries("-L /home/zzk/mqtt_sdk/zlib-1.2.11/_install/lib -lz")

在这里插入图片描述

sudo mkdir build && cd build	# 新建build目录用于构建项目,源码中INSTALL和README有讲到
sudo cmake ..
sudo make -j20	# 编译,完成后再build/lib生成libssh.so.4.9.6;这里如果按照官方手册install就安装到了系统
sudo cp lib/libssh.so* ../../huaweicloud-iot-device-sdk-c/lib/  #拷贝库文件
sudo cp -r include/libssh/ ../../huaweicloud-iot-device-sdk-c/include/  #拷贝 头文件
(★6)交叉编译libnopoll

这个库的INSTALL和README只有一个官网地址,报错解决方法很难找。如果在编译过程中,遇到./nopoll_decl.h:539:1: error: empty enum is invalid.优先排查openssl链接路径,再考虑openssl编译过程是否正确

sudo wget http://www.aspl.es/nopoll/downloads/nopoll-0.4.8.b429.tar.gz	# 下载源码
sudo tar -xvf nopoll-0.4.8.b429.tar.gz && sudo rm nopoll-0.4.8.b429.tar.gz  # 解压
cd nopoll-0.4.8.b429/ 
sudo ./configure --prefix=$(pwd)/_install --host=aarch64-none-linux-gnu CC=/mnt/gcc-arm-11.2-2022.02-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu-gcc CFLAGS=-I/home/zzk/mqtt_sdk/openssl-3.2.0/_install/include LDFLAGS=-L/home/zzk/mqtt_sdk/openssl-3.2.0/_install/lib64 LIBS="-lssl -lcrypto"	# 缺少LIBS会编译报错
sudo make -j20
# 在顶层目录_install下生成include和lib,同上,拷贝到SDK
sudo cp  _install/lib/libnopoll.* ../huaweicloud-iot-device-sdk-c/lib/
sudo cp _install/include/nopoll/*.h ../huaweicloud-iot-device-sdk-c/include/nopoll/

二、移植SDK测试用例到OrangePi 3B运行

(1)配置交叉编译华为云Iot SDK
cd huaweicloud-iot-device-sdk-c/	#切换到sdk目录
sudo vi Makefile	#打开顶层目录的Makefile

打开SDK顶层的Makefile,第一行就是编译器路径,修改为交叉编译工具链,如下

在这里插入图片描述

暂时还不编译,我们到华为云创建iot服务,再修改sdk目录下src/device_demo/device_demo.c,连接到平台进行测试
注意:目前sdk默认使用的是mqtt3.1.1,本版本也支持mqtt5.0,不过需要在顶层目录找到/include/util/mqttv5_util.h,搜索找到#define MQTTV5,并把注释取消;在Makefile中找到MQTTV5 := 1,把注释删掉即可完成编译。

在这里插入图片描述

在这里插入图片描述

(2)在华为云上创建"设备接入ioTDA"服务

大致步骤:开通服务->控制台创建产品->创建设备(详细步骤可见SDK源码中的README),之后会得到如下的MQTT连接参数(三元组)

在这里插入图片描述

sudo vi src/device_demo/device_demo.c	# 打开这个程序,填入连接参数

在这里插入图片描述

注意:按照sdk文档,理论上到这里编译出的示例程序在开发板运行是不会出错的,实际上运行效果却是连接不上服务器,程序也不会异常退出,一直卡在---- start test -----,这是比较坑的地方,如果遇到了这种异常,优先排查nopoll和openssl库的编译过程,因为在宿主机上编译,如果链接路径和头文件路径没有指定清楚,可能会被系统自带的x86 openssl库影响

sudo make -j20	# 编译程序,得到如下的可执行程序MQTT_Demo
file MQTT_Demo		# 查看该程序运行的平台
readelf -d MQTT_Demo | grep NEEDED		# 查看该程序运行时需要链接的库

除了可执行程序MQTT_Demo外,还需要将这些动态库拷贝到开发板,为了方便这里就直接拷贝sdk里的lib/目录

在这里插入图片描述

(3)在Orangepi 3B上运行测试用例

根据上面的信息,将可执行程序和链接库(包括其软链接)一起打包,上传到目标主机OrangePi 3B

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$(pwd)/lib/		#导入链接库环境变量
./MQTT_Demo	#运行,成功结果如下:

在这里插入图片描述

在这里插入图片描述

三、在cmake项目中使用SDK

到这里,我们已经完成SDK及其依赖库的交叉编译,为了将SDK集成到我们的项目中,这里可以将SDK交叉编译成动态库,我们可以在cmake或者Makefile中引入该动态库和相关头文件,就可以更方便地使用SDK了,并且像CLion、VScode等IDE也有代码提示,方便代码编写

(1)将SDK交叉编译成动态库
sudo vi Makefile	#打开顶层目录的Makefile,修改如下
sudo make clean		#清理
sudo make -j20		#重新编译

🔖 接着在顶层目录生成动态库libHWMQTT.so ,将动态库(及其依赖库)拷贝到项目中的lib目录,头文件拷贝到include目录,最后在CMakeList.txt或者是Makefile中去引入即可。
在这里插入图片描述
在这里插入图片描述

(2)在cmake中引入SDK动态库

🔖 CMakeList.txt(实际环境不唯一,仅供参考):

cmake_minimum_required(VERSION 3.22.1)

# 交叉编译器
set(CROSS_COMPILE /mnt/gcc-arm-11.2-2022.02-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu-)
set(CMAKE_C_COMPILER ${CROSS_COMPILE}gcc)
project(smartHome_v2.0_rebuild C)

# 包含SDK头文件
set(SDK_INCLUDE_PATH ${CMAKE_SOURCE_DIR}/include)
include_directories(${SDK_INCLUDE_PATH})
include_directories(${SDK_INCLUDE_PATH}/protocol)
include_directories(${SDK_INCLUDE_PATH}/util)
include_directories(${SDK_INCLUDE_PATH}/base)
include_directories(${SDK_INCLUDE_PATH}/agentlite)
include_directories(${SDK_INCLUDE_PATH}/service)
# SDK依赖库链接路径
set(SDK_LIBS_PATH ${CMAKE_SOURCE_DIR}/lib)
link_libraries("-L ${SDK_LIBS_PATH} -lHWMQTT")
link_libraries("-L ${SDK_LIBS_PATH} -lpaho-mqtt3as")
link_libraries("-L ${SDK_LIBS_PATH} -lssl")
link_libraries("-L ${SDK_LIBS_PATH} -lcrypto")
link_libraries("-L ${SDK_LIBS_PATH} -lboundscheck")
link_libraries("-L ${SDK_LIBS_PATH} -lz")


# 包含系统头文件和系统库
include_directories(/usr/include/cjson)
include_directories(/usr/include)
include_directories(/usr/local/include)

# 本项目头文件
include_directories(src/device)

# 源文件
set(OBJS src/light.c src/voice_ctl.c src/main.c  src/device/device.c)
set(CMAKE_C_STANDARD 11)
add_executable(main ${OBJS})

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1414304.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Ant Design Mini - 支付宝小程序官方推出的免费开源 UI 组件库,新增支持微信小程序,实用性大大增加

支付宝小程序官方的 UI 组件库开始支持运行在微信小程序上了,如果要开发这两家小程序平台,这套组件很合适。 Ant Design Mini 也简称 antd-mini ,是一套运行在支付宝小程序的 UI 组件库,UI 设计遵循 Ant Design 规范,…

【PyTorch】使用PyTorch创建卷积神经网络并在CIFAR-10数据集上进行分类

前言 在深度学习的世界中,图像分类任务是一个经典的问题,它涉及到识别给定图像中的对象类别。CIFAR-10数据集是一个常用的基准数据集,包含了10个类别的60000张32x32彩色图像。在本博客中,我们将探讨如何使用PyTorch框架创建一个简…

TensorFlow2实战-系列教程2:神经网络分类任务

🧡💛💚TensorFlow2实战-系列教程 总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Jupyter Notebook中进行 本篇文章配套的代码资源已经上传 1、Mnist数据集 下载mnist数据集: %matplotlib inline from pathlib imp…

vs2019报错MSB4019 找不到导入的项目“BuildCustomizations\CUDA 9.2.props”

在VS中执行生成,报错如下:严重性 代码 说明 项目 文件 行 禁止显示状态 错误 MSB4019 找不到导入的项目“D:\Microsoft Visual Studio\2019\Community\MSBuild\Microsoft\VC\v160\BuildCustomizations\CUDA 9.2.props”。请确认 Import 声明“D:\Microso…

在autodl训练yolov8时卡在下载字体

1.问题 在autodl训练yolov8到这一步之后会卡住很久 2. 解决办法 Ctric中断后发现是下载Arial字体卡住了,这个字体需要从外网中下载 先手动从链接中下载https://ultralytics.com/assets/Arial.ttf ,然后上传到autodl。然后将这个文件移动到/root/.config/…

机电制造ERP软件有哪些品牌?哪家的机电制造ERP系统比较好

机电制造过程比较复杂,涵盖零配件、采购、图纸设计、工艺派工、生产计划、物料需求计划、委外加工等诸多环节。而供应链涉及供应商的选择、材料采购价格波动分析、材料交货、品质检验等过程,其中某个环节出现问题都可能会影响产品交期和经营效益。 近些…

一文速通Python添加、修改和删除字典元素

添加、修改和删除字典元素是 Python 中使用字典时常见的操作。字典是一种无序、可变的数据结构,用于存储键值对。在 Python 中,对字典元素进行添加、修改和删除操作可以帮助我们动态地管理数据,方便地根据需求对字典进行更新和维护。 一、添…

详讲api网关之kong的基本概念及安装和使用(一)

什么是api网关 前面我们聊过sentinel,用来限流熔断和降级,如果你只有一个服务,用sentinel自然没有问题,但是如果是有多个服务,特别是微服务的兴起,那么每个服务都使用sentinel就给系统维护带来麻烦。那么网…

Making Large Language Models Perform Better in Knowledge Graph Completion论文阅读

文章目录 摘要1.问题的提出引出当前研究的不足与问题KGC方法LLM幻觉现象解决方案 2.数据集和模型构建数据集模型方法基线方法任务模型方法基于LLM的KGC的知识前缀适配器知识前缀适配器 与其他结构信息引入方法对比 3.实验结果与分析结果分析:可移植性实验&#xff1…

那些年与指针的爱恨情仇(一)---- 指针本质及其相关性质用法

关注小庄 顿顿解馋 (≧∇≦) 引言: 小伙伴们在学习c语言过程中是否因为指针而困扰,指针简直就像是小说女主,它逃咱追,我们插翅难飞…本篇文章让博主为你打理打理指针这个傲娇鬼吧~ 本节我们将认识到指针本质,何为指针和…

k8s 版本发布与回滚

一、实验环境准备: kubectl get pods -o wide kubectl get nodes -o wide kubectl get svc 准备两个nginx镜像,版本号一个是V3,一个是V4 二、准备一个nginx.yaml文件 apiVersion: apps/v1 kind: Deployment metadata:name: nginx-deploylab…

解释性人工智能(XAI)—— AI 决策的透明之道

在当今数字化时代,人工智能(AI)已经成为我们生活中不可或缺的一部分。AI 系统的决策和行为对我们的生活产生了深远的影响,从医疗保健到金融服务再到自动驾驶汽车。 然而,有时候 AI 的决策似乎像黑盒子一样难以理解&am…

linux服务器ssh连接慢问题处理

一、 可能导致慢的几个原因 1、网络问题:网络延迟、带宽限制和包丢失等网络问题都有可能导致SSH连接变慢。 2、客户端设置:错误的客户端设置,如使用过高的加密算法或不适当的密钥设置,可能导致SSH连接变慢。 3、服务器负载过高…

element-ui 树形控件 实现点击某个节点获取本身节点和底下所有的子节点数据

1、需求&#xff1a;点击树形控件中的某个节点&#xff0c;需要拿到它本身和底下所有的子节点的id 1、树形控件代码 <el-tree:data"deptOptions"node-click"getVisitCheckedNodes"ref"target_tree_Speech"node-key"id":default-ex…

elasticsearch8的整体总结

es概述 elasticsearch简介 官网: https://www.elastic.co/ ElasticSearch是一个基于Lucene&#xff08;Apache开源全文检索工具包&#xff09;的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎&#xff0c;基于RESTful web接口。Elasticsearch是用Java开发的&…

MySQL:数据库索引详解

1、什么是索引&#xff1a; 索引是一种用于快速查询和检索数据的数据结构。常见的索引结构有: B 树&#xff0c; B树和 Hash。 索引的作用就相当于目录的作用。打个比方: 我们在查字典的时候&#xff0c;如果没有目录&#xff0c;那我们就只能一页一页的去找我们需要查的那个字…

基于comsol热黏性声学模块仿真声学超材料的声学特性

研究内容&#xff1a; 传统的声学吸收器被用于具有与工作波长相当的厚度的结构&#xff0c;这在低频范围的实际应用中造成了主要障碍。我们提出了一种基于超表面的完美吸收体&#xff0c;能够在极低频区域实现声波的完全吸收。具有深亚波长厚度至特征尺寸k&#xff1d;223的超…

基于Matlab/Simulink直驱式风电储能制氢仿真模型

接着还是以直驱式风电为DG中的研究对象&#xff0c;上篇博客考虑的风电并网惯性的问题&#xff0c;这边博客主要讨论功率消纳的问题。 考虑到风速是随机变化的&#xff0c;导致风电输出功率的波动性和间歇性问题突出&#xff1b;随着其应用规模的不断扩大以及风电在电网中渗透率…

【洛谷 P7072】[CSP-J2020] 直播获奖 题解(优先队列+对顶堆)

[CSP-J2020] 直播获奖 题目描述 NOI2130 即将举行。为了增加观赏性&#xff0c;CCF 决定逐一评出每个选手的成绩&#xff0c;并直播即时的获奖分数线。本次竞赛的获奖率为 w % w\% w%&#xff0c;即当前排名前 w % w\% w% 的选手的最低成绩就是即时的分数线。 更具体地&am…

Typora 无法导出 pdf 问题的解决

目录 问题描述 解决困难 解决方法 问题描述 Windows 下&#xff0c;以前&#xff08;Windows 11&#xff09; Typora 可以顺利较快地由 .md 导出 .pdf 文件&#xff0c;此功能当然非常实用与重要。 然而&#xff0c;有一次电脑因故重装了系统&#xff08;刷机&#xff09;…