[RFC PATCH]: System Firmware and SMBIOS Support
From: Prarit Bhargava
Date: Tue May 31 2011 - 11:50:50 EST
Sorry for the wide-distribution. The list of modified files is quite large.
P.
----8<----
DMI, or the Desktop Management Interface, provides access to OEM and hardware
specific details about the x86 or ia64 system the kernel is currently runnig
on. DMI has been deprecated since 2003, which was the last update of the DMI
Specification.
The System Management BIOS, or SMBIOS, supercedes DMI -- the SMBIOS tables
include the possibility of a _DMI_ entry and tables. However, in the
Linux kernel we do not access any of the DMI data and only access SMBIOS data.
Currently, the kernel uses dmi_* functions (as defined in
drivers/firmware/dmi_scan.c) to access the data. The functions allow kernel
subsystems and modules to set specific options based on the platform and BIOS
version.
The dmi_* functions in the kernel fail in several ways. First, as
mentioned the dmi_* functions are really accessing SMBIOS data. The existing
code queries for the _SMB_ entry and determines data access after that. The
existing dmi_* functions create an array of x86 and ia64 specific entries
which are defined as part of x86 and ia64 specific udev entries, and allows
drivers and subsystems to make platform specific decisions. In addition to
the arch specific code, the dmi_* code creates a list of "devices" to which
makes updating very difficult and does not easily scale.
Another key issue with the existing code is that several drivers do their
own search through the SMBIOS, for example, see drivers/pci/hotplug/cpqphp*.c.
A month (or so) ago I proposed a patch which was based on a simple request
from a colleague -- create a sysfs file that would export the SMBIOS version.
This simple request was not something that was easy to do given the layout of
the existing DMI code. The request resulted in having to create a new smbios
class within the kernel, and essentially doing a separate search through
memory.
This new patchset reworks the existing DMI code into two separate layers. It is
based off of the feedback I received previously when discussing the SMBIOS
version patch on LKML.
The first layer is the System Firmware Interface, which is based upon Alan
Cox's suggestion of a common platform driver (unfortunately, platform driver
is already defined and used within the kernel). This is meant to be an
arch independent subsystem in the kernel for all arches. It is a common
interface which provides access to specific system values in the kernel such
as the Chassis Manufacturer, the BIOS developer, or the BIOS date. The
System Firmware Interface, or sysfw allows for easy updating by simply adding
fields to an array in include/linux/mod_devicetable.h.
Standard simple searching functions, sysfw_lookup() and sysfw_callback()
are provided to the kernel and modules. sysfw_callback() is similar to
dmi_check_system() but the new function allows for exact matching which some
drivers required.
The second layer introduced in this patchset is the SMBIOS sysfw driver. This
driver (obviously) registers with the interface and also provides it's own
interface. The reason for the separate interface is that specific drivers
have their own need to search the SMBIOS for OEM or platform specific
information (see, for example, drivers/watchdog/hpwdt.c, or
drivers/pci/pci-label.c). This new driver provides a function, smbios_walk()
which allows individual drivers or subsystems to traverse the SMBIOS table
looking for OEM or platform specific data. The new SMBIOS driver can be
easily updated by adding SMBIOS structure information to the smbios_struct
union in include/linux/smbios.h.
These changes are targeted for at least 3.0.1.
A git tree with these changes has been set up here:
git://git.kernel.org/pub/scm/linux/kernel/git/prarit/smbios.git
with the latest changes in the smbios-3.0-rc1 branch, and well-tested changes
on the smbios-2.6.39 branch.
P.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/