ROS软路由论坛 ROSABC.com 网络方案网络工程交流

 找回密码
 会员注册

QQ登录

只需一步,快速开始

嵌入式linux启动信息完全注释

2014-3-26 02:08| 发布者: admin| 查看: 568| 评论: 0

摘要:   摘要:我们在这里讨论的是对嵌入式linux系统的启动过程的输出信息的注释,通过我们的讨论,大家会对嵌入式linux启动过程中出现的、以前感觉熟悉的、但却又似是而非的东西有一个确切的了解,并且能了解到这些输出 ...

  摘要:我们在这里讨论的是对嵌入式linux系统的启动过程的输出信息的注释,通过我们的讨论,大家会对嵌入式linux启动过程中出现的、以前感觉熟悉的、但却又似是而非的东西有一个确切的了解,并且能了解到这些输出信息的来龙去脉。

  我们在这里讨论的是对嵌入式linux系统的启动过程的输出信息的注释,通过我们的讨论,大家会对嵌入式linux启动过程中出现的、以前感觉熟悉的、但却又似是而非的东西有一个确切的了解,并且能了解到这些输出信息的来龙去脉。

  嵌入式linux的启动信息是一个很值得我们去好好研究的东西,它能将一幅缩影图呈现在我们面前,来指导我们更加深入地理解linux内核。

  正文

  作为一名嵌入系统开发者,你一定遇到过下面的情景:

  在某论坛上看到一篇帖子,贴着嵌入式linux开发板启动时的有关信息,然后大家在帖子里讨论着这个启动过程中出现的问题,随机举例如下:

  的这些输出信息,也可能包括你自己正在做的嵌入式linux开发板的输出信息,其中的每一行,每一个字的含义,你是否深究过,或者说大部分的含义你能确切地知道的?本人想在这里结合本人在实践中一些体会来和广大嵌入式linux的开发者一起读懂这些信息。

  我们在这里将以一个真实的嵌入式linux系统的启动过程为例,来分析这些输出信息。启动信息的原始内容将用标记标出,以区别与注释。

  #P#嵌入式linux的启动主要分为两个阶段:

  ②第二部分linux内核初始化和启动阶段

  第三节:加载linux内核完毕,转入cpu_idle进程

  Bootloader头信息,版本,编译时间等,这个因不同的bootloader的设计而有所不同,由此你能看出bootloader的版本信息,有很多使用的是通用的bootloader,如u-boot,redboot等。

  查找到了启动boot的配置信息

  从flash中启动代码,此处的flash为并行闪存。Flash的分类列举如下:

  闪存分三类:并行,串行,不可擦除。

  NORFlash,Intel于1988年发明.随机读取的速度比较快,随机按字节写,每次可以传输8Bit。一般适合应用于数据/程序的存贮应用中.NOR还可以片内执行(execute-in-place)XIP.写入和擦除速度很低。

  NANDFlash,1989年,东芝公司发明.是以块和页为单位来读写的,不能随机访问某个指定的点.因而相对来说读取速度较慢,而擦除和写入的速度则比较快,每次可以传输16Bit,一般适用在大容量的多应用中,容量大。如:CF,SM.

  ②串行SerialFlash是以字节进行传输的,每次可以传输1-2Bit.如:MMC,SD,MS卡.串行闪存器件体积小,引脚也少,成本相对也更低廉。

  ③不可擦除MaskRomFlash的特点是一次性录入数据,具有不可更改性,经常运用于游戏和需版权文件等的录入。其显著特点是成本低。

  注意:任何flash器件的写入操作只能在空或已擦除的单元内进行,所以大多数情况下,在进行写入操作之前必须先执行擦除。NAND器件执行擦除操作是十分简单的,而NOR则要求在进行擦除前先要将目标块内所有的位都写为0。

  从的信息,我们可以对flash类型特点有个比较明确的了解。

  开发板上所使用的CPU的主频为200MHZ.

  动态内存ram大小为128M。这里我们列举一下内存的类型及工作原理。

  根据内存的工作原理可以划分出两种内存:DRAM和SRAM

  ①DRAM表示动态随机存取存储器。这是一种以电荷形式进行存储的半导体存储器。DRAM中的每个存储单元由一个晶体管和一个电容器组成。数据存储在电容器中。电容器会由于漏电而导致电荷丢失,因而DRAM器件是不稳定的。为了将数据保存在存储器中,DRAM器件必须有规律地进行刷新。

  ②SRAM是静态的,因此只要供电它就会保持一个值。一般而言,SRAM比DRAM要快,这是因为SRAM没有刷新周期。每个SRAM存储单元由6个晶体管组成,而DRAM存储单元由一个晶体管和一个电容器组成。相比而言,DRAM比SRAM每个存储单元的成本要高。照此推理,可以断定在给定的固定区域内DRAM的密度比SRAM的密度要大。

  SRAM常常用于高速缓冲存储器,因为它有更高的速率;而DRAM常常用于PC中的主存储器,因为其拥有更高的密度。

  在嵌入式系统中使用DRAM内存的设计比较广泛。

  地址辅助说明:

  先说明一下内存地址数字情况,主要是为了方便记忆。

  可以访问的内存为4G。

  这个是个快速记忆的方法,你可以根据地址中1的和其后0的个数来快速知道换算后的地址是在多少兆的地方。比如,1的后面5个0,代表1M的大小,6个0,代表16M,以此类推。

  卷名为rom。

  romfs中包括kernel和app应用,不包括bootloader和firmware信息头。romfs只读文件系统里的内容有很多种分类方法,我们可以将kernel和app同时放里面,作为根文件系统下的一个文件,也可以在flash上另外划分区域来分别存放。

  VFS虚拟文件系统交换器

  在linux系统中,目前已经开发出多种文件系统,那么如何让这些文件系统能共存在一个系统中呢,从linux2.0开始,引入了虚拟文件系统管理器VFS的概念。

  Linux下的文件系统主要可分为三大块:

  ①一是上层的文件系统的系统调用,

  ③三是挂载到VFS中的各实际文件系统,例如ext2,jffs等。

  VFS的确切叫法是VirtualFilesystemSwitch虚拟文件系统交换器,这里的VFS中的“S”是指的switch,这个需要强调一下的,它很容易被混淆成“system”,如果理解成“system”将是不正确的,请多加注意。

  VFS是具体文件系统filesystem的一个管理器。

  VFS是Linux内核中的一个软件层,一种软件机制,它也提供了内核中的一个抽象功能,允许不同的文件系统共存,可以称它为Linux的文件系统管理者,与它相关的数据结构只存在于物理内存当中。所以在每次系统初始化期间,Linux都首先要在内存当中构造一棵VFS的目录树。VFS中的各目录其主要用途是用来提供实际文件系统的挂载点。而rootfs将是这个目录树的根结点的(root),即/目录,VFS的结构就是从这个rootfs开始的。有了VFS,那么对文件的操作将使用统一的接口,将来通过文件系统调用对VFS发起的文件操作等指令将被rootfs文件系统中相应的函数接口所接管。

  注意:rootfs并不是一个具体的文件系统类型,如jffs。它只是一个理论上的概念。在具体的嵌入系统实例中,可以将某种具体的文件系统设置为根文件系统rootfs,如我们可以设置romfs为根文件系统,也可以设置jffs为根文件系统。

  这里的ROMFS只读文件系统只是一种具体的文件系统类型,也是在嵌入系统中经常使用到的类型。

  看完了的内容,以后你对出现的类似“kernelPanic:VFS:Unabletomountrootfson0:00”的含义应该已经了解了。其中“VFS:”就是虚拟文件系统管理器操作时的输出信息了。

  linuxkernel内核文件名,它是在只读文件系统romfs上的一个组成部分。

  将romfs中的linuxkernel解压缩到0x90090000,之后会从这个内存地址启动内核。romfs为压缩格式文件,使用压缩的只读文件系统,是为了保持制作出来的整个系统所占用的flash空间减小。这个内核的大小为1.3M左右,这也是目前大多数嵌入系统所使用的方法。

  ,解压中。。。(变大,充气,膨胀)

  做后的CRC检查

  kernel已经被从romfs中到内存地址0x90090000处,可以跳转到此处启动kernel了,这里是指定的kernel的起始地址

  系统等待启动,后面将看到linuxkernel的启动过程了。

  #P#第二部分:linux内核初始化以及启动

  Linux的源代码可以从

  得到,或者你可以查看linux代码交叉引用网站:

  进行在线的代码查看,这是一个很好的工具网站。

  在start_kernel中将调用到大量的init函数,来完成内核的各种初始化。如:

  具体内容可以参考[

  的代码输出信息,是linux代码分析后得到的,进入init目录下的main.c的start_kernel启动函数.

  bootloader经过内存映射后的地址为:0x10000fc0,按的地址换算方法,1后面有7个0,那么虚拟地址256M左右处。

  pT110是ARM微处理器arm核的一种,另一种为pT100。此处为显示ARM的类型。

  Kernel启动命令设为:/dev/mtdblock3(在后面的说明中会看到mtdblock3是指的flash上的romfs分区。),用来指定根文件系统所在的,kernel会将块设备mtdblock3当作文件系统来处理。

  也就是说,内核会根据的kernel命令行,知道只读文件系统romfs将是根文件系统rootfs。

  这行命令是在linux内核启动过程中都会输出的一句。

  代码中console_init()的输出信息,显示控制台属性:一般使用VGAtextconsole,标准是80X25行列的文本控制台,这里是对属性进行了设置。

  串口设置值为115200,此为波特率输出信息。对串口设置的信息做一个打印的动作,在调试时会非常有用。

  Calibrate:校准,进入时延校准循环。检查CPU的MIPS(每秒百万条指令),Bogo是Bogus(伪)的意思。这里是对CPU进行一个实时测试,来得到一个大体的MIPS数值

  Bogomips,是由linusTorvalds写的,是Linux操作系统中衡量计算机处理器运行速度的一种尺度。提供这种度量的程序被称为BogoMips,当启动计算机时,BogoMips能显示系统选项是否处于最佳性能。

  linux内核中有一个函数calibrate_delay(),它可以计算出cpu在一秒钟内执行了多少次一个极短的循环,计算出来的值经过处理后得到BogoMIPS值

  你可以将计算机的bogomips与计算机处理器的bogomips进行比较。Torvalds称这个程序为BogoMips来暗示两台计算机间的性能度量是错误的,因为并非所有起作用因素都能被显示出来或被认可。尽管计算机基准中经常用到MIPS,但的变化容易导致度量的错误。Bogomips能测出一秒钟内某程序运行了多少次。

  察看/proc/cpuinfo文件中的最后一行也能得到这个数值。

  这个输出,在所有的linux系统启动中都会打印出来。

  进入内存初始化

  当前内存使用情况,将列出总的内存大小,及分配给内核的内存大小:包括代码部分,数据部分,初始化部分,总共刚好4M。请留意此处的内核的内存大小的各个值。

  进入虚拟文件系统VFS初始化

  名词:

  ①Dentry:目录数据结构

  Dentry目录数据结构(目录入口缓存),提供了一个将径名为特定的dentry的一个快的查找机制,Dentry只存在于RAM中;

  i节点(inode)数据结构存放磁盘上的一个文件或目录的信息,i节点存在于磁盘驱动器上;存在于RAM中的i节点就是VFS的i节点,dentry所包含的指针指向的就是它;

  buffercache内存缓冲区,类似kupdated,用来在内存与磁盘间做缓冲处理;

  PageCache用来加快对磁盘上映像和数据的访问。

  在内存中建立各个缓冲hash表,为kernel对文件系统的访问做准备。

  的输出信息,在一般的linux启动过程中都会看到。

  在2.6的内核中就将的这句输出给拿掉了。

  此信息,在linux启动过程中都会出现。

  此信息,在linux启动过程中都会出现。

  启动交换守护进程kswapd,进程IO操作例程kpiod

  kswapd可以配合kpiod运行。进程有时候无事可做,当它运行时也不一定需要把其所有的代码和数据都放在内存中。这就意味着我们可以通过把运行中程序不用的内容切换到交换分区来更好的是利用内存。大约每隔1秒,kswapd醒来并检查内存情况。如果在硬盘的东西要读入内存,或者内存可用空间不足,kpiod就会被调用来做移入/移出操作。kswapd负责检查,kpiod负责移动。

  加载日志块设备驱动。

  日志块设备是用来对文件系统进行日志记录的一个块设备。日志文件系统是在传统文件系统的基础上,加入文件系统更改的日志记录。

  它的设计思想是:记录文件系统的变化,并将变化内容记录入日志。日志文件系统在磁盘分区中保存有日志记录,写操作首先是对记录文件进行操作,若整个写操作由于某种原因(如系统掉电)而中断,系统重启时,会根据日志记录来恢复中断前的写操作。在日志文件系统中,所有的文件系统的变化都被记录到日志,每隔一定时间,文件系统会将更新后的元数据及文件内容写入磁盘。在对元数据做任何改变以前,文件系统驱动程序会向日志中写入一个条目,这个条目描述了它将要做些什么,然后它修改元数据。

  Devfs模块的输出信息。

  Pty模块的输出信息,与控制台操作有关的设置。

  ①TTY(/dev/tty)是TeleTYpe的一个老缩写,为用户输入提供不同控制台的设备驱动程序。它的名字来源于实际挂接到UNIX系统的、被称为电传打字机(teletype)的终端。在Linux下,这些文件提供对虚拟控制台的支持,可以通过按<Alt-F1>到<Alt-F6>键来访问这些虚拟控制台。这些虚拟控制台提供的、同时进行的本地登录对话过程

  使用makedev脚本MAKEDEV来建立pty文件。这样系统内核就支持Unix98风格的pty了。在进行Telnet登录时将要用到/dev/pty设备。pty是伪终端设备,在远程登录等需要以终端方式进行连接,但又并非真实终端的应用程序中必须使用这种设备,如telnet或xterm等程序。Linux2.2以后增添了UNIX98风格的Pty设备,它使用一个新的文件系统(devpts针对伪终端的文件系统)和一个克隆的设备cloningdevice来实现其功能。

  加载返还块设备驱动,最多支持8个设备

  RTL8139的接收径设计成一个环形缓冲区(一段线性的内存,映射成一个环形内存)。当设备接收到数据时,数据的内容就保存在这个环形缓冲区内并更新下个存储数据的地址(第一个数据包的开始地址+第一个数据包的长度)。设备会一直保留缓冲区内的数据直到整个缓冲区耗尽。这样,设备会再次重写缓冲区内起始的内容,就像一个环那样。

  USB设备信息,USB会被当做SCSI来处理。

  软中断信息输出。Tasklet是在2.4中才出现,它是为了更好地利用多CPU。

  AMD与富士通合资设立的Flash供货商Spansion。AMD因获利不佳,已经退出Flash市场,后续由Spansion合资公司经营.主要生产NOR类型的flash,特点是容量小,速度快。Spansion商标的flash,在我们开发中会经常看到。以后大家看到Spansion的芯片,就能了解到它和AMD还有富士通的来龙去脉了。

  使用flash写缓冲方式

  fast路由器设置网站flash提供了写BUFFER的命令来加快对flash上块的操作。对Flash擦除和写数据是很慢的。如果用写BUFFER的命令会快一点。据手册上说,会快20倍。BufferSize:5bytes的buffer缓冲不是每个块都有,是整个flash只有一个5bytes的buffer,用写BUFFER命令对所有的块进行写操作,都要用同一个buffer,写Buffer是主要检查buffer是否available,其实buffer起缓冲作用,来提高工作效率。

  比如某flash有128个128K字节块。允许用户对任意块进行字节编程和写缓冲器字节编程操作,每字节编程时间为210μs;若采用写缓冲器字节编程方式,32字节编程共需218μs,每字节编程时间仅为6.8μs。芯片的块擦除时间为1s,允许在编程或块擦除操作的同时进行悬挂中断去进行读操作,待读操作完成后,写入悬挂恢复命令,再继续编程或块擦除。

  此处为重要信息部分,需要特别留意。

  在内存中映射过的flash,创建三个MTD分区:

  flash上的内容将被映射到内存中的对应地址

  的内容,大家可以根据前面的换算公式得到。

  B>在此处就知道了配置信息config是放在第2分区中的;

  C>制作的romfs的大小,一般为8M或10M左右,所以能放得下;

  嵌入式Linux内核的块设备驱动:

  对于linux的根文件系统,目前有三种块设备的驱动可以选择,它们分别是:

  Blkmem驱动是专门为嵌入式linux开发的一种块设备驱动,它是嵌入式linux系统中最为古老和通用的块设备驱动。它原理相对简单但是配置比较复杂,需要根据你即的Flash的分区使用情况来修改代码。当然修改的结果是它可以对一些NOR型的Flash进行读写操作。不过目前支持的Flash类型不够多。如果新加入对一种Flash的支持需要作的工作量比较大。

  Linux的MTD驱动是标准Linux的Flash驱动。它支持大量的设备,有足够的功能来定义Flash的分区,进行地址映射等等。使用MTD你可以在一个系统中使用不同类型的Flash。它可以将不同的Flash组合成一个线性的地址让你来使用。

  在标准的Linux2.4内核中MTD有一系列的选项,你可以根据个人系统的需要来选择,定制。

  另外一种选择就是RAMdisk驱动。在PC上它经常用于没有硬盘的Linux的启动过程。它和Flash没有直接的关系。不过当Flash上启动的是经过压缩的内核时。RAMdisk可以作为根文件系统。

  MTD驱动提供了对Flash强大的支持,你通过它甚至可以在Flash上运行一个可以读写的真正的文件系统,比如JFFS2。而Blkmem驱动则望尘莫及。

  在linux启动过程中,都会看到这句的输出。

  IP由代码的输出信息。

  UNIX网络协议信息。

  的关于网络的输出信息是在linux启动信息中都会出现的。

  加载各种文件系统

  会出现“cramfs:wrongmagic”,别担心这没有什么害处,这个是kernel的书写bug,在2.6中有修改之,它是一个信息,用来检查cramfs的superblock超级块的。superblock也是VFS要用到的数据结构。

  超级块是文件系统的“头部”。它包含文件系统的状态、尺寸和空闲磁盘块等信息。如果损坏了一个文件系统的超级块(例如不小心直接将数据写到了文件系统的超级块分区中),那么系统可能会完全不识别该文件系统,这样也就不能安装它了,即使采用e2fsck命令也不能处理这个问题。

  cramfs是LinusTorvalds本人开发的一个适用于嵌入式系统的小文件系统。由于它是只读的,所以,虽然它采取了zlib做压缩,但是它还是可以做到高效的随机读取。cramfs不会影响系统读取文件的速度,又是一个高度压缩的文件系统。

  我们制作image文件之后,我们还要考虑怎样才能在系统运行的时候,把这个image文件mount上来,成为一个可用的文件系统。由于这个image文件不是一个通常意义上的block设备,我们必须采用loopback设备来完成这一任务,如:

  cramfs的压缩效率一般都能达到将近50%。

  Cramfs通过优化索引节点表的尺寸和除去传统文件系统中文件之间的空间浪费来达到节约空间的目的。它还使用了zlib压缩,实现优于2:1的压缩比例。解压缩过程的系统开销并不是很大,因为Cramfs支持指定单块的解压,而并不必解压缩整个文件。

  Cramfs不仅能节省空间,还能避免非正常关机导致的等待fsck或手工进行fsck的麻烦。它通过只读的方式达到这一目的。

  RamDisk有三种实现方式:

  在Linux中可以将一部分内存mount为分区来使用,通常称之为RamDisk,分为:

  ①第一种就是传统意义上的,可以格式化,然后加载。

  这在Linux内核2.0/2.2就已经支持,其不足之处是大小固定,之后不能改变。

  为了能够使用Ramdisk,我们在编译内核时须将blockdevice中的Ramdisk支持选上,它下面还有两个选项,一个是设定Ramdisk的大小,默认是4096k;另一个是initrd的支持。

  如果对Ramdisk的支持已经编译进内核,我们就可以使用它了:

  ②另两种则是内核2.4才支持的,通过Ramfs或者Tmpfs来实现:

  它们不需经过格式化,用起来灵活,其大小随所需要的空间而增加或减少。

  Ramfs顾名思义是内存文件系统,它处于虚拟文件系统(VFS)层,而不像ramdisk那样基于虚拟在内存中的其他文件系统(ex2fs)。

  因而,它无需格式化,可以创建多个,只要内存足够,在创建时可以指定其最大能使用的内存大小。

  如果你的Linux已经将Ramfs编译进内核,你就可以很容易地使用Ramfs了。创建一个目录,加载Ramfs到该目录即可:

  缺省情况下,Ramfs被最多可使用内存大小的一半。可以通过maxsize(以kbyte为单位)选项来改变。

  ③Tmpfs是一个虚拟内存文件系统,它不同于传统的用块设备形式来实现的Ramdisk,也不同于针对物理内存的Ramfs。

  Tmpfs可以使用物理内存,也可以使用交换分区。在Linux内核中,虚拟内存资源由物理内存(RAM)和交换分区组成,这些资源是由内核中的虚拟内存子系统来负责分配和管理。

  Tmpfs向虚拟内存子系统请求页来存储文件,它同Linux的其它请求页的部分一样,不知道分配给自己的页是在内存中还是在交换分区中。同Ramfs一样,其大小也不是固定的,而是随着所需要的空间而动态的增减。

  然后就可以加载tmpfs文件系统了:

  同样可以在加载时指定tmpfs文件系统大小的最大:

  具体的文件系统FAT格式。

  UMSDOS:一种文件系统,特点容量大但相对而言不大稳定。是Linux使用的扩展了的DOS文件系统。它在DOS文件系统下增加了长文件名、UID/GID、POSIX权限和特殊文件(设备、命名管道等)功能,而不对DOS的兼容性。允许一个普通的msdos文件系统用于Linux,而且无须为它建立单独的分区,特别适合早期的硬盘空间不足的硬件条件。

  再次强调一下一个概念。VFS是一种软件机制,也可称它为Linux的文件系统管理者,它是用来管理实际文件系统的挂载点,目的是为了能支持多种文件系统。kernel会先在内存中建立一颗VFS目录树,是内存中的一个数据对象,然后在其下挂载rootfs文件系统,还可以挂载其他类型的文件系统到某个子目录上。

  加载devfs设备管理文件系统到dev安装点上。

  /dev是我们经常会用到的一个目录。

  在2.4的kernel中才有使用到。每次启动时内核会自动挂载devfs。

  devfs提供了访问内核设备的命名空间。它并不是建立或更改设备节点,devfs只是为你的特别文件系统进行。一般我们可以手工mknod创件设备节点。/dev目录最初是空的,里面特定的文件是在系统启动时、或是加载模组后驱动程序载入时建立的。当模组和驱动程序卸载时,文件就消失了。

  1号用户进程init所占用的内存。

  第三节:加载linux内核完毕,转入cpu_idle进程

  系统启动过程中进程情况:

  一般来说,系统在跑完kernelbootstrapping内核引导自举后(被装入内存、已经开始运行、已经初始化了所有的设备驱动程序和数据结构等等),就去运行init『万process之父』,有了它,才能开始跑其他的进程,因此,init进程,它是内核启动的第一个用户级进程,它的进程号总是1。

  你可以用进程查看命令来验证

  init有许多很重要的任务,比如象启动getty(用于用户登录)、实现运行级别、以及处理孤立进程。

  init一开始就去读/etc/inittab(init初始化表),初始化表是按一定格式排列的关于进程运行时的有关信息的。init程序需要读取/etc/inittab文件作为其行为指针。这个inittab中对于各个runlevel运行级别要跑哪些rc或spawn生出什么有很清楚的设定。

  一般,在Linux中初始化脚本在/etc/inittab文件(或称初始化表)中可以找到关于不同运行级别的描述。inittab是以行为单位的描述性(非执行性)文本,每一个指令行都是固定格式

  inittab中有respawn项,但如果一个命令运行时失败了,为了避免重运行的频率太高,init将追踪一个命令重运行了多少次,并且如果重运行的频率太高,它将被延时五分钟后再运行。

  这些进程就是内核守护进程。大部分内核并不显示在进程列。守护进程在init之后启动,所以他们和其他进程一样有进程ID,但是他们的代码和数据都存放在内核占有的内存中。在列表中使用中括号来区别与其他进程。

  B>输入和输出是通过内存中的缓冲来完成的,这让事情变得更快,程序的写入会存放在内存缓冲中,然后再一起写入硬盘。守护进程kflushd和kupdate管理这些工作。kupdate间断的工作(每5秒)来检查是否有写过的缓冲,如过有,就让kflushd把它们写入磁盘。

  C>进程有时候无事可做,当它运行时也不一定需要把其所有的代码和数据都放在内存中。这就意味着我们可以通过把运行中程序不用的内容切换到交换分区来更好的是利用内存。把这些进程数据移入/移出内存通过进程IO管理守护进程kpiod和交换守护进程kswapd,大约每隔1秒,kswapd醒来并检查内存情况。如果在硬盘的东西要读入内存,或者内存可用空间不足,kpiod就会被调用来做移入/移出操作。

  D>bdflush-BUF_DIRTY,将dirty缓存写回到磁盘的核心守护进程。对于有许多脏的缓冲区(包含必须同时写到磁盘的数据的缓冲区)的系统提供了动态的响应。它在系统启动的时候作为一个核心线程启动,它叫自己为“kflushd”,而这是你用ps显示系统中的进程的时候你会看得的名字。即定期(5秒)将脏(dirty)缓冲区的内容写入磁盘,以腾出内存;

  E>ksoftirqd_CPUx是一个死循环,负责处理软中断的。它是用来对软中断队列进行缓冲处理的进程。当发生软中断时,系统并不急于处理,只是将相应的cpu的中断状态结构中的active的相应的位,置位,并将相应的处理函数挂到相应的队列,然后等待调度时机来临,再来处理.

  F>keventd,它的任务就是执行scheduler调度器队列中的任务,keventd为它运行的任务提供了可预期的进程上下文。

  G>khubd,是用来检测USBhub设备的,当usb有动态插拔时,将交由此内核进程来处理。在检测到有hub事件时会有相应的动作(usb_hub_events())

  NAND的特点是不能在芯片内执行(XIP,eXecuteInPlace),需要把代码读到系统RAM中再执行,传输效率不是最高,最大擦写次数量为一百万次,但写入和擦除的速度很快,擦除单元小,是高数据存储密度的最佳选择。

  NAND需要I/O接口,因此使用时需要驱动程序。

  loopback设备和其他的块设备的使用方法相同。特别的是,可以在该设备上建立一个文件系统,然后利用mount命令把该系统映射到某个目录下以便访问。这种整个建立在一个普通磁盘文件上的文件系统,就是虚拟文件系统(virtualfilesystem)。

  总结:

  的内容是本人为了在实际开发中更加清楚地了解嵌入式linux的启动过程而做的一个总结性的文章。

  在对嵌入式linux的启动过程做了一个详细注释后,大家会对涉及到嵌入系统的各个概念有了一个更加明确的认识,并能对嵌入系统的软硬件的有关设置更加清楚。当你自己动手结合linux源代码来分析时,将会有一个清楚的全局观。

  现在,你如果再回头去看文章前面所列出的启动信息例子中的内容,其中80%的内容,你现在应该能看懂它的来龙去脉了。

  【编辑推荐】

不良信息举报Q:2000617
新用户7天后可回帖!

软路由

不良信息举报Q:2000617|Archiver|ROS软路由论坛 ROSABC.com 网络方案网络工程交流

GMT+8, 2025-11-6 18:52 , Processed in 0.035175 second(s), 15 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

返回顶部