文档库 最新最全的文档下载
当前位置:文档库 › 深入理解Linux软件配置、编译及安装

深入理解Linux软件配置、编译及安装

深入理解Linux软件配置、编译及安装
深入理解Linux软件配置、编译及安装

深入理解Linux软件配置、编译及安

从源代码安装过软件的朋友一定对./configure&&make&&make install安

装三步曲非常熟悉了。然而究竟这个过程中的每一步幕后都发生了些什么呢?本文将带领你一探究竟。深入理解这个过程将有助于你在LFS的基础上玩出自己

的花样来。不过需要说明的是本文对Makefile和make的讲解是相当近视和粗

浅的,但是对于理解安装过程来说足够了。用一句话来解释这个过程就是:根

据源码包中Makefile.in文件的指示,configure脚本检查当前的系统环境和

配置选项,在当前目录中生成Makefile文件(还有其它本文无需关心的文件),然后make程序就按照当前目录中的Makefile文件的指示将源代码编译为二进

制文件,最后将这些二进制文件移动(即安装)到指定的地方(仍然按照

Makefile文件的指示)。由此可见Makefile文件是幕后的核心。要深入理解安

装过程,必须首先对Makefile文件有充分的了解。本文将首先讲述Makefile

与make,然后再讲述configure脚本。并且在讲述这两部分内容时,提供了尽

可能详细的、可以运用于实践的参考资料。Makefile与make用一句话来概括Makefile与make的关系就是:Makefile包含了所有的规则和目标,而make则是为了完成目标而去解释Makefile规则的工具。make语法首先看看make的命

令行语法:make[options][targets][VAR=VALUE].[options]是命令行选项,可以用make--help命令查看全部,[VAR=VALUE]是在命令行上指定环境变量,这

两个大家都很熟悉,将在稍后详细讲解。而[targets]是什么呢?字面的意思是"目标",也就是希望本次make命令所完成的任务。凭经验猜测,这个[targets]大概可以用"ckeck","install"之类(也就是常见的测试和安装命令)。但是它到底是个啥玩意儿?没有任何参数的make命令是什么意思?为什么在安装LFS工具链中的Perl-5.8.8软件包时会出现"make perl utilities"这样怪异的命令?要回答这些问题必须首先理解Makefile文件中的"规则"。Makefile规则

Makefile规则包含了文件之间的依赖关系和更新此规则目标所需要的命令。一

个简单的Makefile规则是这样写的:TARGET:PREREQUISITES COMMAND TARGET 规则的目标。也就是可以被make使用的"目标"。有些目标可以没有依赖而只有动作(命令行),比如"clean",通常仅仅定义一系列删除中间文件的命令。同样,

有些目标可以没有动作而只有依赖,比如"all",通常仅仅用作"终极目标"。PREREQUISITES规则的依赖。通常一个目标依赖于一个或者多个文件。COMMAND 规则的命令行。一个规则可以有零个或多个命令行。OK!现在你明白[targets]是什么了,原来它们来自于Makefile文件中一条条规则的目标。另外,Makefile文件中第一条规则的目标被称为"终极目标",也就是你省略[targets]参数时的目标。当你查看一个实际的Makefile文件时,你会发现有些规则非常复杂,但是它都符合规则的基本格式。此外,Makefile文件中通常还包含了除规则以外的其它很多东西,不过本文只关心其中的变量。Makefile变量Makefile中的"变量"更像是C语言中的宏,代表一个文本字符串(变量的值),可以用于规则的任何部分。变量的定义很简单:VAR=VALUE;变量的引用也很简单:$(VAR)或者${VAR}。变量引用的展开过程是严格的文本替换过程,就是说变量值的字符串被精确的展开在变量被引用的地方。比如,若定义:VAR=c,那么,"$(VAR)$(VAR)-$(VAR)VAR.$(VAR)"将被展开为"c c-c VAR.c"。虽然在Makefile中可以直接使用系统的环境变量,但是也可以通过在Makefile中定

义同名变量来"遮盖"系统的环境变量。另一方面,我们可以在调用make时使用-e参数强制使系统中的环境变量覆盖Makefile中的同名变量,除此之外,在

调用make的命令行上使用VAR=VALUE格式指定的环境变量也可以覆盖

Makefile中的同名变量。Makefile实例下面看一个简单的、实际的Makefile

文件:CC=gccCPPFLAGS=CFLAGS=-O2-pipeLDFLAGS=-sPREFIX=/usrall:prog1 prog2prog1:prog1.o$(CC)$(LDFLAGS)-o prog1 prog1.oprog1.o:

prog1.c$(CC)-c$(CFLAGS)prog1.cprog2:prog2.o$(CC)$(CFLAGS)$(LDFLAGS)-o prog2 prog2.oprog2.o:prog2.c$(CC)-

c$(CPPFLAGS)$(CFLAGS)https://www.wendangku.net/doc/8a17382096.html,lean:rm-f*.{o,a}prog{1,2}install:prog1 prog2 if(test!-d$(PREFIX)/bin);then mkdir-p$(PREFIX)/bin;fi cp-f prog1$(PREFIX)/bin/prog1 cp-f prog2$(PREFIX)/bin/prog2check test:prog1 prog2 prog1 sample1.ref sample1.rz prog1 sample2.ref sample3.rz cmp sample1.ok sample1.rz cmp sample2.ok sample2.rz从中可以看出,make与make all以及make prog1 prog2三条命令其实是等价的。而常用的make check和make install也找到了归属。同时我们也看到了Makefile中的各种变量是如何影响编译的。针对这个特定的Makefile,你甚至可以省略安装三步曲中的make命令而直接使用make install进行安装。同样,为了使用自定义的编译参数编译prog2,我们可以使用make prog2 CFLAGS="-O3-

march=athlon64"或CFLAGS="-O3-march=athlon64"&&make-e prog2命令达到此目的。Makefile惯例下面是Makefile中一些约定俗成的目标名称及其含义:all编译整个软件包,但不重建任何文档。一般此目标作为默认的终极目标。此目标一般对所有源程序的编译和连接使用"-g"选项,以使最终的可执行程序中包含调试信息。可使用strip程序去掉这些调试符号。clean清除当前目录下在make过程中产生的文件。它不能删除软件包的配置文件,也不能删除build时创建的那些文件。distclean类似于"clean",但增加删除当前目录下的的配置文件、build过程产生的文件。info产生必要的Info文档。check或test完成所有的自检功能。在执行检查之前,应确保所有程序已经被创建(但可以尚未安装)。为了进行测试,需要实现在程序没有安装的情况下被执行的测试命令。install完成程序的编译并将最终的可执行程序、库文件等拷贝到指定的目录。此种安装一般不对可执行程序进行strip操作。install-strip和"install"类似,但是会对复制到安装目录下的可执行文件进行strip操作。uninstall删除所有由"install"安装的文件。installcheck执行安装检查。在执行安装检查之前,需要确保所有程序已经被创建并且被安装。installdirs 创建安装目录及其子目录。它不能更改软件的编译目录,而仅仅是创建程序的安装目录。下面是Makefile中一些约定俗成的变量名称及其含义:这些约定俗成的变量分为三类。第一类代表可执行程序的名字,例如CC代表编译器这个可执行程序;第二类代表程序使用的参数(多个参数使用空格分开),例如CFLAGS 代表编译器执行时使用的参数(一种怪异的做法是直接在CC中包含参数);第三类代表安装目录,例如prefix等等,含义简单,下面只列出它们的默认值。AR 函数库打包程序,可创建静态库.a文档。默认是"ar"。AS汇编程序。默认是"as"。CC C编译程序。默认是"cc"。CXX C++编译程序。默认是"g++"。CPP

C/C++预处理器。默认是"$(CC)-E"。FC Fortran编译器。默认是"f77"。PC Pascal语言编译器。默认是"pc"。YACC Yacc文法分析器。默认是"yacc"。ARFLAGS函数库打包程序的命令行参数。默认值是"rv"。ASFLAGS汇编程序的命令行参数。CFLAGS C编译程序的命令行参数。CXXFLAGS C++编译程序的命令行参数。CPPFLAGS C/C++预处理器的命令行参数。FFLAGS Fortran编译器的命令行参数。PFLAGS Pascal编译器的命令行参数。YFLAGS Yacc文法分析器的命令行参数。LDFLAGS链接器的命令行参数。

prefix/usr/localexec_prefix$(prefix)bindir$(exec_prefix)/binsbindir$( exec_prefix)/sbinlibexecdir$(exec_prefix)/libexecdatadir$(prefix)/sha

resysconfdir$(prefix)/etcsharedstatedir$(prefix)/comlocalstatedir$(pr efix)/varlibdir$(exec_prefix)/libinfodir$(prefix)/infoincludedir$(pre fix)/includeoldincludedir$(prefix)/includemandir$(prefix)/mansrcdir

需要编译的源文件所在的目录,无默认值make选项最后说说make的命令行选

项(以Make-3.81版本为准):-B,--always-make无条件的重建所有规则的目标,而不是根据规则的依赖关系决定是否重建某些目标文件。-C DIR,--

directory=DIR在做任何动作之前先切换工作目录到DIR,然后再执行make程序。-d在make执行过程中打印出所有的调试信息。包括:make认为那些文件

需要重建;那些文件需要比较它们的最后修改时间、比较的结果;重建目标所

要执行的命令;使用的隐含规则等。使用该选项我们可以看到make构造依赖关系链、重建目标过程的所有信息,它等效于"-debug=a"。--debug=FLAGS在

make执行过程中打印出调试信息。FLAGS用于控制调试信息级别:a输出所有

类型的调试信息b输出基本调试信息。包括:那些目标过期、是否重建成功过

期目标文件。v除b级别以外还包括:解析的makefile文件名,不需要重建文

件等。i除b级别以外还包括:所有使用到的隐含规则描述。j输出所有执行命令的子进程,包括命令执行的PID等。m输出make读取、更新、执行makefile 的信息。-e,--environment-overrides使用系统环境变量的定义覆盖Makefile 中的同名变量定义。-f FILE,--file=FILE,--makefile=FILE将FILE指定为Makefile文件。-h,--help打印帮助信息。-i,--ignore-errors忽略规则命令

执行过程中的错误。-I DIR,--include-dir=DIR指定包含Makefile文件的搜

索目录。使用多个"-I"指定目录时,搜索目录按照指定顺序进行。-j[N],--

jobs[=N]指定并行执行的命令数目。在没有指定"-j"参数的情况下,执行的命

令数目将是系统允许的最大可能数目。-k,--keep-going遇见命令执行错误时

不终止make的执行,也就是尽可能执行所有的命令,直到出现致命错误才终止。-l[N],--load-average[=N],--max-load[=N]如果系统负荷超过LOAD(浮点数),不再启动新任务。-L,--check-symlink-times同时考察符号连接的时间戳和它

所指向的目标文件的时间戳,以两者中较晚的时间戳为准。-n,--just-print,--dry-run,--recon只打印出所要执行的命令,但并不实际执行命令。-o

FILE,--old-file=FILE,--assume-old=FILE即使相对于它的依赖已经过期也不

重建FILE文件;同时也不重建依赖于此文件任何文件。-p,--print-data-base 命令执行之前,打印出make读取的Makefile的所有数据(包括规则和变量的值),同时打印出make的版本信息。如果只需要打印这些数据信息,可以使用

make-qp命令。查看make执行前的预设规则和变量,可使用命令make– p-

f/dev/null。-q,--question"询问模式"。不运行任何命令,并且无输出,只是返回一个查询状态。返回状态为0表示没有目标需要重建,1表示存在需要重

建的目标,2表示有错误发生。-r,--no-builtin-rules取消所有内嵌的隐含规则,不过你可以在Makefile中使用模式规则来定义规则。同时还会取消所有支持后追规则的隐含后缀列表,同样我们也可以在Makefile中使用".SUFFIXES"

定义我们自己的后缀规则。此选项不会取消make内嵌的隐含变量。-R,--no-builtin-variables取消make内嵌的隐含变量,不过我们可以在Makefile中

明确定义某些变量。注意,此选项同时打开了"-r"选项。因为隐含规则是以内

嵌的隐含变量为基础的。-s,--silent,--quiet不显示所执行的命令。-S,--

no-keep-going,--stop取消"-k"选项。在递归的make过程中子make通过MAKEFLAGS变量继承了上层的命令行选项。我们可以在子make中使用"-S"选项

取消上层传递的"-k"选项,或者取消系统环境变量MAKEFLAGS中的"-k"选项。-t,--touch更新所有目标文件的时间戳到当前系统时间。防止make对所有过时

目标文件的重建。-v,--version打印版本信息。-w,--print-directory在

make进入一个目录之前打印工作目录。使用"-C"选项时默认打开这个选项。--

no-print-directory取消"-w"选项。可以是用在递归的make调用过程中,取消"-C"参数将默认打开"-w"。-W FILE,--what-if=FILE,--new-file=FILE,--assume-new=FILE设定FILE文件的时间戳为当前时间,但不改变文件实际的最

后修改时间。此选项主要是为实现了对所有依赖于FILE文件的目标的强制重建。--warn-undefined-variables在发现Makefile中存在对未定义的变量进行引

用时给出告警信息。此功能可以帮助我们调试一个存在多级套嵌变量引用的复

杂Makefile。但是:我们建议在书写Makefile时尽量避免超过三级以上的变

量套嵌引用。configure此阶段的主要目的是生成Makefile文件,是最关键的

运筹帷幄阶段,基本上所有可以对安装过程进行的个性化调整都集中在这一步。configure脚本能够对Makefile中的哪些内容产生影响呢?基本上可以这么说:所有内容,包括本文最关心的Makefile规则与Makefile变量。那么又是哪些

因素影响着最终生成的Makefile文件呢?答曰:系统环境和配置选项。配置选

项的影响是显而易见的。但是"系统环境"的概念却很宽泛,包含很多方面内容,不过我们这里只关心环境变量,具体说来就是将来会在Makefile中使用到的环境变量以及与Makefile中的变量同名的环境变量。通用configure语法在进一步讲述之前,先看看configure脚本的语法,一般有两种:

configure[OPTIONS][VAR=VALUE].configure[OPTIONS][HOST]不管是哪种语法,我们都可以用configure--help查看所有可用的[OPTIONS],并且通常在结尾部分还能看到这个脚本所关心的环境变量有哪些。在本文中将对这两种语法进行

合并,使用下面这种简化的语法:configure[OPTIONS]这种语法能够被所有的configure脚本所识别,同时也能通过设置环境变量和使用特定的[OPTIONS]完

成上述两种语法的一切功能。通用configure选项虽然每个软件包的

configure脚本千差万别,但是它们却都有一些共同的选项,也基本上都遵守

相同的选项语法。脚本自身选项--help显示帮助信息。--version显示版本信息。--cache-file=FILE在FILE文件中缓存测试结果(默认禁用)。--no-

create configure脚本运行结束后不输出结果文件,常用于正式编译前的测试。--quiet,--silent不显示脚本工作期间输出的"checking."消息。目录选项--srcdir=DIR源代码文件所在目录,默认为configure脚本所在目录或其父目录。--prefix=PREFIX体系无关文件的顶级安装目录PREFIX,默认值一般是

/usr/local或/usr/local/pkgName--exec-prefix=EPREFIX体系相关文件的顶

级安装目录EPREFIX,默认值一般是PREFIX--bindir=DIR用户可执行文件的存

放目录DIR,默认值一般是EPREFIX/bin--sbindir=DIR系统管理员可执行目录DIR,默认值一般是EPREFIX/sbin--libexecdir=DIR程序可执行目录DIR,默

认值一般是EPREFIX/libexec--datadir=DIR通用数据文件的安装目录DIR,默

认值一般是PREFIX/share--sysconfdir=DIR只读的单一机器数据目录DIR,默

认值一般是PREFIX/etc--sharedstatedir=DIR可写的体系无关数据目录DIR,

默认值一般是PREFIX/com--localstatedir=DIR可写的单一机器数据目录DIR,默认值一般是PREFIX/var--libdir=DIR库文件的安装目录DIR,默认值一般是EPREFIX/lib--includedir=DIR C头文件目录DIR,默认值一般是

PREFIX/include--oldincludedir=DIR非gcc的C头文件目录DIR,默认值一般是/usr/include--infodir=DIR Info文档的安装目录DIR,默认值一般是PREFIX/info--mandir=DIR Man文档的安装目录DIR,默认值一般是

PREFIX/man体系结构选项玩交叉编译的朋友对这些选项已经很熟悉了,并且对

于通常的交叉编译情况而言,HOST==BUILD!=TARGET。但是对于不使用交叉编

译的朋友也不必担心,将它们三个都设为相同即可。--host=HOST运行工具链

的机器,默认是config.guess脚本的输出结果。--build=BUILD用来建立工具

链的机器,默认值是HOST--target=TARGET工具链所生成的二进制代码最终运

行的机器,默认值是HOST特性选项--enable-FEATURE启用FEATURE特性--

disable-FEATURE禁用FEATURE特性--with-PACKAGE[=DIR]启用附加软件包PACKAGE,亦可同时指定PACKAGE所在目录DIR--without-PACKAGE禁用附加软件包PACKAGE通用环境变量除了上述通用的选项外,下列环境变量影响着最终生成的Makefile文件:CPP C预处理器命令CXXCPP C++预处理器命令CPPFLAGS C/C++预处理器命令行参数CC C编译器命令CFLAGS C编译器命令行参数CXX C++编译器命令CXXFLAGS C++编译器命令行参数LDFLAGS连接器命令行参数至于设置这些环境变量的方法,你可以将它们export为全局变量在全局范围内使用,也可以在命令行上使用[VAR=VALUE].configure[OPTIONS]的语法局部使用。此处就不详细描述了。

记录激动时刻,赢取超级大奖!点击链接,和我一起参加"2010:我的世界杯Blog日志"活动!

特别声明:

1:资料来源于互联网,版权归属原作者

2:资料内容属于网络意见,与本账号立场无关

3:如有侵权,请告知,立即删除。

Linux内核修改与编译图文教程

Linux 内核修改与编译图文教程 1

1、实验目的 针对Ubuntu10.04中,通过下载新的内核版本,并且修改新版本内核中的系统调用看,然后,在其系统中编译,加载新内核。 2、任务概述 2.1 下载新内核 https://www.wendangku.net/doc/8a17382096.html,/ 2.2 修改新内核系统调用 添加新的系统调用函数,用来判断输入数据的奇偶性。 2.3 进行新内核编译 通过修改新版内核后,进行加载编译。最后通过编写测试程序进行测试 3、实验步骤 3.1 准备工作 查看系统先前内核版本: (终端下)使用命令:uname -r 2

3.2 下载最新内核 我这里使用的内核版本是 3.3 解压新版内核 将新版内核复制到“/usr/src”目录下 在终端下用命令:cd /usr/src进入到该文件目录 解压内核:linux-2.6.36.tar.bz2,在终端进入cd /usr/src目录输入一下命令: bzip2 -d linux-2.6.36.tar.bz2 tar -xvf linux-2.6.36.tar 文件将解压到/usr/src/linux目录中 3

使用命令: ln -s linux-2.6.36 linux 在终端下输入一下命令: sudo apt-get install build-essential kernel-package libncurses5-dev fakeroot sudo aptitude install libqt3-headers libqt3-mt-dev libqt3-compat-headers libqt3-mt 4

如何自行编译一个Linux内核的详细资料概述

如何自行编译一个Linux内核的详细资料概述 曾经有一段时间,升级Linux 内核让很多用户打心里有所畏惧。在那个时候,升级内核包含了很多步骤,也需要很多时间。现在,内核的安装可以轻易地通过像 apt 这样的包管理器来处理。通过添加特定的仓库,你能很轻易地安装实验版本的或者指定版本的内核(比如针对音频产品的实时内核)。 考虑一下,既然升级内核如此容易,为什么你不愿意自行编译一个呢?这里列举一些可能的原因: 你想要简单了解编译内核的过程 你需要启用或者禁用内核中特定的选项,因为它们没有出现在标准选项里 你想要启用标准内核中可能没有添加的硬件支持 你使用的发行版需要你编译内核 你是一个学生,而编译内核是你的任务 不管出于什么原因,懂得如何编译内核是非常有用的,而且可以被视作一个通行权。当我第一次编译一个新的Linux 内核(那是很久以前了),然后尝试从它启动,我从中(系统马上就崩溃了,然后不断地尝试和失败)感受到一种特定的兴奋。 既然这样,让我们来实验一下编译内核的过程。我将使用Ubuntu 16.04 Server 来进行演示。在运行了一次常规的 sudo apt upgrade 之后,当前安装的内核版本是 4.4.0-121。我想要升级内核版本到 4.17,让我们小心地开始吧。 有一个警告:强烈建议你在虚拟机里实验这个过程。基于虚拟机,你总能创建一个快照,然后轻松地从任何问题中回退出来。不要在产品机器上使用这种方式升级内核,除非你知道你在做什么。 下载内核 我们要做的第一件事是下载内核源码。在 Kernel 找到你要下载的所需内核的URL。找到URL 之后,使用如下命令(我以 4.17 RC2 内核为例)来下载源码文件: wget https://git.kernel/torvalds/t/linux-4.17-rc2.tar.gz

嵌入式Linux系统内核的配置、编译和烧写

实验二 嵌入式Linux系统内核的配置、编译和烧写 1.实验目的 1)掌握交叉编译的基本概念; 2)掌握配置和编译嵌入式Linux操作系统内核的方法; 3)掌握嵌入式系统的基本架构。 2.实验环境 1)装有Windows系统的计算机; 2)计算机上装有Linux虚拟机软件; 3)嵌入式系统实验箱及相关软硬件(各种线缆、交叉编译工具链等等)。 3.预备知识 1)嵌入式Linux内核的配置和裁剪方法; 2)交叉编译的基本概念及编译嵌入式Linux内核的方法; 3)嵌入式系统的基本架构。 4.实验内容和步骤 4.1 内核的配置和编译——配置内核的MMC支持 1)由于建立交叉编译器的过程很复杂,且涉及汇编等复杂的指令,在这里 我们提供一个制作好的编译器。建立好交叉编译器之后,我们需要完成 内核的编译,首先我们要有一个完整的Linux内核源文件包,目前流行 的源代码版本有Linux 2.4和Linux 2.6内核,我们使用的是Linux 2.6内核; 2)实验步骤: [1]以root用户登录Linux虚拟机,建立一个自己的工作路径(如用命令 “mkdir ‐p /home/user/build”建立工作路径,以下均采用工作路径 /home/user/build),然后将“cross‐3.3.2.tar.bz2、dma‐linux‐2.6.9.tar.gz、 dma‐rootfs.tar.gz”拷贝到工作路径中(利用Windows与虚拟机Linux 之间的共享目录作为中转),并进入工作目录; [2]解压cross‐3.3.2.tar.bz2到当前路径:“tar ‐jxvf cross‐3.3.2.tar.bz2”; [3]解压完成后,把刚刚解压后在当前路径下生成的“3.3.2”文件夹移 动到“/usr/local/arm/”路径下,如果在“/usr/local/”目录下没有“arm” 文件夹,用户创建即可; [4]解压“dma‐linux‐2.6.9.tar.gz”到当前路径下:

linux内核配置模块编译安装

Linux内核配置编译和加载 Linux内核模块 Linux内核结构非常庞大,包含的组件也非常多,想要把我们需要的部分添加到内核中,有两个方法:直接编译进内核和模块机制 由于直接编译进内核有两个缺点,一是生成的内核过大,二是每次修改内核中功能,就必须重新编译内核,浪费时间。因此我们一般采用模块机制,模块本身不被编译进内核映像,只有在加载之后才会成为内核的一部分,方便了修改调试,节省了编译时间。 配置内核 (1)在drivers目录下创建hello目录存放hello.c源文件 (2)在hello目录下新建Makefile文件和Kconfig文件 Makefile文件内容: obj-y += hello.o //要将hello.c编译得到的hello.o连接进内核 Kconfig文件内容: 允许编译成模块,因此使用了tristate (3)在hello目录的上级目录的Kconfig文件中增加关于新源代码对应项目的编译配置选项 修改即driver目录下的Kconfig文件,添加

source "drivers/hello/Kconfig" //使hello目录下的Kconfig起作用 (4)在hello目录的上级目录的Makefile文件中增加对新源代码的编译条目 修改driver目录下的Makefile文件,添加 obj-$(CONFIG_HELLO_FOR_TEST) += hello/ //使能够被编译命令作用到 (5)命令行输入“make menuconfig”,找到driver device,选择select,发现test menu 已经在配置菜单界面显示出来 (6)选择test menu进入具体的配置,可以选择Y/N/M,这里我选择编译为M,即模块化 (7)保存退出后出现 (8)进入kernels目录中使用“ls -a”查看隐藏文件,发现多出.config隐藏文件,查看.config 文件

linux、内核源码、内核编译与配置、内核模块开发、内核启动流程

linux、内核源码、内核编译与配置、内核模块开发、内核启动流程(转) linux是如何组成的? 答:linux是由用户空间和内核空间组成的 为什么要划分用户空间和内核空间? 答:有关CPU体系结构,各处理器可以有多种模式,而LInux这样的划分是考虑到系统的 安全性,比如X86可以有4种模式RING0~RING3 RING0特权模式给LINUX内核空间RING3给用户空间 linux内核是如何组成的? 答:linux内核由SCI(System Call Interface)系统调用接口、PM(Process Management)进程管理、MM(Memory Management)内存管理、Arch、 VFS(Virtual File Systerm)虚拟文件系统、NS(Network Stack)网络协议栈、DD(Device Drivers)设备驱动 linux 内核源代码 linux内核源代码是如何组成或目录结构? 答:arc目录存放一些与CPU体系结构相关的代码其中第个CPU子目录以分解boot,mm,kerner等子目录 block目录部分块设备驱动代码 crypto目录加密、压缩、CRC校验算法 documentation 内核文档 drivers 设备驱动 fs 存放各种文件系统的实现代码 include 内核所需要的头文件。与平台无关的头文件入在include/linux子目录下,与平台相关的头文件则放在相应的子目录中 init 内核初始化代码 ipc 进程间通信的实现代码 kernel Linux大多数关键的核心功能者是在这个目录实现(程序调度,进程控制,模块化) lib 库文件代码 mm 与平台无关的内存管理,与平台相关的放在相应的arch/CPU目录net 各种网络协议的实现代码,注意而不是驱动 samples 内核编程的范例 scripts 配置内核的脚本 security SElinux的模块 sound 音频设备的驱动程序 usr cpip命令实现程序 virt 内核虚拟机 内核配置与编译 一、清除 make clean 删除编译文件但保留配置文件

史上最全linux内核配置详解

对于每一个配置选项,用户可以回答"y"、"m"或"n"。其中"y"表示将相应特性的支持或设备驱动程序编译进内核;"m"表示将相应特性的支持或设备驱动程序编译成可加载模块,在需要时,可由系统或用户自行加入到内核中去;"n"表示内核不提供相应特性或驱动程序的支持。只有<>才能选择M 1. General setup(通用选项) [*]Prompt for development and/or incomplete code/drivers,设置界面中显示还在开发或者还没有完成的代码与驱动,最好选上,许多设备都需要它才能配置。 [ ]Cross-compiler tool prefix,交叉编译工具前缀,如果你要使用交叉编译工具的话输入相关前缀。默认不使用。嵌入式linux更不需要。 [ ]Local version - append to kernel release,自定义版本,也就是uname -r可以看到的版本,可以自行修改,没多大意义。 [ ]Automatically append version information to the version string,自动生成版本信息。这个选项会自动探测你的内核并且生成相应的版本,使之不会和原先的重复。这需要Perl的支持。由于在编译的命令make-kpkg 中我们会加入- –append-to-version 选项来生成自定义版本,所以这里选N。 Kernel compression mode (LZMA),选择压缩方式。 [ ]Support for paging of anonymous memory (swap),交换分区支持,也就是虚拟内存支持,嵌入式不需要。 [*]System V IPC,为进程提供通信机制,这将使系统中各进程间有交换信息与保持同步的能力。有些程序只有在选Y的情况下才能运行,所以不用考虑,这里一定要选。 [*]POSIX Message Queues,这是POSIX的消息队列,它同样是一种IPC(进程间通讯)。建议你最好将它选上。 [*]BSD Process Accounting,允许进程访问内核,将账户信息写入文件中,主要包括进程的创建时间/创建者/内存占用等信息。可以选上,无所谓。 [*]BSD Process Accounting version 3 file format,选用的话统计信息将会以新的格式(V3)写入,注意这个格式和以前的v0/v1/v2 格式不兼容,选不选无所谓。 [ ]Export task/process statistics through netlink (EXPERIMENTAL),通过通用的网络输出工作/进程的相应数据,和BSD不同的是,这些数据在进程运行的时候就可以通过相关命令访问。和BSD类似,数据将在进程结束时送入用户空间。如果不清楚,选N(实验阶段功能,下同)。 [ ]Auditing support,审计功能,某些内核模块需要它(SELINUX),如果不知道,不用选。 [ ]RCU Subsystem,一个高性能的锁机制RCU 子系统,不懂不了解,按默认就行。 [ ]Kernel .config support,将.config配置信息保存在内核中,选上它及它的子项使得其它用户能从/proc/ config.gz中得到内核的配置,选上,重新配置内核时可以利用已有配置Enable access to .config through /proc/config.gz,上一项的子项,可以通过/proc/ config.gz访问.config配置,上一个选的话,建议选上。 (16)Kernel log buffer size (16 => 64KB, 17 => 128KB) ,内核日志缓存的大小,使用默认值即可。12 => 4 KB,13 => 8 KB,14 => 16 KB单处理器,15 => 32 KB多处理器,16 => 64 KB,17 => 128 KB。 [ ]Control Group support(有子项),使用默认即可,不清楚可以不选。 Example debug cgroup subsystem,cgroup子系统调试例子 Namespace cgroup subsystem,cgroup子系统命名空间 Device controller for cgroups,cgroups设备控制器

linux内核编译和生成makefile文件实验报告

操作系统实验报告 姓名:学号: 一、实验题目 1.编译linux内核 2.使用autoconf和automake工具为project工程自动生成Makefile,并测试 3.在内核中添加一个模块 二、实验目的 1.了解一些命令提示符,也里了解一些linux系统的操作。 2.练习使用autoconf和automake工具自动生成Makefile,使同学们了解Makefile的生成原理,熟悉linux编程开发环境 三、实验要求 1使用静态库编译链接swap.c,同时使用动态库编译链接myadd.c。可运行程序生成在src/main目录下。 2要求独立完成,按时提交 四、设计思路和流程图(如:包括主要数据结构及其说明、测试数据的设计及测试结果分析) 1.Makefile的流程图: 2.内核的编译基本操作 1.在ubuntu环境下获取内核源码 2.解压内核源码用命令符:tar xvf linux- 3.18.12.tar.xz 3.配置内核特性:make allnoconfig 4.编译内核:make 5.安装内核:make install

6.测试:cat/boot/grub/grub.conf 7.重启系统:sudo reboot,看是否成功的安装上了内核 8.详情及结构见附录 3.生成makefile文件: 1.用老师给的projec里的main.c函数。 2.需要使用automake和autoconf两个工具,所以用命令符:sudo apt-get install autoconf 进行安装。 3.进入主函数所在目录执行命令:autoscan,这时会在目录下生成两个文件 autoscan.log和configure.scan,将configure.Scan改名为configure.ac,同时用gedit打开,打开后文件修改后的如下: # -*- Autoconf -*- # Process this file with autoconf to produce a configure script. AC_PREREQ([2.69]) AC_INIT([FULL-PACKAGE-NAME], [VERSION], [BUG-REPORT-ADDRESS]) AC_CONFIG_SRCDIR([main.c]) AC_CONFIG_HEADERS([config.h]) AM_INIT_AUTOMAKE(main,1.0) # Checks for programs. AC_PROG_CC # Checks for libraries. # Checks for header files. # Checks for typedefs, structures, and compiler characteristics. # Checks for library functions. AC_OUTPUT(Makefile) 4.新建Makefile文件,如下: AUTOMAKE_OPTIONS=foreign bin_PROGRAMS=main first_SOURCES=main.c 5.运行命令aclocal 命令成功之后,在目录下会产生aclocal.m4和autom4te.cache两个文件。 6.运行命令autoheader 命令成功之后,会在目录下产生config.h.in这个新文件。 7.运行命令autoconf 命令成功之后,会在目录下产生configure这个新文件。 8.运行命令automake --add-missing输出结果为: Configure.ac:11:installing./compile’ Configure.ac:8:installing ‘.install-sh’ Configure.ac:8:installing ‘./missing’ Makefile.am:installing ‘./decomp’ 9. 命令成功之后,会在目录下产生depcomp,install-sh和missing这三个新文件和执行下一步的Makefile.in文件。 10.运行命令./configure就可以自动生成Makefile。 4.添加内核模块

Linux内核配置编译与文件系统构建要点

Linux内核配置编译与文件系统构建 南京大学 黄开成101180046 2012.11.11 一:实验目的 1.了解嵌入式系统的开发环境,内核与文件系统的下载和启动; 2.了解Linux内核源代码的目录结构及各自目录的相关内容,了解Linux内核各配置选项内容和作用,掌握Linux内核的编译过程; 3.了解嵌入式操作系统中文件系统的类型和应用、了解JFFS2文件系统的优点及其在嵌入式系统中的作用、掌握利用Busybox软件制作嵌入式文件系统的方法,并且掌握嵌入式Linux文件系统的挂载过程。二:实验环境说明 1.PC机使用openSUSE 14 Enterprise 系统。 2.开发板使用深圳市武耀博德信息技术有限公司生产的基于Inter 的PXA270处理器的多功能嵌入式开发平台EELIOD。 3.PC机通过RS-232串口与开发板相连,在PC机终端上运行minicom 程序构造一个开发板上的终端,用于对开发板的控制。 4.PC机与开发板通过ethernet网络相连接,并可在开发板上通过加载网络文件系统(NFS)与PC机通信。 5.Bootloader可以通过tftp协议从PC机上下载内核镜像和根文件系统镜像。下载目录为/tftpboot 。 6.用于开发板的Linux内核源码为linux-2.4.21-51Board_EDR,

busybox版本为busybox-1.00-pre5。 7.交叉编译器的路径为/usr/local/arm-linux/bin/arm-linux。 三:实验操作过程和分析记录 1.嵌入式系统的开发环境和开发流程: 1.1启动minicom和开发板 在PC机上打开一个终端,输入: >minicom 按Ctrl+A-o进入minicom的configuration界面。对串行通信接口进行配置,串口设置为:/dev/ttyS0(串口线接在PC机的串口1上)、bps=115200、8位数据、无校验、无流控制。 然后打开开发板电源,看到屏幕有反应之后,按任意键进入配置界面,如果长时间没有按下任何键,bootloader将会自动从flash中读取内核和根文件系统并启动开发板上的Linux系统。 分析:嵌入式系统中,通常并没有像PC机中BIOS 那样的固件程序,因此整个系统的加载启动任务完全由bootloader来完成。bootloader的主要作用是:初始化硬件设备;建立内存空间的映射图;完成内核的加载,为内核设置启动参数。 按0进入命令行模式,出现51board>,可以设置开发板和PC机的IP 地址: 51board> set myipaddr 192.168.208.133(设置开发板的IP地址) 51board> set destipaddr 192.168.208.33(设置PC机的IP地址)注意IP地址的设置:使其处于同一网段,并且避免和其他系统的

linux2.6内核的编译步骤及模块的动态加载-内核源码学习-linux论坛

[原创]linux2.6内核的编译步骤及模块的动态加载-内核源码 学习-linux论坛 05年本科毕业设计做的是Linux下驱动的剖析,当时就买了一本《Linux设备驱动程序(第二版)》,但是没有实现将最简单的helloworld程 序编译成模块,加载到kernel里。不过,现在自己确实打算做一款芯片的Linux的驱动,因此,又开始看了《Linux设备驱动程序》这本书,不过已 经是第三版了。第二版讲的是2.4的内核,第三版讲的是2.6的内核。两个内核版本之间关于编译内核以及加载模块的方法都有所变化。本文是基于2.6的内核,也建议各位可以先看一下《Linux内核设计与实现(第二版)》作为一个基础知识的铺垫。当然,从实践角度来看,只要按着以下的步骤去做也应该可以实现成功编译内核及加载模块。个人用的Linux版本为:Debian GNU/Linux,内核版本为:2.6.20-1-686.第一步,下载Linux内核的源代码,即构建LDD3(Linux Device Drivers 3rd)上面所说的内核树。 如过安装的Linux系统中已经自带了源代码的话,应该在/usr/src目录下。如果该目录为空的话,则需要自己手动下载源代码。下载代码的方法和链接很多,也可以在CU上通过

https://www.wendangku.net/doc/8a17382096.html,/search/?key=&;q=kernel&a mp;frmid=53去下载。不过,下载的内核版本最好和所运行的Linux系统的内核版本一致。当然,也可以比Linux系统内核的版本低,但高的话应该不行(个人尚未实践)。 Debian下可以很方便的通过Debian源下载: 首先查找一下可下载的内核源代码: # apt-cache search linux-source 其中显示的有:linux-source-2.6.20,没有和我的内核版本完全匹配,不过也没关系,直接下载就可以了: # apt-get install linux-source-2.6.20 下载完成后,安装在/usr/src下,文件名为: linux-source-2.6.20.tar.bz2,是一个压缩包,解压缩既可以得到整个内核的源代码: # tar jxvf linux-source-2.6.20.tar.bz2

配置和编译Linux内核

配置和编译Linux内核 对内核进行正确配置后,才能进行编译。配置不当的内核,很有可能编译出错,或者不能正确运行。 1.1.1 快速配置内核 进入Linux内核源码数顶层目录,输入make menuconfig命令,可进入如图0.1所示的基于Ncurses的Linux内核配置主界面(注意:主机须安装ncurses相关库才能正确运行该命令并出现配置界面)。如果没有在Makefile中指定ARCH,则须在命令行中指定: $ make ARCH=arm menuconfig 图0.1基于Ncurses的Linux内核配置主界面 基于Ncurses的Linux内核配置界面不支持鼠标操作,必须用键盘操作。基本操作方法: ?通过键盘的方向键移动光标,选中的子菜单或者菜单项高亮; ?按TAB键实现光标在菜单区和功能区切换; ?子菜单或者选项高亮,将光标移功能区选中