yfr*_*com 2 linux openssl arm github cross-compiling
我使用 Ubuntu x86 并且有用于 Arm linux 的 gcc 交叉编译器。
我想为 arm linux构建开放的 ssl github 项目。
我阅读了文档,但无法理解如何构建它。
Fra*_*ant 11
假设您正在构建 64 位 arm Linux 系统,此后的自包含程序应该可以工作 - 为我工作Ubuntu 19.10 x86_64:
# openssl
wget https://www.openssl.org/source/openssl-1.1.1e.tar.gz
tar zxf openssl-1.1.1e.tar.gz
# a toolchain I know is working
wget "https://developer.arm.com/-/media/Files/downloads/gnu-a/9.2-2019.12/binrel/gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu.tar.xz?revision=61c3be5d-5175-4db6-9030-b565aae9f766&la=en&hash=0A37024B42028A9616F56A51C2D20755C5EBBCD7" -O gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu.tar.xz
mkdir -p /opt/arm/9
tar Jxf gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu.tar.xz -C /opt/arm/9
# building
cd openssl-1.1.1e
./Configure linux-aarch64 --cross-compile-prefix=/opt/arm/9/gcc-arm-9.2-2019.12-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu- --prefix=/opt/openssl-1.1.1e --openssldir=/opt/openssl-1.1.1e -static
make install
ls -gG /opt/openssl-1.1.1e/bin/
total 10828
-rwxr-xr-x 1 6214 Mar 23 23:27 c_rehash
-rwxr-xr-x 1 11077448 Mar 23 23:27 openssl
file /opt/openssl-1.1.1e/bin/openssl
/opt/openssl-1.1.1e/bin/openssl: ELF 64-bit LSB executable, ARM aarch64, version 1 (GNU/Linux), statically linked, for GNU/Linux 3.7.0, with debug_info, not stripped
Run Code Online (Sandbox Code Playgroud)
如果您想为具有硬件浮点支持的 32 位 arm 系统构建,我们只需要稍微修改一下三个命令的程序:
wget "https://developer.arm.com/-/media/Files/downloads/gnu-a/9.2-2019.12/binrel/gcc-arm-9.2-2019.12-x86_64-arm-none-linux-gnueabihf.tar.xz?revision=fed31ee5-2ed7-40c8-9e0e-474299a3c4ac&la=en&hash=76DAF56606E7CB66CC5B5B33D8FB90D9F24C9D20" -O gcc-arm-9.2-2019.12-x86_64-arm-none-linux-gnueabihf.tar.xz
tar Jxf gcc-arm-9.2-2019.12-x86_64-arm-none-linux-gnueabihf.tar.xz -C /opt/arm/9
./Configure linux-generic32 --cross-compile-prefix=/opt/arm/9/gcc-arm-9.2-2019.12-x86_64-arm-none-linux-gnueabihf/bin/arm-none-linux-gnueabihf- --prefix=/opt/openssl-1.1.1e --openssldir=/opt/openssl-1.1.1e -static
Run Code Online (Sandbox Code Playgroud)
更新:在阅读评论时提供更多信息。
1)linux-generic32顾名思义,它是一个通用的 32 位 linux 目标,应该可以在任何 32 位系统上运行。您可以在 Internet 上的很多地方找到此信息,例如这里。缺点是可执行文件可能未针对您的目标进行优化。如果您阅读Configure脚本,您将看到可以指定用于指导编译的环境变量列表。例如,如果你的SoC是cortex-a9,你可以通过-mtune=cortex-a9设置传递选项CFLAGS——你会在网上找到很多信息,但我建议看一下Configure,它确实包含很多有用的评论。
顺便说一下,如果你Configure使用一个不存在的目标执行,你会得到所有可能的目标列表:
./Configure does-not-exist
Run Code Online (Sandbox Code Playgroud)
2) hf 代表硬件浮点数。有些 32 位 arm SoC 确实有对浮点运算的硬件支持,有些则没有。由于您没有指定您所针对的 SoC 的确切品牌/型号,我进行了猜测,并使用了一个能够为 arm 浮点硬件生成代码的工具链(如果存在)。