centos7 glib2.0 arm版本的编译

        最近在看bluez代码,想编译个例子来玩一下,然后bluez里的例子会用到 libglib-2.0 库里的接口,于是开始了漫长的编译 arm 版本的 libglib-2.0,Linux 系统有时就是很麻烦,要编译一个库,结果发现依赖一大堆库,你需要先把依赖的库成功装好才能正常进行下去。

        首先想要成功编译 glib2.0 库,则需要提前安装两个依赖库,这一步是必须的,即使现在不装等到编译 glib2.0 的时候会失败的。

1,yum install libffi-dev (这里需要注意,如果是需要编译arm版本,还得下载源码安装)

2,yum install -y glibc-devel

特别是第2个,网上搜了大部分都是ubuntu的,人家是用 apt-get libglib2.0-dev,这个软件包名 libglib2.0-dev 在 Centos 上是不对的,真是坑啊。

我的 configure 命令行是这样的:

./configure --prefix=/usr/local/glib --host=arm-himix200-linux --cache-file=arm-himix200-linux.cache CC="arm-himix200-linux-gcc" LIBFFI_CFLAGS=/usr/include/

1, extra flags to get ANSI library prototypes... configure: error: cannot test program while cross compling

这个错误也不知道是什么原因导致的,网上搜了很多,其中看到有人说可能是下载的glib-2.0源码版本过低,当时我也不记得下载的哪个版本了,于是我先了一个比较高的版本:glib-2.30.2.tar.xz

创建一个空目录进行下载:wget http://ftp.acc.umu.se/pub/GNOME/sources/glib/2.30/glib-2.30.2.tar.xz ;确实用这个版本时,没有出现上面这个错误,但出现了其他错误。

2, Could not find a glib-genmarshal in your PATH

这个错误就是上面提到的第 2 个依赖库

3,  No package 'libffi' found

这个错误就是上面提到的第 1 个依赖库,注意这里提到的版本,如果命令行安装的版本不符合,那就直接下载一个合适的版本手动编译安装吧

4, qsort_r uses glibc compatible argument order

有几个类似的错误,都是是否支持一些特性的吧,这里不管了,直接想办法让它正常生成Makefile再说。这里是这样处理:

ac_cv_func_qsort_r=no
glib_cv_stack_grows=no
glic_cv_uscore=no
glib_cv_uscore=no
ac_cv_func_posix_getpwuid_r=no
ac_cv_func_posix_getgrgid_r=no

把这些 echo 到 arm-himix200-linux.cache 里,如:

最后configure 执行成功,才能生成Makefile

我的目标目录下:

5,gclosure.c:29:17: fatal error: ffi.h: No such file or directory

这里有一个问题很奇怪,我在编译的时候用的是:make;make install;然后在编译的过程中还是出现了一个错误:

虽然出现了这个错误,但目标目录下已经生成了glib-2.0的库,不知道为何。而这个错误更奇怪,因为这个头文件是有的,不管是我安装的libffi目录下,还是系统目录下。在最开始的 ./configure 时,我已经加了 LIBFFI_CFLAGS=/usr/include/ 来指定 libffi 的头文件位置,而且我也用过 LIBFFI_CFLAGS=/usr/local/lib/libffi-3.0.13/include/,这两个加了都没用,还是会出现找不到 ffi.h 头文件的错误,而实际这个头文件是有的:

可以看到是目录 gobject 编译gclosure时出错的,相应的我在那里添加了一下打印:

最后无奈我直接把其他地方的 ffi.h 和 ffitarget.h 直接拷贝到 gobject 目录下,再编译就不再有这个错误了。 

6,libffi.so: file not recognized: File format not recognized

这个也是开始提到的依赖库 libffi,但我们上面安装的 x86版本的,arm 版本还得自己下载源码进行编译安装了,我下载的是 libffi-3.0.13.tar.gz,因为提示这个目录下的 libffi.so文件格式不对,它是x86版本的。

我所使用的 configure 是这样的:

./configure --prefix=/usr/GNUstep/System/Library/Libraries/ --host=arm-himix200-linux 

然而实际编译出来的目标目录下还有一个 lib 目录,用 file 命令看,这里已经是 ARM 版本了

继续编译 glib-2.0 还是那个错误,干脆我直接把目标目录下的 lib 的文件拷贝到它的上一层目录下,因为这个库文件目录不知道在Makefile 哪里指定的,省点麻烦:

7, zlib.h: No such file or directory

虽然 libffi.so 的错误已经解决了,但又出现了下面这个错误,应该跟上面一样的依赖库, 

一个坑接着一个坑,真是要崩溃了。最简单的办法就是把 /usr/zlib.h 和 /usr/zconf.h 拷贝到 gio 目录下。

 

 8,arm-linux-gnueabi/bin/ld: cannot find -lz

 拷贝头文件还是不行啊,最后还是没有libz库,没有办法,还是下载源码编译安装,我用的是这个:CC=arm-himix200-linux-gcc ./configure --prefix=/usr/local/zlib/,它没有--host 选项无法指定交叉编译器。

 编译出来的成果

zlib 库虽然编译出来了,但继续编译glib的时候还会出现找不到 libz 的错误,如上面是编译gio的时候找不到 libz 库。我的解决办法就是把库拷贝到 gio 目录下,然后在它的 Makefile 里添加-L,如:

接着编译,然后又出现同样的错误

 

这个简单直接,把zlib拷贝到gio/tests/目录下,然后再修改Makefile,添加 -L./ 指定库文件目录:

 

最后真是大功告成啊,真是不容易啊,比以往所有手动编译源码的事情都复杂得多了,也是遇到前所未有的困难啊,好在最后还是成功了。

 

 最后是编译 bluez,最开始那么多的 undefined reference to xxx,到最后剩下 2 个,有一个是私有库里,但还是有一个应该也是要编译其他库:

 

 

 

### QEMU 9.2.2 的安装指南 QEMU 是一款开源的模拟器和虚拟机监控程序,广泛应用于嵌入式开发、系统测试以及安全性研究等领域[^1]。以下是关于如何安装 QEMU 9.2.2 的详细说明: #### 准备工作 在开始之前,请确认操作系统已满足以下条件: - 已更新至最新状态的操作系统包。 - 开发工具链已就绪(如 GCC 编译器及相关依赖库)。 对于基于 Debian/Ubuntu 的发行版,可以通过以下命令安装必要的编译工具和依赖项: ```bash sudo apt update && sudo apt install -y build-essential git libglib2.0-dev \ pkg-config zlib1g-dev libsdl2-dev libusb-1.0-0-dev qemu-system-x86 ``` 对于基于 Red Hat/CentOS/Fedora 的发行版,则可运行如下命令来准备环境: ```bash sudo yum groupinstall "Development Tools" sudo yum install -y gcc make git glib2-devel zlib-devel SDL2-devel \ libusb-devel ``` #### 下载源码 访问 QEMU 官方网站或其 Git 存储库获取指定版本的源代码文件。例如下载 QEMU 9.2.2 版本: ```bash wget https://download.qemu.org/qemu-9.2.2.tar.xz tar xf qemu-9.2.2.tar.xz cd qemu-9.2.2 ``` #### 配置与编译 进入解压后的目录并执行配置脚本。此过程会检测当前系统的兼容性和所需组件是否存在。如果一切正常,继续完成编译操作即可。 ```bash ./configure --target-list=x86_64-softmmu,i386-softmmu,aarch64-softmmu,arm-softmmu make -j$(nproc) sudo make install ``` 上述 `--target-list` 参数指定了要启用的目标体系结构列表。可以根据实际需求调整这些选项。 #### 测试验证 安装完成后可通过简单指令检验是否成功部署了新版本的 QEMU: ```bash qemu-system-x86_64 --version ``` 该命令应返回所安装的具体版本号信息,比如显示为 “QEMU emulator version 9.2.2”。 --- 尽管 KVM 和其他管理工具有助于增强虚拟化体验[^3],但单独使用 QEMU 同样能够提供丰富的功能集以适应多种应用场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值