forked from intel/libmei
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlibmei.h
286 lines (252 loc) · 9.44 KB
/
libmei.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
/*
* SPDX-License-Identifier: BSD-3-Clause
*
* Copyright(c) 2013 - 2024 Intel Corporation. All rights reserved.
*
* Intel Management Engine Interface (Intel MEI) Library
*/
/*! \file libmei.h
* \brief mei library API
*/
#ifndef __LIBMEI_H__
#define __LIBMEI_H__
#include <linux/uuid.h>
#include <linux/mei.h>
#include <stdbool.h>
#include <stdint.h>
#include <unistd.h>
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
/*! Library API version encode helper
*/
#define MEI_ENCODE_VERSION(major, minor) ((major) << 16 | (minor) << 8)
/*! Library API version
*/
#define LIBMEI_API_VERSION MEI_ENCODE_VERSION(1, 6)
/*! Get current supported library API version
*
* \return version value
*/
unsigned int mei_get_api_version(void);
/*! ME client connection state
*/
enum mei_cl_state {
MEI_CL_STATE_ZERO = 0, /**< reserved */
MEI_CL_STATE_INTIALIZED = 1, /**< client is initialized (typo) */
MEI_CL_STATE_INITIALIZED = 1, /**< client is initialized */
MEI_CL_STATE_CONNECTED, /**< client is connected */
MEI_CL_STATE_DISCONNECTED, /**< client is disconnected */
MEI_CL_STATE_NOT_PRESENT, /**< client with GUID is not present in the system */
MEI_CL_STATE_VERSION_MISMATCH, /**< client version not supported */
MEI_CL_STATE_ERROR, /**< client is in error state */
};
/*! log level
*/
enum mei_log_level {
MEI_LOG_LEVEL_QUIET = 0, /**< no log prints */
MEI_LOG_LEVEL_ERROR = 1, /**< error log prints */
MEI_LOG_LEVEL_VERBOSE = 2 /**< verbose log prints */
};
/*! log callback function format
*/
typedef void(*mei_log_callback)(bool is_error, const char* fmt, ...);
/*! Structure to store connection data
*/
struct mei {
uuid_le guid; /**< client UUID */
unsigned int buf_size; /**< maximum buffer size supported by client*/
unsigned char prot_ver; /**< protocol version */
int fd; /**< connection file descriptor */
int state; /**< client connection state */
int last_err; /**< saved errno */
bool notify_en; /**< notification is enabled */
enum mei_log_level log_level; /**< libmei log level */
bool close_on_exit; /**< close handle on deinit */
char *device; /**< device name */
uint8_t vtag; /**< vtag used in communication */
mei_log_callback log_callback; /**< Log callback */
};
/*! Default name of mei device
*/
#define MEI_DEFAULT_DEVICE_NAME "mei0"
/*! Default path to mei device
*/
#define MEI_DEFAULT_DEVICE_PREFIX "/dev/"
#define MEI_DEFAULT_DEVICE (MEI_DEFAULT_DEVICE_PREFIX MEI_DEFAULT_DEVICE_NAME)
/*! Allocate and initialize me handle structure
*
* \param device device path, set MEI_DEFAULT_DEVICE to use default
* \param guid UUID/GUID of associated mei client
* \param req_protocol_version minimal required protocol version, 0 for any
* \param verbose print verbose output to console
* \return me handle to the mei device. All subsequent calls to the lib's functions
* must be with this handle. NULL on failure.
*/
struct mei *mei_alloc(const char *device, const uuid_le *guid,
unsigned char req_protocol_version, bool verbose);
/*! Allocate and initialize me handle structure
*
* \param fd open file descriptor of MEI device
* \param guid UUID/GUID of associated mei client
* \param req_protocol_version minimal required protocol version, 0 for any
* \param verbose print verbose output to console
* \return me handle to the mei device. All subsequent calls to the lib's functions
* must be with this handle. NULL on failure.
*/
struct mei *mei_alloc_fd(int fd, const uuid_le *guid,
unsigned char req_protocol_version, bool verbose);
/*! Free me handle structure
*
* \param me The mei handle
*/
void mei_free(struct mei *me);
/*! Initializes a mei connection
*
* \param me A handle to the mei device. All subsequent calls to the lib's functions
* must be with this handle
* \param device device path, set MEI_DEFAULT_DEVICE to use default
* \param guid UUID/GUID of associated mei client
* \param req_protocol_version minimal required protocol version, 0 for any
* \param verbose print verbose output to a console
* \return 0 if successful, otherwise error code
*/
int mei_init(struct mei *me, const char *device, const uuid_le *guid,
unsigned char req_protocol_version, bool verbose);
/*! Initializes a mei connection with log callback
*
* \param me A handle to the mei device. All subsequent calls to the lib's functions
* must be with this handle
* \param device device path, set MEI_DEFAULT_DEVICE to use default
* \param guid GUID of associated mei client
* \param req_protocol_version minimal required protocol version, 0 for any
* \param verbose print verbose output to a console
* \param log_callback pointer to function to run for log write, set NULL to use built-in function
* \return 0 if successful, otherwise error code
*/
int mei_init_with_log(struct mei *me, const char *device, const uuid_le *guid,
unsigned char req_protocol_version, bool verbose,
mei_log_callback log_callback);
/*! Initializes a mei connection
*
* \param me A handle to the mei device. All subsequent calls to the lib's functions
* must be with this handle
* \param fd open file descriptor of MEI device
* \param guid UUID/GUID of associated mei client
* \param req_protocol_version minimal required protocol version, 0 for any
* \param verbose print verbose output to a console
* \return 0 if successful, otherwise error code
*/
int mei_init_fd(struct mei *me, int fd, const uuid_le *guid,
unsigned char req_protocol_version, bool verbose);
/*! Closes the session to me driver
* Make sure that you call this function as soon as you are done with the device,
* as other clients might be blocked until the session is closed.
*
* \param me The mei handle
*/
void mei_deinit(struct mei *me);
/*! Open mei device and starts a session with a mei client
* If the application requested specific minimal protocol version
* and the client does not support that version than
* the handle state will be set to MEI_CL_STATE_VERSION_MISMATCH
* but connection will be established
*
* \param me The mei handle
* \return 0 if successful, otherwise error code
*/
int mei_connect(struct mei *me);
/*! Open mei device and starts a session with a mei client
* Provide given vtag as session parameter.
* If the application requested specific minimal protocol version
* and the client does not support that version than
* the handle state will be set to MEI_CL_STATE_VERSION_MISMATCH
* but connection will be established
*
* \param me The mei handle
* \param vtag The vtag value
* \return 0 if successful, otherwise error code
*/
int mei_connect_vtag(struct mei *me, uint8_t vtag);
/*! Setup mei connection to non block
*
* \param me The mei handle
* \return 0 if successful, otherwise error code
*/
int mei_set_nonblock(struct mei *me);
/*! return file descriptor to opened handle
*
* \param me The mei handle
* \return file descriptor or error
*/
int mei_get_fd(struct mei *me);
/*! Read data from the mei device.
*
* \param me The mei handle
* \param buffer A pointer to a buffer that receives the data read from the mei device.
* \param len The number of bytes to be read.
* \return number of byte read if successful, otherwise error code
*/
ssize_t mei_recv_msg(struct mei *me, unsigned char *buffer, size_t len);
/*! Writes the specified buffer to the mei device.
*
* \param me The mei handle
* \param buffer A pointer to the buffer containing the data to be written to the mei device.
* \param len The number of bytes to be written.
* \return number of bytes written if successful, otherwise error code
*/
ssize_t mei_send_msg(struct mei *me, const unsigned char *buffer, size_t len);
/*! Request to Enable or Disable Event Notification
*
* \param me The mei handle
* \param enable A boolean to enable or disable event notification
* \return 0 if successful, otherwise error code
*/
int mei_notification_request(struct mei *me, bool enable);
/*! Acknowledge an event and enable further notification
* notification events are signaled as priority events (POLLPRI) on select/poll
*
* \param me The mei handle
* \return 0 if successful, otherwise error code. -ENOTSUPP is returned
* in case the event notification was not enabled
*/
int mei_notification_get(struct mei *me);
/*! Obtains FW status of device
*
* \param me The mei handle
* \param fwsts_num The FW status register number (0-5).
* \param fwsts FW status to fill
* \return 0 if successful, otherwise error code
*/
int mei_fwstatus(struct mei *me, uint32_t fwsts_num, uint32_t *fwsts);
/*! Obtains TRC status of device
*
* \param me The mei handle
* \param trc_val TRC value fill
* \return 0 if successful, otherwise error code
*/
int mei_gettrc(struct mei *me, uint32_t *trc_val);
/*! Set log level
*
* \param me The mei handle
* \param log_level log level to set
* \return previous log level
*/
uint32_t mei_set_log_level(struct mei *me, uint32_t log_level);
/*! Retrieve current log level
*
* \param me The mei handle
* \return current log level
*/
uint32_t mei_get_log_level(const struct mei *me);
/*! Set log callback
*
* \param me The mei handle
* \param log_callback pointer to function to run for log write, set NULL to use built-in function
* \return 0 if successful, otherwise error code.
*/
int mei_set_log_callback(struct mei *me, mei_log_callback log_callback);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* __LIBMEI_H__ */