freeipmi-faq - phpMan

Command: man perldoc info search(apropos)  


File: freeipmi-faq.info,  Node: Top,  Next: What is IPMI?,  Prev: (dir),  Up: (dir)

Frequently Asked Questions on *FreeIPMI*

   This edition of the documentation was last updated on January 19,
2022 for release 1.6.9 of the FreeIPMI.

* Menu:

* What is IPMI?::
* What is FreeIPMI?::
* How did FreeIPMI start?::
* What operating systems does FreeIPMI run on?::
* FreeIPMI vs OpenIPMI vs Ipmitool vs Ipmiutil::
* What is special about FreeIPMI?::
* Does my system support IPMI?::
* How do I compile FreeIPMI?::
* libgcrypt requirement::
* x86-64 Compilation::
* Installing FreeIPMI on FreeBSD::
* What are some IPMI terminology or acronyms I should be aware of?::
* What setup is needed for FreeIPMI to communicate over LAN?::
* What setup is needed for Serial over LAN (SOL) or Ipmiconsole?::
* Do I need to install or configure a driver to perform IPMI inband?::
* SSIF Driver Configuration::
* How do you setup Powerman with ipmipower?::
* How do you setup Conman with ipmiconsole or libipmiconsole?::
* How do you setup Conserver with libipmiconsole?::
* How do you setup Ganglia or Nagios to monitor IPMI sensors via FreeIPMI?::
* Why are times reported by FreeIPMI tools wrong?::
* Why is the IPMI kernel driver faster than the KCS driver?::
* Why is the output from FreeIPMI different than another software?::
* Why are there so many IPMI compliance bugs?::
* How do I get around an IPMI compliance bug on my motherboard?::
* Why am I seeing so many 'internal IPMI error' or 'driver busy' messages?::
* How do I program with the FreeIPMI libraries?::
* Where can I get additional help or support?::

File: freeipmi-faq.info,  Node: What is IPMI?,  Next: What is FreeIPMI?,  Prev: Top,  Up: Top

1 What is IPMI?
===============

The IPMI specifications define standardized, abstracted interfaces to
the platform management subsystem.  IPMI includes the definition of
interfaces for extending platform management between the board within
the main chassis and between multiple chassis.

   The term platform management is used to refer to the monitoring and
control functions that are built in to the platform hardware and
primarily used for the purpose of monitoring the health of the system
hardware.  This typically includes monitoring elements such as system
temperatures, voltages, fans, power supplies, bus errors, system
physical security, etc.  It includes automatic and manually driven
recovery capabilities such as local or remote system resets and power
on/off operations.  It includes the logging of abnormal or out-of-range
conditions for later examination and alerting where the platform issues
the alert without aid of run-time software.  Lastly it includes
inventory information that can help identify a failed hardware unit.

File: freeipmi-faq.info,  Node: What is FreeIPMI?,  Next: How did FreeIPMI start?,  Prev: What is IPMI?,  Up: Top

2 What is FreeIPMI?
===================

FreeIPMI is a collection of Intelligent Platform Management IPMI system
software.  It provides in-band and out-of-band software and a
development library conforming to the Intelligent Platform Management
Interface (IPMI v1.5 and v2.0) standards.  FreeIPMI also supports
IPMI-related specifications such as the Data Center Management Interface
(DCMI) and Intel Node Manager.

File: freeipmi-faq.info,  Node: How did FreeIPMI start?,  Next: What operating systems does FreeIPMI run on?,  Prev: What is FreeIPMI?,  Up: Top

3 How did FreeIPMI start?
=========================

In October 2003, California Digital Corp.  (CDC) was contracted by
Lawrence Livermore National Laboratory (LLNL) for the assembly of
Thunder, a 1024 node Itanium2 cluster.  This led to software developers
from CDC and LLNL merging the IPMI software developed by both
organizations into FreeIPMI.

   Anand Babu, Balamurugan and Ian Zimmerman at CDC contributed the
in-band KCS driver, 'ipmi-sensors', 'ipmi-sel', 'bmc-info', core
portions of 'ipmi-config', and portions of libfreeipmi.  Albert Chu and
Jim Garlick at LLNL contributed 'ipmipower', 'bmc-watchdog', 'ipmiping',
'rmcpping', portions of libfreeipmi, and IPMI support in Powerman.  In
October 2004, FreeIPMI 0.1.0 was officially released.

   Since the 0.1.0 release, Z Research developers have contributed
'ipmi-chassis', 'ipmi-raw', 'ipmi-locate', and PEF portions of
'ipmi-config'.  LLNL has contributed IPMI 2.0 support, hostrange
support, 'ipmiconsole', libipmiconsole, 'ipmidetect', 'bmc-device',
'ipmi-oem', 'ipmi-dcmi', libipmimonitoring, and the chassis and sensor
portions of 'ipmi-config'.

   (Note: The original FreeIPMI developers from California Digital Corp.
are now at Zresearch Inc.)

File: freeipmi-faq.info,  Node: What operating systems does FreeIPMI run on?,  Next: FreeIPMI vs OpenIPMI vs Ipmitool vs Ipmiutil,  Prev: How did FreeIPMI start?,  Up: Top

4 What operating systems does FreeIPMI run on?
==============================================

FreeIPMI was originally developed on GNU/Linux.  It has been confirmed
to be built on most major GNU/Linux distributions such as Redhat,
Fedora, Suse, and Debian.  FreeIPMI has been ported and confirmed to
work on atleast FreeBSD, OpenBSD, Solaris, OpenSolaris, and Windows via
Cygwin.  We imagine it would build cleanly on other operating systems.
If it doesn't, it should be easily portable to them.  Please contact the
maintainers on the <freeipmi-devel AT gnu.org> mailing lists.

File: freeipmi-faq.info,  Node: FreeIPMI vs OpenIPMI vs Ipmitool vs Ipmiutil,  Next: What is special about FreeIPMI?,  Prev: What operating systems does FreeIPMI run on?,  Up: Top

5 FreeIPMI vs OpenIPMI vs Ipmitool vs Ipmiutil
==============================================

There are multiple implementations, APIs, interfaces, end user
requirements, etc.  that one can choose when developing IPMI drivers,
libraries, and tools.  FreeIPMI has taken some different approaches than
other open-source projects.

   The section below points out a number of the reasons why we feel
FreeIPMI is particularly special compared to the other projects.

   The Ipmiutil project has a good chart describing many of the
differences between the projects:
<http://ipmiutil.sourceforge.net/docs/ipmisw-compare.htm>.

File: freeipmi-faq.info,  Node: What is special about FreeIPMI?,  Next: Does my system support IPMI?,  Prev: FreeIPMI vs OpenIPMI vs Ipmitool vs Ipmiutil,  Up: Top

6 What is special about FreeIPMI?
=================================

In our eyes, there are several reasons why FreeIPMI is particularly
special.

  1. Support for HPC, clusters, and large data centers

     A number of features have been added into the tools to support HPC,
     clusters, and/or large data centers.  Much of this original support
     was added to support the large cluster environments at Lawrence
     Livermore National Laboratory (LLNL).

     Scalable parallel execution of many FreeIPMI tools ('ipmi-sensors',
     'ipmi-sel', 'bmc-info', etc.)  across a cluster is supported
     through hostranged input and output.  For example:

          # > bmc-info -h "pwopr[0-5]" -u XXX -p XXX --get-device-id -C
          ----------------
          pwopr[0-1,5]
          ----------------
          Device ID             : 34
          Device Revision       : 1
          Device SDRs           : unsupported
          Firmware Revision     : 1.0c
          Device Available      : yes (normal operation)
          IPMI Version          : 2.0
          Sensor Device         : supported
          SDR Repository Device : supported
          SEL Device            : supported
          FRU Inventory Device  : supported
          IPMB Event Receiver   : unsupported
          IPMB Event Generator  : unsupported
          Bridge                : unsupported
          Chassis Device        : supported
          Manufacturer ID       : Peppercon AG (10437)
          Product ID            : 4
          Auxiliary Firmware Revision Information : 38420000h
          ----------------
          pwopr[2-4]
          ----------------
          Device ID             : 34
          Device Revision       : 1
          Device SDRs           : unsupported
          Firmware Revision     : 1.17
          Device Available      : yes (normal operation)
          IPMI Version          : 2.0
          Sensor Device         : supported
          SDR Repository Device : supported
          SEL Device            : supported
          FRU Inventory Device  : supported
          IPMB Event Receiver   : unsupported
          IPMB Event Generator  : unsupported
          Bridge                : unsupported
          Chassis Device        : supported
          Manufacturer ID       : Peppercon AG (10437)
          Product ID            : 4
          Auxiliary Firmware Revision Information : 38420000h

     In the above example, its clear to see that pwopr[2-4] have
     different firmware than pwopr[0-1,5].  More information about
     hostrange support can be found in the document
     'freeipmi-hostrange.txt'
     (<http://www.gnu.org/software/freeipmi/freeipmi-hostrange.txt>).

     'Ipmipower' is capable of scaling to large nodes for cluster
     support and is supported by Powerman
     (<https://github.com/chaos/powerman>) for scalable power
     management.  At LLNL, in conjunction with Powerman, ipmipower is
     used for power control on clusters ranging from sizes of 4 to 2000.
     It has been used to determine power status or power control LLNL's
     largest clusters in under a second.

     'libipmiconsole' is currently supported by Conman
     (<https://github.com/dun/conman>) and Conserver
     (<http://www.conserver.com/>) for scalable console management.

     'Ipmi-sensors' and libipmimonitoring are capable of interpreting
     sensor readings as well as just reporting them.  It can be used for
     host monitoring IPMI sensor severity on a cluster.  By mapping
     sensor readings into NOMINAL, WARNING, or CRITICAL states, it makes
     monitoring sensors easier across large numbers of nodes.  Skummee
     (<http://sourceforge.net/projects/skummee>) currently uses
     libipmimonitoring to monitoring sensors on LLNL clusters of up to
     2000 nodes in size.  FreeIPMI sensor monitoring plugins for Ganglia
     (<http://ganglia.info/>) and Nagios (<http://www.nagios.org/>) have
     also been developed and made available for download
     (<http://www.gnu.org/software/freeipmi/download.html>).

     'Ipmi-sel' and libipmimonitoring are capable of interpreting system
     event log (SEL) entries as well as just reporting them.  It can be
     used for host monitoring IPMI event severity on a cluster.  By
     mapping events into NOMINAL, WARNING, or CRITICAL states, it makes
     monitoring system events easier across large numbers of nodes.
     Skummee (<http://sourceforge.net/projects/skummee>) currently uses
     libipmimonitoring to monitoring the SEL on LLNL clusters of up to
     2000 nodes in size.

     The 'ipmi-config' configuration file and command-line interface are
     used to easily copy the BMC configuration from one node to every
     other node in a cluster quickly.  It has been used to modify the
     BMC configuration across large LLNL clusters in a few minutes.
     They also have the capability to verify (via the diff option) that
     the desired configuration has been properly stored to firmware.

     'Ipmidetect' can be used to enhance the efficiency of the
     hostranged input by eliminating those nodes in the cluster that
     have been temporarily removed for servicing.

     FreeIPMI is supported within Slurm for energy consumption
     monitoring.

  2. Additional OEM support

     FreeIPMI contains support for a number of OEM extensions and OEM
     sensors and/or events.  'Ipmi-oem' currently supports OEM command
     extensions for motherboards made by Dell, Fujitsu, IBM, Intel,
     Inventec, Quanta, Sun Microsystems, Supermicro, and Wistron.
     'Ipmi-sensors' and 'ipmi-sel' support OEM sensors and/or events for
     motherboards made from Dell, Fujitsu, HP, Intel, Inventec, Quanta,
     Sun Microsystems, Supermicro, and Wistron.  (Some of the
     motherboards may have been rebranded by vendors, see manpages for
     official list of confirmed supported motherboards.)

  3. Additional flexibility and features

     By implementing various IPMI sub-sections into multiple tools, each
     tool is capable of providing the user with more flexibility and
     ultimately more features in addition to those listed above.  It may
     not be as easy (or architecturally possible) to do in an all-in-one
     tool.

  4. Extra IPMI support

     In addition to the features listed above, FreeIPMI also supports
     specifications related to IPMI.  The Data Center Management
     Interface, or DCMI, is supported via the FreeIPMI tool 'ipmi-dcmi'.
     Some aspects of the Intel Power Node Manager are supported in
     'ipmi-oem'.

  5. Easy setup

     By implementing drivers in userspace libraries, there is no need to
     build/setup/manage any kernel modules/drivers.

  6. Portability

     Likewise, by implementing everything in userspace libraries and
     tools, portability to multiple operating systems and architectures
     should be easier.

File: freeipmi-faq.info,  Node: Does my system support IPMI?,  Next: How do I compile FreeIPMI?,  Prev: What is special about FreeIPMI?,  Up: Top

7 Does my system support IPMI?
==============================

Unfortunately, there are no universally defined mechanisms for
determining if a system supports IPMI via Inband communication.
Assuming IPMI is set up correctly for over LAN communication, a fairly
reliable mechanism exists out-of-band.  Here are some suggestions.

  1. FreeIPMI's 'ipmi-locate' can be used to determine if IPMI can be
     found on your system.  Users are cautioned though, the failure to
     discover IPMI via 'ipmi-locate' is not sufficient to disprove that
     IPMI exists on your system.  Your system may not publish such
     information or may expect clients to communicate at default
     locations.

  2. 'dmidecode' may be similarly used to probe for devices that support
     IPMI on your system.  You may grep for IPMI or specify the IPMI DMI
     type on the command line.

          # > dmidecode --type 38
          # dmidecode 2.10
          SMBIOS 2.5 present.

          Handle 0x0049, DMI type 38, 18 bytes
          IPMI Device Information
                  Interface Type: KCS (Keyboard Control Style)
                  Specification Version: 2.0
                  I2C Slave Address: 0x10
                  NV Storage Device: Not Present
                  Base Address: 0x0000000000000CA2 (I/O)
                  Register Spacing: Successive Byte Boundaries

  3. FreeIPMI's 'ipmi-ping' can be used to see if a machine has an IPMI
     service at a specific host/IP address.  For more wide scale IPMI
     discovery, the 'ipmi-detectd' daemon and 'ipmi-detect' tool can be
     used.

   Again, the failure to find an IPMI supported device is not sufficient
to show lack of IPMI support.

   Ultimately, some amount of information from product documents or
trial and error may be necessary to determine if IPMI is supported on
your system.

File: freeipmi-faq.info,  Node: How do I compile FreeIPMI?,  Next: libgcrypt requirement,  Prev: Does my system support IPMI?,  Up: Top

8 How do I compile FreeIPMI?
============================

Please see the README.build instructions provided with FreeIPMI or on
the FreeIPMI website's documentation
(<http://www.gnu.org/software/freeipmi/README.build>).

File: freeipmi-faq.info,  Node: libgcrypt requirement,  Next: x86-64 Compilation,  Prev: How do I compile FreeIPMI?,  Up: Top

9 libgcrypt requirement
=======================

FreeIPMI requires the libgcrypt library to be installed for a variety of
encryption requirements in IPMI 2.0.  If you are building FreeIPMI and
receive a 'libgcrypt required to build libfreeipmi' error, please
install libgcrypt.  For Linux users, this may require the install of the
libgcrypt-devel package as well.  For those who do not need IPMI 2.0
encryption, FreeIPMI may be built without it by specifying
'--without-encryption' when executing configure.

File: freeipmi-faq.info,  Node: x86-64 Compilation,  Next: Installing FreeIPMI on FreeBSD,  Prev: libgcrypt requirement,  Up: Top

10 x86-64 Compilation
=====================

By default, FreeIPMI's build autotools (e.g.  configure) should detect
if you are on a 64 bit system and should build against 64 bit libraries.
However, some multi-architecture installs (e.g.  you have 32 bit and 64
bit libraries installed) may lead to builds and installs of 32 bit
instead of 64 bit.  For those noticing this, pass libdir appropriately
to the configure script to workaround this problem.  (e.g.
'--libdir=/usr/lib64')

   Example:
       # ./configure  --prefix=/usr --libdir=/usr/lib64

File: freeipmi-faq.info,  Node: Installing FreeIPMI on FreeBSD,  Next: What are some IPMI terminology or acronyms I should be aware of?,  Prev: x86-64 Compilation,  Up: Top

11 Installing FreeIPMI on FreeBSD
=================================

You can install a binary package of freeipmi or use the port, located in
ports/sysutils/freeipmi, to build it from the source.  See ports(7) and
'Packages and Ports' section
(<http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/ports.html>)
in The FreeBSD Handbook.

   Please contact port maintainer (MAINTAINER line in the port's
Makefile), if you have problems building from the port.

File: freeipmi-faq.info,  Node: What are some IPMI terminology or acronyms I should be aware of?,  Next: What setup is needed for FreeIPMI to communicate over LAN?,  Prev: Installing FreeIPMI on FreeBSD,  Up: Top

12 What are some IPMI terminology or acronyms I should be aware of?
===================================================================

Good question, here are some terms and acronyms with general definition
you might want to know.

*BMC*

     The *Baseboard Management Controller* is the management chip on the
     system that is responsible for IPMI.  It is common to refer to
     configuring the "BMC" as synonymous for configuring IPMI.

*inband*

     *inband* IPMI communication refers to communication on a system
     locally (i.e.  not over a network).

*outofband*

     *outofband* and *IPMI over LAN* refer to IPMI communication over a
     network, typically ethernet.

*SDR*

     The *Sensor Data Repository* is a database of system information
     that is needed by many other IPMI functions.  It is commonly read
     before some IPMI action can be taken.  For example, it contains a
     list of all sensors on a system, so it must be downloaded before
     sensors on a system can be read.  In FreeIPMI, the SDR is cached in
     a common location and can be used by a number of tools, such as
     'ipmi-sensors', 'ipmi-sel', and 'ipmi-fru'.

*SEL*

     The *System Event Log* is a log of events stored on the system for
     later diagnostics.  In FreeIPMI, 'ipmi-sel' can be used to read the
     SEL.

*FRU*

     The *Field Replaceable Unit* is a general computing term refering
     to a replaceable unit of electronics.  In IPMI it is common to
     refer to the "FRU" as the database of all FRU components on a
     system.  In FreeIPMI, 'ipmi-fru' can be used to read the FRU
     components on a system.

*PEF*

     *Platform Event Filtering* refers to the rules that determine when
     PETs are generated and where they are sent.  In FreeIPMI, PEF can
     be configured via 'ipmi-config'.

*PET*

     *Platform Event Trap* refers to a trap that can be sent by a system
     to an SNMP agent to indicate an event has occurred on the system.
     In FreeIPMI, a PET trap can be interpreted via 'ipmi-pet'.

*DCMI*

     The *Data Center Management Interface* is a management interface
     defined by a group of vendors that use IPMI as the backend for
     their system management definition.  In FreeIPMI, 'ipmi-dcmi' can
     be used to read/configuring DCMI.

*SOL*

     *Serial over LAN* refers to the forwarding of serial system traffic
     over a network, typically an ethernet network.  It is typically
     used to access a remote system console.  In FreeIPMI, ipmiconsole
     is used to access a remote console via SOL.

*RMCP*

     The *Remote Management Control Protocol* protocol is another remote
     management protocol which IPMI is defined within for outofband
     communication.  For most IPMI users, you will never need to know
     about RMCP.

File: freeipmi-faq.info,  Node: What setup is needed for FreeIPMI to communicate over LAN?,  Next: What setup is needed for Serial over LAN (SOL) or Ipmiconsole?,  Prev: What are some IPMI terminology or acronyms I should be aware of?,  Up: Top

13 What setup is needed for FreeIPMI to communicate over LAN?
=============================================================

Please see the ipmi-config.conf(5) manpage provided with FreeIPMI for
details, or you can read it on the FreeIPMI website's documentation
(<http://www.gnu.org/software/freeipmi/manpages/man5/ipmi-config.conf.5.html>).

File: freeipmi-faq.info,  Node: What setup is needed for Serial over LAN (SOL) or Ipmiconsole?,  Next: Do I need to install or configure a driver to perform IPMI inband?,  Prev: What setup is needed for FreeIPMI to communicate over LAN?,  Up: Top

14 What setup is needed for Serial over LAN (SOL) or Ipmiconsole?
=================================================================

The setup of Serial-over-LAN (SOL) and/or 'Ipmiconsole' is highly
dependent on your system.  However, most motherboardss require the
following:

  1. Adjust the BIOS COM port for serial redirection over SOL instead of
     the normal serial port and set the appropriate baud rate.  If you
     do not know which port is the SOL port, you may need to play around
     and guess.  It is likely a non-default setting, since many
     manufacturers may still assume the default redirection is out of
     the normal serial port.  If you do not have a serial port on your
     motherboard, this part can probably be skipped.

  2. Configure IPMI on the motherboard to use SOL.  Many motherboards
     may have this enabled by default, however you may wish to verify
     with FreeIPMI's 'ipmi-config'.  More information can be found in
     the ipmi-config.conf(5) manpage on the settings.  However, the key
     settings are to enable SOL on the system, enable SOL for individual
     users, and select the appropriate baud.  On many motherboards, the
     selected baud must match what is configured in the BIOS.

  3. Adjust your operating systems serial console settings to use the
     appropriate COM port.  For Linux, the following guide
     (<http://www.vanemery.com/Linux/Serial/serial-console.html>)
     provides a pretty good overview of setting of a serial console on
     Linux.  The only difference for setting up a serial console with
     'Ipmiconsole' or SOL, is the ttySX terminal may need to be changed.

File: freeipmi-faq.info,  Node: Do I need to install or configure a driver to perform IPMI inband?,  Next: SSIF Driver Configuration,  Prev: What setup is needed for Serial over LAN (SOL) or Ipmiconsole?,  Up: Top

15 Do I need to install or configure a driver to perform IPMI inband?
=====================================================================

For most people the answer is no.

   FreeIPMI includes a userspace driver that works on most motherboards
without any driver installation, loading, or configuration required.
FreeIPMI also includes support of a Linux SSIF driver through the SSIF
device (i.e.  '/dev/i2c-0'), the OpenIPMI Linux kernel driver (i.e.
'/dev/ipmi0'), the Sun/Solaris BMC driver (i.e.  '/dev/bmc'), and the
Intel DCMI/MEI driver (i.e.  '/dev/dcmi').  If you communicate through
one of these mechanisms, the appropriate drivers for them should be
loaded.  Most systems should automatically load the appropriate drivers
you need.

   Under most scenarios, the FreeIPMI tools should automatically
discover which in-band interface to use and the proper settings to use.
Some motherboards may require you to determine alternate configurations
for addresses, paths, etc.  on your own and pass them as command line
options to the tools.

   Every system is different and your situation may differ.  Please see
your manufacturer and operating system instructions.

   Special note: At the time of this writing the Intel DCMI/MEI Linux
device drivers are not distributed widely.  Please work with your vendor
to obtain the Intel MEI and DCMI device drivers.

   There are some additional Linux OpenIPMI kernel driver notes here:
<http://www.gnu.org/software/freeipmi/README.openipmi>.

File: freeipmi-faq.info,  Node: SSIF Driver Configuration,  Next: How do you setup Powerman with ipmipower?,  Prev: Do I need to install or configure a driver to perform IPMI inband?,  Up: Top

16 SSIF Driver Configuration
============================

FreeIPMI's SSIF driver works on top of kernel'2 i2c device interface.

   Under GNU/Linux load these kernel modules: i2c-dev, i2c-i801,
i2c-core before using FreeIPMI.

   To identify SSIF device address:

   Example:
     $> lspci  (in the output look for this entry)
      00:1f.3 SMBus: Intel Corp. 6300ESB SMBus Controller (rev 01)
            Subsystem: Intel Corp.: Unknown device 342f
            Flags: medium devsel,  IRQ 17
            I/O ports at 0400 [size=32]
                         ----
     $> cat /proc/bus/i2c
     i2c-0   smbus    SMBus I801 adapter at 0400         Non-I2C SMBus adapter
                                            ----
         Make sure the "0400" above matches with the "0400" address under
         proc.  Also make sure "i2c-0" is not different. If it appears
         different then grep for "i2c-0" in this code "ipmitool.c" and
         change. "i2c-X" is the label assigned to each slave device attached on
         the i2c bus.

     BMC address Locator:
         Refer to the SM BIOS IPMI Device Information Record
         Type 38,  record 06h and 08h. Use the value of record
         06h as the IPMBAddress and load the SMBus controller
         driver at the address value read from record 08h.

         Usual values for record 06h -> 0x42
         Usual values for record 08h -> 0x400

File: freeipmi-faq.info,  Node: How do you setup Powerman with ipmipower?,  Next: How do you setup Conman with ipmiconsole or libipmiconsole?,  Prev: SSIF Driver Configuration,  Up: Top

17 How do you setup Powerman with ipmipower?
============================================

There are additional details in the Powerman
(<https://github.com/chaos/powerman>) documentation, however here are
the basics.  In the powerman.conf file, you want to include the
'ipmipower.dev' device file, setup an ipmipower device in co-process
mode, then configure hosts to use that device.

     include "/etc/powerman/ipmipower.dev"

     device "ipmi0" "ipmipower" "/usr/sbin/ipmipower -h mynodes[0-10] |&"

     node "mynodes[0-10]"  "ipmi0" "mynodes[0-10]"

   You may wish to add some additional ipmipower configuration on the
device line:

     device "ipmi0" "ipmipower" "/usr/sbin/ipmipower --wait-until-on --wait-until-off -h mynodes[0-10] -u username -p password |&"

   although you will probably want to do some of this configuration
(especially the username and password) in 'freeipmi.conf'.

   If you use an alternate set of hostnames for IPMI from the primary
hostname, that can configured like this:

     device "ipmi0" "ipmipower" "/usr/sbin/ipmipower -h altname[0-10] |&"

     node "primaryname[0-10]"  "ipmi0" "altname[0-10]"

   Configuration can be trickier if you want to configure Powerman to
use ipmipower with an OEM extension specified through
'--oem-power-type'.  Many OEM extensions in ipmipower must include
additional arguments, which can be passed in via the node argument.  In
addition, while 'ipmipower' can take a host range as an additional
argument, Powerman may not.

   For example, the following would be suitable to configure OEM
extension support the Dell Poweredge C410x.  A specific node identifier
is used to map to a specific node and additional argument (i.e.
mynodes0-1 maps to mynodes0+1).

     include "/etc/powerman/ipmipower.dev"

     device "ipmi0" "ipmipower" "/usr/sbin/ipmipower -h mynodes[0-10]+[1-16] --oem-power-type=c410x -l admin |&"

     node "mynodes[0-10]-1" "ipmi0" "mynodes[0-10]+1"
     node "mynodes[0-10]-2" "ipmi0" "mynodes[0-10]+2"
     node "mynodes[0-10]-3" "ipmi0" "mynodes[0-10]+3"
     node "mynodes[0-10]-4" "ipmi0" "mynodes[0-10]+4"
     node "mynodes[0-10]-5" "ipmi0" "mynodes[0-10]+5"
     node "mynodes[0-10]-6" "ipmi0" "mynodes[0-10]+6"
     node "mynodes[0-10]-7" "ipmi0" "mynodes[0-10]+7"
     node "mynodes[0-10]-8" "ipmi0" "mynodes[0-10]+8"
     node "mynodes[0-10]-9" "ipmi0" "mynodes[0-10]+9"
     node "mynodes[0-10]-10" "ipmi0" "mynodes[0-10]+10"
     node "mynodes[0-10]-11" "ipmi0" "mynodes[0-10]+11"
     node "mynodes[0-10]-12" "ipmi0" "mynodes[0-10]+12"
     node "mynodes[0-10]-13" "ipmi0" "mynodes[0-10]+13"
     node "mynodes[0-10]-14" "ipmi0" "mynodes[0-10]+14"
     node "mynodes[0-10]-15" "ipmi0" "mynodes[0-10]+15"
     node "mynodes[0-10]-16" "ipmi0" "mynodes[0-10]+16"

   As noted in the manpage, the Dell Poweredge C410x appears to have
difficulty handling new slot power control requests until prior ones
have completed.  Users may wish to configure 'ipmipower' with
'--wait-until-on', '--wait-until-off', and consider using the
'ipmipower-serial.dev' device file instead of 'ipmipower.dev'.

File: freeipmi-faq.info,  Node: How do you setup Conman with ipmiconsole or libipmiconsole?,  Next: How do you setup Conserver with libipmiconsole?,  Prev: How do you setup Powerman with ipmipower?,  Up: Top

18 How do you setup Conman with ipmiconsole or libipmiconsole?
==============================================================

There are additional details in the Conman
(<https://github.com/dun/conman>) documentation and manpages, however
here are some basics.

   To configure Conman to connect via the ipmiconsole tool, Conman comes
with an expect script named ipmiconsole.exp, typically installed into
'/usr/lib/conman/exec/ipmiconsole.exp'.  Consoles can be setup by adding
lines to 'conman.conf' like:

     CONSOLE name="myserver"   dev="/usr/lib/conman/exec/ipmiconsole.exp myserver myusername mypassword"

   One of the useful aspects of using the ipmiconsole.exp script is that
the same configuration options you may have already configured into
'freeipmi.conf', may be loaded automatically when ipmiconsole is
executed via this expect script.

   However, as can be expected, scalability may be a problem as you must
launch a process for every node in your cluster.

   Conman is also capable of connecting to servers natively through the
libipmiconsole library, so that no additional processes are launched.
They can be configured as follows:

     CONSOLE name="myserver" IPMIOPTS="U:myusername,P:mypassword" dev="ipmi:myserver"

   on some older versions of Conman, you would instead use

     CONSOLE name="myserver" IPMIOPTS="myusername,mypassword" dev="ipmi:myserver"

   Please see the Conman documentation for current version options and
additional configuration options available.  Alternate defaults for
libipmiconsole can also be set via the 'libipmiconsole.conf' file.

   One of the additional advantages of configuring Conman to use the
libipmiconsole library natively is that Conman is able to detect and
manage additional IPMI error cases.

File: freeipmi-faq.info,  Node: How do you setup Conserver with libipmiconsole?,  Next: How do you setup Ganglia or Nagios to monitor IPMI sensors via FreeIPMI?,  Prev: How do you setup Conman with ipmiconsole or libipmiconsole?,  Up: Top

19 How do you setup Conserver with libipmiconsole?
==================================================

You can find more details in the conserver.cf
(<https://www.conserver.com/docs/conserver.cf.man.html>) manpage.

   Here is an example configuration entry from the conserver.cf file
that should illustrate the basics:

     break 3 { string '"\d\z"'; delay 250; }

     default ipmisol {
       break 3;
       motd "Generic IPMI SOL. Use \"Ctrl+E c ?\" for help, \"Ctrl+E c l 0 <key>\" for SysRq, \"Return [ ?\" for ipmi sol help";
       username myusername;
       type ipmi;
     }

     console node42 {
       include ipmisol;
       master conserver.example.com;
       password mypassword;
       host node42.bmc.example.com;
     }

File: freeipmi-faq.info,  Node: How do you setup Ganglia or Nagios to monitor IPMI sensors via FreeIPMI?,  Next: Why are times reported by FreeIPMI tools wrong?,  Prev: How do you setup Conman with ipmiconsole or libipmiconsole?,  Up: Top

20 How do you setup Ganglia or Nagios to monitor IPMI sensors via FreeIPMI?
===========================================================================

Scripts to monitor IPMI via FreeIPMI in Ganglia and Nagios have been
developed and are downloadable on the FreeIPMI homepage
(<http://www.gnu.org/software/freeipmi/download.html>).  Instructions
for setup can be found at the top of the scripts.

File: freeipmi-faq.info,  Node: Why are times reported by FreeIPMI tools wrong?,  Next: Why is the IPMI kernel driver faster than the KCS driver?,  Prev: How do you setup Ganglia or Nagios to monitor IPMI sensors via FreeIPMI?,  Up: Top

21 Why are times reported by FreeIPMI tools wrong?
==================================================

Times reported by various FreeIPMI tools (such as 'ipmi-sel') are
reported under the assumption that timestamps are written in localtime.
This is by definition in the IPMI specification.

   Whether or not a system truly stored the timestamps in localtime
varies on many factors, such as the vendor, BIOS, and operating system.

   If the times reported by the tool are off, there is a strong
likelihood the time may be stored in GMT/UTC and needs to be converted
into localtime.  In FreeIPMI tools that have time outputs, the
'--utc-to-localtime' option can be specified or the 'utc-to-localtime'
option can be specified in 'freeipmi.conf'.

File: freeipmi-faq.info,  Node: Why is the IPMI kernel driver faster than the KCS driver?,  Next: Why is the output from FreeIPMI different than another software?,  Prev: Why are times reported by FreeIPMI tools wrong?,  Up: Top

22 Why is the IPMI kernel driver faster than the KCS driver?
============================================================

Internally the IPMI kernel driver chooses to spin while polling for a
response from the base management controller (BMC) while the KCS driver
elects to sleep between poll attempts.  An operating system's scheduler
granularity may be larger than the time it takes to perform a IPMI
transaction, thus the wall clock time of the KCS driver is far worse
than the IPMI kernel driver.  FreeIPMI's KCS driver implements the sleep
between poll attempts because it is believed to provide better overall
system use.  To force the KCS driver to have similar wall clock response
time to the IPMI kernel driver, users can specify the 'spinpoll'
workaround.

File: freeipmi-faq.info,  Node: Why is the output from FreeIPMI different than another software?,  Next: Why are there so many IPMI compliance bugs?,  Prev: Why is the IPMI kernel driver faster than the KCS driver?,  Up: Top

23 Why is the output from FreeIPMI different than another software?
===================================================================

Due to minor implementation differences and or incorrect IPMI firmware,
the resulting output from FreeIPMI tools can differ from other software.
Here are some of the more common inconsistencies that have been seen
before.  More inconsistencies can be seen/fixed by specifying a number
of the workarounds available to many of the FreeIPMI tools.

   * In FreeIPMI's 'ipmi-sel' and 'ipmi-sensors' there are options for
     FreeIPMI to interpret the SEL or sensor readings and give them a
     NOMINAL, WARNING, or CRITICAL status.  Other IPMI software may have
     different interpretations for their sensors and/or SEL readings
     that map to NOMINAL, WARNING, or CRITICAL differently.  These
     interpretations are configurable in FreeIPMI via the
     'freeipmi_interpret_sel.conf' and 'freeipmi_interpret_sensor.conf'
     configuration files.

   * In some IPMI software, sensor and/or FRU records are bridged by
     default and read off satellite controllers.  In FreeIPMI they are
     not due to the discovery that many vendors do not implement their
     bridging correctly or publish invalid slave addresses in the SDR.
     In order to bridge sensors the '--bridge-sensors' option must be
     specified in 'ipmi-sensors'.  In order to bridge FRU records, the
     '--bridge-fru' must be specified in 'ipmi-fru'.

   * In some IPMI software, shared sensors may be read by default.  In
     FreeIPMI's 'ipmi-sensors', they are not read by default due to
     discovery that too many systems implement this incorrectly.  Shared
     sensors can be read by specifying the '--shared-sensors' option.

   * In vendor provided IPMI software, OEM specific sensors, SEL
     records, or FRU records may be output correctly because the vendor
     is aware of how to properly read/output OEM specific information.
     FreeIPMI may not be able to do this by default.  For the
     motherboards in which OEM information is known, it can be output
     using the '--interpret-oem-data'.  This option is available in
     'ipmi-sensors', 'ipmi-sel', and 'ipmi-fru'.

   * In some vendor IPMI software, sensor "names" are constructured
     through a combination of the multiple data in the SDR, rather than
     just the device name listed in the SDR. This can lead to different
     sensor names listed in tools like 'ipmi-sensors' and 'ipmi-sel'.
     In both tools, this can be alleviated through the use of the
     '--entity-sensor-names' option.

   * On several HP systems (observed on HP Proliant DL380 G7 and HP
     ProLiant ML310 G5), the SDR lists sensors using inconsistent
     information.  Some analog sensors are listed as discrete sensors or
     vice versa.  This inconsistency, and implementation differences
     between 'ipmi-sensors' and other IPMI software lead to different
     outputs.  For example, this is one such sensor that was seen in
     'ipmi-sensors':

          2  | Power Supply 1  | Power Supply | N/A        | N/A   | 'Presence detected'

     but this same sensor was see in 'ipmitool' as

          Power Supply 1   | 120 Watts         | nc

     In this example, 'ipmi-sensors' did not output a Watts reading but
     outputs the proper "Presence Detected" state.  'Ipmitool' outputs
     the correct watts reading, but outputs the invalid non-critical
     "nc" state.

     In FreeIPMI, this problem can be worked around using the
     'discretereading' workaround flag.

   * In FreeIPMI's 'ipmi-fru', all multirecord FRU entries are output by
     default.  In 'ipmitool' and perhaps other software, they are not.
     The resulting output from 'ipmi-fru' is much larger than other
     software.  To get similar output in 'ipmitool', the '-v' option
     must be set.

   * In FreeIPMI's 'ipmi-fru', FRU record checksums are automatically
     checked and errors are output if a FRU record cannot assumed to be
     valid due to a failed checksum check.  Other IPMI software has been
     shown to ignore the checksums and assume records are valid.  If
     your system has invalid checksummed FRU entries, the 'skipchecks'
     workaround can be used to get around them.

   * In FreeIPMI's 'ipmi-sensors', sensors may output an "OK" if no
     events are set.  In other IPMI software (such as 'ipmitool' and the
     command "sdr list"), "OK" means that a sensor was simply read
     correctly.  The "OK" may not mean that the device behind the sensor
     is actually functioning properly.  For example, here is an output
     from an 'ipmitool' sdr list entry.

          PSU 1 Status     | 0x0b              | ok

     The 0x0b indicates that the power supply has errors (you normally
     want to see 0x00 or 0x01), however the sensor outputs "ok" because
     the sensor reading was read correctly.  When using FreeIPMI's
     'ipmi-sensors', the 0x0b is properly converted into the event
     messages indicating an error.

          54  | PSU 1 Status | Power Supply | N/A | N/A | 'Presence detected' 'Power Supply Failure detected' 'Power Supply input lost (AC/DC)'

File: freeipmi-faq.info,  Node: Why are there so many IPMI compliance bugs?,  Next: How do I get around an IPMI compliance bug on my motherboard?,  Prev: Why is the output from FreeIPMI different than another software?,  Up: Top

24 Why are there so many IPMI compliance bugs?
==============================================

The IPMI specification is very large.  At last check, the IPMI
specification was 601 pages.  This does not count the various side
specifications related to IPMI, including DCMI, PET, FRU, and the
various OEM extension specifications (e.g.  Intel Node Manager).  Many
sections of text can be ambiguous.  Many components of IPMI are optional
and aren't required to be implemented.  There is some leeway for
implementation interpretation as well.  Ultimately, bugs will happen.
In all fairness, FreeIPMI has had bugs too.

   A number of the IPMI compliance bugs found by FreeIPMI are documented
in the freeipmi-bugs-issues-and-workarounds.txt document (you can find
it on the website here:
<http://www.gnu.org/software/freeipmi/freeipmi-bugs-issues-and-workarounds.txt>).

File: freeipmi-faq.info,  Node: How do I get around an IPMI compliance bug on my motherboard?,  Next: Why am I seeing so many 'internal IPMI error' or 'driver busy' messages?,  Prev: Why are there so many IPMI compliance bugs?,  Up: Top

25 How do I get around an IPMI compliance bug on my motherboard?
================================================================

Most of the FreeIPMI tools and libraries have flags to workaround a
large number of IPMI compliance bugs found on motherboards.  Please see
the appropriate tool manpages or library header files for details on the
workarounds available and for what motherboards.

   If you believe there is a compliance issue on your motherboard that
has not yet been implemented, please contact the maintainers on the
<freeipmi-devel AT gnu.org> mailing list.

File: freeipmi-faq.info,  Node: Why am I seeing so many 'internal IPMI error' or 'driver busy' messages?,  Next: How do I program with the FreeIPMI libraries?,  Prev: How do I get around an IPMI compliance bug on my motherboard?,  Up: Top

26 Why am I seeing so many 'internal IPMI error' or 'driver busy' messages?
===========================================================================

In some Linux distributions (atleast with Redhat Enterprise Linux 6.4 /
RHEL 6.4 and CentOS 6.4), the distributions began compiling the IPMI
kernel driver (i.e.  ipmi_msghandler and ipmi_si modules) into the
kernel instead of as loadable modules.  This was apparently due to a
need for the IPMI kernel drivers to work with ACPI.

   Due to compiling the IPMI kernel driver into the kernel, there is the
potential for inband IPMI communication to occur in the kernel w/o any
knowledge of it from outside software in userspace.  Normally, the IPMI
service (i.e.  /etc/init.d/ipmi) is started to create a device file
(i.e.  /dev/ipmi0) so that userspace software will know to communicate
through this device.  However, some of these distros disable the ipmi
service so that a device file is never created.

   Because of this, multiple IPMI software can communicate inband to the
BMC simultaneously, subsequently racing with each other.  Ultimately,
this can lead to communication problems.  In FreeIPMI, this is most
commonly seen through 'internal IPMI error' or 'driver busy' messages.

   There are several possible solutions for this in FreeIPMI. If you
start the ipmi service (i.e.  /etc/init.d/ipmi start), a device file
will be created which FreeIPMI will recognize.  FreeIPMI will
subsequently communicate via inband IPMI through this device file, thus
eliminating racing with the IPMI occurring in the kernel.

   The other option is to disable the IPMI kernel thread so that
FreeIPMI can perform inband communication with the BMC through its own
mechanisms.  The following is from the Linux kernel documentation.

     When compiled into the kernel, the parameters can be specified on the
     kernel command line as:

       ipmi_si.type=<type1>,<type2>...
            ipmi_si.ports=<port1>,<port2>... ipmi_si.addrs=<addr1>,<addr2>...
            ipmi_si.irqs=<irq1>,<irq2>... ipmi_si.trydefaults=[0|1]
            ipmi_si.regspacings=<sp1>,<sp2>,...
            ipmi_si.regsizes=<size1>,<size2>,...
            ipmi_si.regshifts=<shift1>,<shift2>,...
            ipmi_si.slave_addrs=<addr1>,<addr2>,...
            ipmi_si.force_kipmid=<enable1>,<enable2>,...
            ipmi_si.kipmid_max_busy_us=<ustime1>,<ustime2>,...

     ...

     If your IPMI interface does not support interrupts and is a KCS or
     SMIC interface, the IPMI driver will start a kernel thread for the
     interface to help speed things up.  This is a low-priority kernel
     thread that constantly polls the IPMI driver while an IPMI operation
     is in progress.  The force_kipmid module parameter will all the user to
     force this thread on or off.  If you force it off and don't have
     interrupts, the driver will run VERY slowly.

File: freeipmi-faq.info,  Node: How do I program with the FreeIPMI libraries?,  Next: Where can I get additional help or support?,  Prev: Why am I seeing so many 'internal IPMI error' or 'driver busy' messages?,  Up: Top

27 How do I program with the FreeIPMI libraries?
================================================

If you are looking for a high level library to do Serial-over-LAN (SOL)
or IPMI sensor/SEL monitoring, you may wish to look at the
libipmiconsole and libipmimonitoring libraries.  These libraries attempt
to abstract a large amount of the underlying IPMI detail from
developers.  The majority of the documentation can be found in the
header files.  Some examples can be found in the documentation and the
FreeIPMI tools that use them.

   The libfreeipmi library is the core library used by other FreeIPMI
libraries and tools.  However, it is quite detailed in regards to the
IPMI specification and many components of the library will be quite
confusing to those unfamiliar with the finer details of the IPMI
specification.  It is recommended most use the higher level libraries
described above.

   A more detailed description of the available FreeIPMI libraries can
be found in the 'freeipmi-libraries.txt' document (you can find it on
the website here:
<http://www.gnu.org/software/freeipmi/freeipmi-libraries.txt>).

File: freeipmi-faq.info,  Node: Where can I get additional help or support?,  Prev: How do I program with the FreeIPMI libraries?,  Up: Top

28 Where can I get additional help or support?
==============================================

For help, please email the <freeipmi-users AT gnu.org> mailing list.



Generated by $Id: phpMan.php,v 4.55 2007/09/05 04:42:51 chedong Exp $ Author: Che Dong
On Apache
Under GNU General Public License
2024-12-22 12:11 @3.144.104.118 CrawledBy Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
Valid XHTML 1.0!Valid CSS!