blob: 4c5c25b3222ca9d50d8903497b21341a410efa1d [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 Winkler512f64d2015-07-23 15:08:41 +030021 * @bus: parent mei device
Tomas Winklerdbac9932015-05-07 15:54:07 +030022 * @dev: linux driver model device pointer
23 * @me_cl: me client
24 * @cl: mei client
25 * @name: device name
26 * @event_work: async work to execute event callback
27 * @event_cb: Drivers register this callback to get asynchronous ME
28 * events (e.g. Rx buffer pending) notifications.
29 * @event_context: event callback run context
30 * @events: Events bitmask sent to the driver.
31 * @priv_data: client private data
32 */
33struct mei_cl_device {
Tomas Winkler512f64d2015-07-23 15:08:41 +030034 struct mei_device *bus;
Tomas Winklerdbac9932015-05-07 15:54:07 +030035 struct device dev;
36
37 struct mei_me_client *me_cl;
38 struct mei_cl *cl;
39 char name[MEI_CL_NAME_SIZE];
40
41 struct work_struct event_work;
42 mei_cl_event_cb_t event_cb;
43 void *event_context;
44 unsigned long events;
45
46 void *priv_data;
47};
48
Samuel Ortize5354102013-03-27 17:29:53 +020049struct mei_cl_driver {
50 struct device_driver driver;
51 const char *name;
52
53 const struct mei_cl_device_id *id_table;
54
55 int (*probe)(struct mei_cl_device *dev,
56 const struct mei_cl_device_id *id);
57 int (*remove)(struct mei_cl_device *dev);
58};
59
Samuel Ortiz333e4ee2013-03-27 17:29:54 +020060int __mei_cl_driver_register(struct mei_cl_driver *driver,
61 struct module *owner);
62#define mei_cl_driver_register(driver) \
63 __mei_cl_driver_register(driver, THIS_MODULE)
64
65void mei_cl_driver_unregister(struct mei_cl_driver *driver);
66
Tomas Winkler39db74c2014-11-27 14:07:28 +020067ssize_t mei_cl_send(struct mei_cl_device *device, u8 *buf, size_t length);
68ssize_t mei_cl_recv(struct mei_cl_device *device, u8 *buf, size_t length);
Samuel Ortiz3e833292013-03-27 17:29:55 +020069
Samuel Ortiz3e833292013-03-27 17:29:55 +020070int mei_cl_register_event_cb(struct mei_cl_device *device,
71 mei_cl_event_cb_t read_cb, void *context);
72
73#define MEI_CL_EVENT_RX 0
74#define MEI_CL_EVENT_TX 1
75
Samuel Ortizaa6aef22013-03-27 17:29:59 +020076void *mei_cl_get_drvdata(const struct mei_cl_device *device);
77void mei_cl_set_drvdata(struct mei_cl_device *device, void *data);
78
Samuel Ortize46980a2013-04-09 01:51:38 +030079int mei_cl_enable_device(struct mei_cl_device *device);
80int mei_cl_disable_device(struct mei_cl_device *device);
81
Samuel Ortize5354102013-03-27 17:29:53 +020082#endif /* _LINUX_MEI_CL_BUS_H */