在这里下载openssl 1.1.1下载地址
你可以试一下3.x,我保守起见选的1.x。
下载,解压,进入源码目录。
分三步
- 配置Makefile
- 编译make
- 安装
配置Makefile
在源码目录下,执行以下命令:
ini
./Configure linux-armv4 no-asm no-shared --prefix=$(pwd)/install \
--cross-compile-prefix=/你的SDK/tools/linux/toolchain/arm-rockchip830-linux-uclibcgnueabihf/bin/ \
-march=armv7-a \
--sysroot=/你的_SDK/tools/linux/toolchain/arm-rockchip830-linux-uclibcgnueabihf/arm-rockchip830-linux-uclibcgnueabihf/sysroot
各个参数解释
- linux-armv4:RV1106 芯片使用的是 ARM Cortex-A7 处理器核心。这个核心属于 ARMv7-A 架构系列,因此,
armv7-a
是最通用和最兼容的选项 - no-asm:构建系统不要使用任何汇编语言(Assembly)优化代码,OpenSSL 包含了针对许多不同架构(如 x86、ARM 等)的汇编优化代码。这些汇编代码通常能大幅提升性能,但是!!!如果你的交叉编译环境或者目标处理器存在一些特殊性,导致 OpenSSL 的自动检测机制无法正确生成汇编代码,或者生成的汇编代码存在问题。
- no-shared:只生成静态库
- --prefix:安装目录,$(pwd)是当前目录
- --cross-compile-prefix:交叉编译器的目录
- -march=armv7-a:同第一个参数
- --sysroot:告诉编译器(
gcc
)和链接器(ld
)去哪里寻找所有的头文件、库文件和可执行程序
可选的性能优化选项(我在本地编译时没有加上,原因下文说)
-mfloat-abi=softfp
控制浮点运算的调用约定(ABI)
- softfp :表示编译器会生成硬件浮点指令(如NEON指令),但函数调用时,浮点参数和返回值会像整数一样通过通用寄存器传递。这是一种"软硬结合"的方式。
- soft:所有浮点运算都通过软件库来实现,不使用任何硬件浮点单元。
- hard:所有浮点运算和参数传递都使用硬件浮点单元。
对于 RV1106 的 Cortex-A7 核心,内置了硬件浮点单元(VFPv4-D32),所以使用 softfp
是一个很好的折中方案。它能利用硬件的浮点计算能力来提高性能,同时保持与使用软浮点的老旧 ABI 的兼容性,这在一些大型嵌入式项目中很常见。
-mfpu=neon:
这个选项告诉编译器,你的目标硬件支持 NEON 扩展指令集。NEON 是一种先进的单指令多数据(SIMD)扩展,专为 ARM Cortex-A 系列处理器设计,可以显著加速多媒体、信号处理等应用中的浮点和整数运算。
限制条件
如果使用了硬件寄存器优化执行效率,那么,你就需要确保 OpenSSL 源码中的所有文件,包括核心库和像 blake2b.c
这样的辅助源文件,都使用相同的编译选项进行编译。
我这里没有,所以我没有加这两个修化选项。
编译make
go
make
安装
ruby
make install RANLIB=/你的_SDK/tools/linux/toolchain/arm-rockchip830-linux-uclibcgnueabihf/bin/arm-rockchip830-linux-uclibcgnueabihf-ranlib
指定RANLIB的原因是sdk里的交叉编译工具里,ranlib叫这个名 arm-rockchip830-linux-uclibcgnueabihf-ranlib
。
不指定的话,它有可能直接找一个ranlib
去执行,但这个执行文件其实不存在。
一切以为sdk里的实际情况为准。
执行完后东西都在同目录下的install
里,你也可以一开始--prefix
直接指定到sysroot
目录,这样也不用手动复制生成的头文件和库文件了。