科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件交叉编译场景分析(arm-linux)(一)--基本知识

交叉编译场景分析(arm-linux)(一)--基本知识

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

交叉编译场景分析(arm-linux)(一)--基本知识。

作者:李先静 来源:CSDN 2008年3月27日

关键字: 分析 场景 交叉编译 开源

  • 评论
  • 分享微博
  • 分享邮件

1.         基本知识

linux下,绝大部分的软件包都是用autoconf配置的。除此之外,比较有名的就是X11imake配置方式,imake实际上有点过时了,用起来很不方便,所以xfree86已经计划向autoconf移植了。还有极少的直接使用Makefile编译,通过环境变量或者不同的Makefile配置,当然这只适用于简单的软件包。

 

Autoconf是一个非常有用的配置工具,原理有点复杂,全面了解它要花不少时间,但使用很方便。这里简单介绍一下autoconf交叉编译的基本知识。

 

下载软件包无非两种方式,一种是直接从cvs里取最新版本,另一种是取发布的稳定版本。除非你想测试最新版本,否则后者是比较安全的方式。但有的软件包不提供发布的版本,这时就只能退而求其次了-使用cvs版本了。

 

编译cvs版本有一点不同,cvs版本通常不带configure脚本的,自己要重新产生configure脚本。当然这并不困难,多数开发人员都会在自己的软件包里,放上一个autogen.sh或者bootstartup之类的脚本。利用这个脚本可以自动产生configure脚本。下面是一个autogen.sh脚本示例,若软件包里没有提供这样的文件,可以仿照写一个:

 

#!/bin/sh

# $Id: autogen.sh,v 1.3 2005/02/26 01:47:22 kergoth Exp $

 

autoreconf -f -i -I `pwd`/m4

exit $?

 

echo -n "Libtoolize..."

libtoolize --force --copy

echo "Done."

echo -n "Aclocal..."

aclocal

echo "Done."

echo -n "Autoheader..."

autoheader

echo "Done."

echo -n "Automake..."

automake --add-missing --copy

echo "Done."

echo -n "Autoconf..."

autoconf

echo "Done."

#./configure $*

echo "Now you can do ./configure, make, make install."

 

正式发布的软件包里,已经有做好的configure脚本了。接下来我们要做的就是利用configure进行配置。对于交叉编译来说,最重要的配置选项有以下几个:

 

--host指定目标机的平台类型。一般格式为CPU类型-操作系统名称。比如,目标机的CPUarm,操作系统为linux,可以这样写--host=arm-linux

--prefix这是安装路径的前缀,即编译结果放置的位置。默认值是/usr或者/usr/local,交叉编译时不能使用默认值,否则它会覆盖你本机的文件,所以要指定一个路径。比如,可以指定为--prefix=/work/cross/rootfs/usr

 

配置完成后,运行make编译,运行make install安装。

 

(pkg-config也是一个非常重要的工具,关于pkg-config的使用,可以参考笔者另外一篇文章,这里不再多说。)

 

2.         文档惯例及隐含前提:

 

交叉编译器名称:arm-linux-gcc

交叉编译器版本:3.4.3

目标操作系统版本:2.6.9

默认依赖关系:依赖glibc

 

隐含环境变量:

WORK_DIR:工作目录,设置为/work/cross

ROOTFS_DIR:编译结果根目录,设置为$WORK_DIR/rootfs

ARCH:目标平台的体系架构,设置为arm

 

建立一个脚本用于设置变量和建立必要的目录,在编译前,先运行. corss.env 其内容如下:

 

cross.env

export WORK_DIR=/work/cross

export ROOTFS_DIR=$WORK_DIR/rootfs

export ARCH=arm

export PKG_CONFIG_PATH=$ROOTFS_DIR/usr/local/lib/pkgconfig:$ROOTFS_DIR/usr/lib/pkgconfig:$ROOTFS_DIR/usr/X11R6/lib/pkgconfig

 

if [ ! -e "$ROOTFS_DIR/usr/local/include" ]; then mkdir -p $ROOTFS_DIR/usr/local/include;fi;

if [ ! -e "$ROOTFS_DIR/usr/local/lib" ]; then mkdir -p $ROOTFS_DIR/usr/local/lib; fi;

if [ ! -e "$ROOTFS_DIR/usr/local/etc" ]; then mkdir -p $ROOTFS_DIR/usr/local/etc; fi;

if [ ! -e "$ROOTFS_DIR/usr/local/bin" ]; then mkdir -p $ROOTFS_DIR/usr/local/bin; fi;

if [ ! -e "$ROOTFS_DIR/usr/local/share" ]; then mkdir -p $ROOTFS_DIR/usr/local/share; fi;

if [ ! -e "$ROOTFS_DIR/usr/local/man" ]; then mkdir -p $ROOTFS_DIR/usr/local/man; fi;

 

if [ ! -e "$ROOTFS_DIR/usr/include" ]; then mkdir -p $ROOTFS_DIR/usr/include; fi;

if [ ! -e "$ROOTFS_DIR/usr/lib" ]; then mkdir -p $ROOTFS_DIR/usr/lib; fi;

if [ ! -e "$ROOTFS_DIR/usr/etc" ]; then mkdir -p $ROOTFS_DIR/usr/etc; fi;

if [ ! -e "$ROOTFS_DIR/usr/bin" ]; then mkdir -p $ROOTFS_DIR/usr/bin; fi;

if [ ! -e "$ROOTFS_DIR/usr/share" ]; then mkdir -p $ROOTFS_DIR/usr/share; fi;

if [ ! -e "$ROOTFS_DIR/usr/man" ]; then mkdir -p $ROOTFS_DIR/usr/man; fi;

 

颜色字体含义

颜色字体 表示错误信息。

颜色字体 表示命令行脚本。

颜色字体 表示文件内容。

 

文档格局:

 

1.         基本信息:

软件名称

 

功能简述

 

下载地址

 

软件版本

 

依赖关系

 

前置条件

 

 

2.         过程分析

构建过程中遇到的问题分析。

3.         构建处方

通常是一个可用的Makefile,用它可以编译这个模块。或者一些patch文件。

 

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章