]> Git Repo - u-boot.git/blob - include/sysinfo.h
Merge branch 'master' of https://source.denx.de/u-boot/custodians/u-boot-sh
[u-boot.git] / include / sysinfo.h
1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /*
3  * (C) Copyright 2017
4  * Mario Six,  Guntermann & Drunck GmbH, [email protected]
5  */
6
7 #ifndef __SYSINFO_H__
8 #define __SYSINFO_H__
9
10 #include <linux/errno.h>
11
12 struct udevice;
13
14 #define SYSINFO_CACHE_LVL_MAX 3
15
16 /*
17  * This uclass encapsulates hardware methods to gather information about a
18  * sysinfo or a specific device such as hard-wired GPIOs on GPIO expanders,
19  * read-only data in flash ICs, or similar.
20  *
21  * The interface offers functions to read the usual standard data types (bool,
22  * int, string) from the device, each of which is identified by a static
23  * numeric ID (which will usually be defined as a enum in a header file).
24  *
25  * If for example the sysinfo had a read-only serial number flash IC, we could
26  * call
27  *
28  * ret = sysinfo_detect(dev);
29  * if (ret) {
30  *      debug("sysinfo device not found.");
31  *      return ret;
32  * }
33  *
34  * ret = sysinfo_get_int(dev, ID_SERIAL_NUMBER, &serial);
35  * if (ret) {
36  *      debug("Error when reading serial number from device.");
37  *      return ret;
38  * }
39  *
40  * to read the serial number.
41  */
42
43 /** enum sysinfo_id - Standard IDs defined by U-Boot */
44 enum sysinfo_id {
45         SYSID_NONE,
46
47         /* BIOS Information (Type 0) */
48         SYSID_SM_BIOS_VENDOR,
49         SYSID_SM_BIOS_VER,
50         SYSID_SM_BIOS_REL_DATE,
51
52         /* System Information (Type 1) */
53         SYSID_SM_SYSTEM_MANUFACTURER,
54         SYSID_SM_SYSTEM_PRODUCT,
55         SYSID_SM_SYSTEM_VERSION,
56         SYSID_SM_SYSTEM_SERIAL,
57         SYSID_SM_SYSTEM_WAKEUP,
58         SYSID_SM_SYSTEM_SKU,
59         SYSID_SM_SYSTEM_FAMILY,
60
61         /* Baseboard (or Module) Information (Type 2) */
62         SYSID_SM_BASEBOARD_MANUFACTURER,
63         SYSID_SM_BASEBOARD_PRODUCT,
64         SYSID_SM_BASEBOARD_VERSION,
65         SYSID_SM_BASEBOARD_SERIAL,
66         SYSID_SM_BASEBOARD_ASSET_TAG,
67         SYSID_SM_BASEBOARD_FEATURE,
68         SYSID_SM_BASEBOARD_CHASSIS_LOCAT,
69         SYSID_SM_BASEBOARD_TYPE,
70         SYSID_SM_BASEBOARD_OBJS_NUM,
71         SYSID_SM_BASEBOARD_OBJS_HANDLE,
72
73         /* System Enclosure or Chassis (Type 3) */
74         SYSID_SM_ENCLOSURE_MANUFACTURER,
75         SYSID_SM_ENCLOSURE_VERSION,
76         SYSID_SM_ENCLOSURE_SERIAL,
77         SYSID_SM_ENCLOSURE_ASSET_TAG,
78         SYSID_SM_ENCLOSURE_TYPE,
79         SYSID_SM_ENCLOSURE_BOOTUP,
80         SYSID_SM_ENCLOSURE_POW,
81         SYSID_SM_ENCLOSURE_THERMAL,
82         SYSID_SM_ENCLOSURE_SECURITY,
83         SYSID_SM_ENCLOSURE_OEM,
84         SYSID_SM_ENCLOSURE_HEIGHT,
85         SYSID_SM_ENCLOSURE_POWCORE_NUM,
86         SYSID_SM_ENCLOSURE_ELEMENT_CNT,
87         SYSID_SM_ENCLOSURE_ELEMENT_LEN,
88         SYSID_SM_ENCLOSURE_ELEMENTS,
89         SYSID_SM_ENCLOSURE_SKU,
90
91         /* Processor Information (Type 4) */
92         SYSID_SM_PROCESSOR_SOCKET,
93         SYSID_SM_PROCESSOR_TYPE,
94         SYSID_SM_PROCESSOR_MANUFACT,
95         SYSID_SM_PROCESSOR_ID,
96         SYSID_SM_PROCESSOR_VERSION,
97         SYSID_SM_PROCESSOR_VOLTAGE,
98         SYSID_SM_PROCESSOR_EXT_CLOCK,
99         SYSID_SM_PROCESSOR_MAX_SPEED,
100         SYSID_SM_PROCESSOR_CUR_SPEED,
101         SYSID_SM_PROCESSOR_STATUS,
102         SYSID_SM_PROCESSOR_UPGRADE,
103         SYSID_SM_PROCESSOR_SN,
104         SYSID_SM_PROCESSOR_ASSET_TAG,
105         SYSID_SM_PROCESSOR_PN,
106         SYSID_SM_PROCESSOR_CORE_CNT,
107         SYSID_SM_PROCESSOR_CORE_EN,
108         SYSID_SM_PROCESSOR_THREAD_CNT,
109         SYSID_SM_PROCESSOR_CHARA,
110         SYSID_SM_PROCESSOR_FAMILY,
111         SYSID_SM_PROCESSOR_FAMILY2,
112         SYSID_SM_PROCESSOR_CORE_CNT2,
113         SYSID_SM_PROCESSOR_CORE_EN2,
114         SYSID_SM_PROCESSOR_THREAD_CNT2,
115         SYSID_SM_PROCESSOR_THREAD_EN,
116
117         /*
118          * Cache Information (Type 7)
119          * Each of the id should reserve space for up to
120          * SYSINFO_CACHE_LVL_MAX levels of cache
121          */
122         SYSID_SM_CACHE_LEVEL,
123         SYSID_SM_CACHE_HANDLE,
124         SYSID_SM_CACHE_INFO_START,
125         SYSID_SM_CACHE_SOCKET = SYSID_SM_CACHE_INFO_START,
126         SYSID_SM_CACHE_CONFIG =
127                 SYSID_SM_CACHE_SOCKET + SYSINFO_CACHE_LVL_MAX,
128         SYSID_SM_CACHE_MAX_SIZE =
129                 SYSID_SM_CACHE_CONFIG + SYSINFO_CACHE_LVL_MAX,
130         SYSID_SM_CACHE_INST_SIZE =
131                 SYSID_SM_CACHE_MAX_SIZE + SYSINFO_CACHE_LVL_MAX,
132         SYSID_SM_CACHE_SUPSRAM_TYPE =
133                 SYSID_SM_CACHE_INST_SIZE + SYSINFO_CACHE_LVL_MAX,
134         SYSID_SM_CACHE_CURSRAM_TYPE =
135                 SYSID_SM_CACHE_SUPSRAM_TYPE + SYSINFO_CACHE_LVL_MAX,
136         SYSID_SM_CACHE_SPEED =
137                 SYSID_SM_CACHE_CURSRAM_TYPE + SYSINFO_CACHE_LVL_MAX,
138         SYSID_SM_CACHE_ERRCOR_TYPE =
139                 SYSID_SM_CACHE_SPEED + SYSINFO_CACHE_LVL_MAX,
140         SYSID_SM_CACHE_SCACHE_TYPE =
141                 SYSID_SM_CACHE_ERRCOR_TYPE + SYSINFO_CACHE_LVL_MAX,
142         SYSID_SM_CACHE_ASSOC =
143                 SYSID_SM_CACHE_SCACHE_TYPE + SYSINFO_CACHE_LVL_MAX,
144         SYSID_SM_CACHE_MAX_SIZE2 =
145                 SYSID_SM_CACHE_ASSOC + SYSINFO_CACHE_LVL_MAX,
146         SYSID_SM_CACHE_INST_SIZE2 =
147                 SYSID_SM_CACHE_MAX_SIZE2 + SYSINFO_CACHE_LVL_MAX,
148         SYSID_SM_CACHE_INFO_END =
149                 SYSID_SM_CACHE_INST_SIZE2 + SYSINFO_CACHE_LVL_MAX - 1,
150
151         /* For show_board_info() */
152         SYSID_BOARD_MODEL,
153         SYSID_BOARD_MANUFACTURER,
154         SYSID_PRIOR_STAGE_VERSION,
155         SYSID_PRIOR_STAGE_DATE,
156
157         /* First value available for downstream/board used */
158         SYSID_USER = 0x1000,
159 };
160
161 struct sysinfo_ops {
162         /**
163          * detect() - Run the hardware info detection procedure for this
164          *            device.
165          * @dev:      The device containing the information
166          *
167          * This operation might take a long time (e.g. read from EEPROM,
168          * check the presence of a device on a bus etc.), hence this is not
169          * done in the probe() method, but later during operation in this
170          * dedicated method. This method will be called before any other
171          * methods.
172          *
173          * Return: 0 if OK, -ve on error.
174          */
175         int (*detect)(struct udevice *dev);
176
177         /**
178          * get_bool() - Read a specific bool data value that describes the
179          *              hardware setup.
180          * @dev:        The sysinfo instance to gather the data.
181          * @id:         A unique identifier for the bool value to be read.
182          * @val:        Pointer to a buffer that receives the value read.
183          *
184          * Return: 0 if OK, -ve on error.
185          */
186         int (*get_bool)(struct udevice *dev, int id, bool *val);
187
188         /**
189          * get_int() - Read a specific int data value that describes the
190          *             hardware setup.
191          * @dev:       The sysinfo instance to gather the data.
192          * @id:        A unique identifier for the int value to be read.
193          * @val:       Pointer to a buffer that receives the value read.
194          *
195          * Return: 0 if OK, -ve on error.
196          */
197         int (*get_int)(struct udevice *dev, int id, int *val);
198
199         /**
200          * get_str() - Read a specific string data value that describes the
201          *             hardware setup.
202          * @dev:        The sysinfo instance to gather the data.
203          * @id:         A unique identifier for the string value to be read.
204          * @size:       The size of the buffer to receive the string data.
205          * @val:        Pointer to a buffer that receives the value read.
206          *
207          * Return: 0 if OK, -ve on error.
208          */
209         int (*get_str)(struct udevice *dev, int id, size_t size, char *val);
210
211         /**
212          * get_data() - Read a specific string data value that describes the
213          *             hardware setup.
214          * @dev:        The sysinfo instance to gather the data.
215          * @id:         A unique identifier for the data area to be get.
216          * @data:       Pointer to the address of the data area.
217          * @size:       Pointer to the size of the data area.
218          *
219          * Return: 0 if OK, -ve on error.
220          */
221         int (*get_data)(struct udevice *dev, int id, void **data, size_t *size);
222
223         /**
224          * get_fit_loadable - Get the name of an image to load from FIT
225          * This function can be used to provide the image names based on runtime
226          * detection. A classic use-case would when DTBOs are used to describe
227          * additional daughter cards.
228          *
229          * @dev:        The sysinfo instance to gather the data.
230          * @index:      Index of the image. Starts at 0 and gets incremented
231          *              after each call to this function.
232          * @type:       The type of image. For example, "fdt" for DTBs
233          * @strp:       A pointer to string. Untouched if the function fails
234          *
235          * Return: 0 if OK, -ENOENT if no loadable is available else -ve on
236          * error.
237          */
238         int (*get_fit_loadable)(struct udevice *dev, int index,
239                                 const char *type, const char **strp);
240 };
241
242 #define sysinfo_get_ops(dev)    ((struct sysinfo_ops *)(dev)->driver->ops)
243
244 #if CONFIG_IS_ENABLED(SYSINFO)
245 /**
246  * sysinfo_detect() - Run the hardware info detection procedure for this device.
247  *
248  * @dev:        The device containing the information
249  *
250  * This function must be called before any other accessor function for this
251  * device.
252  *
253  * Return: 0 if OK, -ve on error.
254  */
255 int sysinfo_detect(struct udevice *dev);
256
257 /**
258  * sysinfo_get_bool() - Read a specific bool data value that describes the
259  *                    hardware setup.
260  * @dev:        The sysinfo instance to gather the data.
261  * @id:         A unique identifier for the bool value to be read.
262  * @val:        Pointer to a buffer that receives the value read.
263  *
264  * Return: 0 if OK, -EPERM if called before sysinfo_detect(), else -ve on
265  * error.
266  */
267 int sysinfo_get_bool(struct udevice *dev, int id, bool *val);
268
269 /**
270  * sysinfo_get_int() - Read a specific int data value that describes the
271  *                   hardware setup.
272  * @dev:        The sysinfo instance to gather the data.
273  * @id:         A unique identifier for the int value to be read.
274  * @val:        Pointer to a buffer that receives the value read.
275  *
276  * Return: 0 if OK, -EPERM if called before sysinfo_detect(), else -ve on
277  * error.
278  */
279 int sysinfo_get_int(struct udevice *dev, int id, int *val);
280
281 /**
282  * sysinfo_get_str() - Read a specific string data value that describes the
283  *                   hardware setup.
284  * @dev:        The sysinfo instance to gather the data.
285  * @id:         A unique identifier for the string value to be read.
286  * @size:       The size of the buffer to receive the string data.
287  * @val:        Pointer to a buffer that receives the value read.
288  *
289  * Return: 0 if OK, -EPERM if called before sysinfo_detect(), else -ve on
290  * error.
291  */
292 int sysinfo_get_str(struct udevice *dev, int id, size_t size, char *val);
293
294 /**
295  * sysinfo_get_data() - Get a data area from the platform.
296  * @dev:        The sysinfo instance to gather the data.
297  * @id:         A unique identifier for the data area to be get.
298  * @data:       Pointer to the address of the data area.
299  * @size:       Pointer to the size of the data area.
300  *
301  * Return: 0 if OK, -EPERM if called before sysinfo_detect(), else -ve on
302  * error.
303  */
304 int sysinfo_get_data(struct udevice *dev, int id, void **data, size_t *size);
305
306 /**
307  * sysinfo_get() - Return the sysinfo device for the sysinfo in question.
308  * @devp: Pointer to structure to receive the sysinfo device.
309  *
310  * Since there can only be at most one sysinfo instance, the API can supply a
311  * function that returns the unique device. This is especially useful for use
312  * in sysinfo files.
313  *
314  * Return: 0 if OK, -EPERM if called before sysinfo_detect(), else -ve on
315  * error.
316  */
317 int sysinfo_get(struct udevice **devp);
318
319 /**
320  * sysinfo_get_fit_loadable - Get the name of an image to load from FIT
321  * This function can be used to provide the image names based on runtime
322  * detection. A classic use-case would when DTBOs are used to describe
323  * additional daughter cards.
324  *
325  * @dev:        The sysinfo instance to gather the data.
326  * @index:      Index of the image. Starts at 0 and gets incremented
327  *              after each call to this function.
328  * @type:       The type of image. For example, "fdt" for DTBs
329  * @strp:       A pointer to string. Untouched if the function fails
330  *
331  *
332  * Return: 0 if OK, -EPERM if called before sysinfo_detect(), -ENOENT if no
333  * loadable is available else -ve on error.
334  */
335 int sysinfo_get_fit_loadable(struct udevice *dev, int index, const char *type,
336                              const char **strp);
337
338 #else
339
340 static inline int sysinfo_detect(struct udevice *dev)
341 {
342         return -ENOSYS;
343 }
344
345 static inline int sysinfo_get_bool(struct udevice *dev, int id, bool *val)
346 {
347         return -ENOSYS;
348 }
349
350 static inline int sysinfo_get_int(struct udevice *dev, int id, int *val)
351 {
352         return -ENOSYS;
353 }
354
355 static inline int sysinfo_get_str(struct udevice *dev, int id, size_t size,
356                                   char *val)
357 {
358         return -ENOSYS;
359 }
360
361 static inline int sysinfo_get_data(struct udevice *dev, int id, void **data,
362                                    size_t *size)
363 {
364         return -ENOSYS;
365 }
366
367 static inline int sysinfo_get(struct udevice **devp)
368 {
369         return -ENOSYS;
370 }
371
372 static inline int sysinfo_get_fit_loadable(struct udevice *dev, int index,
373                                            const char *type, const char **strp)
374 {
375         return -ENOSYS;
376 }
377
378 #endif
379 #endif
This page took 0.049247 seconds and 4 git commands to generate.