Copyright (c) 2003, Sun Microsystems, Inc.
The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
STOP-A
BREAK
initial system power-on
exit from a client program, e.g., the Operating System
The CPU board of a workstation contains one or more EPROMs or EEPROMs. The program which executes from the PROMs is referred to as "the monitor". Among other things, the monitor performs system initialization at power-on and provides a user interface.
The monitor of earlier workstations was known as the SunMON monitor and displayed the > for its prompt. See the SunMON MONITOR USAGE section for further details.
Existing workstations use a monitor which is known as the OpenBoot monitor. The OpenBoot monitor typically displays ok as its prompt, but it may also display the > prompt under certain circumstances.
If the 'auto-boot?' NVRAM parameter is set to 'false' when the workstation is powered on, the system does not attempt to boot and the monitor issues its prompt. If 'auto-boot' is set to 'true', the system initiates the boot sequence. The boot sequence can be aborted by simultaneously pressing two keys on the system's keyboard: L1 and A (on older keyboards), or Stop and A (on newer keyboards). Either a lower case a or an upper case A works for the keyboard abort sequence. If a console has been attached by way of one of the system's serial ports then the abort sequence can be accomplished by sending a BREAK. See tip(1).
When the NVRAM 'security-mode' parameter has been turned on, or when the value of the 'sunmon-compat?' parameter is true, then the OpenBoot monitor displays the message: Type b (boot), c (continue), or n (new command mode)
and the > prompt appears.
Some of the more useful commands that can be issued from OpenBoot's ok prompt are described here. Refer to the book for a complete list of commands.
Help for various functional areas of the OpenBoot monitor can be obtained by typing help. The help listing provides a number of other key words which can then be used in the help command to provide further details.
Each workstation contains one or more NVRAM devices which contains unique system ID information, as well as a set of user-configurable parameters. The NVRAM parameters allow the user a certain level of flexibility in configuring the system to act in a given manner under a specific set of circumstances.
See eeprom(1M) for a description of the parameters and information regarding setting the parameters from the OS level.
The following commands can be used at the OpenBoot monitor to access the NVRAM parameters. printenv
Used to list the NVRAM parameters, along with their default values and current values.
Used to set or modify a parameter. The pn represents the parameter name, and pv represents the parameter value.
Used to set an individual parameter back to its default value.
Used to reset all parameters to their default values. (Note that 'set-defaults' only affects parameters that have assigned default values.)
Newer OpenBoot monitors contain user interfaces that support the storage and listing of keys for later use by client programs. list-security-keys
Lists the names of keys currently stored on a machine.
Stores key data keydata in a key named keyname. Actual key data can be up to 32 bytes in length. The maximum length of keyname is 64 bytes, which allows for the hex-formatted ASCII used to present the key data. If keydata is not present, keyname and its corresponding data is deleted.
The following commands are available for testing or checking the system's hardware. If the 'diag-switch?' NVRAM parameter is set to true when the system is powered on, then a Power-On Self Test (POST) diagnostic is run, if present, sending its results messages to the system's serial port A. Not all of the commands shown are available on all workstations. test-all
Run the diagnostic tests on each device which has provided a self-test.
Run diagnostics on the system's floppy device.
Run the main memory tests. If the NVRAM parameter 'diag-switch?' is set to true, then all of main memory is tested. If the parameter is false then only the amount of memory specified in the 'selftest-#megs' NVRAM parameter is tested.
Test the network connection for the on-board network controller.
Monitor the network attached to the on-board net controller.
Monitor the network attached to the on-board net controller, as well as the network controllers installed in SBus slots.
Test the system's clock function.
The following commands are available for displaying information about the system. Not all commands are available on all workstations. banner
Display the power-on banner.
Display the system's Ethernet address.
Display the formatted contents of the IDPROM.
Display information about the system's processor(s).
Identify the devices attached to the on-board SCSI controller.
Identify the devices attached to the on-board SCSI controller as well as those devices which are attached to SBus SCSI controllers.
Display a list of the device paths for installed SCSI disk controllers.
Display a list of the device paths for installed display devices.
Display a list of the device paths for installed Ethernet controllers.
Display list of installed SBus devices.
Display a list of the device paths for installed SCSI tape controllers.
Display a list of the device paths for tty devices.
Display a list of the SPARC trap types.
Display the version and date of the OpenBoot PROM.
These commands must be typed from the keyboard, they do not work from a console which is attached by way of the serial ports. With the exception of the Stop-A command, these commands are issued by pressing and holding down the indicated keys on the keyboard immediately after the system has been powered on. The keys must be held down until the monitor has checked their status. The Stop-A command can be issued at any time after the console display begins, and the keys do not need to be held down once they've been pressed. The Stop-D, Stop-F and Stop-N commands are not allowed when one of the security modes has been set. Not all commands are available on all workstations. Stop (L1)
Bypass the Power-On Self Test (POST). This is only effective if the system has been placed into the diagnostic mode.
Abort the current operation and return to the monitor's default prompt.
Set the system's 'diag-switch?' NVRAM parameter to 'true', which places the system in diagnostic mode. POST diagnostics, if present, are run, and the messages are displayed by way of the system's serial port A.
Enter the OpenBoot monitor before the monitor has probed the system for devices. Issue the 'fexit' command to continue with system initialization.
Causes the NVRAM parameters to be reset to their default values. Note that not all parameters have default values.
The following commands can be used while the monitor is displaying the ok prompt. Not all of these editing commands are available on all workstations. CTRL-A
Place the cursor at the start of line.
Move the cursor backward one character.
Move the cursor backward one word.
Erase the character that the cursor is currently highlighting.
Erase the portion of word from the cursor's present position to the end of the word.
Place the cursor at the end of line.
Move the cursor forward one character.
Move the cursor forward one word.
Erase the character preceding the cursor (also use Delete or Back Space)
Erase the portion of the word which precedes the cursor (use also CTRL-W)
Erase from the cursor's present position to the end of the line.
Show the command history list.
Recall the next command from the command history list
Recall a previous command from the command history list.
Quote the next character (used to type a control character).
Retype the current line.
Erase from the cursor's present position to the beginning of the line.
Insert the contents of the memory buffer into the line, in front (to the left) of the cursor.
The nvramrc is an area of the system's NVRAM where users may store Forth programs. The programs which are stored in the nvramrc are executed each time the system is reset, provided that the 'use-nvramrc?' NVRAM parameter has been set to 'true'. Refer to the book for information on how to edit and use the nvramrc.
The command 'old-mode' is used to move OpenBoot into a restricted monitor mode, causing the > prompt to be displayed. Only three commands are allowed while in the restricted monitor; the 'go' command (to resume a program which was interrupted with the Stop-A command), the 'n' command (to return to the normal OpenBoot monitor), and boot commands. The restricted monitor's boot commands approximate the older SunMON monitor's boot command syntax. If a 'security-mode' has been turned on then the restricted monitor becomes the default monitor environment. The restricted monitor may also become the default environment if the 'sunmon-compat?' NVRAM parameter is set to true. Not all workstations have the 'sunmon-compat?' parameter.
The following commands are available systems with older SunMON-based PROM: +|-
Increment or decrement the current address and display the contents of the new location.
(caret-C) Copy, byte-by-byte, a block of length n from the source address to the destination address.
(caret-I) Display the compilation date and location of program.
(caret-T) Display the physical address to which virtual_address is mapped.
Reset appropriate parts of the system and bootstrap a program. A `!' (preceding the device argument) prevents the system reset from occurring. Programs can be loaded from various devices (such as a disk, tape, or Ethernet). `b' with no arguments causes a default boot, either from a disk, or from an Ethernet controller. `b?' displays all boot devices and their devices. device
one of le
Lance Ethernet
Intel Ethernet
SCSI disk, CDROM
SCSI 1/4" or 1/2" tape
Diskette
IPI disk
Tape Master 9-track 1/2" tape
Xylogics 7053 disk
Xylogics 1/2" tape
Xylogics 440/450 disk
A controller number (0 if only one controller),
A unit number (0 if only one driver), and
A partition.
A list of up to seven arguments to pass to the program being booted.
Resume execution of a program. When given, virtual_address is the address at which execution resumes. The default is the current PC. Registers are restored to the values shown by the d, and r commands.
Display (dump) the state of the processor. The processor state is observable only after:
An unexpected trap was encountered.
A user program dropped into the monitor (by calling abortent).
The user manually entered the monitor by typing L1-A or BREAK.
The special registers: PSR, PC, nPC, TBR, WIM, and Y
Eight global registers
24 window registers (8 in, 8 local, and 8 out), corresponding to one of the 7 available windows. If a Floating-Point Unit is on board, its status register along with 32 floating-point registers are also shown.
Display the indicated window_number, which can be any value between 0 and 6, inclusive. If no window is specified and the PSR's current window pointer contains a valid window number, registers from the window that was active just prior to entry into the monitor are displayed. Otherwise, registers from window 0 are displayed.
Open the 16-bit word at virtual_address (default zero). The address is interpreted in the address space defined by the s command. See the a command for a description of action.
Fill the bytes, words, or long words from virtual_address1 (lower) to virtual_address2 (higher) with the constant, pattern. The size argument can take one of the following values: b
byte format (the default)
word format
long word format
g [virtual_address\|] [argument\|]
Goto (jump to) a predetermined or default routine (first form), or to a user-specified routine (second form). The value of argument is passed to the routine. If the vector or virtual_address argument is omitted, the value in the PC is used as the address to jump to. To set up a predetermined routine to jump to, a user program must, prior to executing the monitor's g command, set the variable *romp->v_vector_cmd to be equal to the virtual address of the desired routine. Predetermined routines need not necessarily return control to the monitor. The default routine, defined by the monitor, prints the user-supplied vector according to the format supplied in argument. This format can be one of: %x
hexadecimal
decimal
Force a panic and produce a crash dump when the monitor is running as a result of the system being interrupted,
(Sun-4 systems only) Force a kernel stack trace when the monitor is running as a result of the system being interrupted,
Display the help menu for monitor commands and their descriptions. To return to the monitor's basic command level, press ESCAPE or q before pressing RETURN.
Modify cache data RAM command. Display and/or modify one or more of the cache data addresses. See the a command for a description of action.
Modify cache tag RAM command. Display and/or modify the contents of one or more of the cache tag addresses. See the a command for a description of action.
Reset the system, where reset_level is: 0
Reset VMEbus, interrupt registers, video monitor (Sun-4 systems). This is the default.
Software reset.
Power-on reset. Resets and clears the memory. Runs the EPROM-based diagnostic self test, which can take several minutes, depending upon how much memory is being tested.
Display the system banner.
Open the long word (32 bit) at memory address virtual_address (default zero). The address is interpreted in the address space defined by the s command (below). See the a command for a description of action.
Open the segment map entry that maps virtual_address (default zero). The address is interpreted in the address space defined by the s command. See the a command for a description of action.
Disable, enable, or invalidate the cache, respectively.
Open the byte location specified by virtual_address (default zero). The address is interpreted in the address space defined by the s command. See the a command for a description of action.
Open the page map entry that maps virtual_address (default zero) in the address space defined by the s command. See the a command for a description of action.
Open the EEPROM eeprom_offset (default zero) in the EEPROM address space. All addresses are referenced from the beginning or base of the EEPROM in physical address space, and a limit check is performed to insure that no address beyond the EEPROM physical space is accessed. This command is used to display or modify configuration parameters, such as: the amount of memory to test during self test, whether to display a standard or custom banner, if a serial port (A or B) is to be the system console, etc. See the a command for a description of action.
r\| [register_type\|]
r\| [w window_number\|]
Display and/or modify one or more of the IU or FPU registers. A hexadecimal register_number can be one of: 0x00-0x0f
window(0,i0)-window(0,i7), window(0,i0)\(emwindow(0,i7)
window(1,i0)-window(1,i7), window(1,i0)\(emwindow(1,i7)
window(2,i0)-window(2,i7), window(2,i0)\(emwindow(2,i7)
window(3,i0)-window(3,i7), window(3,i0)\(emwindow(3,i7)
window(4,i0)-window(4,i7), window(4,i0)\(emwindow(4,i7)
window(5,i0)-window(5,i7), window(5,i0)\(emwindow(5,i7)
window(6,i0)-window(6,i7), window(6,i0)\(emwindow(6,i7)
g0, g1, g2, g3, g4, g5, g6, g7
PSR, PC, nPC, WIM, TBR, Y.
FSR, f0-f31
floating-point
global
special
Set or display the Address Space Identifier. With no argument, s displays the current Address Space Identifier. The asi value can be one of: 0x2
control space
segment table
Page table
user instruction
supervisor instruction
user data
supervisor data
flush segment
flush page
flush context
cache data
With no arguments, display the current I/O device characteristics including: current input device, current output device, baud rates for serial ports A and B, an input-to-output echo indicator, and virtual addresses of mapped UART devices. With arguments, set or configure the current I/O device. With the u argument (uu.\|.\|.), set the I/O device to be the virtual_address of a UART device currently mapped. echo
Can be either e to enable input to be echoed to the output device, or ne, to indicate that input is not echoed.
Assign the indicated port to be the current I/O device. port can be one of: a
serial port A
serial port B
the workstation keyboard
the workstation screen
Any legal baud rate.
can be any combination of: i
input
output
UART
echo input to output
do not echo input
reset indicated serial port (a and b ports only)
Display the contents of virtual_address1 (lower) virtual_address2 (higher) in the format specified by size: b
byte format (the default)
word format
long word format
Set the execution vector to a predetermined or default routine. Pass virtual_address and argument to that routine. To set up a predetermined routine to jump to, a user program must, prior to executing the monitor's w command, set the variable *romp->v_vector_cmd to be equal to the virtual address of the desired routine. Predetermined routines need not necessarily return control to the monitor. The default routine, defined by the monitor, prints the user-supplied vector according to the format supplied in argument. This format can be one of: %x
hexadecimal
decimal
Display a menu of extended tests. These diagnostics permit additional testing of such things as the I/O port connectors, video memory, workstation memory and keyboard, and boot device paths.
Flush the indicated context, context page, or context segment. c
flush context context_number
flush the page beginning at virtual_address within context context_number
flush the segment beginning at virtual_address within context context_number
See attributes(5) for descriptions of the following attributes:
ATTRIBUTE TYPE ATTRIBUTE VALUE |
Architecture SPARC |
tip(1), boot(1M), eeprom(1M), attributes(5)