iPXE
smbios.h File Reference

System Management BIOS. More...

#include <stdint.h>
#include <ipxe/api.h>
#include <config/general.h>
#include <ipxe/null_smbios.h>
#include <ipxe/efi/efi_smbios.h>
#include <ipxe/linux/linux_smbios.h>
#include <bits/smbios.h>

Go to the source code of this file.

Data Structures

struct  smbios_entry
 SMBIOS 32-bit entry point. More...
struct  smbios3_entry
 SMBIOS 64-bit entry point. More...
struct  smbios_header
 An SMBIOS structure header. More...
struct  smbios_system_information
 SMBIOS system information structure. More...
struct  smbios_base_board_information
 SMBIOS base board information structure. More...
struct  smbios_enclosure_information
 SMBIOS enclosure information structure. More...
struct  smbios
 SMBIOS entry point descriptor. More...

Macros

#define PROVIDE_SMBIOS(_subsys, _api_func, _func)
 Provide an SMBIOS API implementation.
#define SMBIOS_SIGNATURE    ( ( '_' << 0 ) + ( 'S' << 8 ) + ( 'M' << 16 ) + ( '_' << 24 ) )
 Signature for 32-bit SMBIOS entry point.
#define SMBIOS3_SIGNATURE    ( ( '_' << 0 ) + ( 'S' << 8 ) + ( 'M' << 16 ) + ( '3' << 24 ) )
 Signature for 64-bit SMBIOS entry point.
#define SMBIOS_TYPE_SYSTEM_INFORMATION   1
 SMBIOS system information structure type.
#define SMBIOS_TYPE_BASE_BOARD_INFORMATION   2
 SMBIOS base board information structure type.
#define SMBIOS_TYPE_ENCLOSURE_INFORMATION   3
 SMBIOS enclosure information structure type.
#define SMBIOS_TYPE_OEM_STRINGS   11
 SMBIOS OEM strings structure type.
#define SMBIOS_TYPE_END   127
 SMBIOS end of table type.
#define SMBIOS_VERSION(major, minor)
 Calculate SMBIOS version.

Functions

 FILE_LICENCE (GPL2_OR_LATER_OR_UBDL)
 FILE_SECBOOT (PERMITTED)
struct smbios_entry __attribute__ ((packed))
int find_smbios (struct smbios *smbios)
const struct smbios_entryfind_smbios_entry (const void *start, size_t len)
 Scan for SMBIOS 32-bit entry point structure.
const struct smbios3_entryfind_smbios3_entry (const void *start, size_t len)
 Scan for SMBIOS 64-bit entry point structure.
const struct smbios_headersmbios_structure (unsigned int type, unsigned int instance)
 Find specific structure type within SMBIOS.
const char * smbios_string (const struct smbios_header *header, unsigned int index)
 Get indexed string within SMBIOS structure.
int smbios_version (void)
 Get SMBIOS version.
void smbios_clear (void)
 Clear SMBIOS entry point descriptor.

Variables

uint32_t signature
 Signature.
uint8_t checksum
 Checksum.
uint8_t len
 Length.
uint8_t major
 Major version.
uint8_t minor
 Minor version.
uint16_t max
 Maximum structure size.
uint8_t revision
 Entry point revision.
uint8_t formatted [5]
 Formatted area.
uint8_t dmi_signature [5]
 DMI Signature.
uint8_t dmi_checksum
 DMI checksum.
uint16_t smbios_len
 Structure table length.
uint32_t smbios_address
 Structure table address.
uint16_t smbios_count
 Number of SMBIOS structures.
uint8_t bcd_revision
 BCD revision.
uint8_t extra
 Signature extra byte.
uint8_t docrev
 Documentation revision.
uint8_t reserved
 Reserved.
uint8_t type
 Type.
uint16_t handle
 Handle.
struct smbios_header header
 SMBIOS structure header.
uint8_t manufacturer
 Manufacturer string.
uint8_t product
 Product string.
uint8_t version
 Version string.
uint8_t serial
 Serial number string.
uint8_t uuid [16]
 UUID.
uint8_t wakeup
 Wake-up type.
uint8_t asset_tag
 Asset tag.
struct smbios __attribute__

Detailed Description

System Management BIOS.

Definition in file smbios.h.

Macro Definition Documentation

◆ PROVIDE_SMBIOS

#define PROVIDE_SMBIOS ( _subsys,
_api_func,
_func )
Value:
PROVIDE_SINGLE_API ( SMBIOS_PREFIX_ ## _subsys, _api_func, _func )
#define PROVIDE_SINGLE_API(_prefix, _api_func, _func)
Provide an API implementation.
Definition api.h:55

Provide an SMBIOS API implementation.

Parameters
_prefixSubsystem prefix
_api_funcAPI function
_funcImplementing function

Definition at line 24 of file smbios.h.

24#define PROVIDE_SMBIOS( _subsys, _api_func, _func ) \
25 PROVIDE_SINGLE_API ( SMBIOS_PREFIX_ ## _subsys, _api_func, _func )

◆ SMBIOS_SIGNATURE

#define SMBIOS_SIGNATURE    ( ( '_' << 0 ) + ( 'S' << 8 ) + ( 'M' << 16 ) + ( '_' << 24 ) )

Signature for 32-bit SMBIOS entry point.

Definition at line 36 of file smbios.h.

36#define SMBIOS_SIGNATURE \
37 ( ( '_' << 0 ) + ( 'S' << 8 ) + ( 'M' << 16 ) + ( '_' << 24 ) )

Referenced by efi_find_smbios(), and find_smbios_entry().

◆ SMBIOS3_SIGNATURE

#define SMBIOS3_SIGNATURE    ( ( '_' << 0 ) + ( 'S' << 8 ) + ( 'M' << 16 ) + ( '3' << 24 ) )

Signature for 64-bit SMBIOS entry point.

Definition at line 40 of file smbios.h.

40#define SMBIOS3_SIGNATURE \
41 ( ( '_' << 0 ) + ( 'S' << 8 ) + ( 'M' << 16 ) + ( '3' << 24 ) )

Referenced by efi_find_smbios(), and find_smbios3_entry().

◆ SMBIOS_TYPE_SYSTEM_INFORMATION

#define SMBIOS_TYPE_SYSTEM_INFORMATION   1

SMBIOS system information structure type.

Definition at line 148 of file smbios.h.

Referenced by __setting(), __setting(), __setting(), __setting(), and smsc95xx_vm3_fetch_mac().

◆ SMBIOS_TYPE_BASE_BOARD_INFORMATION

#define SMBIOS_TYPE_BASE_BOARD_INFORMATION   2

SMBIOS base board information structure type.

Definition at line 165 of file smbios.h.

Referenced by __setting().

◆ SMBIOS_TYPE_ENCLOSURE_INFORMATION

#define SMBIOS_TYPE_ENCLOSURE_INFORMATION   3

SMBIOS enclosure information structure type.

Definition at line 184 of file smbios.h.

Referenced by __setting().

◆ SMBIOS_TYPE_OEM_STRINGS

#define SMBIOS_TYPE_OEM_STRINGS   11

SMBIOS OEM strings structure type.

Definition at line 187 of file smbios.h.

Referenced by smsc95xx_vm3_fetch_mac().

◆ SMBIOS_TYPE_END

#define SMBIOS_TYPE_END   127

SMBIOS end of table type.

Definition at line 190 of file smbios.h.

Referenced by smbios_structure().

◆ SMBIOS_VERSION

#define SMBIOS_VERSION ( major,
minor )
Value:
( ( (major) << 8 ) | (minor) )
uint32_t major
Major version.
Definition netvsc.h:3
uint32_t minor
Minor version.
Definition netvsc.h:5

Calculate SMBIOS version.

Parameters
majorMajor version
minorMinor version
Return values
versionSMBIOS version

Definition at line 216 of file smbios.h.

Referenced by bios_find_smbios2(), bios_find_smbios3(), efi_find_smbios(), and smbios_fetch().

Function Documentation

◆ FILE_LICENCE()

FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL )

◆ FILE_SECBOOT()

FILE_SECBOOT ( PERMITTED )

◆ __attribute__()

struct smbios_entry __attribute__ ( (packed) )

◆ find_smbios()

int find_smbios ( struct smbios * smbios)
extern

◆ find_smbios_entry()

const struct smbios_entry * find_smbios_entry ( const void * start,
size_t len )
extern

Scan for SMBIOS 32-bit entry point structure.

Parameters
startStart address of region to scan
lenLength of region to scan
Return values
entrySMBIOS entry point structure, or NULL if not found

Definition at line 70 of file smbios.c.

71 {
72 static size_t offset = 0; /* Avoid repeated attempts to locate SMBIOS */
73 const struct smbios_entry *entry;
74 uint8_t sum;
75
76 /* Try to find SMBIOS */
77 for ( ; ( offset + sizeof ( *entry ) ) <= len ; offset += 0x10 ) {
78
79 /* Verify signature */
80 entry = ( start + offset );
81 if ( entry->signature != SMBIOS_SIGNATURE )
82 continue;
83
84 /* Verify length */
85 if ( ( entry->len < sizeof ( *entry ) ) ||
86 ( ( offset + entry->len ) > len ) ) {
87 DBGC ( &smbios, "SMBIOS at %#08lx has bad length "
88 "%#02x\n", virt_to_phys ( entry ), entry->len );
89 continue;
90 }
91
92 /* Verify checksum */
93 if ( ( sum = smbios_checksum ( entry, entry->len ) ) != 0 ) {
94 DBGC ( &smbios, "SMBIOS at %#08lx has bad checksum "
95 "%#02x\n", virt_to_phys ( entry ), sum );
96 continue;
97 }
98
99 /* Fill result structure */
100 DBGC ( &smbios, "Found SMBIOS v%d.%d entry point at %#08lx\n",
101 entry->major, entry->minor, virt_to_phys ( entry ) );
102 return entry;
103 }
104
105 DBGC ( &smbios, "No SMBIOS found\n" );
106 return NULL;
107}
#define NULL
NULL pointer (VOID *)
Definition Base.h:322
unsigned char uint8_t
Definition stdint.h:10
uint16_t offset
Offset to command line.
Definition bzimage.h:3
ring len
Length.
Definition dwmac.h:226
#define DBGC(...)
Definition compiler.h:505
uint32_t start
Starting offset.
Definition netvsc.h:1
#define SMBIOS_SIGNATURE
Signature for 32-bit SMBIOS entry point.
Definition smbios.h:36
static uint8_t smbios_checksum(const void *start, size_t len)
Calculate SMBIOS entry point structure checksum.
Definition smbios.c:52
SMBIOS 32-bit entry point.
Definition smbios.h:50
uint8_t minor
Minor version.
Definition smbios.h:63
uint32_t signature
Signature.
Definition smbios.h:55
uint8_t major
Major version.
Definition smbios.h:61
uint8_t len
Length.
Definition smbios.h:59
SMBIOS entry point descriptor.
Definition smbios.h:198

References DBGC, len, smbios_entry::len, smbios_entry::major, smbios_entry::minor, NULL, offset, smbios_entry::signature, smbios_checksum(), SMBIOS_SIGNATURE, and start.

Referenced by bios_find_smbios2().

◆ find_smbios3_entry()

const struct smbios3_entry * find_smbios3_entry ( const void * start,
size_t len )
extern

Scan for SMBIOS 64-bit entry point structure.

Parameters
startStart address of region to scan
lenLength of region to scan
Return values
entrySMBIOS entry point structure, or NULL if not found

Definition at line 116 of file smbios.c.

117 {
118 static size_t offset = 0; /* Avoid repeated attempts to locate SMBIOS */
119 const struct smbios3_entry *entry;
120 uint8_t sum;
121
122 /* Try to find SMBIOS */
123 for ( ; ( offset + sizeof ( *entry ) ) <= len ; offset += 0x10 ) {
124
125 /* Verify signature */
126 entry = ( start + offset );
127 if ( entry->signature != SMBIOS3_SIGNATURE )
128 continue;
129
130 /* Verify length */
131 if ( ( entry->len < sizeof ( *entry ) ) ||
132 ( ( offset + entry->len ) > len ) ) {
133 DBGC ( &smbios, "SMBIOS at %#08lx has bad length "
134 "%#02x\n", virt_to_phys ( entry ), entry->len );
135 continue;
136 }
137
138 /* Verify checksum */
139 if ( ( sum = smbios_checksum ( entry, entry->len ) ) != 0 ) {
140 DBGC ( &smbios, "SMBIOS3 at %#08lx has bad checksum "
141 "%#02x\n", virt_to_phys ( entry ), sum );
142 continue;
143 }
144
145 /* Fill result structure */
146 DBGC ( &smbios, "Found SMBIOS3 v%d.%d entry point at %#08lx\n",
147 entry->major, entry->minor, virt_to_phys ( entry ) );
148 return entry;
149 }
150
151 DBGC ( &smbios, "No SMBIOS3 found\n" );
152 return NULL;
153}
#define SMBIOS3_SIGNATURE
Signature for 64-bit SMBIOS entry point.
Definition smbios.h:40
SMBIOS 64-bit entry point.
Definition smbios.h:91
uint8_t major
Major version.
Definition smbios.h:104
uint8_t len
Length.
Definition smbios.h:102
uint8_t minor
Minor version.
Definition smbios.h:106
uint32_t signature
Signature.
Definition smbios.h:96

References DBGC, len, smbios3_entry::len, smbios3_entry::major, smbios3_entry::minor, NULL, offset, smbios3_entry::signature, SMBIOS3_SIGNATURE, smbios_checksum(), and start.

Referenced by bios_find_smbios3().

◆ smbios_structure()

const struct smbios_header * smbios_structure ( unsigned int type,
unsigned int instance )
extern

Find specific structure type within SMBIOS.

Parameters
typeStructure type to search for
instanceInstance of this type of structure
Return values
structureSMBIOS structure header, or NULL if not found

Definition at line 183 of file smbios.c.

184 {
185 const struct smbios_header *structure;
186 unsigned int count = 0;
187 size_t offset = 0;
188 size_t strings_offset;
189 size_t terminator_offset;
190 size_t strings_len;
191 int rc;
192
193 /* Find SMBIOS */
194 if ( ( smbios.address == NULL ) &&
195 ( ( rc = find_smbios ( &smbios ) ) != 0 ) )
196 return NULL;
197 assert ( smbios.address != NULL );
198
199 /* Scan through list of structures */
200 while ( ( ( offset + sizeof ( *structure ) ) < smbios.len ) &&
201 ( ( smbios.count == 0 ) || ( count < smbios.count ) ) ) {
202
203 /* Access next SMBIOS structure header */
204 structure = ( smbios.address + offset );
205
206 /* Determine start and extent of strings block */
207 strings_offset = ( offset + structure->len );
208 if ( strings_offset > smbios.len ) {
209 DBGC ( &smbios, "SMBIOS structure at offset %#zx "
210 "with length %#x extends beyond SMBIOS\n",
211 offset, structure->len );
212 return NULL;
213 }
214 terminator_offset = find_strings_terminator ( strings_offset );
215 if ( ! terminator_offset ) {
216 DBGC ( &smbios, "SMBIOS structure at offset %#zx has "
217 "unterminated strings section\n", offset );
218 return NULL;
219 }
220 strings_len = ( terminator_offset - strings_offset);
221 DBGC ( &smbios, "SMBIOS structure at offset %#zx has type %d, "
222 "length %#x, strings length %#zx\n", offset,
223 structure->type, structure->len, strings_len );
224
225 /* Stop if we have reached an end-of-table marker */
226 if ( ( smbios.count == 0 ) &&
227 ( structure->type == SMBIOS_TYPE_END ) )
228 break;
229
230 /* If this is the structure we want, return */
231 if ( ( structure->type == type ) &&
232 ( instance-- == 0 ) ) {
233 return structure;
234 }
235
236 /* Move to next SMBIOS structure */
237 offset = ( terminator_offset + 1 );
238 count++;
239 }
240
241 DBGC ( &smbios, "SMBIOS structure type %d not found\n", type );
242 return NULL;
243}
struct arbelprm_rc_send_wqe rc
Definition arbel.h:3
#define assert(condition)
Assert a condition at run-time.
Definition assert.h:50
uint32_t type
Operating system type.
Definition ena.h:1
static unsigned int count
Number of entries.
Definition dwmac.h:220
int find_smbios(struct smbios *smbios)
#define SMBIOS_TYPE_END
SMBIOS end of table type.
Definition smbios.h:190
static size_t find_strings_terminator(size_t offset)
Find SMBIOS strings terminator.
Definition smbios.c:161
An SMBIOS structure header.
Definition smbios.h:120
uint8_t len
Length.
Definition smbios.h:124
uint8_t type
Type.
Definition smbios.h:122
size_t len
Length of SMBIOS structures.
Definition smbios.h:202
unsigned int count
Number of SMBIOS structures.
Definition smbios.h:204
const void * address
Start of SMBIOS structures.
Definition smbios.h:200

References smbios::address, assert, count, smbios::count, DBGC, find_smbios(), find_strings_terminator(), smbios::len, smbios_header::len, NULL, offset, rc, SMBIOS_TYPE_END, smbios_header::type, and type.

Referenced by smbios_fetch(), and smsc95xx_vm3_fetch_mac().

◆ smbios_string()

const char * smbios_string ( const struct smbios_header * structure,
unsigned int index )
extern

Get indexed string within SMBIOS structure.

Parameters
structureSMBIOS structure header
indexString index
Return values
stringSMBIOS string, or NULL if not fond

Definition at line 252 of file smbios.c.

253 {
254 const char *string;
255 unsigned int i;
256 size_t len;
257
258 /* Sanity check */
259 assert ( smbios.address != NULL );
260
261 /* Step through strings */
262 string = ( ( ( const void * ) structure ) + structure->len );
263 for ( i = index ; i-- ; ) {
264 /* Get string length. This is known safe, since we
265 * check for the empty-string terminator in
266 * smbios_structure().
267 */
268 len = strlen ( string );
269 if ( ! len )
270 break;
271 if ( i == 0 )
272 return string;
273 string += ( len + 1 /* NUL */ );
274 }
275
276 DBGC ( &smbios, "SMBIOS string index %d not found\n", index );
277 return NULL;
278}
long index
Definition bigint.h:65
uint32_t string
Definition multiboot.h:2
size_t strlen(const char *src)
Get length of string.
Definition string.c:244

References smbios::address, assert, DBGC, index, len, smbios_header::len, NULL, string, and strlen().

Referenced by smbios_fetch(), and smsc95xx_vm3_fetch_mac().

◆ smbios_version()

int smbios_version ( void )
extern

Get SMBIOS version.

Return values
versionVersion, or negative error

Definition at line 285 of file smbios.c.

285 {
286 int rc;
287
288 /* Find SMBIOS */
289 if ( ( smbios.address == NULL ) &&
290 ( ( rc = find_smbios ( &smbios ) ) != 0 ) )
291 return rc;
292 assert ( smbios.address != NULL );
293
294 return smbios.version;
295}
uint16_t version
SMBIOS version.
Definition smbios.h:206

References smbios::address, assert, find_smbios(), NULL, rc, and smbios::version.

Referenced by smbios_fetch().

◆ smbios_clear()

void smbios_clear ( void )
extern

Clear SMBIOS entry point descriptor.

Definition at line 301 of file smbios.c.

301 {
302
303 /* Clear address */
305}

References smbios::address, and NULL.

Variable Documentation

◆ signature

uint32_t signature

Signature.

Must be equal to SMBIOS_SIGNATURE

Must be equal to SMBIOS3_SIGNATURE

Definition at line 4 of file smbios.h.

◆ checksum

uint8_t checksum

Checksum.

Definition at line 6 of file smbios.h.

◆ len

uint8_t len

Length.

Definition at line 8 of file smbios.h.

◆ major

uint8_t major

Major version.

Definition at line 10 of file smbios.h.

◆ minor

uint8_t minor

Minor version.

Definition at line 12 of file smbios.h.

◆ max

uint16_t max

Maximum structure size.

Definition at line 14 of file smbios.h.

◆ revision

uint8_t revision

Entry point revision.

Definition at line 16 of file smbios.h.

◆ formatted

uint8_t formatted[5]

Formatted area.

Definition at line 18 of file smbios.h.

Referenced by uri_churi_okx(), and uri_resolve_okx().

◆ dmi_signature

uint8_t dmi_signature[5]

DMI Signature.

Definition at line 20 of file smbios.h.

◆ dmi_checksum

uint8_t dmi_checksum

DMI checksum.

Definition at line 22 of file smbios.h.

◆ smbios_len

uint32_t smbios_len

Structure table length.

Definition at line 24 of file smbios.h.

◆ smbios_address

uint64_t smbios_address

Structure table address.

Definition at line 26 of file smbios.h.

◆ smbios_count

uint16_t smbios_count

Number of SMBIOS structures.

Definition at line 28 of file smbios.h.

◆ bcd_revision

uint8_t bcd_revision

BCD revision.

Definition at line 30 of file smbios.h.

◆ extra

uint8_t extra

Signature extra byte.

Definition at line 6 of file smbios.h.

Referenced by asn1_grow(), asn1_parse_gcm(), deflate_inflate(), and gzip_extract().

◆ docrev

uint8_t docrev

Documentation revision.

Definition at line 16 of file smbios.h.

◆ reserved

uint8_t reserved

Reserved.

Definition at line 20 of file smbios.h.

◆ type

uint8_t type

Type.

Type string.

Definition at line 1 of file smbios.h.

◆ handle

uint16_t handle

Handle.

Definition at line 5 of file smbios.h.

Referenced by chained_locate(), dbg_efi_opener(), dbg_efi_openers(), dbg_efi_protocol(), dbg_efi_protocols(), efi_autoexec_filesystem(), efi_autoexec_load(), efi_autoexec_network(), efi_block_boot(), efi_block_connect(), efi_block_filename(), efi_block_local(), efi_block_match(), efi_block_root(), efi_block_scan(), efi_close_by_child(), efi_close_by_driver(), efi_close_protocol_wrapper(), efi_close_unsafe(), efi_download_install(), efi_download_uninstall(), efi_driver_handles(), efi_dump_image(), efi_file_install(), efi_file_path_claim(), efi_file_uninstall(), efi_handle_name(), efi_handle_protocol_wrapper(), efi_image_exec(), efi_image_probe(), efi_init_stack_guard(), efi_install_multiple_protocol_interfaces_wrapper(), efi_install_protocol_interface_wrapper(), efi_open_by_child_untyped(), efi_open_by_driver_untyped(), efi_open_protocol_information_wrapper(), efi_open_protocol_wrapper(), efi_open_unsafe_untyped(), efi_open_untyped(), efi_protocols_per_handle_wrapper(), efi_pxe_find(), efi_pxe_install(), efi_pxe_uninstall(), efi_reinstall_protocol_interface_wrapper(), efi_service_add(), efi_service_del(), efi_shim_inhibit_pxe(), efi_shim_install(), efi_stack_cookie(), efi_uninstall_multiple_protocol_interfaces_wrapper(), efi_uninstall_protocol_interface_wrapper(), efi_veto_close(), efi_veto_close_handle(), efi_veto_close_protocol(), efi_veto_disconnect(), efi_wrap_image(), efipci_discover(), efipci_discover_any(), efipci_discover_one(), efipci_ioremap(), efipci_read(), efipci_root_open(), efipci_write(), FILE_SECBOOT(), find_snpdev(), mnptemp_create(), phantom_poll(), phantom_post_rds(), phantom_refill_rx_ring(), usbio_bulk_in_poll(), usbio_bulk_out_poll(), usbio_config(), usbio_control_poll(), usbio_endpoint_open(), usbio_interface(), usbio_interfaces(), usbio_interrupt_callback(), usbio_interrupt_open(), usbio_open(), usbio_path(), usbio_start(), usbio_stop(), and usbio_supported().

◆ header

struct smbios_header header

SMBIOS structure header.

Definition at line 1 of file smbios.h.

◆ manufacturer

◆ product

◆ version

uint8_t version

Version string.

Definition at line 7 of file smbios.h.

◆ serial

uint8_t serial

Serial number string.

Definition at line 9 of file smbios.h.

◆ uuid

uint8_t uuid[16]

UUID.

Definition at line 11 of file smbios.h.

◆ wakeup

uint8_t wakeup

Wake-up type.

Definition at line 13 of file smbios.h.

◆ asset_tag

uint8_t asset_tag

Asset tag.

Definition at line 11 of file smbios.h.

Referenced by __setting().