| #ifndef QEMU_SMBIOS_H |
| #define QEMU_SMBIOS_H |
| |
| #include "qapi/qapi-types-machine.h" |
| |
| /* |
| * SMBIOS Support |
| * |
| * Copyright (C) 2009 Hewlett-Packard Development Company, L.P. |
| * |
| * Authors: |
| * Alex Williamson <alex.williamson@hp.com> |
| * |
| * This work is licensed under the terms of the GNU GPL, version 2. See |
| * the COPYING file in the top-level directory. |
| * |
| */ |
| |
| |
| #define SMBIOS_MAX_TYPE 127 |
| #define offsetofend(TYPE, MEMBER) \ |
| (offsetof(TYPE, MEMBER) + sizeof_field(TYPE, MEMBER)) |
| |
| /* memory area description, used by type 19 table */ |
| struct smbios_phys_mem_area { |
| uint64_t address; |
| uint64_t length; |
| }; |
| |
| /* SMBIOS Entry Point |
| * There are two types of entry points defined in the SMBIOS specification |
| * (see below). BIOS must place the entry point(s) at a 16-byte-aligned |
| * address between 0xf0000 and 0xfffff. Note that either entry point type |
| * can be used in a 64-bit target system, except that SMBIOS 2.1 entry point |
| * only allows the SMBIOS struct table to reside below 4GB address space. |
| */ |
| |
| /* SMBIOS 2.1 (32-bit) Entry Point |
| * - introduced since SMBIOS 2.1 |
| * - supports structure table below 4GB only |
| */ |
| struct smbios_21_entry_point { |
| uint8_t anchor_string[4]; |
| uint8_t checksum; |
| uint8_t length; |
| uint8_t smbios_major_version; |
| uint8_t smbios_minor_version; |
| uint16_t max_structure_size; |
| uint8_t entry_point_revision; |
| uint8_t formatted_area[5]; |
| uint8_t intermediate_anchor_string[5]; |
| uint8_t intermediate_checksum; |
| uint16_t structure_table_length; |
| uint32_t structure_table_address; |
| uint16_t number_of_structures; |
| uint8_t smbios_bcd_revision; |
| } QEMU_PACKED; |
| |
| /* SMBIOS 3.0 (64-bit) Entry Point |
| * - introduced since SMBIOS 3.0 |
| * - supports structure table at 64-bit address space |
| */ |
| struct smbios_30_entry_point { |
| uint8_t anchor_string[5]; |
| uint8_t checksum; |
| uint8_t length; |
| uint8_t smbios_major_version; |
| uint8_t smbios_minor_version; |
| uint8_t smbios_doc_rev; |
| uint8_t entry_point_revision; |
| uint8_t reserved; |
| uint32_t structure_table_max_size; |
| uint64_t structure_table_address; |
| } QEMU_PACKED; |
| |
| typedef union { |
| struct smbios_21_entry_point ep21; |
| struct smbios_30_entry_point ep30; |
| } QEMU_PACKED SmbiosEntryPoint; |
| |
| /* This goes at the beginning of every SMBIOS structure. */ |
| struct smbios_structure_header { |
| uint8_t type; |
| uint8_t length; |
| uint16_t handle; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 0 - BIOS Information */ |
| struct smbios_type_0 { |
| struct smbios_structure_header header; |
| uint8_t vendor_str; |
| uint8_t bios_version_str; |
| uint16_t bios_starting_address_segment; |
| uint8_t bios_release_date_str; |
| uint8_t bios_rom_size; |
| uint64_t bios_characteristics; |
| uint8_t bios_characteristics_extension_bytes[2]; |
| uint8_t system_bios_major_release; |
| uint8_t system_bios_minor_release; |
| uint8_t embedded_controller_major_release; |
| uint8_t embedded_controller_minor_release; |
| } QEMU_PACKED; |
| |
| /* UUID encoding. The time_* fields are little-endian, as specified by SMBIOS |
| * version 2.6. |
| */ |
| struct smbios_uuid { |
| uint32_t time_low; |
| uint16_t time_mid; |
| uint16_t time_hi_and_version; |
| uint8_t clock_seq_hi_and_reserved; |
| uint8_t clock_seq_low; |
| uint8_t node[6]; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 1 - System Information */ |
| struct smbios_type_1 { |
| struct smbios_structure_header header; |
| uint8_t manufacturer_str; |
| uint8_t product_name_str; |
| uint8_t version_str; |
| uint8_t serial_number_str; |
| struct smbios_uuid uuid; |
| uint8_t wake_up_type; |
| uint8_t sku_number_str; |
| uint8_t family_str; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 2 - Base Board */ |
| struct smbios_type_2 { |
| struct smbios_structure_header header; |
| uint8_t manufacturer_str; |
| uint8_t product_str; |
| uint8_t version_str; |
| uint8_t serial_number_str; |
| uint8_t asset_tag_number_str; |
| uint8_t feature_flags; |
| uint8_t location_str; |
| uint16_t chassis_handle; |
| uint8_t board_type; |
| uint8_t contained_element_count; |
| /* contained elements follow */ |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 3 - System Enclosure (v2.7) */ |
| struct smbios_type_3 { |
| struct smbios_structure_header header; |
| uint8_t manufacturer_str; |
| uint8_t type; |
| uint8_t version_str; |
| uint8_t serial_number_str; |
| uint8_t asset_tag_number_str; |
| uint8_t boot_up_state; |
| uint8_t power_supply_state; |
| uint8_t thermal_state; |
| uint8_t security_status; |
| uint32_t oem_defined; |
| uint8_t height; |
| uint8_t number_of_power_cords; |
| uint8_t contained_element_count; |
| uint8_t contained_element_record_length; |
| uint8_t sku_number_str; |
| /* contained elements follow */ |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 4 - Processor Information (v2.6) */ |
| struct smbios_type_4 { |
| struct smbios_structure_header header; |
| uint8_t socket_designation_str; |
| uint8_t processor_type; |
| uint8_t processor_family; |
| uint8_t processor_manufacturer_str; |
| uint32_t processor_id[2]; |
| uint8_t processor_version_str; |
| uint8_t voltage; |
| uint16_t external_clock; |
| uint16_t max_speed; |
| uint16_t current_speed; |
| uint8_t status; |
| uint8_t processor_upgrade; |
| uint16_t l1_cache_handle; |
| uint16_t l2_cache_handle; |
| uint16_t l3_cache_handle; |
| uint8_t serial_number_str; |
| uint8_t asset_tag_number_str; |
| uint8_t part_number_str; |
| uint8_t core_count; |
| uint8_t core_enabled; |
| uint8_t thread_count; |
| uint16_t processor_characteristics; |
| uint16_t processor_family2; |
| /* SMBIOS spec 3.0.0, Table 21 */ |
| uint16_t core_count2; |
| uint16_t core_enabled2; |
| uint16_t thread_count2; |
| } QEMU_PACKED; |
| |
| typedef enum smbios_type_4_len_ver { |
| SMBIOS_TYPE_4_LEN_V28 = offsetofend(struct smbios_type_4, |
| processor_family2), |
| SMBIOS_TYPE_4_LEN_V30 = offsetofend(struct smbios_type_4, thread_count2), |
| } smbios_type_4_len_ver; |
| |
| /* SMBIOS type 8 - Port Connector Information */ |
| struct smbios_type_8 { |
| struct smbios_structure_header header; |
| uint8_t internal_reference_str; |
| uint8_t internal_connector_type; |
| uint8_t external_reference_str; |
| uint8_t external_connector_type; |
| uint8_t port_type; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 11 - OEM strings */ |
| struct smbios_type_11 { |
| struct smbios_structure_header header; |
| uint8_t count; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 16 - Physical Memory Array (v2.7) */ |
| struct smbios_type_16 { |
| struct smbios_structure_header header; |
| uint8_t location; |
| uint8_t use; |
| uint8_t error_correction; |
| uint32_t maximum_capacity; |
| uint16_t memory_error_information_handle; |
| uint16_t number_of_memory_devices; |
| uint64_t extended_maximum_capacity; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 17 - Memory Device (v2.8) */ |
| struct smbios_type_17 { |
| struct smbios_structure_header header; |
| uint16_t physical_memory_array_handle; |
| uint16_t memory_error_information_handle; |
| uint16_t total_width; |
| uint16_t data_width; |
| uint16_t size; |
| uint8_t form_factor; |
| uint8_t device_set; |
| uint8_t device_locator_str; |
| uint8_t bank_locator_str; |
| uint8_t memory_type; |
| uint16_t type_detail; |
| uint16_t speed; |
| uint8_t manufacturer_str; |
| uint8_t serial_number_str; |
| uint8_t asset_tag_number_str; |
| uint8_t part_number_str; |
| uint8_t attributes; |
| uint32_t extended_size; |
| uint16_t configured_clock_speed; |
| uint16_t minimum_voltage; |
| uint16_t maximum_voltage; |
| uint16_t configured_voltage; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 19 - Memory Array Mapped Address (v2.7) */ |
| struct smbios_type_19 { |
| struct smbios_structure_header header; |
| uint32_t starting_address; |
| uint32_t ending_address; |
| uint16_t memory_array_handle; |
| uint8_t partition_width; |
| uint64_t extended_starting_address; |
| uint64_t extended_ending_address; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 32 - System Boot Information */ |
| struct smbios_type_32 { |
| struct smbios_structure_header header; |
| uint8_t reserved[6]; |
| uint8_t boot_status; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 41 - Onboard Devices Extended Information */ |
| struct smbios_type_41 { |
| struct smbios_structure_header header; |
| uint8_t reference_designation_str; |
| uint8_t device_type; |
| uint8_t device_type_instance; |
| uint16_t segment_group_number; |
| uint8_t bus_number; |
| uint8_t device_number; |
| } QEMU_PACKED; |
| |
| /* SMBIOS type 127 -- End-of-table */ |
| struct smbios_type_127 { |
| struct smbios_structure_header header; |
| } QEMU_PACKED; |
| |
| void smbios_entry_add(QemuOpts *opts, Error **errp); |
| void smbios_set_cpuid(uint32_t version, uint32_t features); |
| void smbios_set_defaults(const char *manufacturer, const char *product, |
| const char *version, bool legacy_mode, |
| bool uuid_encoded, SmbiosEntryPointType ep_type); |
| uint8_t *smbios_get_table_legacy(MachineState *ms, size_t *length); |
| void smbios_get_tables(MachineState *ms, |
| const struct smbios_phys_mem_area *mem_array, |
| const unsigned int mem_array_size, |
| uint8_t **tables, size_t *tables_len, |
| uint8_t **anchor, size_t *anchor_len, |
| Error **errp); |
| #endif /* QEMU_SMBIOS_H */ |