Open Boot PROM

更新时间:2022-07-23 09:32

Open Boot PROM简称OBP,可以理解为普通pc的BIOS的增强版,它是控制sun服务器的引导过程、初始化配置某些硬件和提供了某些诊断的工具。

主要特点

Open Boot PROM配置保存在主板的prom固件中,配置的方式是通过在OBP命令行下进行配置我们可以通过它来调整启动设备和启动参数,如从光盘引导,检测硬件故障完成某些必须在操作系统启动之前完成的配置,如某些硬件设备的配置等等功能。

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

软件构成

每个Sun的计算机上都有一块可编程只读存储器(BootPROM),又称OpenBootPROM,其中固化了提供基本的硬件诊断、初始化,加载第三方板卡的驱动程序,以及提供一个交互式的命令行环境的软件。BootPROM通常固化在系统的主板上。新的系统如Ultra工作站上的BootPROM是用软件就可以升级的,称为flashPROM(FPROM)。升级FPROM时需要去掉写保护(通常是设置写保护跳线)。迄今为止,Sun的BootPROM有以下系列版本:

1.x--封闭的接口,不支持第三方设备

2.x--开放式接口,支持第三方设备

3.x--支持软件可擦写,固件(firmware)可升级

4.x--支持的设备

5.x--支持硬件域(domain),主要在高端机器(如6800,15K)上应用

查看系统当前的BootPROM版本号如果在操作系统状态可以用prtdiag-v或则prtconf-v命令,如果在ok状态则可以用banner命令。

BootPROM中包含以下内容:

1.上电自检程序(POST)

2.基本的设备驱动程序

3.ok状态命令行程序

4.省缺的配置参数

其它的系统配置信息如网卡的MAC地址、hostID、用户可配置参数(又称NVRAM参数或EEPROM参数)被放在了NVRAM芯片、SEEPROM或系统配置卡SCC上,其目的是为了方便系统迁移。

NVRAM芯片是主板上可插拔的一块芯片,有自己的锂电池用来保证所保存的信息不丢失,同时也提供了系统的时间。将NVRAM芯片设计成可插拔是为了便于一些依赖于hostid的软件迁移到别的主机。

实现过程

上电自检过程有以下步骤:

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中的超级终端软件。

操作命令

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

引导操作系统

boot[device_name]-option

boot-s用默认设备引导操作系统进入单用户模式

bootcdrom-s用cdrom引导操作系统进入单用户模式

boot-a交互式启动操作系统

boot-r引导操作系统,并将检测到的新硬件加入到操作系统

boot-v详细模式

获得命令的帮助

ok状态下可以使用help命令得到常用命令的帮助,help可以指定一个类别或者某个具体命令。具体分类用不带参数的help命令可以得到。

例如:helpboot将输出:

#TODO:justinaddhelpbootoutput

NVRAM参数

printenv,setenv,set-default,set-defaults这些命令用于显示、设置NVRAM参数

printenv不带参数时输出所有NVRAM参数的名称、当前值、默认值

例如:printenv

VariableNameValueDefaultValue

tpe-link-test?truetrue

scsi-initator-id77

ttyb-mode9600,8,n,1,-9600,8,n,1,-

boot-devicedisknetdisknet

auto-boot?truetrue

local-mac-address?falsefalse

use-nvramrc?falsefalse

nvramrcdevaliaspgx24/pcilf,0...

diag-switch?falsefalse

如果要输出某个参数的值,可以用printenv命令跟上该参数的名称,例如要知道当前OpenBootPROM是否自动引导操作系统可以用

printenvauto-boot?

NVRAM参数的命名有一定的规律,凡是布尔值参数名以问号结尾,像auto-boot?,tpe-link-test?,diag-switch?,local-mac-address?,use-nvramrc?等。

改变NVRAM参数用setenv命令,用法setenv参数名参数值,例如:

setenvauto-boot?true

要使修改的参数生效需要运行reset-all命令。

使用setenv修改参数可能引入错误,所以OpenBootPROM引入set-default和set-defaults两个命令用来将NVRAM参数恢复为出厂设置

set-default用于恢复单个NVRAM参数,set-default用于恢复所有NVRAM参数。

检测系统总线上的设备

OpenBootPROM中的probe族命令用来检测系统总线上的设备。

siftingprobe命令列出这些命令。

probe命令主要是用来检测scsi或ide设备是否正常,相应的命令是probe-scsi,probe-scsi-all和probe-ide。对于OpenBootPROM版本3.x或以上的系统运行probe族命令时,要确保操作系统未被引到过,否则容易导致系统挂起,从而引起可能的数据丢失。所以谨慎的做法是将auto-boot?设为false,然后重启系统进入ok状态。具体的操作办法是:如果当前处于操作系统状态,运行eepromauto-boot?=false和init0命令;如果当前处于ok状态,运行setenvauto-boot?false和reset-all。

如果不想执行上述谨慎的操作步骤,可以在ok状态通过.registers命令查看所有寄存器的值来确定运行probe族命令是否安全。只有当所有寄存器的值都为0时才是安全的。

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

设备名及设备别名

OpenBootPROM在自检完成后把设备按照它们在总线、控制器中的位置组织成一棵设备树。show-devs命令用来查看自检到的设备树

#TODO:justinaddshow-devsoutputsample

此外,show-ttys,show-displays,show-nets,show-disks,show-tapes分别用来查看相应类型的设备。

由于使用设备物理名称表示设备比较复杂,OBP中使用设备别名简化对设备的表示,devalias命令列出设备别名和设备物理名称的对应关系。

#TODO:justinadddevaliasoutputsample

除了预定义的设备别名外,OpenBootPROM允许自定义设备别名。要使自定义别名生效,应当将use-nvramrc?设为true。

定义设备别名用nvalias命令,用法nvaliasaliasnamedevice_path

删除设备别名用nvunalias命令,用法nvunaliasaliasname

在操作系统状态查看修改NVRAM参数

在Solaris操作系统运行时通过/usr/sbin/eeprom命令可以参看或修改NVRAM参数

不带参数的eeprom列出所有NVRAM参数,列出单个NVRAM参数在eeprom命令后加上该参数名,设置参数eeprom命令后加上参数名的赋值表达式。例如:

eeprom--显示所有NVRAM参数

eepromboot-device--显示默认的引导设备

eepromboot-device=disk2--将别名为disk2的设备设置成默认的引导设备

eepromauto-boot?=true--将OBP设置为自动引导操作系统

要注意的是在某些shell带有问号的参数需要用单用号引用,如Cshell。

免责声明
隐私政策
用户协议
目录 22
0{{catalogNumber[index]}}. {{item.title}}
{{item.title}}