- 在线时间
- 63 小时
- 最后登录
- 2019-5-3
- 注册时间
- 2004-5-10
- 听众数
- 442
- 收听数
- 0
- 能力
- -250 分
- 体力
- 10122 点
- 威望
- -12 点
- 阅读权限
- 150
- 积分
- -586
- 相册
- 6
- 日志
- 10
- 记录
- 10
- 帖子
- 2003
- 主题
- 1253
- 精华
- 43
- 分享
- 8
- 好友
- 1292

复兴中华数学头子
TA的每日心情 | 开心 2011-9-26 17:31 |
|---|
签到天数: 3 天 [LV.2]偶尔看看I
- 自我介绍
- 数学中国网站(www.madio.cn)是目前中国最大的数学建模交流社区
 群组: 越狱吧 群组: 湖南工业大学数学建模同盟会 群组: 四川农业大学数学建模协会 群组: 重庆交通大学数学建模协会 群组: 中国矿业大学数学建模协会 |
< >linux内核在启动的时候,能接收某些命令行选项或启动时参数。当内核不能识别某些硬件进而不能设置硬件参数或者为了避免内核更改某些参数的值,可以通过这种方式手动将这些参数传递给内核。 如果不使用启动管理器,比如直接从BIOS或者把内核文件用“cp zImage /dev/fd0”等方法直接从设备启动,就不能给内核传递参数或选项--这也许是我们使用引导管理器比如LILO的好处之一吧。
3 a3 b& A4 L9 ?/ K; ]$ N0 S0 F$ n+ x' U) m+ V
LINUX的内核参数是以空格分开的一个字符串列表,通常具有如下形式: + D/ N, Y/ U4 {9 R, a( G
name[=value_1][,value_2]...[,value_10]
; ^$ z: E3 T' W: g$ R" n# P“name”是关键字,内核用它来识别应该把“关键字”后面的值传递给谁,也就是如何处理这个值,是传递给处理例程还是作为环境变量或者抛给“init”。值的个数限制为10,你可以通过再次使用该关键字使用超过10个的参数。
. O2 D- t5 E& q5 R+ f G- ?; Q6 [2 c& w4 \% j- U6 Y
首先,内核检查关键字是不是 `root=',`nfsroot=', `nfsaddrs=', `ro', `rw', `debug'或 `init',然后内核在bootsetups数组里搜索于该关键字相关联的已注册的处理函数,如果找到相关的已注册的处理函数,则调用这些函数并把关键字后面的值作为参数传递给这些函数。比如你在启动时设置参数name=a,b,c,d,内核搜索bootsetups数组,如果发现“name”已注册,则调用“name”的设置函数如name_setup(),并把a,b,c,d传递给name_setup()执行。 1 s- g3 C9 R/ N/ ^# R9 O
) O4 S& R5 t4 k# i0 L% g2 i9 K所有型如“name=value”参数,如果没有被上面所述的设置函数接收,将被解释为系统启动后的环境变量,比如“TERM=vt100”就会被作为一个启动时参数。
( v8 b4 Z/ Y& F. o F4 K+ }
* A9 V$ E9 Z3 l' I9 l7 {, ~所有没有被内核设置函数接收也没又被设置成环境变量的参数都将留给init进程处理,比如“single”。
1 S7 C) }% _$ S$ ~
3 F9 Q! `0 l: C# }+ N( C3 O常用的设备无关启动时参数 8 q- `" I7 Z( Y5 ^, @4 P
, f" g! X: ?( A2 Z/ \
1、init=...
1 V/ {3 g$ O+ ?3 x5 B0 D设置内核执行的初始化进程名,如果该项没有设置,内核会按顺序尝试/etc/init, # Z* y- ]9 a- N7 [ @
/bin/init,/sbin/init, /bin/sh,如果所有的都没找到,内核会抛出 kernel panic:的错误。
3 O4 ^7 g( d$ X6 ]5 y( N# ^1 C2、nfsaddrs=... & I7 P! s7 S, F* F
设置从网络启动时NFS的启动地址,已字符串的形式给出。 8 e( }5 g# F! P, [7 ]# D/ y" S
3、nfsroot=...
$ h+ P, ?1 o0 G6 t/ k# x设置网络启动时的NFS根名字,如果该字符串不是以 "/"、","、"."开始,默认指向“/tftp-boot”。
* e) w+ i" g& ?. X1 z7 F9 n' a以上2、3在无盘站中很有用处。
* f1 O% z( y1 L4、no387
5 C: \. a3 f6 g1 {1 _, D该选项仅当定义了CONFIG_BUGi386时才能用,某些i387协处理器芯片使用32位的保护模式时会有BUG,比如一些浮点运算,使用这个参数可以让内核忽略387协处理器。 ( _& i: }* u" l& {6 V
5、no-hlt $ F' i Z5 @$ W4 b. Q
该选项仅当定义了CONFIG_BUGi386时才能用,一些早期的i486DX-100芯片在处理“hlt”指令时会有问题,执行该指令后不能可靠的返回操作系统,使用该选项,可以让linux系统在CPU空闲的时候不要挂起CPU。
2 L/ ?& N" n" F' Q$ R; M; g8 P9 l6、root=... : q) K- U6 i" Q8 Y' `
该参数告诉内核启动时使用哪个设备作为根文件系统。比如可以指定根文件为hda8:root=/dev/hda8。 # P4 G5 B! A' h8 {' ]
7、ro和rw
2 Q& A2 j" _2 M. p- b0 @& Vro参数告诉内核以只读方式加载根文件系统,以便进行文件系统完整性检查,比如运行fsck;rw参数告诉内核以读写方式加载根文件系统,这是默认值。 / f# d2 C/ P" r
8、reserve=... 8 E6 `9 |& F3 H0 e/ ]2 ]
保留端口号。格式:reserve=iobase,extent[,iobase,extent]...,用来保护一定区域的I/O端口不被设备驱动程序自动探测。在某些机器上,自动探测会失败,或者设备探测错误或者不想让内核初始化设备时会用到该参数;比如: reserve=0x300,32 device=0x300,除device=0x300外所有设备驱动不探测 0x300-0x31f范围的I/O端口。
8 A0 O, i ^! h8 w" ~0 M* m9、mem=... ' x# s( A# T1 n7 ?8 @" X2 W
限制内核使用的内存数量。早期BIOS设计为只能识别64M以下的内存,如果你的内存数量大于64M,你可以指明,如果你指明的数量超过了实际安装的内存数量,系统崩溃是迟早的事情。如:mem=0x1000000意味着有16M内存,如果是mem=0x6000000,就是96M内存了。
' d& J- Y8 z# c# s- u' P# p# u( g, f# \3 S- t: Q" Y
注意:很多机型把部分内存作为BIOS的映射,所以你在指定内存大小的时候一定要预留空间。你也可以在 pentium或者更新的CPU上使用mem=nopentium关闭4M的页表,这要在内核配置时申明。 - l8 c2 d9 {- @2 \1 Z* Q; ^, ?, _
10、panic=N 8 M1 N" Z5 V7 N0 N* h
默认情况,内核崩溃--kernel panic 后会宕机而不会重启,你可以设置宕机多少秒之后重启机器;也可以在/proc/sys/kernel/panic文件里设置。
1 Z: S& \3 {7 K) k& D11、reboot=[warm|cold][,[bios|hard]]
- B- ~' v6 {4 F: i" d1 z! ?( K& C! q该选项仅当定义了CONFIG_BUGi386时才能用。2.0.22的内核重启默认为cool reboot,warm reboot 更快,使用"reboot=bios"可以继承bios的设置。
& S! f5 Q1 f' s4 b12、nosmp 和 maxcpus=N
6 g2 n W% [5 `; ~5 F1 o仅当定义了 __SMP__,该选项才可用。可以用来禁用多CPU或者指明最多支持的CPU个数。</P> |
zan
|