皮皮网

【桥接模式源码】【苹果app 源码】【element ui源码】linuxrc源码

2024-11-18 23:45:35 来源:arrayblockqueue 源码

1.终端模拟器禁止安装软件命令
2.Linux9.01 不能识别 SATA 硬盘
3.用 BusyBox 构建根文件系统

linuxrc源码

终端模拟器禁止安装软件命令

       free

       1.作用

       free命令用来显示内存的使用情况,使用权限是所有用户。

       2.格式

       free[-b|-k|-m][-o][-sdelay][-t][-V]

       3.主要参数

       -b-k-m:分别以字节(KB、MB)为单位显示内存使用情况。

       -sdelay:显示每隔多少秒数来显示一次内存使用情况。

       -t:显示内存总和列。桥接模式源码

       -o:不显示缓冲区调节列。

       4.应用实例

       free命令是用来查看内存使用情况的主要命令。和top命令相比,它的优点是使用简单,并且只占用很少的系统资源。通过-S参数可以使用free命令不间断地监视有多少内存在使用,这样可以把它当作一个方便实时监控器。

       #free-b-s5

       使用这个命令后终端会连续不断地报告内存使用情况(以字节为单位),每5秒更新一次。

       Android系统在超级终端下必会的命令大全(一)

       busybox

       BusyBox是标准Linux工具的一个单个可执行实现。BusyBox包含了一些简单的工具,例如cat和echo,还包含了一些更大、更复杂的工具,例如grep、苹果app 源码find、mount以及telnet。有些人将BusyBox称为Linux工具里的瑞士军刀.简单的说BusyBox就好像是个大工具箱,它集成压缩了Linux的许多工具和命令。

       1、BusyBox的诞生

       BusyBox最初是由BrucePerens在年为DebianGNU/Linux安装盘编写的。其目标是在一张软盘上创建一个可引导的GNU/Linux系统,这可以用作安装盘和急救盘。

       2、busybox的用法

       可以这样用busybox

       #busyboxls

       他的功能就相当运行ls命令

       最常用的用法是建立指向busybox的链接,不同的链接名完成不同的功能.

       #ln-sbusyboxls

       #ln-sbusyboxrm

       #ln-sbusyboxmkdir

       然后分别运行这三个链接:

       #./ls

       #./rm

       #./mkdir

       就可以分别完成了lsrm和mkdir命令的功能.虽然他们都指向同一个可执行程序busybox,但是只要链接名不同,完成的功能就不同,很多linux网站都提供busybox的源代码下载。。

       3、配置busybox

       busybox的配置程序和linux内核菜单配置方式简直一模一样.熟悉用makemenuconfig方式配置linux内核的朋友很容易上手.

       #cpbusybox-1..tar.gz/babylinux

       #cd/babylinux

       #tarxvfzbusybox-1..tar.gz

       #cdbusybox-1.

       #makemenuconfig

       下面是需要编译进busybox的功能选项。

       GeneralConfiguration应该选的选项

       Showverboseappletusagemessages

       RuntimeSUID/SGIDconfigurationvia/etc/busybox.conf

       BuildOptions

       BuildBusyBoxasastaticbinary(nosharedlibs)

       这个选项是一定要选择的,这样才能把busybox编译成静态链接的可执行文件,运行时才独立于其他函数库.否则必需要其他库文件才能运行,在单一个linux内核不能使它正常工作.

       InstallationOptions

       Don’tuse/usr

       这个选项也一定要选,否则makeinstall后busybox将安装在原系统的/usr下,这将覆盖掉系统原有的命令.选择这个选项后,makeinstall后会在busybox目录下生成一个叫_install的目录,里面有busybox和指向它的链接.

       其它选项都是一些linux基本命令选项,自己需要哪些命令就编译进去,一般用默认的就可以了,配置好后退出并保存。

       保存。

       4、编译并安装busybox

       #make

       #makeinstall

       编译好后在busybox目录下生成子目录_install,element ui源码里面的内容:

       drwxr-xr-x2rootroot月:bin

       rwxrwxrwx1rootroot月:linuxrc->bin/busybox

       drwxr-xr-x2rootroot月:sbin

       其中可执行文件busybox在bin目录下,其他的都是指向他的符号链接.

       Android系统在超级终端下必会的命令大全(二)一、安装和登录命令

       reboot1.作用

       reboot命令的作用是重新启动计算机,它的使用权限是系统管理者。

       2.格式

       reboot[-n][-w][-d][-f][-i]

       3.主要参数

       -n:在重开机前不做将记忆体资料写回硬盘的动作。

       -w:并不会真的重开机,只是把记录写到/var/log/wtmp文件里。

       -d:不把记录写到/var/log/wtmp文件里(-n这个参数包含了-d)。

       -i:在重开机之前先把所有与网络相关的装置停止。

       mount

       1.作用

       mount命令的作用是加载文件系统,它的用权限是超级用户或/etc/fstab中允许的使用者。

       2.格式

       mount-a[-fv][-tvfstype][-n][-rw][-F]devicedir

       3.主要参数

       -h:显示辅助信息。

       -v:显示信息,通常和-f用来除错。

       -a:将/etc/fstab中定义的所有文件系统挂上。

       -F:这个命令通常和-a一起使用,它会为每一个mount的动作产生一个行程负责执行。在系统需要挂上大量NFS文件系统时可以加快加载的速度。

       -f:通常用于除错。它会使mount不执行实际挂上的动作,而是模拟整个挂上的过程,通常会和-v一起使用。劫持注入源码

       -tvfstype:显示被加载文件系统的类型。

       -n:一般而言,mount挂上后会在/etc/mtab中写入一笔资料,在系统中没有可写入文件系统的情况下,可以用这个选项取消这个动作。

       4.应用技巧

       在Linux和Unix系统上,所有文件都是作为一个大型树(以/为根)的一部分访问的。要访问CD-ROM上的文件,需要将CD-ROM设备挂装在文件树中的某个挂装点。如果发行版安装了自动挂装包,那么这个步骤可自动进行。在Linux中,如果要使用硬盘、光驱等储存设备,就得先将它加载,当储存设备挂上了之后,就可以把它当成一个目录来访问。挂上一个设备使用mount命令。在使用mount这个指令时,至少要先知道下列三种信息:要加载对象的线程结束源码文件系统类型、要加载对象的设备名称及要将设备加载到哪个目录下。

       (1)Linux可以识别的文件系统

       ◆Windows/常用的FAT文件系统:vfat;

       ◆WinNT/的文件系统:ntfs;

       ◆OS/2用的文件系统:hpfs;

       ◆Linux用的文件系统:ext2、ext3;

       ◆CD-ROM光盘用的文件系统:iso。

       虽然vfat是指FAT系统,但事实上它也兼容FAT的文件系统类型。

       (2)确定设备的名称

       在Linux中,设备名称通常都存在/dev里。这些设备名称的命名都是有规则的,可以用“推理”的方式把设备名称找出来。例如,/dev/hda1这个

       IDE设备,hd是HardDisk(硬盘)的,sd是SCSIDevice,fd是FloppyDevice(或是Floppy

       Disk?)。a代表第一个设备,通常IDE接口可以接上4个IDE设备(比如4块硬盘)。所以要识别IDE硬盘的方法分别就是hda、hdb、hdc、

       hdd。hda1中的“1”代表hda的第一个硬盘分区

       (partition),hda2代表hda的第二主分区,第一个逻辑分区从hda5开始,依此类推。此外,可以直接检查/var/log/messages文件,在该文件中可以找到计算机开机后系统已辨认出来的设备代号。

       (3)查找挂接点

       在决定将设备挂接之前,先要查看一下计算机是不是有个/mnt的空目录,该目录就是专门用来当作挂载点(MountPoint)的目录。建议在/mnt里建几个/mnt/cdrom、/mnt/floppy、/mnt/mo等目录,当作目录的专用挂载点。举例而言,如要挂载下列5个设备,其执行指令可能如下(假设都是Linux的ext2系统,如果是WindowsXX请将ext2改成vfat):

       软盘===>mount-text2/dev/fd0/mnt/floppy

       cdrom===>mount-tiso/dev/hdc/mnt/cdrom

       SCSIcdrom===>mount-tiso/dev/sdb/mnt/scdrom

       SCSIcdr===>mount-tiso/dev/sdc/mnt/scdr

       不过目前大多数较新的Linux发行版本(包括红旗Linux、中软Linux、MandrakeLinux等)都可以自动挂装文件系统,但RedHatLinux除外。

Linux9. 不能识别 SATA 硬盘

       è¿™æ˜¯æ¥è‡ª IBM developerworks 的一个非常好的文章可以清楚地解释如何启动火线和USB设备 Linux操作系统的原理。

       å¸Œæœ›å®ƒåœ¨å¯¹ä»»ä½•æœ‰å…´è¶£æŠŠLinux操作系统安装到外部设备的人有所帮助。

       åŽŸå§‹çš„网址/developerwor...l-fireboot.html

       ä»Žç«çº¿è®¾å¤‡ä¸Šå¯åŠ¨Linux

       å¯ç§»åŠ¨é©±åŠ¨å™¨ä¸Šå®‰è£…Linux操作系统

       éš¾åº¦ç­‰çº§ï¼šä¸­ç­‰

       Martyn Honeyford(martynh@uk.ibm.com) IBM英国实验室 软件工程师

       å®£å¯è¾¾(austin.dada@gmail.com)翻译 webzi@linuxsir

       å¹´7月日

       å¹´7月日开始翻译,7月日完成。

       ç¿»è¯‘经验不多。如有不妥,欢迎EMAIL交流。

       ä½¿ç”¨ä¸€ä¸ªå¤–部驱动器是一个极棒的方法,能给你的老硬件带来新生和让你在你不能(或者不想)改变内置硬盘的计算机上使用Linux系统。

       å‡è®¾ä½ æƒ³ä½¿ç”¨Linux在一个双启动环境,但是你的计算机硬盘又没有任何空余的空间。一种解决方法是使用"live"的linux发行版本象是Knoppix,他们这能直接从CD启动运行。 对于偶尔使用,这是一种可行的办法,但是它有若干的劣势:

       *你将会仍然需要些固定文件存储。如果你只是操作少量的文件,一张1.MB的磁盘就可以胜任,或者一个USB闪存棒适合中等量的文件,但是这些都不够理想。

       *当使用一个LiveCD 的时候,最困难、最糟糕、最不可能的是安装你自己的应用程序或者定制现存的程序。

       *使用LiveCD在性能上的牺牲,在启动初所有的设备检测时尤为明显,同样发生使用中(所有的文件从 CD 载入通常是比从硬盘中载入慢的多)。

       çš„确,还有其他可选方案。举例来说,你可以买额外的内置驱动器并且在此安装Linux操作系统。但是常常,你可能没有任何空闲的扩展阜。(这特别容易发生在笔记本上,通常他们只允许一个内置硬盘。)

       æˆ–者,你可以使用一个较大的硬盘取代当前的硬盘, 获得额外空间用于安装 Linux操作系统。 然而,这的确是一个耗费大量时间的方案,需要你重新安装现有的操作系统在新的硬盘, 重新安装和配置你所有应用程序, 和恢复所有数据。

       æ›´å¥½çš„解决方案是购买一个外置硬盘并安装 Linux操作系统。 这样使得你在想使用Linux系统时候不必涉及现有的硬件和软件而只是简单连接外部驱动器。

       å¯é€‰çš„可移动设备

       å¯ç”¨äºŽå®‰è£…Linux操作系统设备涵盖磁盘驱动器、USB-闪存设备、通过USB/火线连接的硬盘等等。

       åœ¨ä¸€ä¸ªå°å®¹é‡çš„设备中安装linux是可行的,例如在一个1.MB的磁盘或者一个MB的USB棒中,他们通常(必须)为特定目的定制,采用裁减的发行版本,例如,拯救中断的安装过程。

       å¤–置的硬盘在为使用一个常规目的的linux系统提供最大的灵活性同时,带来一个合理的成本。

       è®¸å¤šä¸åŒçš„厂商提供许多种不同容量的外置的驱动器。 (Maxtor, 西西部数据, 等等)。这些驱动器还会包含一个外置盒子,用于固定标准的 3-1/2 寸或 2-1/2 寸 IDE 硬盘。 然后这些驱动器经由 USB 或 IEEE(火线) 连接到计算机。

       USB 受到在二个主要的版本中的影响,1.1 和 2.0. 1.1 版速度为 Mbit/ s(每秒1Mbit) ,而 2.0 版支持最高达到 Mbit/s 的传输速度。 大多数2.0相容的驱动器也向后兼容1.1,通常建议尽量不要采用1.1接口除非没有其他的选择(因为其低速不适应此环境。)

       ç«çº¿æ ‡å‡†ä¹Ÿå®šä¹‰è‹¥å¹²ä¸åŒçš„速度, 实际上,大部分人所指的FireWire ,是“FireWire”标准 ,支持最大传输速度为 Mbit/s 。

       USB2.0和火线在速度上不分伯仲: 虽然 USB 2.0 有比较高的传输速度, 但是实际中因为协议的不同两者速度十分的接近。 如果你的计算机拥有2种接口, 最好使用USB而非火线(理由我将后将解释), 但是如果只有火线接口,当然你就选择它了。为了实现最大的灵活性, 可以选择众多同时支持 USB 2.0 和火线的驱动器中的一种。(像我稍后将在这一个文章中使用的那个一样。)

       å¯¹äºŽé‚£äº›æ²¡æœ‰å¿…须的接口, PCI(对于桌面) 和 PCMCIA(对于笔记本型电脑) ,现在火线和USB 2.0扩展卡也并非贵不可及: 举例来说, 我稍后将在文章中提及PCMCIA火线扩展卡大约为英镑.($ 美元以下)

       ä¸ºäº†è¾¾åˆ°æœ¬æ–‡çš„目的,我已经购买 5-1/4寸外置驱动器的硬盘盒。 这是一件非常灵活的硬盘盒,并没提供驱动器而且能固定任何的标准 IDE 设备,包括 3-1/2 寸驱动器和像CD-RW/DVD-RW等5-1/4 寸 IDE 设备 。硬盘盒兼有 USB 2.0 和火线接口。

       ä¸ºäº†æŠŠç¡¬ç›˜ç›’连接到我的IBM Thinkpad T笔记本电脑,我也购买了一个 PCMCIA 火线转接卡。 ( 因为内置的USB 接口只支持USB 1.1)

       ç¡¬ç›˜ç›’和火线转接卡相对比较便宜。 (大约分别为英镑和英镑。)

       æµ‹è¯•æœŸé—´, 我把一个手边闲置的 GB 3-1/2 寸 IDE 硬盘放进硬盘盒——对于真实情况,我会买一个较大的容量驱动器, 现在另购一个硬盘相当低廉( 大约每个英镑!)

       Linux 支持

       æ­£å¦‚你所期待,linux对这些硬盘盒支持的确非常好。任何遵从SBP(串行总线协议)标准的大储存设备在linux中使用非常简单。

       å¤§ä½“上, 使对这些装置的支持你能够将会需要在你的核心中支持某些选项( 或直接地编译或通过模块。)

       å¯¹äºŽUSB和火线,SBP 装置通过SCSI模拟来实现-- 也就是说,Linux会把他们当作SCSI硬盘来处理 。 这是在 Linux 世界里面使用存储设备的一个常规方法。 ( 举例来说, IDE CD/DVD设备通常通过SCSI模拟来连接)。基于以上原因,下列的选项需要被内核支持:

       * SCSI support

       * SCSI emulation

       * SCSI disk support

       é™¤æ­¤ä¹‹å¤–,不同连接方式需要一下的内核支持:

       * 针对火线:

       * IEEE support

       * OHCI support

       * RAW support

       * SBP-2 support

       * 针对USB:

       *(host-side) USB support

       * OHCI support

       * UHCI support

       * USB mass-storage support

       æ˜Žæ˜¾åœ°ï¼Œä½ è¿˜å¿…须为其他的硬件 ( 如显卡等等)编译常规的支持, 而且可能需要一些额外的模块,取决你的具体硬件。

       ä¸¾ä¾‹æ¥è¯´ï¼Œæˆ‘正在使用 PCMCIA(cardbus) 火线转接卡,因此,我还需要增加:

       * PCMCIA support

       * cardbus support

       å®‰è£…

       çŽ°åœ¨æˆ‘们有很完美外置驱动器,我们将开始安装在其安装Linux美妙之旅。

       ç›®å‰æœ€ç®€å•çš„安装linux方法(当然仅个人意见) , 是连接你的所有硬件;(我的情况是,插入火线转接卡,连上转接线盒驱动器,然后打开驱动器的电源) 然后从你选择的发行版安装CD上启动你的计算机。

       æˆ‘采用的发行版是Gentoo(资源详见链接),因此,我用了最新的 “通用”x LiveCD。 (.1) 其他的发行版本必须的步骤大致和此相似。

       ä¸€æ—¦ä½ ä½¿ç”¨å®‰è£…CD启动,要藉由一点运气让他要辨认出你的驱动器。 磁盘应该出现在/dev/sdX, X 是一个小写字母从“a”开始。 在我的系统上,外置硬盘被当做 /dev/sda, 但是如果你有其他的 SCSI硬盘,这数字将会改变;( 或模拟了SCSI硬盘) 那种情况下,它可能是 /dev/sdb 或一些其他的字母。 如果你的驱动器不能被自动检测到, 就需要进一步采取措施 -- 举例来说,你可能必须打开启动选项使用火线或者PCMCIA接口, 或你可能必须手动装载一些内核模块 , 或其他一类选项。 (资源详见故障发现与维修指导链接)

       ä¸€æ—¦é©±åŠ¨å™¨è¢«è¾¨è®¤å‡ºæ¥ï¼Œå®‰è£…过程种其运作起来就像一个内置的硬盘。然后就你可以对其分区并且用常规方法安装linux。

       æœ‰ä¸€å¥è¯æˆ‘着重要提醒,小心选择何处安装boot loader(通常是GRUB和LILO)--我建议不要装到主引导记录(MBR)中( 通常是默认值) 而是装到外置驱动器的根分区 ( 或/boot分区,如果你单独分了一个话)。

       æ—¢ç„¶æˆ‘们已经安装 Linux 在这个设备上,我们想要从上面启动它。 事情到此开始变的有点复杂了。

       å¯åŠ¨

       åœ¨æˆ‘前讨论在如何的新驱动器上面启动,我要讲解一些boot loader的小知识。

       boot loader程序通常安装在计算机的第一个硬盘的MBR上。 当boot loader被调用 (BIOS自动地运行MBR里的代码),它通常显示一份可启动操作系统的菜单。以便选择一个给定的操作系统启动计算机。

       ä¸¤ä»¶ç»†èŠ‚在这个章节中应该注意:

       * 操作系统选择菜单(通常)从磁盘中载入。

       *为了启动有关的操作系统, boot loader 需要从磁盘中读取相关的内核。

       åœ¨æ“ä½œç³»ç»Ÿè¢«è£…载之前 ,以上各步骤已经执行,这意味着所有的磁盘读取在BIOS调用时。 这是一个必须的前提,即,为了直接启动磁盘,你的 BIOS必须支持通过火线或USB被连接的磁盘。通常能在BIOS中看到关于从这些设备上启动选项。 火线BIOS支持现在的确非常的少见,但是 USB 支持正在变得相当的平常。 因此,如果你正在使用一部相对比较新的计算机上的USB接口,应该可以直接启动驱动器进Linux。

       å½“经由 USB 连接,在安装外部的驱动器的 MBR 的幼虫之后,我能够直接地启动它。 当以被连接的磁盘片启动的时候,只是进入 BIOS 装备公用程序。 外部的磁盘片将会出现如一个一般的硬盘: 移动它,如此它在启动次序中的内在驱动器之前。

       æˆ‘也能够在一个内置的硬盘的MBR上安装一个boot loader而且使用其启动USB硬盘(在GRUB中被成为hd1)。 如果你正在使用火线, 有可能你的 BIOS 将会无法直接地启动硬盘,而且你需要更多一点步骤。

       å¹¸è¿çš„是,由于 Linux 的多样性,这有非常容易解决,如果你不能直接地启动,( 我就是这样的情况,使用一个PCMCIA转接卡!) 你能运行初始启动步骤,来自一个支持的设备 , 像是一台软驱,CD-ROM,USB棒,或在主硬盘上的小分区, 然后使用外部的驱动器继续其他步骤。

       åˆ›å»ºä¸€ä¸ªå¯åŠ¨é•œåƒ

       æˆ‘们有2种方法启动:

       *单阶启动

       å†…核启动, 挂载根分区文件系统, 接着调用初始化教本继续初始化( 通常是/sbin/init)

       *双阶启动 (initrd)的启动

       å†…核启动,挂载一个初始ram disk (initrd),进一步运行定制的初始化, 然后挂载根分区文件系统继续初始化(同样, 通常调用/sbin/init)

       æ¯ç§æ–¹æ³•éƒ½æœ‰å®ƒè‡ªå·±çš„优点和缺点。

       å•é˜¶å¯åŠ¨

       ä¸ºäº†è¦ä½¿ç”¨ä¸€ä¸ªå•é˜¶çš„启动,我们需要建立一个内核包含挂载一个根分区文件系统所需的所有驱动程序。( 任何其他的驱动能作为模块编译并在根分区载入时候进行常规初始化。)

       å¦‚果我们正在从像软盘这样的一个非常小的装置尝试启动, 最好的方式是创建的一个正合适内核,编译进所有挂载根外部分区系统所需驱动 -- 而且编译其他的作为模块。 举例来说,我的内核编译进了SCSI支持, PCMCIA 支持, IEE , SBP ,和其他相似的支持, 但是其他的(包括显卡支持,网络设备支持,等等)当做模块编译并储存在根分区上(在外部的驱动器的),而不是存储在软盘上。

       è¿™ç§æ–¹æ³•çš„主要问题是需要我们给内核源代码打补丁-- 那是一种最糟糕的痛苦(当新的内核发布),而真正的问题是如果补丁没有在维护,这样就不能跟上内核的变化。

       ä½ å¯èƒ½ä»¥ä¸ºå¦‚果计算机BIOS支持USB和火线直接启动,我们能避免发生以上的2个问题。 不幸地,事情不是这样:这一个方法使用BIOS在启动时调用磁盘,一旦内核开始初始化, BIOS就失去了作用,而且使用内核驱动来调用磁盘-- 所以你仍然会碰到同样的问题。

       äºŒé˜¶å¯åŠ¨

       å†…æ ¸2.0.X版本 ,添加了一个有趣的功能到内核 -- 使用“initial RAM disk(初始内存磁盘)”(or initrd)来实现二阶启动。

       ç®€è¨€ä¹‹ï¼Œå†…核一概既往的启动;挂载一个创建在内存里迷你的根分区文件系统取代挂载“真正”的根分区系统。 无论任何命令都在这个初始环境中执行在“真正”的根分区系统被挂载之前直到我们切换到真正的根分区文件系统并销毁初始内存磁盘(initial RAM disk)。

       è¿™ç‚¹åœ¨å„种环境中都非常有用,但是我们的目标仅仅是简单的利用我们的迷你环境去重新扫描SCSI总线,等待外部驱动器识别,然后用它切换到我们真正的根而后继续启动。

       ä½¿ç”¨è¿™ç§æ–¹æ³•ï¼Œæˆ‘们需要创建2个文件,一个内核和一个初始镜像文件。

       å†…核仅是一个内建启动镜像(initrd)支持常规内核。 initrd 镜像是一个包涵我们迷你根分区系统的环路(loopback)文件系统镜像。 (该镜像可以有选折地使用gzip压缩来减小它的大小)。

       ä½ èƒ½åœ¨èµ„源章节里找到关于如何创建和定制你自己的初始镜像的更多信息。

       åœ¨é•œåƒæ–‡ä»¶é‡Œï¼Œæœ‰ä¸€ä¸ªlinuxrc的文件。当镜像给载入时,该文件自动运行,所以请确定其有运行权限!为了达到我们的目的,linuxrc文件非常的简单:

       åˆ—举 1. initrd linuxrc

       #!/bin/sh

       REAL_ROOT=/dev/sda1

       # mount the /proc filesystem

       mount -t proc none /proc

       #for scsi-emulation (SCSI模拟)

       # modprobe sd_mod

       #for pcmcia (PCNCIA卡)

       # modprobe pcmcia_core

       #for FireWire (火线)

       # modprobe ieee

       # modprobe ohci

       # modprobe raw

       # modprobe sbp2

       #for USB (USB)

       # modprobe usbcore

       # modprobe ohci-hcd

       # modprobe uhci-hcd

       # modprobe usb-storage

       # loop rescanning the scsi bus + rerunning devfsd

       retries=5

       i=1

       until [ -e $REAL_ROOT ]

       do

       if [ $i -gt $retries ]

       then

       echo "Unable to mount real root ($REAL_ROOT) - Giving up!"

       /bin/ash

       exit

       fi

       echo "Real root ($REAL_ROOT) not found, retrying ($i)"

       sleep 1

       echo "scsi add-single-device 0 0 0" > /proc/scsi/scsi

       echo "scsi add-single-device 1 0 0" > /proc/scsi/scsi

       echo "scsi add-single-device 2 0 0" > /proc/scsi/scsi

       /bin/devfsd /dev -np

       i=$((i+1))

       done

       #umount /proc as it will be remounted by the normal init process

       ï¼ˆè§£é™¤æŒ‚è½½/proc分区当它会给常规的INIT进程重新挂载)

       umount /proc

       #now we simply exit, and the normal boot process should continue

       ï¼ˆçŽ°åœ¨æˆ‘们可以退出了,常规的启动进程将会继续)

       exit 0

       æˆ‘们正在做的是载入适当的模块去支持外部驱动器: 请按需注视相应行。 (我把所有需要的支持编译进内核,因此不需要模块)。 然后循环, 再扫描 SCSI 总线 (回应一个命令到/proc虚拟文件系统下一个特别文件并调用devfsd程序) 直到根分区设备出现(我的情况是/dev/sda1 )。在我的情况,被访问的火线模拟SCSI总线是1 0 0,但是并不影响尝试部分其他的总线 -- 如果你知道将会使用哪一个,你可以裁减这个教本。 同时, 如果你有其他的 SCSI 设备 (或模拟 SCSI设备), 驱动器可能有一个不同的字母。(例如,/dev/sdb1) 而且如果你没有使用外置驱动器上的第一个分区, 你将会需要使用一个不同的数字。( 例如,/dev/sda2)

       çŽ°åœ¨æˆ‘们需要做的全部是复制相关的文件进initrd镜像.( 你能够使用mount -o loop 命令挂载未压缩的镜像)尤其,我们需要确定我们有 linuxrc 文件、所有被用到的命令和其依赖的库。 这个(未挂载的)镜像可以有选折的压缩。

       å¤åˆ¶å†…æ ¸ (bzImage) 和 initrd 镜像 (initrd.gz)到磁盘。

       æœ€åŽçš„步是在磁盘上安装一个boot loader, 而且用下列的选项启动内核: kernel bzImage root=/dev/sda1 initrd=initrd.gz.

       ä½ çŽ°åœ¨åº”该可以使用磁盘来启动了:它会从软盘中载入内核,载入initrd镜像入内存,然后从那里继续常规启动。这点以后,磁盘就可以拿开了。

       å¦‚果磁盘不合适 ( 例如,计算机没有软驱),任何设备在BIOS能用于启动都可以使用。 个人而言,我就使用一个小小的MB的USB棒来达到这个目的。

       å‚考资料:

       http://www.linuxsir.org/bbs/showthread.php?t=

用 BusyBox 构建根文件系统

       构建Linux嵌入式系统的基石是根文件系统,它是一个集成核心组件的单一目录,为后续软件和设备管理提供基础。根文件系统内包含了诸如/bin的系统命令(strong>如ls、cd等),/dev管理设备,/etc配置文件以设置环境,/lib存放必要库文件,/mnt用于临时挂载,/proc虚拟系统信息确保系统运行透明,/usr为软件资源库,/var存储可变数据,而/sbin则包含管理员工具,/sys用于设备管理和监控,/opt则存放可选软件,sysfs和sysfs类似但功能略有差异。

       BusyBox,这个强大的瑞士军刀工具,扮演着构建根文件系统的关键角色。首先,从官网下载适合的版本,如busybox-1..0,并在Ubuntu虚拟机中借助NFS服务进行定制。这里,我们需要确保在Makefile中针对目标架构进行适当的调整,尤其是处理可能的COMPILE错误,使用绝对路径,并解决中文字符问题,比如在源码中的printable_string.c和unicode.c文件中,可能需要注释或调整字符编码规则以支持中文显示。

       定制BusyBox的过程可通过两种方式完成:defconfig(默认配置)或图形化的menuconfig。推荐动态编译,并激活mdev和Unicode支持,以确保兼容性和功能性。

       编译步骤如下:首先运行make defconfig 或 make menuconfig,然后选择动态编译和必要的Unicode支持。接着,使用make make install CONFIG_PREFIX=/path 命令将编译后的工具和文件安装到指定的rootfs目录,这里会生成bin、sbin、usr和linuxrc文件夹,其中Linux内核通过寻找init程序(通常是linuxrc)进入用户态。

       接下来,为了增强根文件系统的功能性,我们需要添加lib库。从交叉编译器的/usr/local/arm/gcc-linaro-...目录下的arm-linux-gnueabihf/libc/lib子目录中复制.so和.a文件到rootfs/lib,特别注意处理特殊库文件ld-linux-armhf.so.3。

       除了基本的文件夹结构,如dev、proc、mnt、sys、tmp和root,还需要创建额外的目录以支持系统的完整功能。例如,dev目录用于设备文件管理,proc用于虚拟系统信息,mnt用于挂载外部存储,sys用于设备驱动的配置,而tmp则存放临时文件。

       最后,通过NFS服务将rootfs挂载到开发板上,确保在bootargs中正确设置root,例如:root=/dev/nfs, nfsroot=...:/home/andyxi/linux/nfs/rootfs, proto=tcp, rw。然后,通过串口设置bootargs启动Linux,如果出现错误,表明rootfs可能还不完整,后续我们将深入探讨如何修复和完善这个关键步骤。

       获取BusyBox的具体资源,请关注相关渠道并输入关键词"busybox"获取详细信息。