xref: /linux-6.15/include/linux/dmi.h (revision 7c237880)
1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
21da177e4SLinus Torvalds #ifndef __DMI_H__
31da177e4SLinus Torvalds #define __DMI_H__
41da177e4SLinus Torvalds 
5ebad6a42SAndrey Panin #include <linux/list.h>
6d7f96f97SIvan Khoronzhuk #include <linux/kobject.h>
7d945b697SDavid Woodhouse #include <linux/mod_devicetable.h>
8ebad6a42SAndrey Panin 
9d945b697SDavid Woodhouse /* enum dmi_field is in mod_devicetable.h */
101da177e4SLinus Torvalds 
11ebad6a42SAndrey Panin enum dmi_device_type {
12ebad6a42SAndrey Panin 	DMI_DEV_TYPE_ANY = 0,
13ebad6a42SAndrey Panin 	DMI_DEV_TYPE_OTHER,
14ebad6a42SAndrey Panin 	DMI_DEV_TYPE_UNKNOWN,
15ebad6a42SAndrey Panin 	DMI_DEV_TYPE_VIDEO,
16ebad6a42SAndrey Panin 	DMI_DEV_TYPE_SCSI,
17ebad6a42SAndrey Panin 	DMI_DEV_TYPE_ETHERNET,
18ebad6a42SAndrey Panin 	DMI_DEV_TYPE_TOKENRING,
19ebad6a42SAndrey Panin 	DMI_DEV_TYPE_SOUND,
20b4bd7d59SWim Van Sebroeck 	DMI_DEV_TYPE_PATA,
21b4bd7d59SWim Van Sebroeck 	DMI_DEV_TYPE_SATA,
22b4bd7d59SWim Van Sebroeck 	DMI_DEV_TYPE_SAS,
232e0c1f6cSShem Multinymous 	DMI_DEV_TYPE_IPMI = -1,
24b4bd7d59SWim Van Sebroeck 	DMI_DEV_TYPE_OEM_STRING = -2,
25911e1c9bSNarendra K 	DMI_DEV_TYPE_DEV_ONBOARD = -3,
26e5b6c151SJordan Hargrave 	DMI_DEV_TYPE_DEV_SLOT = -4,
27ebad6a42SAndrey Panin };
28ebad6a42SAndrey Panin 
2993c890dbSMike Waychison enum dmi_entry_type {
3093c890dbSMike Waychison 	DMI_ENTRY_BIOS = 0,
3193c890dbSMike Waychison 	DMI_ENTRY_SYSTEM,
3293c890dbSMike Waychison 	DMI_ENTRY_BASEBOARD,
3393c890dbSMike Waychison 	DMI_ENTRY_CHASSIS,
3493c890dbSMike Waychison 	DMI_ENTRY_PROCESSOR,
3593c890dbSMike Waychison 	DMI_ENTRY_MEM_CONTROLLER,
3693c890dbSMike Waychison 	DMI_ENTRY_MEM_MODULE,
3793c890dbSMike Waychison 	DMI_ENTRY_CACHE,
3893c890dbSMike Waychison 	DMI_ENTRY_PORT_CONNECTOR,
3993c890dbSMike Waychison 	DMI_ENTRY_SYSTEM_SLOT,
4093c890dbSMike Waychison 	DMI_ENTRY_ONBOARD_DEVICE,
4193c890dbSMike Waychison 	DMI_ENTRY_OEMSTRINGS,
4293c890dbSMike Waychison 	DMI_ENTRY_SYSCONF,
4393c890dbSMike Waychison 	DMI_ENTRY_BIOS_LANG,
4493c890dbSMike Waychison 	DMI_ENTRY_GROUP_ASSOC,
4593c890dbSMike Waychison 	DMI_ENTRY_SYSTEM_EVENT_LOG,
4693c890dbSMike Waychison 	DMI_ENTRY_PHYS_MEM_ARRAY,
4793c890dbSMike Waychison 	DMI_ENTRY_MEM_DEVICE,
4893c890dbSMike Waychison 	DMI_ENTRY_32_MEM_ERROR,
4993c890dbSMike Waychison 	DMI_ENTRY_MEM_ARRAY_MAPPED_ADDR,
5093c890dbSMike Waychison 	DMI_ENTRY_MEM_DEV_MAPPED_ADDR,
5193c890dbSMike Waychison 	DMI_ENTRY_BUILTIN_POINTING_DEV,
5293c890dbSMike Waychison 	DMI_ENTRY_PORTABLE_BATTERY,
5393c890dbSMike Waychison 	DMI_ENTRY_SYSTEM_RESET,
5493c890dbSMike Waychison 	DMI_ENTRY_HW_SECURITY,
5593c890dbSMike Waychison 	DMI_ENTRY_SYSTEM_POWER_CONTROLS,
5693c890dbSMike Waychison 	DMI_ENTRY_VOLTAGE_PROBE,
5793c890dbSMike Waychison 	DMI_ENTRY_COOLING_DEV,
5893c890dbSMike Waychison 	DMI_ENTRY_TEMP_PROBE,
5993c890dbSMike Waychison 	DMI_ENTRY_ELECTRICAL_CURRENT_PROBE,
6093c890dbSMike Waychison 	DMI_ENTRY_OOB_REMOTE_ACCESS,
6193c890dbSMike Waychison 	DMI_ENTRY_BIS_ENTRY,
6293c890dbSMike Waychison 	DMI_ENTRY_SYSTEM_BOOT,
6393c890dbSMike Waychison 	DMI_ENTRY_MGMT_DEV,
6493c890dbSMike Waychison 	DMI_ENTRY_MGMT_DEV_COMPONENT,
6593c890dbSMike Waychison 	DMI_ENTRY_MGMT_DEV_THRES,
6693c890dbSMike Waychison 	DMI_ENTRY_MEM_CHANNEL,
6793c890dbSMike Waychison 	DMI_ENTRY_IPMI_DEV,
6893c890dbSMike Waychison 	DMI_ENTRY_SYS_POWER_SUPPLY,
6993c890dbSMike Waychison 	DMI_ENTRY_ADDITIONAL,
7093c890dbSMike Waychison 	DMI_ENTRY_ONBOARD_DEV_EXT,
7193c890dbSMike Waychison 	DMI_ENTRY_MGMT_CONTROLLER_HOST,
7293c890dbSMike Waychison 	DMI_ENTRY_INACTIVE = 126,
7393c890dbSMike Waychison 	DMI_ENTRY_END_OF_TABLE = 127,
7493c890dbSMike Waychison };
7593c890dbSMike Waychison 
76ebad6a42SAndrey Panin struct dmi_header {
77ebad6a42SAndrey Panin 	u8 type;
78ebad6a42SAndrey Panin 	u8 length;
79ebad6a42SAndrey Panin 	u16 handle;
809ea650c8SJean Delvare } __packed;
81ebad6a42SAndrey Panin 
82ebad6a42SAndrey Panin struct dmi_device {
83ebad6a42SAndrey Panin 	struct list_head list;
84ebad6a42SAndrey Panin 	int type;
85ebad6a42SAndrey Panin 	const char *name;
86ebad6a42SAndrey Panin 	void *device_data;	/* Type specific data */
87ebad6a42SAndrey Panin };
88ebad6a42SAndrey Panin 
89e9928674SAndi Kleen #ifdef CONFIG_DMI
901da177e4SLinus Torvalds 
91911e1c9bSNarendra K struct dmi_dev_onboard {
92911e1c9bSNarendra K 	struct dmi_device dev;
93911e1c9bSNarendra K 	int instance;
94911e1c9bSNarendra K 	int segment;
95911e1c9bSNarendra K 	int bus;
96911e1c9bSNarendra K 	int devfn;
97911e1c9bSNarendra K };
98911e1c9bSNarendra K 
99d7f96f97SIvan Khoronzhuk extern struct kobject *dmi_kobj;
1001855256cSJeff Garzik extern int dmi_check_system(const struct dmi_system_id *list);
101d7b1956fSRafael J. Wysocki const struct dmi_system_id *dmi_first_match(const struct dmi_system_id *list);
1021855256cSJeff Garzik extern const char * dmi_get_system_info(int field);
1031855256cSJeff Garzik extern const struct dmi_device * dmi_find_device(int type, const char *name,
1041855256cSJeff Garzik 	const struct dmi_device *from);
1050fca0812SRobert Richter extern void dmi_setup(void);
1063e5cd1f2STejun Heo extern bool dmi_get_date(int field, int *yearp, int *monthp, int *dayp);
1073af34525SAndy Shevchenko extern int dmi_get_bios_year(void);
1081855256cSJeff Garzik extern int dmi_name_in_vendors(const char *str);
109fd8cd7e1SAlok Kataria extern int dmi_name_in_serial(const char *str);
11081b4e1f6SLen Brown extern int dmi_available;
111e7a19c56SJean Delvare extern int dmi_walk(void (*decode)(const struct dmi_header *, void *),
112e7a19c56SJean Delvare 	void *private_data);
113d61c72e5SJiri Slaby extern bool dmi_match(enum dmi_field f, const char *str);
114dd6dad42SChen, Gong extern void dmi_memdev_name(u16 handle, const char **bank, const char **device);
1156deae96bSTony Luck extern u64 dmi_memdev_size(u16 handle);
1169e0afe39SJean Delvare extern u8 dmi_memdev_type(u16 handle);
117*7c237880SJean Delvare extern u16 dmi_memdev_handle(int slot);
118e9928674SAndi Kleen 
1191da177e4SLinus Torvalds #else
1201da177e4SLinus Torvalds 
dmi_check_system(const struct dmi_system_id * list)1211855256cSJeff Garzik static inline int dmi_check_system(const struct dmi_system_id *list) { return 0; }
dmi_get_system_info(int field)1221855256cSJeff Garzik static inline const char * dmi_get_system_info(int field) { return NULL; }
dmi_find_device(int type,const char * name,const struct dmi_device * from)1231855256cSJeff Garzik static inline const struct dmi_device * dmi_find_device(int type, const char *name,
1241855256cSJeff Garzik 	const struct dmi_device *from) { return NULL; }
dmi_setup(void)1250fca0812SRobert Richter static inline void dmi_setup(void) { }
dmi_get_date(int field,int * yearp,int * monthp,int * dayp)1263e5cd1f2STejun Heo static inline bool dmi_get_date(int field, int *yearp, int *monthp, int *dayp)
1273e5cd1f2STejun Heo {
1283e5cd1f2STejun Heo 	if (yearp)
1293e5cd1f2STejun Heo 		*yearp = 0;
1303e5cd1f2STejun Heo 	if (monthp)
1313e5cd1f2STejun Heo 		*monthp = 0;
1323e5cd1f2STejun Heo 	if (dayp)
1333e5cd1f2STejun Heo 		*dayp = 0;
1343e5cd1f2STejun Heo 	return false;
1353e5cd1f2STejun Heo }
dmi_get_bios_year(void)1363af34525SAndy Shevchenko static inline int dmi_get_bios_year(void) { return -ENXIO; }
dmi_name_in_vendors(const char * s)1371855256cSJeff Garzik static inline int dmi_name_in_vendors(const char *s) { return 0; }
dmi_name_in_serial(const char * s)138fd8cd7e1SAlok Kataria static inline int dmi_name_in_serial(const char *s) { return 0; }
13981b4e1f6SLen Brown #define dmi_available 0
dmi_walk(void (* decode)(const struct dmi_header *,void *),void * private_data)140e7a19c56SJean Delvare static inline int dmi_walk(void (*decode)(const struct dmi_header *, void *),
141c9268200SAndy Lutomirski 	void *private_data) { return -ENXIO; }
dmi_match(enum dmi_field f,const char * str)142d61c72e5SJiri Slaby static inline bool dmi_match(enum dmi_field f, const char *str)
143d61c72e5SJiri Slaby 	{ return false; }
dmi_memdev_name(u16 handle,const char ** bank,const char ** device)144dd6dad42SChen, Gong static inline void dmi_memdev_name(u16 handle, const char **bank,
145dd6dad42SChen, Gong 		const char **device) { }
dmi_memdev_size(u16 handle)1466deae96bSTony Luck static inline u64 dmi_memdev_size(u16 handle) { return ~0ul; }
dmi_memdev_type(u16 handle)1479e0afe39SJean Delvare static inline u8 dmi_memdev_type(u16 handle) { return 0x0; }
dmi_memdev_handle(int slot)148*7c237880SJean Delvare static inline u16 dmi_memdev_handle(int slot) { return 0xffff; }
149d8204ee2SKumar Gala static inline const struct dmi_system_id *
dmi_first_match(const struct dmi_system_id * list)150d8204ee2SKumar Gala 	dmi_first_match(const struct dmi_system_id *list) { return NULL; }
1511da177e4SLinus Torvalds 
1521da177e4SLinus Torvalds #endif
1531da177e4SLinus Torvalds 
1541da177e4SLinus Torvalds #endif	/* __DMI_H__ */
155