Set a name for the BMC. This will control other things, like the
default value of the ipmi_sim startup command file and the place where
persistent data is stored.
|user usernum enabled username password max-priv max-session [auth [auth [...]]]|
usernum specifies the user number for the user. Note that user number 0 is
invalid, and user number 1 is the special "anonymous" user, whose
username is ignored. This value may be up to 63, the maximum possible
IPMI user. If you want anonymous access, you
must have a user number 1.
enabled is a boolean that specified whether the user is enabled or not.
username specifies the name of the user, specified as a name.
password specifies the password of the user, specified as a name.
max-priv specifies the maximum privilege level allowed for the user.
max.sessions specifies the maximum number of session the user may open.
auth specifies the allowed authorization types for the user. Only the specified ones are allowed, so if none are specified, the user will be disabled.
specifies a command to execute when a power on is requested. This lets
a virtual machine be started that can then connect back to the simulator.
The simulator does management of the process here, and the power on
state of the process depends on if the process exists or not. If a
poweroff is requested, if the process is connected to a VM serial
interface, a graceful shutdown is first requested. If the process
does not terminate in a specified amount of time, a SIGTERM is sent
to the process. The SIGTERM is sent immediately if there is no
connection. If the process doesnt go way in another specified amount
of time, a SIGKILL is sent.
If true, start the startcmd at the startup of the simulator. Otherwise
wait until a poweron is issued.
specifies the amount of time to wait for the startcmd to do a graceful shutdown
on a powerdown request. The simulator will send a request to the
target, wait this amount of time, and then do a SIGTERM kill on the
process. If this is zero, a SIGTERM will not be done (nor will a SIGKILL).
Note that if the simulator does not have a connection to the VM, the
graceful shutdown is skipped and a SIGTERM is done immediately.
Default time is 60 seconds.
specifies the amount of time to wait for SIGTERM to kill the process.
If the process does not terminate in this period of time, send a
SIGKILL kill. If this is zero, dont send the SIGKILL. Default time
is 20 seconds.
|console address port|
specifies that a console port be opened at the given address and port.
You can telnet to the console and execute emulation commands. Note that
this is a pretty huge security hole, it should only be used for debugging
in a captive environment.
|serial channel addr port [option [option [...]]]|
channel specifies the channel number or type. This may be kcs,
smic, or bt or it may be 15. Currently, only the system
interface channel (channel 15) is supported for serial interfaces, if
the others are specified it is channel 15 and the given interface is
reported in channel configuration commands.
addr specifies the IP address to listen on for connections.
port specifies the port to listen on for connections.
Valid options are:
codec name specifies which codec to use on the serial port. Valid options are: TerminalMode, Direct, RadisysAscii, and VM. The first three are implementations of IPMI serial interfaces on certain systems and might be used for simulations of that system. The VM is probably the most interesting; it is designed to be used with a virtual machine like qemu.
oem name specified implementation of some OEM custom commands and options on the interface. Valid options oare PigeonPoint and Radisys.
attn c1[,c2[...]] specifies a list of characters, separated by commas, to use as the attention character on the interface. Generally the default is correct. The characters are specified as decimal, octal, or hex digits in C style.
ipmb addr specifies the IPMI address of the interface. The default, 0x20, is usually correct, but when emulating ATCA systems this might be required.
|sol device default_baud [history=size[,backupfile=filename]] [historyfru=frunum]|
Allow a Serial Over LAN (SOL) connection to the given device. This will be over interface 1 for the MC.
device is the full path to the device name.
default_baud sets the initial default baud rate to use. This is overriden by the persistent SOL settings.
history creates a history device on SOL interface 2. The size is the size of the buffer. Data from the device is stored in the history buffer all the time. Connecting to SOL interface 2 will cause the full history buffer to be dumped. If backupfile is specified, then the history is made persistent. However, it is only stored when a catchable signal or normal shutdown is done, so a poweroff or fatal signal will cause the data to be lost.
historyfru makes the history available via the given FRU number on the MC.
|loadlib "module" ["options"]|
Load the given shared object into the program.
module is the full path to the module. It must be in quotes.
options is an optional string in quotes that passes options to the module. The contents of the string are not specified, the module defines that.
The module may have a number of functions that are called:
ipmi_sim_module_print_version(sys_data_t *sys, char *options) is called when ipmi_sim is started with the version print option. This way the versions of all loaded modules may be printed. The module should print its version. You must provide this function.
ipmi_sim_module_init(sys_data_t *sys, char *options) is called after the configuration file is read and before any other initialization is done. The module should do most of its initialization here. You must provide this function.
ipmi_sim_module_post_init(sys_data_t *sys) is called after ipmi_sim has finished initializing. This function is optional.
sys parameter is used for most functions interfacing to the main ipmi_sim
code, like logging, timers, and a few of the MC calls. The contents
are opaque to the module.
Starts a LAN configuration area. This specifies the settings for a LAN
connection using the given channel. This may be specified more than
once in a file to support multiple LAN connections. Commands following
this, up to endlan, are LAN-specific commands listed below.
channel specifies the channel to set the LAN configuration for.
The following commands are only valid inside a startlen area.
addr IP-address [UDP-port] IP-address specifies the IP address to use for an IP port. Up to 4 addresses may be specified. If no address is specified, it defaults to one port at 0.0.0.0 (for every address on the machine) at port 623.
UDP-port specifies an optional port to listen on. It defaults to 623 (the standard port).
PEF_alerting boolean Turn PEF alerting on or off (not currently supported).
per_msg_auth boolean Turn per-message authentication on or off.
priv_limit priv The maximum privilege allowed on this interface.
allowed_auths_callback [auth [auth [...]]] auth specifies allowed authorization levels for the callback privilege level. Only the levels specified on this line are allowed for the authorization level. If this line is not present, callback authorization cannot be used.
allowed_auths_user [auth [auth [...]]] auth specifies allowed authorization levels for the user privilege level. Only the levels specified on this line are allowed for the authorization level. If this line is not present, user authorization cannot be used.
allowed_auths_operator [auth [auth [...]]] auth specifies allowed authorization levels for the operator privilege level. Only the levels specified on this line are allowed for the authorization level. If this line is not present, operator authorization cannot be used.
allowed_auths_admin [auth [auth [...]]] auth specifies allowed authorization levels for the admin privilege level. Only the levels specified on this line are allowed for the authorization level. If this line is not present, user authorization cannot be used.
guid name Allows the 16-byte GUID for the IPMI LAN connection to be specified. If this is not specified, then the GUID command is not supported.
IPMI is unnecessarily complicated.
Corey Minyard <email@example.com>