stolen from:
libmxml (mini-xml)
一个轻量级的xml库,可完成读写。适合系统资源受限的嵌入式设备。项目主页移植过程:首先准备好交叉编译环境。我使用的是eabi生成的arm-linux-gcc 4.3.2,位于/usr/local/arm/4.3.2/;环境变量已经设置/usr/local/arm/4.3.2/bin。
转载自
主机环境
linux-mint 8 i386
arm-linux-gcc 4.3.2 (eabi)
gcc 4.4
目标机环境
友善之臂mini2440开发板
linux 2.6.31
下载源码,得到mxml-2.6.tar.gz
解压,进入mxmx-2.6
./configure --enable-shared--host=arm-linux
make
接着make报错:
Testing library...
./testmxml test.xml >temp1.xml 2>temp1s.xml
make: *** [testmxml] 错误2
这是测试编译出的可执行文件是否可以正常运行时失败的结果。废话,arm-linux-gcc编译出的东西在主机上显然不能运行。
但是在Testing library之前,编译已经全部结束。我们可以直接拿走要用的文件。
有用的文件一共5个:
mxml.h 头文件
libmxml.a 静态链接库文件
libmxml.so 动态链接库的链接文件,链接到libmxml.so.1.4
libmxml.so.1 动态链接库的链接文件,链接到libmxml.so.1.4
libmxml.so.1.4 动态链接库本体
把库文件复制到交叉编译链所在位置:
我之所以没有在configure的时候直接设定prefix,是因为eabi生成的编译链的文件结构有点诡异,头的存放目录和库文件存放目录不在一个父目录下。
mxml.h → /usr/local/arm/4.3.2/arm-none-linux-gnueabi/libc/usr/include
libmxml.a → /usr/local/arm/4.3.2/arm-none-linux-gnueabi/libc/armv4t/lib
libmxml.so → /usr/local/arm/4.3.2/arm-none-linux-gnueabi/libc/armv4t/lib
libmxml.so.1 → /usr/local/arm/4.3.2/arm-none-linux-gnueabi/libc/armv4t/lib
libmxml.so.1.4 → /usr/local/arm/4.3.2/arm-none-linux-gnueabi/libc/armv4t/lib
对于其他版本的gcc,路径很可能不一样。在这里我们应该灵活处理。
在交叉编译链所在目录中:
1、搜索头文件最多的目录,用来存放头文件。这个目录下一般有很多子文件夹。如果不行,就在每个有头文件存放的位置都放一个mxml.h,以保证编译器能找到该文件
2、搜多存有so文件的目录(一般有多个),每个都把动态链接库和静态链接库的所有文件放进去。以保证编译器能找到。
3、相同的文件存放在多个目录,一定保证这些文件完全一致。即同一次编译的产物。
在库文件和头文件就位后,我们就可以在项目中使用libmxml了。
使用方法:
1、添加
#include
2、增加编译参数
例如
arm-linux-gcc -o test test.c -lmxml-lpthread
其中-lpthread是必选参数,因为libmxml库用到了pthread库
在编译时,编译器会优先选择动态链接库编译,这样编译出的文件会小很多。但是同时也需要目标板上有动态链接库支持。如果想静态编译,在编译参数中加上-static
为目标机添加动态链接库
将
libmxml.so
libmxml.so.1
libmxml.so.1.4
复制到目标板的库目录,一般为/lib或/usr/lib
这样,动态编译的文件就能在目标板上运行了。