diff options
Diffstat (limited to 'drivers/misc/mei/client.c')
-rw-r--r-- | drivers/misc/mei/client.c | 76 |
1 files changed, 55 insertions, 21 deletions
diff --git a/drivers/misc/mei/client.c b/drivers/misc/mei/client.c index 753608185b77..8c078b808cd3 100644 --- a/drivers/misc/mei/client.c +++ b/drivers/misc/mei/client.c | |||
@@ -71,23 +71,69 @@ int mei_me_cl_by_id(struct mei_device *dev, u8 client_id) | |||
71 | 71 | ||
72 | 72 | ||
73 | /** | 73 | /** |
74 | * mei_io_list_flush - removes list entry belonging to cl. | 74 | * mei_cl_cmp_id - tells if the clients are the same |
75 | * | 75 | * |
76 | * @list: An instance of our list structure | 76 | * @cl1: host client 1 |
77 | * @cl: host client | 77 | * @cl2: host client 2 |
78 | * | ||
79 | * returns true - if the clients has same host and me ids | ||
80 | * false - otherwise | ||
81 | */ | ||
82 | static inline bool mei_cl_cmp_id(const struct mei_cl *cl1, | ||
83 | const struct mei_cl *cl2) | ||
84 | { | ||
85 | return cl1 && cl2 && | ||
86 | (cl1->host_client_id == cl2->host_client_id) && | ||
87 | (cl1->me_client_id == cl2->me_client_id); | ||
88 | } | ||
89 | |||
90 | /** | ||
91 | * mei_io_list_flush - removes cbs belonging to cl. | ||
92 | * | ||
93 | * @list: an instance of our list structure | ||
94 | * @cl: host client, can be NULL for flushing the whole list | ||
95 | * @free: whether to free the cbs | ||
78 | */ | 96 | */ |
79 | void mei_io_list_flush(struct mei_cl_cb *list, struct mei_cl *cl) | 97 | static void __mei_io_list_flush(struct mei_cl_cb *list, |
98 | struct mei_cl *cl, bool free) | ||
80 | { | 99 | { |
81 | struct mei_cl_cb *cb; | 100 | struct mei_cl_cb *cb; |
82 | struct mei_cl_cb *next; | 101 | struct mei_cl_cb *next; |
83 | 102 | ||
103 | /* enable removing everything if no cl is specified */ | ||
84 | list_for_each_entry_safe(cb, next, &list->list, list) { | 104 | list_for_each_entry_safe(cb, next, &list->list, list) { |
85 | if (cb->cl && mei_cl_cmp_id(cl, cb->cl)) | 105 | if (!cl || (cb->cl && mei_cl_cmp_id(cl, cb->cl))) { |
86 | list_del(&cb->list); | 106 | list_del(&cb->list); |
107 | if (free) | ||
108 | mei_io_cb_free(cb); | ||
109 | } | ||
87 | } | 110 | } |
88 | } | 111 | } |
89 | 112 | ||
90 | /** | 113 | /** |
114 | * mei_io_list_flush - removes list entry belonging to cl. | ||
115 | * | ||
116 | * @list: An instance of our list structure | ||
117 | * @cl: host client | ||
118 | */ | ||
119 | static inline void mei_io_list_flush(struct mei_cl_cb *list, struct mei_cl *cl) | ||
120 | { | ||
121 | __mei_io_list_flush(list, cl, false); | ||
122 | } | ||
123 | |||
124 | |||
125 | /** | ||
126 | * mei_io_list_free - removes cb belonging to cl and free them | ||
127 | * | ||
128 | * @list: An instance of our list structure | ||
129 | * @cl: host client | ||
130 | */ | ||
131 | static inline void mei_io_list_free(struct mei_cl_cb *list, struct mei_cl *cl) | ||
132 | { | ||
133 | __mei_io_list_flush(list, cl, true); | ||
134 | } | ||
135 | |||
136 | /** | ||
91 | * mei_io_cb_free - free mei_cb_private related memory | 137 | * mei_io_cb_free - free mei_cb_private related memory |
92 | * | 138 | * |
93 | * @cb: mei callback struct | 139 | * @cb: mei callback struct |
@@ -193,8 +239,8 @@ int mei_cl_flush_queues(struct mei_cl *cl) | |||
193 | 239 | ||
194 | cl_dbg(dev, cl, "remove list entry belonging to cl\n"); | 240 | cl_dbg(dev, cl, "remove list entry belonging to cl\n"); |
195 | mei_io_list_flush(&cl->dev->read_list, cl); | 241 | mei_io_list_flush(&cl->dev->read_list, cl); |
196 | mei_io_list_flush(&cl->dev->write_list, cl); | 242 | mei_io_list_free(&cl->dev->write_list, cl); |
197 | mei_io_list_flush(&cl->dev->write_waiting_list, cl); | 243 | mei_io_list_free(&cl->dev->write_waiting_list, cl); |
198 | mei_io_list_flush(&cl->dev->ctrl_wr_list, cl); | 244 | mei_io_list_flush(&cl->dev->ctrl_wr_list, cl); |
199 | mei_io_list_flush(&cl->dev->ctrl_rd_list, cl); | 245 | mei_io_list_flush(&cl->dev->ctrl_rd_list, cl); |
200 | mei_io_list_flush(&cl->dev->amthif_cmd_list, cl); | 246 | mei_io_list_flush(&cl->dev->amthif_cmd_list, cl); |
@@ -956,20 +1002,8 @@ void mei_cl_all_wakeup(struct mei_device *dev) | |||
956 | */ | 1002 | */ |
957 | void mei_cl_all_write_clear(struct mei_device *dev) | 1003 | void mei_cl_all_write_clear(struct mei_device *dev) |
958 | { | 1004 | { |
959 | struct mei_cl_cb *cb, *next; | 1005 | mei_io_list_free(&dev->write_list, NULL); |
960 | struct list_head *list; | 1006 | mei_io_list_free(&dev->write_waiting_list, NULL); |
961 | |||
962 | list = &dev->write_list.list; | ||
963 | list_for_each_entry_safe(cb, next, list, list) { | ||
964 | list_del(&cb->list); | ||
965 | mei_io_cb_free(cb); | ||
966 | } | ||
967 | |||
968 | list = &dev->write_waiting_list.list; | ||
969 | list_for_each_entry_safe(cb, next, list, list) { | ||
970 | list_del(&cb->list); | ||
971 | mei_io_cb_free(cb); | ||
972 | } | ||
973 | } | 1007 | } |
974 | 1008 | ||
975 | 1009 | ||