描述
交叉编译,按照个人的理解,是为了让原本在PC能够正常运行的APP,换了一个执行环境以后依然能够正常执行。一个APP执行起来,势必会依赖到某些动态库,因此,这些库文件也需要进行交叉编译,并放到相应的路径下,才能给APP使用。
前提
首先,对一个库进行交叉编译,肯定需要一份相应的源码,要清楚使用的是什么编译工具,编译该库时应注意哪些开关项,编译该库是否有依赖项未解决……
交叉编译libxml2-2.9.1
Libxml2是为Gnome项目开发的XML C解析器和工具包(但可以在Gnome平台之外使用),它是MIT License下的免费软件。XML本身是设计标记语言的元语言,即使用尖括号之间的额外“标记”信息将语义和结构添加到内容的文本语言。
源码
下载链接,选择相应版本的tar包下载即可。
步骤
- tar zxvf libxml2-2.9.1.tar.gz
- cd libxml2-2.9.1
- ./configure CC=/opt/hisi-linux/x86-arm/arm-himix200-linux/bin/arm-himix200-linux-gcc --host=arm-linux --prefix=/home/feng/Downloads/SoftwareInstallPacket/libxml2-2.9.1/_build --with-python=no
- make
- make install
参数解释:
- ./configure是为了配置相应的开关项从而生成相应makefile;
- CC=XXX,CC即“CROSS_COMPILE”,交叉编译的意思,XXX指定相应的编译器,如此处使用的编译器是arm-himix200-linux-gcc,一般来说加上绝对路径会更稳妥,不加绝对路径偶尔会报错“找不到该编译器”;
- –host=XXX,指定为arm-linux,如果是移植到板子上,基本都是使用这个参数;
- –prefix=XXX,指定编译输出路径,即编译完成后生成的文件的存放路径,注意如果这个路径是普通用户没有写权限的话,则需要加上“sudo”操作,包括后面的make等;
- –with-python=no,这一项指定不编译python,不加这一项可能也不会报错,但是如果报错信息中出现“python”的字眼,尝试添加这一项重新编译;
Ps:
一般来说,配置成功以后会生成相应的makefile,可以打开makefile查看其中的选项是否与自己配置的相同,如果不同,说明配置失败;
问题的出现有很多,比如前面提到的编译器没有添加绝对路径导致的无法找到编译器,或者–prefix的参数需要用双引号“”包括起来等,具体问题具体分析,多次尝试。
当出现编译(make)失败时,耐心查看error的问题,查找是否缺少依赖项或者权限问题,如果需要对编译清除,则可以使用“make clean”,或使用“make distclean ”彻底清除。