blob: 81ab56dd0ae0b3a278221708920f6dbcf0f82731 [file] [log] [blame]
Samuel Ortize5354102013-03-27 17:29:53 +02001#ifndef _LINUX_MEI_CL_BUS_H
2#define _LINUX_MEI_CL_BUS_H
3
4#include <linux/device.h>
5#include <linux/uuid.h>
Tomas Winkler1f180352014-09-29 16:31:46 +03006#include <linux/mod_devicetable.h>
Samuel Ortize5354102013-03-27 17:29:53 +02007
8struct mei_cl_device;
Tomas Winkler512f64d2015-07-23 15:08:41 +03009struct mei_device;
Samuel Ortize5354102013-03-27 17:29:53 +020010
Tomas Winklerdbac9932015-05-07 15:54:07 +030011typedef void (*mei_cl_event_cb_t)(struct mei_cl_device *device,
12 u32 events, void *context);
13
14/**
15 * struct mei_cl_device - MEI device handle
16 * An mei_cl_device pointer is returned from mei_add_device()
17 * and links MEI bus clients to their actual ME host client pointer.
18 * Drivers for MEI devices will get an mei_cl_device pointer
19 * when being probed and shall use it for doing ME bus I/O.
20 *
Tomas Winkler0ff0a8d2015-07-23 15:08:42 +030021 * @bus_list: device on the bus list
Tomas Winkler512f64d2015-07-23 15:08:41 +030022 * @bus: parent mei device
Tomas Winklerdbac9932015-05-07 15:54:07 +030023 * @dev: linux driver model device pointer
24 * @me_cl: me client
25 * @cl: mei client
26 * @name: device name
27 * @event_work: async work to execute event callback
28 * @event_cb: Drivers register this callback to get asynchronous ME
29 * events (e.g. Rx buffer pending) notifications.
30 * @event_context: event callback run context
31 * @events: Events bitmask sent to the driver.
Tomas Winkler71ce7892015-07-23 15:08:43 +030032 *
33 * @do_match: wheather device can be matched with a driver
Tomas Winkler0ff0a8d2015-07-23 15:08:42 +030034 * @is_added: device is already scanned
Tomas Winklerdbac9932015-05-07 15:54:07 +030035 * @priv_data: client private data
36 */
37struct mei_cl_device {
Tomas Winkler0ff0a8d2015-07-23 15:08:42 +030038 struct list_head bus_list;
Tomas Winkler512f64d2015-07-23 15:08:41 +030039 struct mei_device *bus;
Tomas Winklerdbac9932015-05-07 15:54:07 +030040 struct device dev;
41
42 struct mei_me_client *me_cl;
43 struct mei_cl *cl;
44 char name[MEI_CL_NAME_SIZE];
45
46 struct work_struct event_work;
47 mei_cl_event_cb_t event_cb;
48 void *event_context;
49 unsigned long events;
Tomas Winkler71ce7892015-07-23 15:08:43 +030050
51 unsigned int do_match:1;
Tomas Winkler0ff0a8d2015-07-23 15:08:42 +030052 unsigned int is_added:1;
Tomas Winklerdbac9932015-05-07 15:54:07 +030053
54 void *priv_data;
55};
56
Samuel Ortize5354102013-03-27 17:29:53 +020057struct mei_cl_driver {
58 struct device_driver driver;
59 const char *name;
60
61 const struct mei_cl_device_id *id_table;
62
63 int (*probe)(struct mei_cl_device *dev,
64 const struct mei_cl_device_id *id);
65 int (*remove)(struct mei_cl_device *dev);
66};
67
Samuel Ortiz333e4ee2013-03-27 17:29:54 +020068int __mei_cl_driver_register(struct mei_cl_driver *driver,
69 struct module *owner);
70#define mei_cl_driver_register(driver) \
71 __mei_cl_driver_register(driver, THIS_MODULE)
72
73void mei_cl_driver_unregister(struct mei_cl_driver *driver);
74
Tomas Winkler39db74c2014-11-27 14:07:28 +020075ssize_t mei_cl_send(struct mei_cl_device *device, u8 *buf, size_t length);
76ssize_t mei_cl_recv(struct mei_cl_device *device, u8 *buf, size_t length);
Samuel Ortiz3e833292013-03-27 17:29:55 +020077
Samuel Ortiz3e833292013-03-27 17:29:55 +020078int mei_cl_register_event_cb(struct mei_cl_device *device,
79 mei_cl_event_cb_t read_cb, void *context);
80
81#define MEI_CL_EVENT_RX 0
82#define MEI_CL_EVENT_TX 1
83
Samuel Ortizaa6aef22013-03-27 17:29:59 +020084void *mei_cl_get_drvdata(const struct mei_cl_device *device);
85void mei_cl_set_drvdata(struct mei_cl_device *device, void *data);
86
Samuel Ortize46980a2013-04-09 01:51:38 +030087int mei_cl_enable_device(struct mei_cl_device *device);
88int mei_cl_disable_device(struct mei_cl_device *device);
89
Samuel Ortize5354102013-03-27 17:29:53 +020090#endif /* _LINUX_MEI_CL_BUS_H */