xref: /rk3399_rockchip-uboot/include/smbios.h (revision 42fd8c19b58fe8f8fe7559ea53b1cef12fc06240)
14b6dddc2SAlexander Graf /*
24b6dddc2SAlexander Graf  * Copyright (C) 2015, Bin Meng <bmeng.cn@gmail.com>
34b6dddc2SAlexander Graf  *
44b6dddc2SAlexander Graf  * Adapted from coreboot src/include/smbios.h
54b6dddc2SAlexander Graf  *
64b6dddc2SAlexander Graf  * SPDX-License-Identifier:	GPL-2.0+
74b6dddc2SAlexander Graf  */
84b6dddc2SAlexander Graf 
94b6dddc2SAlexander Graf #ifndef _SMBIOS_H_
104b6dddc2SAlexander Graf #define _SMBIOS_H_
114b6dddc2SAlexander Graf 
124b6dddc2SAlexander Graf /* SMBIOS spec version implemented */
134b6dddc2SAlexander Graf #define SMBIOS_MAJOR_VER	3
144b6dddc2SAlexander Graf #define SMBIOS_MINOR_VER	0
154b6dddc2SAlexander Graf 
164b6dddc2SAlexander Graf /* SMBIOS structure types */
174b6dddc2SAlexander Graf enum {
184b6dddc2SAlexander Graf 	SMBIOS_BIOS_INFORMATION = 0,
194b6dddc2SAlexander Graf 	SMBIOS_SYSTEM_INFORMATION = 1,
204b6dddc2SAlexander Graf 	SMBIOS_BOARD_INFORMATION = 2,
214b6dddc2SAlexander Graf 	SMBIOS_SYSTEM_ENCLOSURE = 3,
224b6dddc2SAlexander Graf 	SMBIOS_PROCESSOR_INFORMATION = 4,
234b6dddc2SAlexander Graf 	SMBIOS_CACHE_INFORMATION = 7,
244b6dddc2SAlexander Graf 	SMBIOS_SYSTEM_SLOTS = 9,
254b6dddc2SAlexander Graf 	SMBIOS_PHYS_MEMORY_ARRAY = 16,
264b6dddc2SAlexander Graf 	SMBIOS_MEMORY_DEVICE = 17,
274b6dddc2SAlexander Graf 	SMBIOS_MEMORY_ARRAY_MAPPED_ADDRESS = 19,
284b6dddc2SAlexander Graf 	SMBIOS_SYSTEM_BOOT_INFORMATION = 32,
294b6dddc2SAlexander Graf 	SMBIOS_END_OF_TABLE = 127
304b6dddc2SAlexander Graf };
314b6dddc2SAlexander Graf 
324b6dddc2SAlexander Graf #define SMBIOS_INTERMEDIATE_OFFSET	16
334b6dddc2SAlexander Graf #define SMBIOS_STRUCT_EOS_BYTES		2
344b6dddc2SAlexander Graf 
354b6dddc2SAlexander Graf struct __packed smbios_entry {
364b6dddc2SAlexander Graf 	u8 anchor[4];
374b6dddc2SAlexander Graf 	u8 checksum;
384b6dddc2SAlexander Graf 	u8 length;
394b6dddc2SAlexander Graf 	u8 major_ver;
404b6dddc2SAlexander Graf 	u8 minor_ver;
414b6dddc2SAlexander Graf 	u16 max_struct_size;
424b6dddc2SAlexander Graf 	u8 entry_point_rev;
434b6dddc2SAlexander Graf 	u8 formatted_area[5];
444b6dddc2SAlexander Graf 	u8 intermediate_anchor[5];
454b6dddc2SAlexander Graf 	u8 intermediate_checksum;
464b6dddc2SAlexander Graf 	u16 struct_table_length;
474b6dddc2SAlexander Graf 	u32 struct_table_address;
484b6dddc2SAlexander Graf 	u16 struct_count;
494b6dddc2SAlexander Graf 	u8 bcd_rev;
504b6dddc2SAlexander Graf };
514b6dddc2SAlexander Graf 
524b6dddc2SAlexander Graf /* BIOS characteristics */
534b6dddc2SAlexander Graf #define BIOS_CHARACTERISTICS_PCI_SUPPORTED	(1 << 7)
544b6dddc2SAlexander Graf #define BIOS_CHARACTERISTICS_UPGRADEABLE	(1 << 11)
554b6dddc2SAlexander Graf #define BIOS_CHARACTERISTICS_SELECTABLE_BOOT	(1 << 16)
564b6dddc2SAlexander Graf 
574b6dddc2SAlexander Graf #define BIOS_CHARACTERISTICS_EXT1_ACPI		(1 << 0)
58e663b350SAlexander Graf #define BIOS_CHARACTERISTICS_EXT1_UEFI		(1 << 3)
594b6dddc2SAlexander Graf #define BIOS_CHARACTERISTICS_EXT2_TARGET	(1 << 2)
604b6dddc2SAlexander Graf 
614b6dddc2SAlexander Graf struct __packed smbios_type0 {
624b6dddc2SAlexander Graf 	u8 type;
634b6dddc2SAlexander Graf 	u8 length;
644b6dddc2SAlexander Graf 	u16 handle;
654b6dddc2SAlexander Graf 	u8 vendor;
664b6dddc2SAlexander Graf 	u8 bios_ver;
674b6dddc2SAlexander Graf 	u16 bios_start_segment;
684b6dddc2SAlexander Graf 	u8 bios_release_date;
694b6dddc2SAlexander Graf 	u8 bios_rom_size;
704b6dddc2SAlexander Graf 	u64 bios_characteristics;
714b6dddc2SAlexander Graf 	u8 bios_characteristics_ext1;
724b6dddc2SAlexander Graf 	u8 bios_characteristics_ext2;
734b6dddc2SAlexander Graf 	u8 bios_major_release;
744b6dddc2SAlexander Graf 	u8 bios_minor_release;
754b6dddc2SAlexander Graf 	u8 ec_major_release;
764b6dddc2SAlexander Graf 	u8 ec_minor_release;
774b6dddc2SAlexander Graf 	char eos[SMBIOS_STRUCT_EOS_BYTES];
784b6dddc2SAlexander Graf };
794b6dddc2SAlexander Graf 
804b6dddc2SAlexander Graf struct __packed smbios_type1 {
814b6dddc2SAlexander Graf 	u8 type;
824b6dddc2SAlexander Graf 	u8 length;
834b6dddc2SAlexander Graf 	u16 handle;
844b6dddc2SAlexander Graf 	u8 manufacturer;
854b6dddc2SAlexander Graf 	u8 product_name;
864b6dddc2SAlexander Graf 	u8 version;
874b6dddc2SAlexander Graf 	u8 serial_number;
884b6dddc2SAlexander Graf 	u8 uuid[16];
894b6dddc2SAlexander Graf 	u8 wakeup_type;
904b6dddc2SAlexander Graf 	u8 sku_number;
914b6dddc2SAlexander Graf 	u8 family;
924b6dddc2SAlexander Graf 	char eos[SMBIOS_STRUCT_EOS_BYTES];
934b6dddc2SAlexander Graf };
944b6dddc2SAlexander Graf 
954b6dddc2SAlexander Graf #define SMBIOS_BOARD_FEATURE_HOSTING	(1 << 0)
964b6dddc2SAlexander Graf #define SMBIOS_BOARD_MOTHERBOARD	10
974b6dddc2SAlexander Graf 
984b6dddc2SAlexander Graf struct __packed smbios_type2 {
994b6dddc2SAlexander Graf 	u8 type;
1004b6dddc2SAlexander Graf 	u8 length;
1014b6dddc2SAlexander Graf 	u16 handle;
1024b6dddc2SAlexander Graf 	u8 manufacturer;
1034b6dddc2SAlexander Graf 	u8 product_name;
1044b6dddc2SAlexander Graf 	u8 version;
1054b6dddc2SAlexander Graf 	u8 serial_number;
1064b6dddc2SAlexander Graf 	u8 asset_tag_number;
1074b6dddc2SAlexander Graf 	u8 feature_flags;
1084b6dddc2SAlexander Graf 	u8 chassis_location;
1094b6dddc2SAlexander Graf 	u16 chassis_handle;
1104b6dddc2SAlexander Graf 	u8 board_type;
1114b6dddc2SAlexander Graf 	char eos[SMBIOS_STRUCT_EOS_BYTES];
1124b6dddc2SAlexander Graf };
1134b6dddc2SAlexander Graf 
1144b6dddc2SAlexander Graf #define SMBIOS_ENCLOSURE_DESKTOP	3
1154b6dddc2SAlexander Graf #define SMBIOS_STATE_SAFE		3
1164b6dddc2SAlexander Graf #define SMBIOS_SECURITY_NONE		3
1174b6dddc2SAlexander Graf 
1184b6dddc2SAlexander Graf struct __packed smbios_type3 {
1194b6dddc2SAlexander Graf 	u8 type;
1204b6dddc2SAlexander Graf 	u8 length;
1214b6dddc2SAlexander Graf 	u16 handle;
1224b6dddc2SAlexander Graf 	u8 manufacturer;
1234b6dddc2SAlexander Graf 	u8 chassis_type;
1244b6dddc2SAlexander Graf 	u8 version;
1254b6dddc2SAlexander Graf 	u8 serial_number;
1264b6dddc2SAlexander Graf 	u8 asset_tag_number;
1274b6dddc2SAlexander Graf 	u8 bootup_state;
1284b6dddc2SAlexander Graf 	u8 power_supply_state;
1294b6dddc2SAlexander Graf 	u8 thermal_state;
1304b6dddc2SAlexander Graf 	u8 security_status;
1314b6dddc2SAlexander Graf 	u32 oem_defined;
1324b6dddc2SAlexander Graf 	u8 height;
1334b6dddc2SAlexander Graf 	u8 number_of_power_cords;
1344b6dddc2SAlexander Graf 	u8 element_count;
1354b6dddc2SAlexander Graf 	u8 element_record_length;
1364b6dddc2SAlexander Graf 	char eos[SMBIOS_STRUCT_EOS_BYTES];
1374b6dddc2SAlexander Graf };
1384b6dddc2SAlexander Graf 
1394b6dddc2SAlexander Graf #define SMBIOS_PROCESSOR_TYPE_CENTRAL	3
1404b6dddc2SAlexander Graf #define SMBIOS_PROCESSOR_STATUS_ENABLED	1
1414b6dddc2SAlexander Graf #define SMBIOS_PROCESSOR_UPGRADE_NONE	6
1424b6dddc2SAlexander Graf 
14396476206SAlexander Graf #define SMBIOS_PROCESSOR_FAMILY_OTHER	1
14496476206SAlexander Graf #define SMBIOS_PROCESSOR_FAMILY_UNKNOWN	2
14596476206SAlexander Graf 
1464b6dddc2SAlexander Graf struct __packed smbios_type4 {
1474b6dddc2SAlexander Graf 	u8 type;
1484b6dddc2SAlexander Graf 	u8 length;
1494b6dddc2SAlexander Graf 	u16 handle;
1504b6dddc2SAlexander Graf 	u8 socket_designation;
1514b6dddc2SAlexander Graf 	u8 processor_type;
1524b6dddc2SAlexander Graf 	u8 processor_family;
1534b6dddc2SAlexander Graf 	u8 processor_manufacturer;
1544b6dddc2SAlexander Graf 	u32 processor_id[2];
1554b6dddc2SAlexander Graf 	u8 processor_version;
1564b6dddc2SAlexander Graf 	u8 voltage;
1574b6dddc2SAlexander Graf 	u16 external_clock;
1584b6dddc2SAlexander Graf 	u16 max_speed;
1594b6dddc2SAlexander Graf 	u16 current_speed;
1604b6dddc2SAlexander Graf 	u8 status;
1614b6dddc2SAlexander Graf 	u8 processor_upgrade;
1624b6dddc2SAlexander Graf 	u16 l1_cache_handle;
1634b6dddc2SAlexander Graf 	u16 l2_cache_handle;
1644b6dddc2SAlexander Graf 	u16 l3_cache_handle;
1654b6dddc2SAlexander Graf 	u8 serial_number;
1664b6dddc2SAlexander Graf 	u8 asset_tag;
1674b6dddc2SAlexander Graf 	u8 part_number;
1684b6dddc2SAlexander Graf 	u8 core_count;
1694b6dddc2SAlexander Graf 	u8 core_enabled;
1704b6dddc2SAlexander Graf 	u8 thread_count;
1714b6dddc2SAlexander Graf 	u16 processor_characteristics;
1724b6dddc2SAlexander Graf 	u16 processor_family2;
1734b6dddc2SAlexander Graf 	u16 core_count2;
1744b6dddc2SAlexander Graf 	u16 core_enabled2;
1754b6dddc2SAlexander Graf 	u16 thread_count2;
1764b6dddc2SAlexander Graf 	char eos[SMBIOS_STRUCT_EOS_BYTES];
1774b6dddc2SAlexander Graf };
1784b6dddc2SAlexander Graf 
1794b6dddc2SAlexander Graf struct __packed smbios_type32 {
1804b6dddc2SAlexander Graf 	u8 type;
1814b6dddc2SAlexander Graf 	u8 length;
1824b6dddc2SAlexander Graf 	u16 handle;
1834b6dddc2SAlexander Graf 	u8 reserved[6];
1844b6dddc2SAlexander Graf 	u8 boot_status;
1854b6dddc2SAlexander Graf 	u8 eos[SMBIOS_STRUCT_EOS_BYTES];
1864b6dddc2SAlexander Graf };
1874b6dddc2SAlexander Graf 
1884b6dddc2SAlexander Graf struct __packed smbios_type127 {
1894b6dddc2SAlexander Graf 	u8 type;
1904b6dddc2SAlexander Graf 	u8 length;
1914b6dddc2SAlexander Graf 	u16 handle;
1924b6dddc2SAlexander Graf 	u8 eos[SMBIOS_STRUCT_EOS_BYTES];
1934b6dddc2SAlexander Graf };
1944b6dddc2SAlexander Graf 
1954b6dddc2SAlexander Graf struct __packed smbios_header {
1964b6dddc2SAlexander Graf 	u8 type;
1974b6dddc2SAlexander Graf 	u8 length;
1984b6dddc2SAlexander Graf 	u16 handle;
1994b6dddc2SAlexander Graf };
2004b6dddc2SAlexander Graf 
2014b6dddc2SAlexander Graf /**
2024b6dddc2SAlexander Graf  * fill_smbios_header() - Fill the header of an SMBIOS table
2034b6dddc2SAlexander Graf  *
2044b6dddc2SAlexander Graf  * This fills the header of an SMBIOS table structure.
2054b6dddc2SAlexander Graf  *
2064b6dddc2SAlexander Graf  * @table:	start address of the structure
2074b6dddc2SAlexander Graf  * @type:	the type of structure
2084b6dddc2SAlexander Graf  * @length:	the length of the formatted area of the structure
2094b6dddc2SAlexander Graf  * @handle:	the structure's handle, a unique 16-bit number
2104b6dddc2SAlexander Graf  */
fill_smbios_header(void * table,int type,int length,int handle)2114b6dddc2SAlexander Graf static inline void fill_smbios_header(void *table, int type,
2124b6dddc2SAlexander Graf 				      int length, int handle)
2134b6dddc2SAlexander Graf {
2144b6dddc2SAlexander Graf 	struct smbios_header *header = table;
2154b6dddc2SAlexander Graf 
2164b6dddc2SAlexander Graf 	header->type = type;
2174b6dddc2SAlexander Graf 	header->length = length - SMBIOS_STRUCT_EOS_BYTES;
2184b6dddc2SAlexander Graf 	header->handle = handle;
2194b6dddc2SAlexander Graf }
2204b6dddc2SAlexander Graf 
2214b6dddc2SAlexander Graf /**
2224b6dddc2SAlexander Graf  * Function prototype to write a specific type of SMBIOS structure
2234b6dddc2SAlexander Graf  *
2244b6dddc2SAlexander Graf  * @addr:	start address to write the structure
2254b6dddc2SAlexander Graf  * @handle:	the structure's handle, a unique 16-bit number
2264b6dddc2SAlexander Graf  * @return:	size of the structure
2274b6dddc2SAlexander Graf  */
228*42fd8c19SSimon Glass typedef int (*smbios_write_type)(ulong *addr, int handle);
2294b6dddc2SAlexander Graf 
2304b6dddc2SAlexander Graf /**
2314b6dddc2SAlexander Graf  * write_smbios_table() - Write SMBIOS table
2324b6dddc2SAlexander Graf  *
2334b6dddc2SAlexander Graf  * This writes SMBIOS table at a given address.
2344b6dddc2SAlexander Graf  *
2354b6dddc2SAlexander Graf  * @addr:	start address to write SMBIOS table
2364b6dddc2SAlexander Graf  * @return:	end address of SMBIOS table
2374b6dddc2SAlexander Graf  */
238*42fd8c19SSimon Glass ulong write_smbios_table(ulong addr);
2394b6dddc2SAlexander Graf 
2404b6dddc2SAlexander Graf #endif /* _SMBIOS_H_ */
241