linux引导内核(grub引导)
这篇文章给大家聊聊关于linux引导内核,以及grub引导对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。
Linux 内核启动及文件系统加载过程
Linux内核启动及文件系统加载过程
在u-boot引导Linux内核开始执行bootcmd命令后,Linux内核启动过程便开始。普通Linux内核启动通常分为三个阶段。本文将根据项目中使用的linux-2.6.37源码,详细描述内核启动的全过程。
第一阶段为内核自解压过程。在启动过程中,可以看到内核自解压界面。压缩和解压缩代码位于kernel/arch/arm/boot/compressed目录下。编译后产生head.o、misc.o、piggy.gzip.o、vmlinux、decompress.o等文件。BootLoader将系统引导至内核内存后,调用do_bootm_linux(),若内核未被压缩,直接启动;如被压缩,则进行解压。压缩内核头部包含解压程序,入口文件位于arch/arm/boot/compressed/head.S。
decompress_kernel()函数在misc.c文件中实现,调用proc_decomp_setup()、arch_decomp_setup()进行设置。解压缩过程开始后,打印“Uncompressing Linux...”信息,调用gunzip()解压并放置指定位置。内核解压完成后,返回head.S的583行,启动内核。
第二阶段主要工作包括设置ARM处理器工作模式、启用MMU、设置一级页表等。汇编代码通过查找处理器内核类型和机器码类型调用相应的初始化函数,建立页表,跳转至start_kernel()函数开始内核初始化。处理器类型检测在汇编子函数__lookup_processor_type中完成,机器码类型检测在__lookup_machine_type中。建立页表后,跳转至C程序入口start_kernel()。
第三阶段由start_kernel函数开始,这是所有Linux平台进入系统内核初始化后的入口。它完成与硬件平台相关的初始化工作,调用init进程并等待执行,完成Linux内核启动。
启动init服务并挂载根文件系统
在启动init服务前,需要挂载根文件系统。根文件系统至少包含五大目录。以只读方式挂载,防止内核不稳定时破坏数据或延长开机时间。
挂载根文件系统后,执行init服务。Linux内核依据/etc/inittab文件中设置进行初始化系统环境。init启动后,表示Linux内核成功启动。
在启动init服务时,init会读取/etc/inittab文件,执行rc.sysinit、rc、rc.local等脚本进行系统初始化。rc.sysinit主要功能包括启动udev、设置内核参数、系统时间、启用交换内存、检查并挂载文件系统、初始化硬件设备、管理串行端口、清除过期锁定文件、建立用户接口等。
整个Linux内核启动过程至此完成。
linux内核打印linux内核打印
linuxconsole是什么文件
linuxconsole是一个为内核提供打印的缓冲文件。
linux系统下的打印机无法打印怎么解决?
点击屏幕左下角的“开始”按钮,从弹出的菜单列表中选择“打印机和传真”;
在打开的“打印机和传真”窗口中单击左侧的“添加打印机”命令;
接着会弹出“添加打印机向导”对话框,单击“下一步”按钮继续;
一般我们是选择第一项,使用网络打印机也更多的选.
Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。
它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。
Linux操作系统诞生于1991年10月5日(这是第一次正式向外公布时间)。Linux存在着许多不同的Linux版本,但它们都使用了Linux内核。
Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。
严格来讲,Linux这个词本身只表示Linux内核,但实际上人们已经习惯了用Linux来形容整个基于Linux内核,并且使用GNU工程各种工具和数据库的操作系统。
在Linux下查自己的IP怎么查?
可以使用ifconfig命令查看IP。
ifconfig命令用于配置和显示Linux内核中网络接口的网络参数。
输入ifconfig,会打印出网络接口的参数,除了IP地址还会打印出物理地址、掩码地址等网络接口相关参数.
linuxdmesg命令详解?
linuxdmesg命令参数及用法详解(linux显示开机信息命令)
功能说明:显示开机信息。
语法:dmesg
补充说明:kernel会将开机信息存储在ringbuffer中。您若是开机时来不及查看信息,可利用dmesg来查看。开机信息亦保存在/var/log目录中,名称为dmesg的文件里。
参数:
-c显示信息后,清除ringbuffer中的内容。
-s缓冲区大小>预设置为8196,刚好等于ringbuffer的大小。
-n设置记录信息的层级。扩展阅读一:dmesg命令主要用途
主要应用:
dmesg用来显示内核环缓冲区(kernel-ringbuffer)内容,内核将各种消息存放在这里。在系统引导时,内核将与硬件和模块初始化相关的信息填到这个缓冲区中。内核环缓冲区中的消息对于诊断系统问题通常非常有用。在运行dmesg时,它显示大量信息。通常通过less或grep使用管道查看dmesg的输出,这样可以更容易找到待查信息。例如,如果发现硬盘性能低下,可以使用dmesg来检查它们是否运行在DMA模式:
$dmesg|grepDMA
...
ide0:BM-DMAat0xf000-0xf007,BIOSsettings:hda:DMA,hdb:DMA
ide1:BM-DMAat0xf008-0xf00f,BIOSsettings:hdc:DMA,hdd:DMA
...上面几行可以说明每个IDE设备正在什么模式下运行。如果以太网连接出现问题,那么可以在dmesg日志中搜索eth:
$dmesg|grepeth
forcedeth.c:ReverseEngineerednForce
ethernetdriver.Version0.49.
eth0:forcedeth.c:subsystem:0147b:1c00
boundto0000:00:04.0
eth0:noIPv6routerspresent如果一切正常,那么dmesg显示每个网卡的硬件配置信息。如果某项系统服务未能得到正确的配置,dmesg日志很快就填满错误消息,这是诊断故障的良好起点。
还可以用来探测系统内核模块的加载情况,比如要检测ACPI的加载情况,使用dmesg|grepacpi
dmesg|egrep-i''(apm|acpi)''
Kernelcommandline:vga=274quietconsole=ttyS3,9600acpi=no-idleoot=/dev/hda3
ACPI:CoreSubsystemversion
ACPI:Subsystemenabled
ACPI:Systemfirmwaresupports:C2
ACPI:plvl2lat=99plvl3lat=1001
ACPI:C2enter=1417C2exit=354
ACPI:C3enter=-1C3exit=-1
ACPI:NotusingACPIidle
ACPI:Systemfirmwaresupports:S0S1S4S5
扩展阅读二:dmesg命令使用示例
使用示例
示例一将开机信息发邮件
mandmesg写道
Theprogramhelpsuserstoprintouttheirbootupmessages.Insteadofcopyingthemessagesbyhand,theuserneedonly:
dmesg>boot.messages
andmailtheboot.messagesfiletowhoevercandebugtheirproblem.
#dmesg>boot.messages
#ls-lboot.messages
-rw-r--r--1rootroot1583812-0912begin_of_the_skype_highlighting
1583812-0912免费end_of_the_skype_highlighting:55boot.messages#mail-s"BootLogofLinuxServer"public@web3q.netboot.messages
#示例二浏览dmesg输出的信息
#uname-a
Linuxnew552.6.18-194.el5#1SMPTueMar1621:52:43EDT2010i686i686i386GNU/Linux#dmesg|less
Linuxversion2.6.18-194.el5(mockbuild@x86-007.build.bos.redhat.com)(gccversion4.1.220080704(RedHat4.1.2-48))#1SMPTueMar1621:52:43EDT2010
BIOS-providedphysicalRAMmap:
BIOS-e820:0000000000010000-000000000009fc00(usable)
BIOS-e820:000000000009fc00-00000000000a0000(reserved)
BIOS-e820:00000000000e0000-0000000000100000(reserved)
BIOS-e820:0000000000100000-000000001f7d0000(usable)
BIOS-e820:000000001f7d0000-000000001f7efc00(reserved)
BIOS-e820:000000001f7efc00-000000001f7fb000(ACPINVS)
BIOS-e820:000000001f7fb000-000000001f800000(reserved)
BIOS-e820:00000000e0000000-00000000f0000000(reserved)
BIOS-e820:00000000fec00000-00000000fec02000(reserved)
BIOS-e820:00000000fed20000-00000000fed9b000(reserved)
BIOS-e820:00000000feda0000-00000000fedc0000(reserved)
BIOS-e820:00000000ffb00000-00000000ffc00000(reserved)
BIOS-e820:00000000fff00000-0000000100000000(reserved)
0MBHIGHMEMavailable.
503MBLOWMEMavailable.
Memoryforcrashkernel(0x0to0x0)notwithinpermissiblerange
disablingkdump
Usingx86segmentlimitstoapproximateNXprotection
Onnode0totalpages:128976
DMAzone:4096pages,LIFObatch:0
Normalzone:124880pages,LIFObatch:31
DMI2.3present.
UsingAPICdriverdefault
ACPI:RSDP(v000HP)@0x000fe270
ACPI:RSDT(v001HP30C40x31100620HP0x00000001)@0x1f7efc84
ACPI:FADT(v002HP30C40x00000002HP0x00000001)@0x1f7efc00
ACPI:MADT(v001HP30C40x00000001HP0x00000001)@0x1f7efcb8
ACPI:MCFG(v001HP30C40x00000001HP0x00000001)@0x1f7efd14
ACPI:SSDT(v001HPHPQPpc0x00001001MSFT0x0100000e)@0x1f7f6698
ACPI:DSDT(v001HPDAU000x00010000MSFT0x0100000e)@0x00000000
ACPI:PM-TimerIOPort:0x1008
ACPI:LocalAPICaddress0xfec01000
ACPI:LAPIC(acpi_idlapic_idenabled)
Processor#06:13APICversion20
ACPI:LAPIC_NMI(acpi_idhighedgelint)
ACPI:IOAPIC(idaddressgsi_base)
IOAPIC:apic_id1,version32,address0xfec00000,GSI0-23
:
示例三查看dmesg尾部的信息
#dmesg|tail
Bluetooth:L2CAPver2.8
Bluetooth:L2CAPsocketlayerinitialized
Bluetooth:RFCOMMsocketlayerinitialized
Bluetooth:RFCOMMTTYlayerinitialized
Bluetooth:RFCOMMver1.8
Bluetooth:HIDP(HumanInterfaceEmulation)ver1.1
eth0:noIPv6routerspresent
Installingknfsd(copyright(C)1996okir@monad.swb.de).
NFSD:Using/var/lib/nfs/v4recoveryastheNFSv4staterecoverydirectory
NFSD:starting90-secondgraceperiod
#
示例四安装SS7卡驱动时的内核日志
#cdSS7HD_DRIVER/
#ls
bbdddlnx_iss.hbbd_hbi.hbbd_ioc.cbbd_isr.cbbd_pci.cBSD_license.txtGPL_V2-only_license.txtinstall_ss7hd.shMakefile26
bbd_def.hbbd_hs.cbbd_ioc.hbbd_lnx.cbbd_pro.hbuild_ss7hd.shi21555.hMakefile24
#./build_ss7hd.sh
make:Enteringdirectory`/usr/src/kernels/2.6.9-22.EL-i686'
CC/root/setup/ss7dpklnx/SS7HD_DRIVER/bbd_hs.o
CC/root/setup/ss7dpklnx/SS7HD_DRIVER/bbd_ioc.o
CC/root/setup/ss7dpklnx/SS7HD_DRIVER/bbd_isr.o
CC/root/setup/ss7dpklnx/SS7HD_DRIVER/bbd_pci.o
CC/root/setup/ss7dpklnx/SS7HD_DRIVER/bbd_lnx.o
LD/root/setup/ss7dpklnx/SS7HD_DRIVER/ss7hddvr26.o
Buildingmodules,stage2.
MODPOST
CC/root/setup/ss7dpklnx/SS7HD_DRIVER/ss7hddvr26.mod.o
LD/root/setup/ss7dpklnx/SS7HD_DRIVER/ss7hddvr26.ko
make:Leavingdirectory`/usr/src/kernels/2.6.9-22.EL-i686'
#lsmod|grepss7
ss7hddvr26258080
#dmesg|tail
ACPI:PCIinterrupt0000:02:0d.0->GSI9(level,low)->IRQ9
BBD64bit
SS7HD-suspend
DialogicSS7HDDeviceDriverV100.00(SourceV1.21)
Copyright(C)DialogicCorporation2003-2010.AllRightsReserved
Usingmajordevicenumber251.
ACPI:PCIinterrupt0000:02:0d.0->GSI9(level,low)->IRQ9
BBD64bit
#./install_ss7hd.shremove
#lsmod|grepss7
#dmesg|tail
BBD64bit
SS7HD-suspend
DialogicSS7HDDeviceDriverV100.00(SourceV1.21)
Copyright(C)DialogicCorporation2003-2010.AllRightsReserved
Usingmajordevicenumber251.
ACPI:PCIinterrupt0000:02:0d.0->GSI9(level,low)->IRQ9
BBD64bit
SS7HD-suspend
#
示例五打印并清除内核环形缓冲区
#dmesg-c
Linuxversion2.6.18-194.el5(mockbuild@x86-007.build.bos.redhat.com)(gccversion4.1.220080704(RedHat4.1.2-48))#1SMPTueMar1621:52:43EDT2010
BIOS-providedphysicalRAMmap:
BIOS-e820:0000000000010000-000000000009fc00(usable)
BIOS-e820:000000000009fc00-00000000000a0000(reserved)
BIOS-e820:00000000000e0000-0000000000100000(reserved)
BIOS-e820:0000000000100000-000000001f7d0000(usable)
BIOS-e820:000000001f7d0000-000000001f7efc00(reserved)
BIOS-e820:000000001f7efc00-000000001f7fb000(ACPINVS)
BIOS-e820:000000001f7fb000-000000001f800000(reserved)
BIOS-e820:00000000e0000000-00000000f0000000(reserved)
BIOS-e820:00000000fec00000-00000000fec02000(reserved)
BIOS-e820:00000000fed20000-00000000fed9b000(reserved)
BIOS-e820:00000000feda0000-00000000fedc0000(reserved)
BIOS-e820:00000000ffb00000-00000000ffc00000(reserved)
BIOS-e820:00000000fff00000-0000000100000000(reserved)
0MBHIGHMEMavailable.
503MBLOWMEMavailable.
Memoryforcrashkernel(0x0to0x0)notwithinpermissiblerange
disablingkdump
Usingx86segmentlimitstoapproximateNXprotection
Onnode0totalpages:128976
DMAzone:4096pages,LIFObatch:0
Normalzone:124880pages,LIFObatch:31
DMI2.3present.省略输出
Bluetooth:HIDP(HumanInterfaceEmulation)ver1.1
eth0:noIPv6routerspresent
Installingknfsd(copyright(C)1996okir@monad.swb.de).
NFSD:Using/var/lib/nfs/v4recoveryastheNFSv4staterecoverydirectory
NFSD:starting90-secondgraceperiod
#dmesg#less/var/log/dmesg
Linuxversion2.6.18-194.el5(mockbuild@x86-007.build.bos.redhat.com)(gccversion4.1.220080704(RedHat4.1.2-48))#1SMPTueMar1621:52:43EDT2010
BIOS-providedphysicalRAMmap:
BIOS-e820:0000000000010000-000000000009fc00(usable)
BIOS-e820:000000000009fc00-00000000000a0000(reserved)
BIOS-e820:00000000000e0000-0000000000100000(reserved)
BIOS-e820:0000000000100000-000000001f7d0000(usable)
BIOS-e820:000000001f7d0000-000000001f7efc00(reserved)
BIOS-e820:000000001f7efc00-000000001f7fb000(ACPINVS)
BIOS-e820:000000001f7fb000-000000001f800000(reserved)
BIOS-e820:00000000e0000000-00000000f0000000(reserved)
BIOS-e820:00000000fec00000-00000000fec02000(reserved)
BIOS-e820:00000000fed20000-00000000fed9b000(reserved)
BIOS-e820:00000000feda0000-00000000fedc0000(reserved)
BIOS-e820:00000000ffb00000-00000000ffc00000(reserved)
BIOS-e820:00000000fff00000-0000000100000000(reserved)
0MBHIGHMEMavailable.
503MBLOWMEMavailable.
Memoryforcrashkernel(0x0to0x0)notwithinpermissiblerange
disablingkdump
Usingx86segmentlimitstoapproximateNXprotection
Onnode0totalpages:128976
DMAzone:4096pages,LIFObatch:0
Normalzo
如何用GRUB引导LINUX
步骤如下:
a进入grub的命令模式。进入grub界面后按C键进入命令行界面。
b先熟悉一下grub的一些命令 grub>help
c熟悉一下cat命令
d root指令来指定/boot所在的分区
e kernel指令来指定linux的内核,及所在的分区
f用initrd命令来指定initrd文件
g boot引导系统
cat命令的用法
cat指令是用来查看文件内容的,有时不知道Linux的/boot分区,以及/根分区所在的位置,要查看/etc/fstab的内容来得知,这时,就要用到cat(hd[0-n],y)/etc/fstab来获得这些内容;注意要学会用tab键命令补齐的功能;
grub> cat(按tab键会出来hd0或hd1之类的;
grub> cat(hd0,注:输入hd0,然后再按tab键;会出来分区之类的;
grub> cat(hd0,6)
Possible partitions are:
Partition num: 0, Filesystem type unknown, partition type 0x7
Partition num: 4, Filesystem type is fat, partition type 0xb
Partition num: 5, Filesystem type is reiserfs, partition type 0x83
Partition num: 6, Filesystem type is ext2fs, partition type 0x83
Partition num: 7, Filesystem type unknown, partition type 0x83
Partition num: 8, Filesystem type is reiserfs, partition type 0x83
Partition num: 9, Filesystem type unknown, partition type 0x82
grub> cat(hd0,6)/etc/fstab注:比如我想查看一下(hd0,6)/etc/fstab的内容就这样输入;
LABEL=// ext3 defaults 1 1
/dev/devpts/dev/pts devpts gid=5,mode=620 0 0
/dev/shm/dev/shm tmpfs defaults 0 0
/dev/proc/proc proc defaults 0 0
/dev/sys/sys sysfs defaults 0 0
LABEL=SWAP-hda1 swap swap defaults 0 0
/dev/hdc/media/cdrecorder auto pamconsole,exec,noauto,
managed 0 0
主要查看/etc/fstab中的内容,主要是Linux的/分区及/boot是否是独立的分区;如果没有/boot类似的行,证明/boot和 Linux的/处于同一个硬盘分区;比如上面的例子中LABEL=/这行是极为重要的;说明Linux系统就安在标签为LABEL=/的分区中;
如果您的Linux系统/boot和/没有位于同一个分区,可能cat(hd[a-n],y)查到的是类似下面的;
LABEL=// ext3 defaults 1 1
LABEL=/boot/boot ext3 defaults 1 2
root(hd[0-n,y)指令来指定/boot所在的分区;
其实这个root(hd[0,n],y)是可以省略的,如果省略了,要在kerenl命令中指定;前面已经说过(hd[0-n],y)硬盘分区的表示方法的用途;主要是用来指定/boot所在的分区;
eg:
grub> root(hd0,0)
kernel指令,用来指定Linux的内核,及/所在的分区;
kernel这个指令可能初学者有点怕,不知道内核在哪个分区,及内核文件名的全称是什么。不要忘记tab键的命令补齐的应用;
如果已经通过root(hd[0-n],y)指定了/boot所在的分区,语法有两个:
如果/boot和Linux的/位于同一个分区,应该是下面的一种格式;
kernel/boot/vmlinuz在这里按tab键来补齐,就看到内核全称了 ro root=/dev/hd[a-z]X
如果/boot有自己独立的分区,应该是;
kernel/vmlinuz在这里按tab键来补齐,就看到内核全称了 ro root=/dev/hd[a-z]X
在这里 root=/dev/hd[a-z]X是Linux的/根所位于的分区,如果不知道是哪个分区,就用tab出来的来计算,一个一个的尝试;或用cat(hd[0-n],y)/etc/fstab中得到Linux的/所在的分区或分区的标签;
grub> kernel/boot/在这里按tab键;这样就列出/boot中的文件了;
Possible files are: grub initrd-2.6.11-1.1369_FC4.img System.map-2.6.11-1.1369
_FC4 config-2.6.11-1.1369_FC4 vmlinuz-2.6.11-1.1369_FC4 grubBAK memtest86+-1.55
.1 xen-syms xen.gz
grub> kernel/boot/vmlinuz-2.6.11-1.1369_FC4 ro root=LABEL=/
[Linux-bzImage, setup=0x1e00, size=0x18e473]
注解: root=LABEL=/是Linux的/所在的分区的文件系统的标签;如果您知道Linux的/在哪个具体的分区,用root=/dev/hd[a-z]X来指定也行。比如下面的一行也是可以的;
grub> kernel/boot/vmlinuz-2.6.11-1.1369_FC4 ro root=/dev/hda7
也可以把/boot所在的分区的指定 root(hd[0-n],y)这行省掉,直接在kernel中指定/boot所在的分区;所以就在下面的语法;
如果是/boot和Linux的根同处一个分区;
kernel(hd[0-n],y)/boot/vmlinuz ro root=/dev/hd[a-z]X
比如:
grub>kernel
如果是/boot和Linux所在的根不在一个分区;则是;
kernel(hd[0-n],y)/vmlinuz ro root=/dev/hd[a-z]X
grub> kernel(hd0,0)/boot/vmlinuz-2.6.11-1.1369_FC4 ro root=/dev/hda7
[Linux-bzImage, setup=0x1e00, size=0x18e473]
或下面的输入,以cat出/etc/fstab内容为准;
grub> kernel(hd0,0)/boot/vmlinuz-2.6.11-1.1369_FC4 ro root=LABEL=/
[Linux-bzImage, setup=0x1e00, size=0x18e473]
initrd命令行来指定initrd文件;
grub> initrd/boot/initrd在这里tab来补齐;
grub> initrd/boot/initrd-2.6.11-1.1369_FC4.img
[Linux-initrd@ 0x2e1000, 0x10e685 bytes]
如果/boot是独立的一个分区,应该是如下样子的语法;比如下面的;
grub> initrd/initrd在这里tab来补齐;
grub> initrd/initrd-2.6.11-1.1369_FC4.img
[Linux-initrd@ 0x2e1000, 0x10e685 bytes]
boot引导系统;
grub>boot
下面是在我机器上的命令:
grub> cat(hd0,0)/etc/fstab
# This file is edited by fstab-sync- see'man fstab-sync' for details
LABEL=// ext3 defaults 1 1
/dev/devpts/dev/pts devpts gid=5,mode=620 0 0
/dev/shm/dev/shm tmpfs defaults 0 0
/dev/proc/proc proc defaults 0 0
/dev/sys/sys sysfs defaults 0 0
LABEL=SWAP-hda1 swap swap defaults 0 0
/dev/hdc/media/cdrecorder auto pamconsole,exec,noauto,managed 0 0
grub> root(hd0,0)
Filesystem type is ext2fs, partition type 0x83
grub> kernel/boot/在这里按tab补齐,全列出/boot所有的文件;
Possible files are: grub initrd-2.6.11-1.1369_FC4.img System.map-2.6.11-1.1369_FC4 config-2.6.11-1.1369_FC4 vmlinuz-2.6.11-1.1369_FC4
memtest86+-1.55.1 xen-syms xen.gz
grub> kernel/boot/vmlinuz-2.6.11-1.1369_FC4 ro root=LABEL=/
[Linux-bzImage, setup=0x1e00, size=0x18e473]
grub> initrd/boot/在这里按tab补齐
Possible files are: grub initrd-2.6.11-1.1369_FC4.img System.map-2.6.11-1.1369_FC4 config-2.6.11-1.1369_FC4 vmlinuz-2.6.11-1.1369_FC4 grubBAK
memtest86+-1.55.1 xen-syms xen.gz
grub> initrd/boot/initrd-2.6.11-1.1369_FC4.img注;输入intrd文件名的全名;
[Linux-initrd@ 0x2e1000, 0x10e685 bytes]
grub> boot