diff options
Diffstat (limited to 'code/projects/lcm_compile.html')
-rw-r--r-- | code/projects/lcm_compile.html | 119 |
1 files changed, 119 insertions, 0 deletions
diff --git a/code/projects/lcm_compile.html b/code/projects/lcm_compile.html new file mode 100644 index 0000000..dbc8109 --- /dev/null +++ b/code/projects/lcm_compile.html | |||
@@ -0,0 +1,119 @@ | |||
1 | <!DOCTYPE html> | ||
2 | <html xmlns="http://www.w3.org/1999/xhtml" lang="" xml:lang=""> | ||
3 | |||
4 | <head> | ||
5 | <meta charset="utf-8" /> | ||
6 | <meta name="generator" content="pandoc" /> | ||
7 | <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> | ||
8 | <title>LCM 交叉编译</title> | ||
9 | <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> | ||
10 | <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/js/myhighlight.js"></script> | ||
11 | <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> | ||
12 | </head> | ||
13 | |||
14 | <body> | ||
15 | <div class="pandoc"> | ||
16 | <div class="main"> | ||
17 | <p class="title">LCM 交叉编译</p> | ||
18 | <!-- 编译集成lcm模块 --> | ||
19 | <h1 id="lcm-简介">LCM 简介</h1> | ||
20 | <p>LCM(Lightweight Communications and | ||
21 | Marshalling)是一种轻量级的通信和编组库,是一种针对高带宽、低延迟、实时性要求高的场景下的通讯工具,用于在多个进程之间传递消息。LCM 的设计目标是提供一种简单的方法来传递结构化数据,而不需要复杂的 | ||
22 | API 或协议定义。LCM 的消息传递是基于发布/订阅模型的,发布者和订阅者之间通过一个中心化的消息传递系统进行通信。</p> | ||
23 | <p>在机器人和自动驾驶系统中,LCM 可作为 ROS 的替代品,借以完成进程间、设备间的通讯。</p> | ||
24 | <p>为了方便地在不同进程、不同设备间传递数据,我们在 OHOS 系统中集成了 LCM 模块。</p> | ||
25 | <p>参考文档:</p> | ||
26 | <ul> | ||
27 | <li><a href="https://lcm-proj.github.io/">LCM 官方文档</a></li> | ||
28 | <li><a href="https://zhuanlan.zhihu.com/p/621943685">一篇博客</a></li> | ||
29 | </ul> | ||
30 | <h1 id="依赖项安装">依赖项安装</h1> | ||
31 | <pre><code>sudo apt update | ||
32 | sudo apt upgrade | ||
33 | sudo apt install build-essential cmake libglib2.0-dev | ||
34 | sudo apt install openjdk-8-jdk # lcm仅支持jdk8</code></pre> | ||
35 | <h1 id="x86-的-lcm">x86 的 lcm</h1> | ||
36 | <p>如果我们仅仅需要 x86 架构的 lcm,执行下列命令即可:</p> | ||
37 | <pre><code>git clone https://github.com/lcm-proj/lcm | ||
38 | cd lcm | ||
39 | mkdir build && cd build | ||
40 | cmake .. | ||
41 | make | ||
42 | sudo make install</code></pre> | ||
43 | <p>编译完成后,注意观察<kbd>build</kbd>目录下是否有<kbd>lcm-java</kbd>文件夹,如果没有,证明没有安装 java 或者 java 版本不对。</p> | ||
44 | <h2 id="lcm-python">lcm-python</h2> | ||
45 | <p>若想使用<kbd>lcm-python</kbd>,在<kbd>lcm/lcm-python</kbd>下执行<code>sudo python3 setup.py install</code>即可,使用时<code>import python</code>。 | ||
46 | </p> | ||
47 | <h2 id="lcm-spy-的使用">lcm-spy 的使用</h2> | ||
48 | <p>lcm-spy 是 LCM 配套的数据可视化工具。 可以通过 lcm-spy 监视 lcm 数据发送频率、数据量、数据结构,甚至实时画图。 如果安装了 JAVA,则 lcm-spy 会连同 LCM 一同被安装。 | ||
49 | </p> | ||
50 | <p>启动 lcm-spy:</p> | ||
51 | <pre><code>export CLASSPATH=${your lcm-type class path} | ||
52 | lcm-spy</code></pre> | ||
53 | <h1 id="交叉编译">交叉编译</h1> | ||
54 | <p>既然 lcm 用的是 cmake,何不交叉编译到 OHOS 里用呢?</p> | ||
55 | <p>首先,我们可以设置一下 Native Development Kit(NDK)的路径:</p> | ||
56 | <pre><code># 设置成自己的NDK工具目录 | ||
57 | export OHOS_ROOT=~/app/native</code></pre> | ||
58 | <pre><code>$OHOS_ROOT/build-tools/cmake/bin/cmake \ | ||
59 | -DOHOS_STL=c++_shared \ | ||
60 | -DOHOS_ARCH=armv8-a \ | ||
61 | -DOHOS_PLATFORM=OHOS \ | ||
62 | -DCMAKE_TOOLCHAIN_FILE=$(find $OHOS_ROOT -name "ohos.toolchain.cmake")</code></pre> | ||
63 | <p>不出意外的话,就要出意外了。果不其然,报错<kbd>Could NOT fid Glib2</kbd>。思考之后,我们认为,问题出现在 lcm 所依赖的 glib 库上:在 x86 | ||
64 | 架构上,我们直接向系统安装了<code>libglib2.0-dev</code>,而 lcm 编译时直接从系统里找到了这个库;但当交叉编译时,由于 OHOS 交叉编译工具未提供 | ||
65 | libglib2.0-dev,lcm 找遍了系统也没找到 arm 架构下的这个库,因而直接报错。</p> | ||
66 | <p>解决方案自然是自己手动交叉编译<code>libglib2.0-dev</code>。</p> | ||
67 | <h2 id="glib2.0-交叉编译">Glib2.0 交叉编译</h2> | ||
68 | <p>从<a href="https://download.gnome.org/sources/glib/">官网</a>下载 glib-2.79.2 源码,解压后进入源码目录。</p> | ||
69 | <pre><code>mkdir glib && cd glib | ||
70 | wget https://download.gnome.org/sources/glib/2.79/glib-2.79.2.tar.xz | ||
71 | tar -xvf glib-2.79.2.tar.xz | ||
72 | mkdir build</code></pre> | ||
73 | <p>这里需要注意的是:</p> | ||
74 | <ul> | ||
75 | <li>虽然 glib 编译需要<code>meson</code>,但它并不能直接交叉编译,OHOS 也并未提供用于交叉编译的<code>meson</code>。</li> | ||
76 | <li><code>meson</code>要求保证源码目录与构建目录不能相同,以保证构建过程的干净,因此我们在源码目录外新建了一个<code>build</code>目录。</li> | ||
77 | </ul> | ||
78 | <p>接着,参考博客<a | ||
79 | href="https://t.csdnimg.cn/YfSJC">这篇博客</a>,撰写如下<kbd>meson_ohos.txt</kbd>(友情提醒,使用该文件时把<kbd>native</kbd>也就是 | ||
80 | NDK 的路径修改为自己的路径、源平台与目标平台按需修改):</p> | ||
81 | <pre><code>[binaries] | ||
82 | c = '$OHOS_ROOT/llvm/bin/aarch64-unknown-linux-ohos-clang' | ||
83 | cpp = '$OHOS_ROOT/llvm/bin/aarch64-unknown-linux-ohos-clang++' | ||
84 | ar = '$OHOS_ROOT/llvm/bin/llvm-ar' | ||
85 | strip = '$OHOS_ROOT/llvm/bin/llvm-strip' | ||
86 | ld = '$OHOS_ROOT/llvm/bin/llvm-link' | ||
87 | |||
88 | [properties] | ||
89 | skip_sanity_check = true | ||
90 | sys_root = '$OHOS_ROOT/sysroot' | ||
91 | c_args = ['-L$OHOS_ROOT/sysroot/usr/lib/aarch64-linux-ohos'] | ||
92 | |||
93 | [host_machine] | ||
94 | system = 'linux' | ||
95 | cpu_family = 'aarch64' | ||
96 | cpu = 'aarch64' | ||
97 | endian = 'little' | ||
98 | |||
99 | [target_machine] | ||
100 | system = 'ohos' | ||
101 | cpu_family = 'aarch64' | ||
102 | cpu = 'armv8a' | ||
103 | endian = 'little'</code></pre> | ||
104 | <p>将该文件放置在<kbd>glib-2.79.2</kbd>源码目录下,而后在<kbd>build</kbd>目录下执行以下命令:</p> | ||
105 | <pre><code>meson --cross-file=../glib-2.79.2/meson_ohos.txt .. | ||
106 | ninja</code></pre> | ||
107 | <p>编译完成,正确地安装 glib2 到交叉编译工具链中(???),之后我们回到 lcm 的源码目录,重新执行 cmake 命令:</p> | ||
108 | <pre><code>$OHOS_ROOT/build-tools/cmake/bin/cmake \ | ||
109 | -DOHOS_STL=c++_shared \ | ||
110 | -DOHOS_ARCH=armv8-a \ | ||
111 | -DOHOS_PLATFORM=OHOS \ | ||
112 | -DCMAKE_TOOLCHAIN_FILE=$(find $OHOS_ROOT -name "ohos.toolchain.cmake")</code></pre> | ||
113 | <p>这次,编译成功了。万岁!</p> | ||
114 | <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script> | ||
115 | </div> | ||
116 | </div> | ||
117 | </body> | ||
118 | |||
119 | </html> \ No newline at end of file | ||