编译可在Android上运行的依赖库(三):libffi库
作者:寻禹@阿里聚安全
前言
libffi版本:3.2.1。
本文在Ubuntu 64位系统上对libffi项目进行交叉编译。
下文中的"NDK"若无特殊说明均指"Android NDK"。
步骤
1. 下载并安装Android NDK
下载并安装Android NDK的过程在这里不做介绍。
2. 下载libffi
到libffi的官网去下载这个库的源码。官网地址:https://sourceware.org/libffi/
3. 设置NDK和SYSROOT环境变量
请参考编译可在Android上运行的glib库中相应的步骤。
注意:这里没有也不需要“创建NDK工具的软链接”这个步骤。
4. 运行configure
CPP="arm-linux-eabi-gcc -E" CXXCPP="arm-linux-eabi-gcc -E" CPPFLAGS="-I${SYSROOT}/usr/include" ./configure --prefix="${SYSROOT}/usr" --host=arm-linux-androideabi CFLAGS="--sysroot $SYSROOT"
对./configure命令的解析请参考编译可在Android上运行的libiconv库中的相应步骤。
5. 编译和安装
使用make命令编译源码,当编译成功是使用"make install"命令进行安装,libiconv将会被安装到${SYSROOT}/usr/lib目录下,在上文中"--prefix="${SYSROOT}/usr"命令选项就是用来指定安装的目录的。
注意:libffi库安装后的库文件被安装到"${SYSROOT}/usr/lib"目录下,头文件被安装到"${SYSROOT}/usr/lib/libffi-3.2.1/include"目录下,将"${SYSROOT}/usr/lib/libffi-3.2.1/include"目录下的头文件拷贝到"${SYSROOT}/usr/include"目录下。
作者:寻禹@阿里聚安全,更多技术文章,请点击阿里聚安全博客
阿里聚安全由阿里巴巴移动安全部出品,面向企业和开发者提供企业安全解决方案,全面覆盖移动安全、数据风控、内容安全、实人认证等维度,并在业界率先提出“以业务为中心的安全”,赋能生态,与行业共享阿里巴巴集团多年沉淀的专业安全能力。