编译busybox

make[1]: *** [ipsvd/tcpudp.o] Error 1

make: *** [ipsvd] Error 2


【具体步骤】: 

     1) 下载busybox源代码,并解包 

     $ wget -c http://www.busybox.net/downloads/busybox-1.7.0.tar.bz2

     $ tar jxvf busybox-1.7.0.tar.bz2 

  

     2) 下载交叉编译工具,并安装 

     我下载的是:arm-2009q1-161-arm-none-eabi.bin 

     说明:要正确设置好PATH变量。 

     例如将“你的目录”/CodeSourcery/Sourcery_G++_Lite/bin加到PATH路径中。 

  

     3)进入到busybox解压后的源文件目录中,修改Makefile 

     将第176行改为: 

     CROSS_COMPILE   ?=arm-none-linux-gnueabi-

  

     4)进行编译选项配置 

     a、 

     $ make menuconfig 

     Busybox Settings ---> 

            Build Options ---> 

                [*] Build BusyBox as a static binary(no shared libs) 

 

  

     说明:这个选项一定要选,这样才能把busybox编译成静态链接的可执行文件,运行时可以独立于其他库。 

  

     b、 

            Installation Options ---> 

                [*] Don't use /usr   

  

     说明:这个也一定要选,否则make install后,busybox将安装在原来系统的/usr下,将你原有的命令都覆盖了! 

  

     5)配置好后可以编译了,执行如下命令: 

     $ make 

     发现没过多久,就报错了,晕,错误内容如下: 

     applets/applets.c:20:2: warning: #warning Static linking against glibc produces buggy executables 

     applets/applets.c:21:2: warning: #warning (glibc does not cope well with ld --gc-sections). 

     applets/applets.c:22:2: warning: #warning See sources.redhat.com/bugzilla/show_bug.cgi?id=3400 

     applets/applets.c:23:2: warning: #warning Note that glibc is unsuitable for static linking anyway. 

     applets/applets.c:24:2: warning: #warning If you still want to do it, remove -Wl,--gc-sections 

     applets/applets.c:25:2: warning: #warning from top-level Makefile and remove this warning. 

     applets/applets.c:26:2: error: #error Aborting compilation. 

     make[1]: *** [applets/applets.o] 错误1 

     make: *** [applets] 错误2 

     看到它给出了提示,说glibc库不适和用来静态编译,最后给出解决方案就是将applets/applets.c中这部分内容给去掉,也就是19-27行。 

     

     然后再make进行编译。 

     不多久又报错了,看看具体错误: 

     .../compal/CodeSourcery/Sourcery_G++_Lite/bin/../arm-none-linux-gnueabi/libc/usr/include/linux/netfilter.h:56:17: error: field 'in' has incomplete type 

     .../CodeSourcery/Sourcery_G++_Lite/bin/../arm-none-linux-gnueabi/libc/usr/include/linux/netfilter.h:57:18: error: field 'in6' has incomplete type 

     ipsvd/tcpudp.c: In function 'tcpudpsvd_main': 

     ipsvd/tcpudp.c:314:10: warning: ignoring return value of 'write', declared with attribute warn_unused_result 

     make[1]: *** [ipsvd/tcpudp.o] 错误1 

     make: *** [ipsvd] 错误2 

     看到说在我们下载的交叉编译库中有个头文件中的in及in6类型不对,解决的办法就是: 

     在.../arm-none-linux-gnueabi/libc/usr/include/linux/netfilter.h的开头 
添加缺少的头文件: 
     #include <netinet/in.h> 

  

     然后再进行编译。(这次可以安全到最后了,呵呵) 

     结束后会在当前目录下看到busybox这个可执行文件


<think>我们正在处理用户关于编译BusyBox源代码的请求。根据引用内容,特别是引用[1]和引用[2],我们可以总结出编译BusyBox的基本步骤。同时,引用[3]提供了BusyBox项目的目录结构,引用[4]则涉及添加新Applet(但用户当前问题不涉及扩展功能,因此我们主要关注基本编译步骤)。 编译BusyBox的步骤通常包括: 1. 获取源代码:从官方网站或GitHub仓库下载。 2. 配置编译环境:安装交叉编译工具链(如果目标平台与主机不同)。 3. 配置BusyBox:通过菜单选择需要编译的命令(applets)。 4. 编译:使用make命令进行编译。 5. 安装:将编译好的BusyBox二进制文件和符号链接安装到指定目录。 下面我们详细说明每个步骤。 ### 步骤1:获取BusyBox源代码 用户可以从BusyBox官方网站(https://www.busybox.net)下载源代码,也可以从GitHub仓库克隆。例如,使用git克隆: ```bash git clone https://github.com/mirror/busybox.git ``` 或者下载特定版本的压缩包并解压。 ### 步骤2:准备编译环境 在编译之前,需要确保系统已安装必要的编译工具(如gcc, make等)。对于嵌入式开发,通常需要交叉编译工具链。例如,对于ARM平台,可能需要安装`arm-linux-gnueabihf-gcc`。确保交叉编译工具链的路径已添加到环境变量PATH中。 ### 步骤3:配置BusyBox 进入BusyBox源代码目录,运行配置菜单: ```bash make menuconfig ``` 这将打开一个基于ncurses的配置菜单,用户可以选择需要编译的applets(命令)以及设置其他选项(如静态链接、安装路径等)。如果不进行配置,默认会编译所有applets。 注意:在配置菜单中,可以设置安装路径(在“Busybox Settings” -> “Installation Options”中设置“BusyBox installation prefix”),例如设置为`_install`,这样后续安装时会将文件安装到当前目录的`_install`子目录下。 ### 步骤4:编译BusyBox 使用make命令进行编译: ```bash make ``` 如果需要指定交叉编译工具链,可以在make命令中指定: ```bash make CROSS_COMPILE=arm-linux-gnueabihf- ``` 或者通过配置菜单设置交叉编译工具链前缀(在“Busybox Settings” -> “Build Options”中设置“Cross Compiler prefix”)。 ### 步骤5:安装BusyBox 编译完成后,运行安装命令: ```bash make install ``` 这将在之前设置的安装路径(默认为`_install`目录)下生成BusyBox二进制文件以及指向该二进制文件的符号链接(对应每个启用的applet)。 安装后的目录结构通常如下: ``` _install/ bin/ busybox # 主程序 ls -> busybox # ls命令的符号链接 cat -> busybox # cat命令的符号链接 ... # 其他命令的符号链接 sbin/ usr/ ``` 现在,可以将`_install`目录下的内容复制到目标嵌入式设备的根文件系统中。 ### 注意事项 - 在配置过程中,如果不需要某些命令,可以取消选择以减少生成的二进制文件大小。 - 如果需要静态链接,可以在配置菜单中选中“Build BusyBox as a static binary (no shared libs)”。 - 编译过程中可能会遇到依赖问题,需要根据错误提示安装相应的开发包。 以上步骤是编译BusyBox的基本流程。根据具体需求,可能还需要进行其他配置(如设置初始化进程、修改启动脚本等)。 §§相关问题§§ 1. 如何为特定的嵌入式平台交叉编译BusyBox? 2. BusyBox配置菜单中常见选项的含义是什么? 3. 如何将编译好的BusyBox集成到嵌入式根文件系统中? 4. BusyBox编译过程中常见的错误有哪些?如何解决?</think>### BusyBox 编译步骤指南 编译 BusyBox 源代码需要以下步骤,请根据您的目标平台(嵌入式设备或本地主机)选择相应的配置: #### 1. **获取源代码** ```bash wget https://busybox.net/downloads/busybox-1.36.1.tar.bz2 tar -xvf busybox-1.36.1.tar.bz2 cd busybox-1.36.1 ``` > 官网提供最新版本下载,建议选择稳定版[^1] #### 2. **配置编译环境** ```bash # 本地主机编译 make defconfig # 嵌入式设备交叉编译(示例:ARM架构) make CROSS_COMPILE=arm-linux-gnueabihf- defconfig ``` > 交叉编译工具链需提前安装,`CROSS_COMPILE` 指定目标架构前缀[^2] #### 3. **自定义配置** ```bash make menuconfig # 文本图形界面 ``` 关键配置项: - **Busybox Settings** → **Build Options**: - `[ ] Build static binary`(静态链接减小依赖) - `Cross compiler prefix`(交叉编译时填写) - **Applets**:禁用不需要的命令减小体积 - **Installation Options**: - `Installation prefix`(设置安装路径,如`_install`) #### 4. **编译源代码** ```bash make -j$(nproc) # 使用所有CPU核心加速编译 ``` > 成功编译后生成 `busybox` 可执行文件 #### 5. **安装到目标目录** ```bash make install ``` 安装目录结构示例: ``` _install/ ├── bin/ │ ├── busybox → 所有命令的软链接 │ ├── ls → busybox │ └── sh → busybox └── sbin/... ``` #### 6. **集成到根文件系统(嵌入式系统)** ```bash # 将_install目录复制到根文件系统 cp -r _install/* /path/to/rootfs/ # 创建必要目录 mkdir -p /path/to/rootfs/{proc,sys,dev} ``` #### 常见问题解决 - **编译错误**:检查是否缺少依赖库(如libc-dev) - **命令缺失**:在 `menuconfig` 中启用对应 Applet - **启动失败**:检查 `/bin/busybox` 路径和权限 > 完整编译指南参考官方文档:[BusyBox Documentation](https://busybox.net/docs.html)[^3]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值