]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blame - include/linux/dmi.h
mm/hotplug: invalid PFNs from pfn_to_online_page()
[mirror_ubuntu-bionic-kernel.git] / include / linux / dmi.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
1da177e4
LT
2#ifndef __DMI_H__
3#define __DMI_H__
4
ebad6a42 5#include <linux/list.h>
d7f96f97 6#include <linux/kobject.h>
d945b697 7#include <linux/mod_devicetable.h>
ebad6a42 8
d945b697 9/* enum dmi_field is in mod_devicetable.h */
1da177e4 10
ebad6a42
AP
11enum dmi_device_type {
12 DMI_DEV_TYPE_ANY = 0,
13 DMI_DEV_TYPE_OTHER,
14 DMI_DEV_TYPE_UNKNOWN,
15 DMI_DEV_TYPE_VIDEO,
16 DMI_DEV_TYPE_SCSI,
17 DMI_DEV_TYPE_ETHERNET,
18 DMI_DEV_TYPE_TOKENRING,
19 DMI_DEV_TYPE_SOUND,
b4bd7d59
WVS
20 DMI_DEV_TYPE_PATA,
21 DMI_DEV_TYPE_SATA,
22 DMI_DEV_TYPE_SAS,
2e0c1f6c 23 DMI_DEV_TYPE_IPMI = -1,
b4bd7d59 24 DMI_DEV_TYPE_OEM_STRING = -2,
911e1c9b 25 DMI_DEV_TYPE_DEV_ONBOARD = -3,
e5b6c151 26 DMI_DEV_TYPE_DEV_SLOT = -4,
ebad6a42
AP
27};
28
93c890db
MW
29enum dmi_entry_type {
30 DMI_ENTRY_BIOS = 0,
31 DMI_ENTRY_SYSTEM,
32 DMI_ENTRY_BASEBOARD,
33 DMI_ENTRY_CHASSIS,
34 DMI_ENTRY_PROCESSOR,
35 DMI_ENTRY_MEM_CONTROLLER,
36 DMI_ENTRY_MEM_MODULE,
37 DMI_ENTRY_CACHE,
38 DMI_ENTRY_PORT_CONNECTOR,
39 DMI_ENTRY_SYSTEM_SLOT,
40 DMI_ENTRY_ONBOARD_DEVICE,
41 DMI_ENTRY_OEMSTRINGS,
42 DMI_ENTRY_SYSCONF,
43 DMI_ENTRY_BIOS_LANG,
44 DMI_ENTRY_GROUP_ASSOC,
45 DMI_ENTRY_SYSTEM_EVENT_LOG,
46 DMI_ENTRY_PHYS_MEM_ARRAY,
47 DMI_ENTRY_MEM_DEVICE,
48 DMI_ENTRY_32_MEM_ERROR,
49 DMI_ENTRY_MEM_ARRAY_MAPPED_ADDR,
50 DMI_ENTRY_MEM_DEV_MAPPED_ADDR,
51 DMI_ENTRY_BUILTIN_POINTING_DEV,
52 DMI_ENTRY_PORTABLE_BATTERY,
53 DMI_ENTRY_SYSTEM_RESET,
54 DMI_ENTRY_HW_SECURITY,
55 DMI_ENTRY_SYSTEM_POWER_CONTROLS,
56 DMI_ENTRY_VOLTAGE_PROBE,
57 DMI_ENTRY_COOLING_DEV,
58 DMI_ENTRY_TEMP_PROBE,
59 DMI_ENTRY_ELECTRICAL_CURRENT_PROBE,
60 DMI_ENTRY_OOB_REMOTE_ACCESS,
61 DMI_ENTRY_BIS_ENTRY,
62 DMI_ENTRY_SYSTEM_BOOT,
63 DMI_ENTRY_MGMT_DEV,
64 DMI_ENTRY_MGMT_DEV_COMPONENT,
65 DMI_ENTRY_MGMT_DEV_THRES,
66 DMI_ENTRY_MEM_CHANNEL,
67 DMI_ENTRY_IPMI_DEV,
68 DMI_ENTRY_SYS_POWER_SUPPLY,
69 DMI_ENTRY_ADDITIONAL,
70 DMI_ENTRY_ONBOARD_DEV_EXT,
71 DMI_ENTRY_MGMT_CONTROLLER_HOST,
72 DMI_ENTRY_INACTIVE = 126,
73 DMI_ENTRY_END_OF_TABLE = 127,
74};
75
ebad6a42
AP
76struct dmi_header {
77 u8 type;
78 u8 length;
79 u16 handle;
9ea650c8 80} __packed;
ebad6a42 81
ebad6a42
AP
82struct dmi_device {
83 struct list_head list;
84 int type;
85 const char *name;
86 void *device_data; /* Type specific data */
87};
1da177e4 88
e9928674 89#ifdef CONFIG_DMI
1da177e4 90
911e1c9b
N
91struct dmi_dev_onboard {
92 struct dmi_device dev;
93 int instance;
94 int segment;
95 int bus;
96 int devfn;
97};
98
d7f96f97 99extern struct kobject *dmi_kobj;
1855256c 100extern int dmi_check_system(const struct dmi_system_id *list);
d7b1956f 101const struct dmi_system_id *dmi_first_match(const struct dmi_system_id *list);
1855256c
JG
102extern const char * dmi_get_system_info(int field);
103extern const struct dmi_device * dmi_find_device(int type, const char *name,
104 const struct dmi_device *from);
e9928674 105extern void dmi_scan_machine(void);
dd6dad42 106extern void dmi_memdev_walk(void);
98e5e1bf 107extern void dmi_set_dump_stack_arch_desc(void);
3e5cd1f2 108extern bool dmi_get_date(int field, int *yearp, int *monthp, int *dayp);
1855256c 109extern int dmi_name_in_vendors(const char *str);
fd8cd7e1 110extern int dmi_name_in_serial(const char *str);
81b4e1f6 111extern int dmi_available;
e7a19c56
JD
112extern int dmi_walk(void (*decode)(const struct dmi_header *, void *),
113 void *private_data);
d61c72e5 114extern bool dmi_match(enum dmi_field f, const char *str);
dd6dad42 115extern void dmi_memdev_name(u16 handle, const char **bank, const char **device);
e9928674 116
1da177e4
LT
117#else
118
1855256c
JG
119static inline int dmi_check_system(const struct dmi_system_id *list) { return 0; }
120static inline const char * dmi_get_system_info(int field) { return NULL; }
121static inline const struct dmi_device * dmi_find_device(int type, const char *name,
122 const struct dmi_device *from) { return NULL; }
7ae9392c 123static inline void dmi_scan_machine(void) { return; }
dd6dad42 124static inline void dmi_memdev_walk(void) { }
98e5e1bf 125static inline void dmi_set_dump_stack_arch_desc(void) { }
3e5cd1f2
TH
126static inline bool dmi_get_date(int field, int *yearp, int *monthp, int *dayp)
127{
128 if (yearp)
129 *yearp = 0;
130 if (monthp)
131 *monthp = 0;
132 if (dayp)
133 *dayp = 0;
134 return false;
135}
1855256c 136static inline int dmi_name_in_vendors(const char *s) { return 0; }
fd8cd7e1 137static inline int dmi_name_in_serial(const char *s) { return 0; }
81b4e1f6 138#define dmi_available 0
e7a19c56 139static inline int dmi_walk(void (*decode)(const struct dmi_header *, void *),
c9268200 140 void *private_data) { return -ENXIO; }
d61c72e5
JS
141static inline bool dmi_match(enum dmi_field f, const char *str)
142 { return false; }
dd6dad42
CG
143static inline void dmi_memdev_name(u16 handle, const char **bank,
144 const char **device) { }
d8204ee2
KG
145static inline const struct dmi_system_id *
146 dmi_first_match(const struct dmi_system_id *list) { return NULL; }
1da177e4
LT
147
148#endif
149
150#endif /* __DMI_H__ */