glib交叉编译
2016-05-03 16:28
756 查看
转自:http://blog.csdn.net/ty3219/article/details/46942493 glib是一个C语言函数库,它对很多系统调用进行了封装,提供了很多实用的功能,能极大地方便编程。 为了在产品上尝试使用glib,需要对glib进行交叉编译,使其能在ARM9上运行。以下是版本信息: 开发平台:Linux ubuntu 3.8.0-35-generic #52~precise1-Ubuntu SMP PC gcc 版本 4.6.3 (Ubuntu/Linaro 4.6.3-1ubuntu5) ARM gcc version 4.1.2 zlib-1.2.8 libffi-3.2.1 glib-2.45.3 为了方便说明,先假设1、zlib-1.2.8.tar.gz、libffi-3.2.1.tar.gz和glib-2.45.3.zip都已经解压到/home/user/build/目录下,分别是/home/user/build/zlib-1.2.8、/home/user/build/libffi-3.2.1和/home/user/build/glib-2.45.3。2、CC是交叉编译器,根据自己的实际编译器而不同,这里CC最好时包含完整的路径。我这里是/opt/freescale/usr/local/gcc-4.1.2-glibc-2.5-nptl-3/arm-none-linux-gnueabi/bin/arm-none-linux-gnueabi-gcc开始编译1. 编译zlib,编译脚本如下:[plain] viewplain copycd /home/user/build/zlib-1.2.8 CC=/opt/freescale/usr/local/gcc-4.1.2-glibc-2.5-nptl-3/arm-none-linux-gnueabi/bin/arm-none-linux-gnueabi-gcc \ ./configure --prefix=/home/user/build/zlib-1.2.8/install/arm/ make if [ $? == 0 ]; then make install else echo -e "\n\tmake fail\n" fi 执行成功之后,zlib就会安装在/home/user/build/zlib-1.2.8/install/arm/目录2. 编译libffi,编译脚本如下:[plain] viewplain copy#!/bin/bash cd /home/user/build/libffi-3.2.1 ./configure --prefix=/home/huo/dbus/libffi-3.2.1/install/arm/ \ CC=/opt/freescale/usr/local/gcc-4.1.2-glibc-2.5-nptl-3/arm-none-linux-gnueabi/bin/arm-none-linux-gnueabi-gcc \ --host=arm-none-linux-gnueabi make if [ $? == 0 ]; then make install else echo -e "\n\tmake fail\n" fi 执行成功之后,zlib就会安装在/home/user/build/libffi-3.2.1/install/arm/目录3. 下面编译glib,是个硬骨头,会有一些错误。1)首先,glib需要一些配置,下面是一个配置文件glib.cache,这个配置文件需要放在/home/user/glib-2.45.3目录下面。[plain] viewplain copyglib_cv_long_long_format=ll glib_cv_stack_grows=no glib_cv_have_strlcpy=no glib_cv_have_qsort_r=yes glib_cv_va_val_copy=yes glib_cv_uscore=no glib_cv_rtldglobal_broken=no ac_cv_func_posix_getpwuid_r=yes ac_cv_func_posix_getgrgid_r=yes 这个配置文件的选项,以及选项的意义看这里 https://developer.gnome.org/glib/stable/glib-cross-compiling.html 2)运行autogen.sh[plain] viewplain copy#!/bin/bash cd /home/user/build/glib-2.45.3 ./autogen.sh 3)编译PC版glib没错,你没看错,想交叉编译glib,需要先编译一个PC版本,而编译PC版glib又需要依赖PC版zlib和libffi由于我使用的是ubuntu,所以直接sudo apt-get install libffi-dev就可以了,zlib系统已经带了所以我编译PC版glib非常简单[plain] viewplain copy#!/bin/bash cd /home/user/build/glib-2.45.3 ./configure --prefix=/home/usr/build/glib-2.45.3/install/pc --cache-file=glib.cache make if [ $? == 0 ]; then make install else echo -e "\n\tmake fail\n" fi 编译完成以后,就会在/home/usr/build/glib-2.45.3/install/pc/bin/目录下得到glib-genmarshal,否则在执行configure的时候会提示configure: error: Could not find a glib-genmarshal in your PATH。至于为什么PC版就可以这个我还没有搞懂。4)开始编译glib[plain] viewplain copy#!/bin/bash export PATH=$PATH:/home/huo/dbus/glib-2.45.3/install/pc/bin cd /home/user/build/glib-2.45.3 ./configure --prefix=/home/user/build/glib-2.45.3/install/arm \ CC=/opt/freescale/usr/local/gcc-4.1.2-glibc-2.5-nptl-3/arm-none-linux-gnueabi/bin/arm-none-linux-gnueabi-gcc \ --host=arm-none-linux-gnueabi LIBFFI_CFLAGS="-I/home/user/build/libffi-3.2.1/install/lib/libffi-3.2.1/include" \ LIBFFI_LIBS="-lffi -L/home/user/build/libffi-3.2.1/install/lib" ZLIB_CFLAGS="-I/home/user/build/zlib-1.2.8/install/include" \ ZLIB_LIBS="-lz -L/home/user/build/zlib-1.2.8/install/lib" --cache-file=glib.cache \ --disable-selinux --disable-xattr --disable-libelf make if [ $? == 0 ]; then make install else echo -e "\n\tmake fail\n" fi 这时,make的时候就应该会出错,提示
CCLD gobject-query./.libs/libgobject-2.0.so: undefined reference to `ffi_type_pointer'
./.libs/libgobject-2.0.so: undefined reference to `ffi_type_float'
./.libs/libgobject-2.0.so: undefined reference to `ffi_type_void'
./.libs/libgobject-2.0.so: undefined reference to `ffi_type_sint64'
./.libs/libgobject-2.0.so: undefined reference to `ffi_prep_cif'
./.libs/libgobject-2.0.so: undefined reference to `ffi_type_uint32'
./.libs/libgobject-2.0.so: undefined reference to `ffi_type_double'
./.libs/libgobject-2.0.so: undefined reference to `ffi_call'
./.libs/libgobject-2.0.so: undefined reference to `ffi_type_sint32'
./.libs/libgobject-2.0.so: undefined reference to `ffi_type_uint64'
collect2: ld returned 1 exit status这是由于没找到libffi.so的缘故。虽然我在配置里已经指定了libffi.so的路径,但glib就是死活找不到,暂时没找到解决方法,只能绕一下,把libffi.so libffi.so.6 libffi.so.6.0.4复制到arm gcc的目录下,我这里的目录是/opt/freescale/usr/local/gcc-4.1.2-glibc-2.5-nptl-3/arm-none-linux-gnueabi/arm-none-linux-gnueabi/sysroot/lib。如果你不知道你该复制到哪里,你可以在你的交叉编译器目录下找以下libc.so.*,比如find /opt/freescale -name libc.so.*,看libc.so.*放哪你就放哪。同理,libz.so libz.so.1和libz.1.2.8也要拷贝到这个目录下。后面继续make,又会弹出来一个错误gfile.c:2749: error: too many arguments to function 'splice'这个错误是跟系统以及编译器的版本有关系的。splice是一个系统调用,它的声明在交叉编译器的fcntl.h文件里的,但我这个编译器的splice只有4个参数,glib却传了6个参数。这肯定不匹配嘛,没办法,只能修改glib-2.45.3目录下的config.h,把#define HAVE_SPLICE注释掉,这样就能编译过去了。至于影响,暂时还不清楚,这个splice是linux的一个数据拷贝优化技术,可以减少数据的拷贝次数,提高系统效率,即使没有应该也是可以正常工作的。再继续make,又蹦出来一个错误,我内心也是崩溃的
./.libs/libgio-2.0.so: undefined reference to `g_module_close'
./.libs/libgio-2.0.so: undefined reference to `g_module_symbol'
./.libs/libgio-2.0.so: undefined reference to `g_module_supported'
./.libs/libgio-2.0.so: undefined reference to `g_module_open'
./.libs/libgio-2.0.so: undefined reference to `g_module_error'
collect2: error: ld returned 1 exit status这个错误又是没找到动态库,这次是没找到gmodule.so,需要修改gio/Makefile找到glib_compile_resources_LDADD, gsettings_LDADD, gdbus_LDADD, gapplication_LDADD, gresource_LDADD这几个变量,在给每个变量都加上一句$(top_builddir)/gmodule/libgmodule-2.0.la \加上之后类似这样gdbus_LDADD = libgio-2.0.la \ $(top_builddir)/gobject/libgobject-2.0.la \ $(top_builddir)/gmodule/libgmodule-2.0.la \ $(top_builddir)/glib/libglib-2.0.la \ $(NULL)再继续make。。。。。。。终于。。。。。。。4. make install
相关文章推荐
- 自定义ViewPagerIndicater
- bootstrap 模态框 遮住了 ueditor 编辑器的表情框
- iOS instruments
- Swift 单例
- Session
- python cx_oracle 取回数据后 LOB variable no longer valid after subsequent fetch
- 27. Remove Element
- Visual Studio 2013 的 Xamarin 安装教程
- 复合数据类型(简答)
- 防御性编程
- Codeforces Beta Round #94 div 2 C Statues dfs或者bfs
- 高性能网站建设指南
- iOS使用Object-C自定义cordova插件(-)
- 清除WKWebView的缓存
- UVa 10299 :Relatives 欧拉函数
- 练习三 1011
- Software Enginering-------Architecture Patterns
- opencv arm 交叉编译资料
- Python入门
- CSS3让登陆面板3D旋转起来