openssl移植到arm-linux全过程

本文章记录了将openssl移植到arm-linux下的全部过程

移植环境

编译环境:Ubuntu18.04-amd64
模板环境:i.mx6ul Linux 4.1.15
编译链:arm-linux-gnueabihf-4.7

下载openssl源代码

在官网下载源代码,我使用的最新版本1.1.1c,官网链接如下:
https://www.openssl.org/source/
或者直接下载链接如下
直接下载链接
在linux下可以使用如下命令直接下载

wget https://www.openssl.org/source/openssl-1.1.1c.tar.gz

下载完成后解压,解压命令如下:

tar zxvf openssl-1.1.1c.tar.gz

交叉编译

进入解压后的openssl-1.1.1c文件夹下,根据习惯应该使用./config进行配置自动生成Makefile文件

./config no-asm shared --prefix=/home/xx/arm-openssl/ CROSS_COMPILE=/home/xx/arm-linux-gnueabihf-4.7/bin/arm-linux-gnueabihf- CC=gcc

完成后直接make就行
但是!发现编译过程大量警告,基本都是64位和32位不兼容问题。这个可以忽略。
然后严重的问题是arm-linux-gnueabihf-4.7编译器是不提供GNU C的ucontext库,最后有些tools找不到对应函数,导致编译报错。
也就是./config的简单配置是不行的,要用./Configure的自定义配置

./Configure linux-generic32 no-asm shared no-async --prefix=/home/xx/arm-software/arm-openssl CROSS_COMPILE=/home/xx/arm-linux-gnueabihf-4.7/bin/arm-linux-gnueabihf- CC=gcc

这里解释下:
linux-generic32表示标准32位linux
no-asm: 是在交叉编译过程中不使用汇编代码代码加速编译过程,原因是它的汇编代码是对arm格式不支持的
shared :生成动态连接库
no-async:没有提供GNU C的ucontext库
完成后直接

make
make install


然后在上面—prefix=指定路径下就找到了编译好的文件

openssl移植到arm-linux全过程_第1张图片
然后查看文件属性
openssl文件属性
确定交叉编译成功。

移植到开发板下

将编译好的文件夹打包发送到开发板下任意可读写目录,然后解压缩。
例如我放在了/opt/openssl下,得到如下路径和文件夹

进入bin目录运行openssl报错
运行报错
查看该so文件在lib目录下呢,说明环境变量不对,修改环境变量

export LD_LIBRARY_PATH=/opt/openssl/lib:$LD_LIBRARY_PATH

上面命令以我的路径为例,请自行修改自己的lib路径。运行后再进入bin目录运行openssl程序,看到>就是说明运行成功了
运行成功
下面测试下openssl在i.mx6ul(Cortex A7单核800MHz)下的性能吧,以RSA-2048为例:

./openssl speed rsa2048

openssl移植到arm-linux全过程_第2张图片
妈耶!私匙生成每秒8.4次???!!!还好这个过程不会很频繁啊(大概吧,SSL和TLS我也不懂)。

结语

总之记录下所有移植过程,方便自己回忆并放在其他人走弯路。不过i.mx6ul跑openssl确实不太适合,低频Cortex-A7对于大运算量还是有点吃力了。
之前移植ptyhon2.7和sqlite过程就没有记录,现在也不想再来一次了。下一步有时间了计划移植ubuntu-core文件系统到i.mx6ul下,不知道256MB的FLASH能否放得下。如果可以就能免去交叉编译之苦了。

有啥不对的地方欢迎指正,有什么问题欢迎留言探讨。

你可能感兴趣的:(嵌入式linux软件移植)