OpenBoot PROM简介

OpenBoot PROM简介
Sparc平台上的Solaris操作系统启动时要经历Boot PROM、引导程序、内核初始化、初始化进程init等阶段。Boot PROM阶段进入了一个操作系统预引导状态,也就是通常所说的ok状态。有了这个预引导状态使得系统可以从硬盘、光驱、网络等地方加载操作系统,无盘工作站就是利用这个原理实现的。了解Sparc主机的Boot PROM(也就是OpenBoot PROM)的组成、作用和命令行工作对系统的故障排错是非常有帮助的。

OpenBoot PROM构成
每个Sun的计算机上都有一块可编程只读存储器(Boot PROM),又称OpenBoot PROM,其中固化了提供基本的硬件诊断、初始化,加载第三方板卡的驱动程序,以及提供一个交互式的命令行环境的软件。Boot PROM通常固化在系统的主板上。新的系统如Ultra工作站上的Boot PROM是用软件就可以升级的,称为flash PROM(FPROM)。升级FPROM时需要去掉写保护(通常是设置写保护跳线)。迄今为止,Sun的Boot PROM有以下系列版本:
1.x -- 封闭的接口,不支持第三方设备
2.x -- 开放式接口,支持第三方设备
3.x -- 支持软件可擦写,固件(firmware)可升级
4.x -- 支持的设备
5.x -- 支持硬件域(domain),主要在高端机器(如6800,15K)上应用
查看系统当前的Boot PROM版本号如果在操作系统状态可以用prtdiag -v或则prtconf -v命令,如果在ok状态则可以用banner命令。

Boot PROM中包含以下内容:
1. 上电自检程序(POST)
2. 基本的设备驱动程序
3. ok状态命令行程序
4. 省缺的配置参数

其它的系统配置信息如网卡的MAC地址、host ID、用户可配置参数(又称NVRAM参数或EEPROM参数)被放在了NVRAM芯片、SEEPROM或系统配置卡SCC上,其目的是为了方便系统迁移。
NVRAM芯片是主板上可插拔的一块芯片,有自己的锂电池用来保证所保存的信息不丢失,同时也提供了系统的时间。将NVRAM芯片设计成可插拔是为了便于一些依赖于host id的软件迁移到别的主机。

POST过程
上电自检过程有以下步骤:
1. 低级别硬件自检
2. 测试内存和CPU
3. 测试总线上的设备,构建设备树
4. 安装控制台,即系统的串口A和串口B

在POST过程中系统还会检测键盘上是否有Stop和其它键(A,D或N)同时按下:
如果stop-D同时按下,固件将进入诊断模式,进行更广泛的硬件自检,并把结果输出到控制台A,把NVRAM变量diag-switch?设成true:
如果stop-N同时按下,系统将使用省缺参数,忽略NVRAM中的设置;
如果stop-A同时按下,系统将进入ok状态,而不自动引导操作系统,即使auto-boot?变量为true。
stop-D和stop-N键仅在系统启动时有效,而stop-A不仅在系统启动时有效,而且在操作系统状下也有效。为了避免误按stop-A键引起的系统不可用,可以修改/etc/default/kbd文件的的参数KEYBOARD_ABORT=disable并运行kbd -i命令在操作系统状态下禁用stop-A。

通常在自检过程中如果系统没有检测到键盘则会向串口打印自检过程产生的输出。为了获得串口上的输出可以使用Windows中的超级终端软件。

OpenBoot命令
在ok状态下可以运行OpenBoot命令,这些命令用来检测设备、设置参数、引导操作系统、获得系统信息及帮助信息等。

引导操作系统
boot [device_name] -option
boot -s 用默认设备引导操作系统进入单用户模式
boot cdrom -s 用cdrom引导操作系统进入单用户模式
boot -a 交互式启动操作系统
boot -r 引导操作系统,并将检测到的新硬件加入到操作系统
boot -v 详细模式

获得命令的帮助
ok状态下可以使用help命令得到常用命令的帮助,help可以指定一个类别或者某个具体命令。具体分类用不带参数的help命令可以得到。
例如:help boot将输出:
#TODO:justin add help boot output

NVRAM参数
printenv,setenv,set-default,set-defaults这些命令用于显示、设置NVRAM参数
printenv不带参数时输出所有NVRAM参数的名称、当前值、默认值
例如:printenv
Variable Name Value Default Value

tpe-link-test? true true
scsi-initator-id 7 7

ttyb-mode 9600,8,n,1,- 9600,8,n,1,-

boot-device disk net disk net
auto-boot? true true
local-mac-address? false false
use-nvramrc? false false
nvramrc devalias pgx24 /pcilf,0 ...
diag-switch? false false

如果要输出某个参数的值,可以用printenv命令跟上该参数的名称,例如要知道当前OpenBoot PROM是否自动引导操作系统可以用
printenv auto-boot?
NVRAM参数的命名有一定的规律,凡是布尔值参数名以问号结尾,像auto-boot?,tpe-link-test?, diag-switch?, local-mac-address?, use-nvramrc? 等。
改变NVRAM参数用setenv命令,用法setenv 参数名 参数值,例如:
setenv auto-boot? true
要使修改的参数生效需要运行reset-all命令。
使用setenv修改参数可能引入错误,所以OpenBoot PROM引入set-default和set-defaults两个命令用来将NVRAM参数恢复为出厂设置。
set-default用于恢复单个NVRAM参数,set-default用于恢复所有NVRAM参数。

检测系统总线上的设备
OpenBoot PROM中的probe族命令用来检测系统总线上的设备。
sifting probe命令列出这些命令。
probe命令主要是用来检测scsi或ide设备是否正常,相应的命令是probe-scsi,probe-scsi-all和probe-ide。对于OpenBoot PROM版本3.x或以上的系统运行probe族命令时,要确保操作系统未被引到过,否则容易导致系统挂起,从而引起可能的数据丢失。所以谨慎的做法是将auto-boot?设为false,然后重启系统进入ok状态。具体的操作办法是:如果当前处于操作系统状态,运行eeprom auto-boot?=false和init 0命令;如果当前处于ok状态,运行setenv auto-boot? false和reset-all。
如果不想执行上述谨慎的操作步骤,可以在ok状态通过.registers命令查看所有寄存器的值来确定运行probe族命令是否安全。只有当所有寄存器的值都为0时才是安全的。

probe-scsi命令将检测主板上的scsi控制器上接的设备,probe-scsi-all命令除了检测主板上的scsi控制器上接的设备外,还将检测scsi卡上接的设备。probe-ide命令将检测主板ide控制器上接的设备。

设备名及设备别名
OpenBoot PROM在自检完成后把设备按照它们在总线、控制器中的位置组织成一棵设备树。show-devs命令用来查看自检到的设备树。
#TODO:justin add show-devs output sample
此外,show-ttys,show-displays,show-nets,show-disks,show-tapes分别用来查看相应类型的设备。
由于使用设备物理名称表示设备比较复杂,OBP中使用设备别名简化对设备的表示,devalias命令列出设备别名和设备物理名称的对应关系。
#TODO:justin add devalias output sample
除了预定义的设备别名外,OpenBoot PROM允许自定义设备别名。要使自定义别名生效,应当将use-nvramrc?设为true。
定义设备别名用nvalias命令,用法nvalias aliasname device_path
删除设备别名用nvunalias命令,用法nvunalias aliasname

在操作系统状态查看修改NVRAM参数
在Solaris操作系统运行时通过/usr/sbin/eeprom命令可以参看或修改NVRAM参数
不带参数的eeprom列出所有NVRAM参数,列出单个NVRAM参数在eeprom命令后加上该参数名,设置参数eeprom命令后加上参数名的赋值表达式。例如:
eeprom -- 显示所有NVRAM参数
eeprom boot-device -- 显示默认的引导设备
eeprom boot-device=disk2 -- 将别名为disk2的设备设置成默认的引导设备
eeprom auto-boot?=true -- 将OBP设置为自动引导操作系统
要注意的是在某些shell带有问号的参数需要用单用号引用,如C shell。



 

你可能感兴趣的:(设计模式,软件测试,Solaris,网络应用,ide)