xref: /openbmc/linux/drivers/net/wireless/intel/iwlwifi/mei/main.c (revision a48acad789ff33d90e079311ed0323e5e5fc5cbd)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (C) 2021-2022 Intel Corporation
4  */
5 
6 #include <linux/etherdevice.h>
7 #include <linux/netdevice.h>
8 #include <linux/ieee80211.h>
9 #include <linux/rtnetlink.h>
10 #include <linux/module.h>
11 #include <linux/moduleparam.h>
12 #include <linux/mei_cl_bus.h>
13 #include <linux/rcupdate.h>
14 #include <linux/debugfs.h>
15 #include <linux/skbuff.h>
16 #include <linux/wait.h>
17 #include <linux/slab.h>
18 #include <linux/mm.h>
19 
20 #include <net/cfg80211.h>
21 
22 #include "internal.h"
23 #include "iwl-mei.h"
24 #include "trace.h"
25 #include "trace-data.h"
26 #include "sap.h"
27 
28 MODULE_DESCRIPTION("The Intel(R) wireless / CSME firmware interface");
29 MODULE_LICENSE("GPL");
30 
31 #define MEI_WLAN_UUID UUID_LE(0x13280904, 0x7792, 0x4fcb, \
32 			      0xa1, 0xaa, 0x5e, 0x70, 0xcb, 0xb1, 0xe8, 0x65)
33 
34 /*
35  * Since iwlwifi calls iwlmei without any context, hold a pointer to the
36  * mei_cl_device structure here.
37  * Define a mutex that will synchronize all the flows between iwlwifi and
38  * iwlmei.
39  * Note that iwlmei can't have several instances, so it ok to have static
40  * variables here.
41  */
42 static struct mei_cl_device *iwl_mei_global_cldev;
43 static DEFINE_MUTEX(iwl_mei_mutex);
44 static unsigned long iwl_mei_status;
45 
46 enum iwl_mei_status_bits {
47 	IWL_MEI_STATUS_SAP_CONNECTED,
48 };
49 
50 bool iwl_mei_is_connected(void)
51 {
52 	return test_bit(IWL_MEI_STATUS_SAP_CONNECTED, &iwl_mei_status);
53 }
54 EXPORT_SYMBOL_GPL(iwl_mei_is_connected);
55 
56 #define SAP_VERSION	3
57 #define SAP_CONTROL_BLOCK_ID 0x21504153 /* SAP! in ASCII */
58 
59 struct iwl_sap_q_ctrl_blk {
60 	__le32 wr_ptr;
61 	__le32 rd_ptr;
62 	__le32 size;
63 };
64 
65 enum iwl_sap_q_idx {
66 	SAP_QUEUE_IDX_NOTIF = 0,
67 	SAP_QUEUE_IDX_DATA,
68 	SAP_QUEUE_IDX_MAX,
69 };
70 
71 struct iwl_sap_dir {
72 	__le32 reserved;
73 	struct iwl_sap_q_ctrl_blk q_ctrl_blk[SAP_QUEUE_IDX_MAX];
74 };
75 
76 enum iwl_sap_dir_idx {
77 	SAP_DIRECTION_HOST_TO_ME = 0,
78 	SAP_DIRECTION_ME_TO_HOST,
79 	SAP_DIRECTION_MAX,
80 };
81 
82 struct iwl_sap_shared_mem_ctrl_blk {
83 	__le32 sap_id;
84 	__le32 size;
85 	struct iwl_sap_dir dir[SAP_DIRECTION_MAX];
86 };
87 
88 /*
89  * The shared area has the following layout:
90  *
91  * +-----------------------------------+
92  * |struct iwl_sap_shared_mem_ctrl_blk |
93  * +-----------------------------------+
94  * |Host -> ME data queue              |
95  * +-----------------------------------+
96  * |Host -> ME notif queue             |
97  * +-----------------------------------+
98  * |ME -> Host data queue              |
99  * +-----------------------------------+
100  * |ME -> host notif queue             |
101  * +-----------------------------------+
102  * |SAP control block id (SAP!)        |
103  * +-----------------------------------+
104  */
105 
106 #define SAP_H2M_DATA_Q_SZ	48256
107 #define SAP_M2H_DATA_Q_SZ	24128
108 #define SAP_H2M_NOTIF_Q_SZ	2240
109 #define SAP_M2H_NOTIF_Q_SZ	62720
110 
111 #define _IWL_MEI_SAP_SHARED_MEM_SZ \
112 	(sizeof(struct iwl_sap_shared_mem_ctrl_blk) + \
113 	 SAP_H2M_DATA_Q_SZ + SAP_H2M_NOTIF_Q_SZ + \
114 	 SAP_M2H_DATA_Q_SZ + SAP_M2H_NOTIF_Q_SZ + 4)
115 
116 #define IWL_MEI_SAP_SHARED_MEM_SZ \
117 	(roundup(_IWL_MEI_SAP_SHARED_MEM_SZ, PAGE_SIZE))
118 
119 struct iwl_mei_shared_mem_ptrs {
120 	struct iwl_sap_shared_mem_ctrl_blk *ctrl;
121 	void *q_head[SAP_DIRECTION_MAX][SAP_QUEUE_IDX_MAX];
122 	size_t q_size[SAP_DIRECTION_MAX][SAP_QUEUE_IDX_MAX];
123 };
124 
125 struct iwl_mei_filters {
126 	struct rcu_head rcu_head;
127 	struct iwl_sap_oob_filters filters;
128 };
129 
130 /**
131  * struct iwl_mei - holds the private date for iwl_mei
132  *
133  * @get_nvm_wq: the wait queue for the get_nvm flow
134  * @send_csa_msg_wk: used to defer the transmission of the CHECK_SHARED_AREA
135  *	message. Used so that we can send CHECK_SHARED_AREA from atomic
136  *	contexts.
137  * @get_ownership_wq: the wait queue for the get_ownership_flow
138  * @shared_mem: the memory that is shared between CSME and the host
139  * @cldev: the pointer to the MEI client device
140  * @nvm: the data returned by the CSME for the NVM
141  * @filters: the filters sent by CSME
142  * @got_ownership: true if we own the device
143  * @amt_enabled: true if CSME has wireless enabled
144  * @csa_throttled: when true, we can't send CHECK_SHARED_AREA over the MEI
145  *	bus, but rather need to wait until send_csa_msg_wk runs
146  * @csme_taking_ownership: true when CSME is taking ownership. Used to remember
147  *	to send CSME_OWNERSHIP_CONFIRMED when the driver completes its down
148  *	flow.
149  * @link_prot_state: true when we are in link protection PASSIVE
150  * @device_down: true if the device is down. Used to remember to send
151  *	CSME_OWNERSHIP_CONFIRMED when the driver is already down.
152  * @csa_throttle_end_wk: used when &csa_throttled is true
153  * @pldr_wq: the wait queue for PLDR flow
154  * @pldr_active: PLDR flow is in progress
155  * @data_q_lock: protects the access to the data queues which are
156  *	accessed without the mutex.
157  * @netdev_work: used to defer registering and unregistering of the netdev to
158  *	avoid taking the rtnl lock in the SAP messages handlers.
159  * @sap_seq_no: the sequence number for the SAP messages
160  * @seq_no: the sequence number for the SAP messages
161  * @dbgfs_dir: the debugfs dir entry
162  */
163 struct iwl_mei {
164 	wait_queue_head_t get_nvm_wq;
165 	struct work_struct send_csa_msg_wk;
166 	wait_queue_head_t get_ownership_wq;
167 	struct iwl_mei_shared_mem_ptrs shared_mem;
168 	struct mei_cl_device *cldev;
169 	struct iwl_mei_nvm *nvm;
170 	struct iwl_mei_filters __rcu *filters;
171 	bool got_ownership;
172 	bool amt_enabled;
173 	bool csa_throttled;
174 	bool csme_taking_ownership;
175 	bool link_prot_state;
176 	bool device_down;
177 	struct delayed_work csa_throttle_end_wk;
178 	wait_queue_head_t pldr_wq;
179 	bool pldr_active;
180 	spinlock_t data_q_lock;
181 	struct work_struct netdev_work;
182 
183 	atomic_t sap_seq_no;
184 	atomic_t seq_no;
185 
186 	struct dentry *dbgfs_dir;
187 };
188 
189 /**
190  * struct iwl_mei_cache - cache for the parameters from iwlwifi
191  * @ops: Callbacks to iwlwifi.
192  * @netdev: The netdev that will be used to transmit / receive packets.
193  * @conn_info: The connection info message triggered by iwlwifi's association.
194  * @power_limit: pointer to an array of 10 elements (le16) represents the power
195  *	restrictions per chain.
196  * @rf_kill: rf kill state.
197  * @mcc: MCC info
198  * @mac_address: interface MAC address.
199  * @nvm_address: NVM MAC address.
200  * @priv: A pointer to iwlwifi.
201  *
202  * This used to cache the configurations coming from iwlwifi's way. The data
203  * is cached here so that we can buffer the configuration even if we don't have
204  * a bind from the mei bus and hence, on iwl_mei structure.
205  */
206 struct iwl_mei_cache {
207 	const struct iwl_mei_ops *ops;
208 	struct net_device __rcu *netdev;
209 	const struct iwl_sap_notif_connection_info *conn_info;
210 	const __le16 *power_limit;
211 	u32 rf_kill;
212 	u16 mcc;
213 	u8 mac_address[6];
214 	u8 nvm_address[6];
215 	void *priv;
216 };
217 
218 static struct iwl_mei_cache iwl_mei_cache = {
219 	.rf_kill = SAP_HW_RFKILL_DEASSERTED | SAP_SW_RFKILL_DEASSERTED
220 };
221 
222 static void iwl_mei_free_shared_mem(struct mei_cl_device *cldev)
223 {
224 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
225 
226 	if (mei_cldev_dma_unmap(cldev))
227 		dev_err(&cldev->dev, "Couldn't unmap the shared mem properly\n");
228 	memset(&mei->shared_mem, 0, sizeof(mei->shared_mem));
229 }
230 
231 #define HBM_DMA_BUF_ID_WLAN 1
232 
233 static int iwl_mei_alloc_shared_mem(struct mei_cl_device *cldev)
234 {
235 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
236 	struct iwl_mei_shared_mem_ptrs *mem = &mei->shared_mem;
237 
238 	mem->ctrl = mei_cldev_dma_map(cldev, HBM_DMA_BUF_ID_WLAN,
239 				       IWL_MEI_SAP_SHARED_MEM_SZ);
240 
241 	if (IS_ERR(mem->ctrl)) {
242 		int ret = PTR_ERR(mem->ctrl);
243 
244 		mem->ctrl = NULL;
245 
246 		return ret;
247 	}
248 
249 	memset(mem->ctrl, 0, IWL_MEI_SAP_SHARED_MEM_SZ);
250 
251 	return 0;
252 }
253 
254 static void iwl_mei_init_shared_mem(struct iwl_mei *mei)
255 {
256 	struct iwl_mei_shared_mem_ptrs *mem = &mei->shared_mem;
257 	struct iwl_sap_dir *h2m;
258 	struct iwl_sap_dir *m2h;
259 	int dir, queue;
260 	u8 *q_head;
261 
262 	mem->ctrl->sap_id = cpu_to_le32(SAP_CONTROL_BLOCK_ID);
263 
264 	mem->ctrl->size = cpu_to_le32(sizeof(*mem->ctrl));
265 
266 	h2m = &mem->ctrl->dir[SAP_DIRECTION_HOST_TO_ME];
267 	m2h = &mem->ctrl->dir[SAP_DIRECTION_ME_TO_HOST];
268 
269 	h2m->q_ctrl_blk[SAP_QUEUE_IDX_DATA].size =
270 		cpu_to_le32(SAP_H2M_DATA_Q_SZ);
271 	h2m->q_ctrl_blk[SAP_QUEUE_IDX_NOTIF].size =
272 		cpu_to_le32(SAP_H2M_NOTIF_Q_SZ);
273 	m2h->q_ctrl_blk[SAP_QUEUE_IDX_DATA].size =
274 		cpu_to_le32(SAP_M2H_DATA_Q_SZ);
275 	m2h->q_ctrl_blk[SAP_QUEUE_IDX_NOTIF].size =
276 		cpu_to_le32(SAP_M2H_NOTIF_Q_SZ);
277 
278 	/* q_head points to the start of the first queue */
279 	q_head = (void *)(mem->ctrl + 1);
280 
281 	/* Initialize the queue heads */
282 	for (dir = 0; dir < SAP_DIRECTION_MAX; dir++) {
283 		for (queue = 0; queue < SAP_QUEUE_IDX_MAX; queue++) {
284 			mem->q_head[dir][queue] = q_head;
285 			q_head +=
286 				le32_to_cpu(mem->ctrl->dir[dir].q_ctrl_blk[queue].size);
287 			mem->q_size[dir][queue] =
288 				le32_to_cpu(mem->ctrl->dir[dir].q_ctrl_blk[queue].size);
289 		}
290 	}
291 
292 	*(__le32 *)q_head = cpu_to_le32(SAP_CONTROL_BLOCK_ID);
293 }
294 
295 static ssize_t iwl_mei_write_cyclic_buf(struct mei_cl_device *cldev,
296 					struct iwl_sap_q_ctrl_blk *notif_q,
297 					u8 *q_head,
298 					const struct iwl_sap_hdr *hdr,
299 					u32 q_sz)
300 {
301 	u32 rd = le32_to_cpu(READ_ONCE(notif_q->rd_ptr));
302 	u32 wr = le32_to_cpu(READ_ONCE(notif_q->wr_ptr));
303 	size_t room_in_buf;
304 	size_t tx_sz = sizeof(*hdr) + le16_to_cpu(hdr->len);
305 
306 	if (rd > q_sz || wr > q_sz) {
307 		dev_err(&cldev->dev,
308 			"Pointers are past the end of the buffer\n");
309 		return -EINVAL;
310 	}
311 
312 	room_in_buf = wr >= rd ? q_sz - wr + rd : rd - wr;
313 
314 	/* we don't have enough room for the data to write */
315 	if (room_in_buf < tx_sz) {
316 		dev_err(&cldev->dev,
317 			"Not enough room in the buffer\n");
318 		return -ENOSPC;
319 	}
320 
321 	if (wr + tx_sz <= q_sz) {
322 		memcpy(q_head + wr, hdr, tx_sz);
323 	} else {
324 		memcpy(q_head + wr, hdr, q_sz - wr);
325 		memcpy(q_head, (const u8 *)hdr + q_sz - wr, tx_sz - (q_sz - wr));
326 	}
327 
328 	WRITE_ONCE(notif_q->wr_ptr, cpu_to_le32((wr + tx_sz) % q_sz));
329 	return 0;
330 }
331 
332 static bool iwl_mei_host_to_me_data_pending(const struct iwl_mei *mei)
333 {
334 	struct iwl_sap_q_ctrl_blk *notif_q;
335 	struct iwl_sap_dir *dir;
336 
337 	dir = &mei->shared_mem.ctrl->dir[SAP_DIRECTION_HOST_TO_ME];
338 	notif_q = &dir->q_ctrl_blk[SAP_QUEUE_IDX_DATA];
339 
340 	if (READ_ONCE(notif_q->wr_ptr) != READ_ONCE(notif_q->rd_ptr))
341 		return true;
342 
343 	notif_q = &dir->q_ctrl_blk[SAP_QUEUE_IDX_NOTIF];
344 	return READ_ONCE(notif_q->wr_ptr) != READ_ONCE(notif_q->rd_ptr);
345 }
346 
347 static int iwl_mei_send_check_shared_area(struct mei_cl_device *cldev)
348 {
349 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
350 	struct iwl_sap_me_msg_start msg = {
351 		.hdr.type = cpu_to_le32(SAP_ME_MSG_CHECK_SHARED_AREA),
352 		.hdr.seq_num = cpu_to_le32(atomic_inc_return(&mei->seq_no)),
353 	};
354 	int ret;
355 
356 	lockdep_assert_held(&iwl_mei_mutex);
357 
358 	if (mei->csa_throttled)
359 		return 0;
360 
361 	trace_iwlmei_me_msg(&msg.hdr, true);
362 	ret = mei_cldev_send(cldev, (void *)&msg, sizeof(msg));
363 	if (ret != sizeof(msg)) {
364 		dev_err(&cldev->dev,
365 			"failed to send the SAP_ME_MSG_CHECK_SHARED_AREA message %d\n",
366 			ret);
367 		return ret;
368 	}
369 
370 	mei->csa_throttled = true;
371 
372 	schedule_delayed_work(&mei->csa_throttle_end_wk,
373 			      msecs_to_jiffies(100));
374 
375 	return 0;
376 }
377 
378 static void iwl_mei_csa_throttle_end_wk(struct work_struct *wk)
379 {
380 	struct iwl_mei *mei =
381 		container_of(wk, struct iwl_mei, csa_throttle_end_wk.work);
382 
383 	mutex_lock(&iwl_mei_mutex);
384 
385 	mei->csa_throttled = false;
386 
387 	if (iwl_mei_host_to_me_data_pending(mei))
388 		iwl_mei_send_check_shared_area(mei->cldev);
389 
390 	mutex_unlock(&iwl_mei_mutex);
391 }
392 
393 static int iwl_mei_send_sap_msg_payload(struct mei_cl_device *cldev,
394 					struct iwl_sap_hdr *hdr)
395 {
396 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
397 	struct iwl_sap_q_ctrl_blk *notif_q;
398 	struct iwl_sap_dir *dir;
399 	void *q_head;
400 	u32 q_sz;
401 	int ret;
402 
403 	lockdep_assert_held(&iwl_mei_mutex);
404 
405 	if (!mei->shared_mem.ctrl) {
406 		dev_err(&cldev->dev,
407 			"No shared memory, can't send any SAP message\n");
408 		return -EINVAL;
409 	}
410 
411 	if (!iwl_mei_is_connected()) {
412 		dev_err(&cldev->dev,
413 			"Can't send a SAP message if we're not connected\n");
414 		return -ENODEV;
415 	}
416 
417 	hdr->seq_num = cpu_to_le32(atomic_inc_return(&mei->sap_seq_no));
418 	dev_dbg(&cldev->dev, "Sending %d\n", hdr->type);
419 
420 	dir = &mei->shared_mem.ctrl->dir[SAP_DIRECTION_HOST_TO_ME];
421 	notif_q = &dir->q_ctrl_blk[SAP_QUEUE_IDX_NOTIF];
422 	q_head = mei->shared_mem.q_head[SAP_DIRECTION_HOST_TO_ME][SAP_QUEUE_IDX_NOTIF];
423 	q_sz = mei->shared_mem.q_size[SAP_DIRECTION_HOST_TO_ME][SAP_QUEUE_IDX_NOTIF];
424 	ret = iwl_mei_write_cyclic_buf(q_head, notif_q, q_head, hdr, q_sz);
425 
426 	if (ret < 0)
427 		return ret;
428 
429 	trace_iwlmei_sap_cmd(hdr, true);
430 
431 	return iwl_mei_send_check_shared_area(cldev);
432 }
433 
434 void iwl_mei_add_data_to_ring(struct sk_buff *skb, bool cb_tx)
435 {
436 	struct iwl_sap_q_ctrl_blk *notif_q;
437 	struct iwl_sap_dir *dir;
438 	struct iwl_mei *mei;
439 	size_t room_in_buf;
440 	size_t tx_sz;
441 	size_t hdr_sz;
442 	u32 q_sz;
443 	u32 rd;
444 	u32 wr;
445 	u8 *q_head;
446 
447 	if (!iwl_mei_global_cldev)
448 		return;
449 
450 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
451 
452 	/*
453 	 * We access this path for Rx packets (the more common case)
454 	 * and from Tx path when we send DHCP packets, the latter is
455 	 * very unlikely.
456 	 * Take the lock already here to make sure we see that remove()
457 	 * might have cleared the IWL_MEI_STATUS_SAP_CONNECTED bit.
458 	 */
459 	spin_lock_bh(&mei->data_q_lock);
460 
461 	if (!iwl_mei_is_connected()) {
462 		spin_unlock_bh(&mei->data_q_lock);
463 		return;
464 	}
465 
466 	/*
467 	 * We are in a RCU critical section and the remove from the CSME bus
468 	 * which would free this memory waits for the readers to complete (this
469 	 * is done in netdev_rx_handler_unregister).
470 	 */
471 	dir = &mei->shared_mem.ctrl->dir[SAP_DIRECTION_HOST_TO_ME];
472 	notif_q = &dir->q_ctrl_blk[SAP_QUEUE_IDX_DATA];
473 	q_head = mei->shared_mem.q_head[SAP_DIRECTION_HOST_TO_ME][SAP_QUEUE_IDX_DATA];
474 	q_sz = mei->shared_mem.q_size[SAP_DIRECTION_HOST_TO_ME][SAP_QUEUE_IDX_DATA];
475 
476 	rd = le32_to_cpu(READ_ONCE(notif_q->rd_ptr));
477 	wr = le32_to_cpu(READ_ONCE(notif_q->wr_ptr));
478 	hdr_sz = cb_tx ? sizeof(struct iwl_sap_cb_data) :
479 			 sizeof(struct iwl_sap_hdr);
480 	tx_sz = skb->len + hdr_sz;
481 
482 	if (rd > q_sz || wr > q_sz) {
483 		dev_err(&mei->cldev->dev,
484 			"can't write the data: pointers are past the end of the buffer\n");
485 		goto out;
486 	}
487 
488 	room_in_buf = wr >= rd ? q_sz - wr + rd : rd - wr;
489 
490 	/* we don't have enough room for the data to write */
491 	if (room_in_buf < tx_sz) {
492 		dev_err(&mei->cldev->dev,
493 			"Not enough room in the buffer for this data\n");
494 		goto out;
495 	}
496 
497 	if (skb_headroom(skb) < hdr_sz) {
498 		dev_err(&mei->cldev->dev,
499 			"Not enough headroom in the skb to write the SAP header\n");
500 		goto out;
501 	}
502 
503 	if (cb_tx) {
504 		struct iwl_sap_cb_data *cb_hdr = skb_push(skb, sizeof(*cb_hdr));
505 
506 		memset(cb_hdr, 0, sizeof(*cb_hdr));
507 		cb_hdr->hdr.type = cpu_to_le16(SAP_MSG_CB_DATA_PACKET);
508 		cb_hdr->hdr.len = cpu_to_le16(skb->len - sizeof(cb_hdr->hdr));
509 		cb_hdr->hdr.seq_num = cpu_to_le32(atomic_inc_return(&mei->sap_seq_no));
510 		cb_hdr->to_me_filt_status = cpu_to_le32(BIT(CB_TX_DHCP_FILT_IDX));
511 		cb_hdr->data_len = cpu_to_le32(skb->len - sizeof(*cb_hdr));
512 		trace_iwlmei_sap_data(skb, IWL_SAP_TX_DHCP);
513 	} else {
514 		struct iwl_sap_hdr *hdr = skb_push(skb, sizeof(*hdr));
515 
516 		hdr->type = cpu_to_le16(SAP_MSG_DATA_PACKET);
517 		hdr->len = cpu_to_le16(skb->len - sizeof(*hdr));
518 		hdr->seq_num = cpu_to_le32(atomic_inc_return(&mei->sap_seq_no));
519 		trace_iwlmei_sap_data(skb, IWL_SAP_TX_DATA_FROM_AIR);
520 	}
521 
522 	if (wr + tx_sz <= q_sz) {
523 		skb_copy_bits(skb, 0, q_head + wr, tx_sz);
524 	} else {
525 		skb_copy_bits(skb, 0, q_head + wr, q_sz - wr);
526 		skb_copy_bits(skb, q_sz - wr, q_head, tx_sz - (q_sz - wr));
527 	}
528 
529 	WRITE_ONCE(notif_q->wr_ptr, cpu_to_le32((wr + tx_sz) % q_sz));
530 
531 out:
532 	spin_unlock_bh(&mei->data_q_lock);
533 }
534 
535 static int
536 iwl_mei_send_sap_msg(struct mei_cl_device *cldev, u16 type)
537 {
538 	struct iwl_sap_hdr msg = {
539 		.type = cpu_to_le16(type),
540 	};
541 
542 	return iwl_mei_send_sap_msg_payload(cldev, &msg);
543 }
544 
545 static void iwl_mei_send_csa_msg_wk(struct work_struct *wk)
546 {
547 	struct iwl_mei *mei =
548 		container_of(wk, struct iwl_mei, send_csa_msg_wk);
549 
550 	if (!iwl_mei_is_connected())
551 		return;
552 
553 	mutex_lock(&iwl_mei_mutex);
554 
555 	iwl_mei_send_check_shared_area(mei->cldev);
556 
557 	mutex_unlock(&iwl_mei_mutex);
558 }
559 
560 /* Called in a RCU read critical section from netif_receive_skb */
561 static rx_handler_result_t iwl_mei_rx_handler(struct sk_buff **pskb)
562 {
563 	struct sk_buff *skb = *pskb;
564 	struct iwl_mei *mei =
565 		rcu_dereference(skb->dev->rx_handler_data);
566 	struct iwl_mei_filters *filters = rcu_dereference(mei->filters);
567 	bool rx_for_csme = false;
568 	rx_handler_result_t res;
569 
570 	/*
571 	 * remove() unregisters this handler and synchronize_net, so this
572 	 * should never happen.
573 	 */
574 	if (!iwl_mei_is_connected()) {
575 		dev_err(&mei->cldev->dev,
576 			"Got an Rx packet, but we're not connected to SAP?\n");
577 		return RX_HANDLER_PASS;
578 	}
579 
580 	if (filters)
581 		res = iwl_mei_rx_filter(skb, &filters->filters, &rx_for_csme);
582 	else
583 		res = RX_HANDLER_PASS;
584 
585 	/*
586 	 * The data is already on the ring of the shared area, all we
587 	 * need to do is to tell the CSME firmware to check what we have
588 	 * there.
589 	 */
590 	if (rx_for_csme)
591 		schedule_work(&mei->send_csa_msg_wk);
592 
593 	if (res != RX_HANDLER_PASS) {
594 		trace_iwlmei_sap_data(skb, IWL_SAP_RX_DATA_DROPPED_FROM_AIR);
595 		dev_kfree_skb(skb);
596 	}
597 
598 	return res;
599 }
600 
601 static void iwl_mei_netdev_work(struct work_struct *wk)
602 {
603 	struct iwl_mei *mei =
604 		container_of(wk, struct iwl_mei, netdev_work);
605 	struct net_device *netdev;
606 
607 	/*
608 	 * First take rtnl and only then the mutex to avoid an ABBA
609 	 * with iwl_mei_set_netdev()
610 	 */
611 	rtnl_lock();
612 	mutex_lock(&iwl_mei_mutex);
613 
614 	netdev = rcu_dereference_protected(iwl_mei_cache.netdev,
615 					   lockdep_is_held(&iwl_mei_mutex));
616 	if (netdev) {
617 		if (mei->amt_enabled)
618 			netdev_rx_handler_register(netdev, iwl_mei_rx_handler,
619 						   mei);
620 		else
621 			netdev_rx_handler_unregister(netdev);
622 	}
623 
624 	mutex_unlock(&iwl_mei_mutex);
625 	rtnl_unlock();
626 }
627 
628 static void
629 iwl_mei_handle_rx_start_ok(struct mei_cl_device *cldev,
630 			   const struct iwl_sap_me_msg_start_ok *rsp,
631 			   ssize_t len)
632 {
633 	if (len != sizeof(*rsp)) {
634 		dev_err(&cldev->dev,
635 			"got invalid SAP_ME_MSG_START_OK from CSME firmware\n");
636 		dev_err(&cldev->dev,
637 			"size is incorrect: %zd instead of %zu\n",
638 			len, sizeof(*rsp));
639 		return;
640 	}
641 
642 	if (rsp->supported_version != SAP_VERSION) {
643 		dev_err(&cldev->dev,
644 			"didn't get the expected version: got %d\n",
645 			rsp->supported_version);
646 		return;
647 	}
648 
649 	mutex_lock(&iwl_mei_mutex);
650 	set_bit(IWL_MEI_STATUS_SAP_CONNECTED, &iwl_mei_status);
651 	/*
652 	 * We'll receive AMT_STATE SAP message in a bit and
653 	 * that will continue the flow
654 	 */
655 	mutex_unlock(&iwl_mei_mutex);
656 }
657 
658 static void iwl_mei_handle_csme_filters(struct mei_cl_device *cldev,
659 					const struct iwl_sap_csme_filters *filters)
660 {
661 	struct iwl_mei *mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
662 	struct iwl_mei_filters *new_filters;
663 	struct iwl_mei_filters *old_filters;
664 
665 	old_filters =
666 		rcu_dereference_protected(mei->filters,
667 					  lockdep_is_held(&iwl_mei_mutex));
668 
669 	new_filters = kzalloc(sizeof(*new_filters), GFP_KERNEL);
670 	if (!new_filters)
671 		return;
672 
673 	/* Copy the OOB filters */
674 	new_filters->filters = filters->filters;
675 
676 	rcu_assign_pointer(mei->filters, new_filters);
677 
678 	if (old_filters)
679 		kfree_rcu(old_filters, rcu_head);
680 }
681 
682 static void
683 iwl_mei_handle_conn_status(struct mei_cl_device *cldev,
684 			   const struct iwl_sap_notif_conn_status *status)
685 {
686 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
687 	struct iwl_mei_conn_info conn_info = {
688 		.lp_state = le32_to_cpu(status->link_prot_state),
689 		.ssid_len = le32_to_cpu(status->conn_info.ssid_len),
690 		.channel = status->conn_info.channel,
691 		.band = status->conn_info.band,
692 		.auth_mode = le32_to_cpu(status->conn_info.auth_mode),
693 		.pairwise_cipher = le32_to_cpu(status->conn_info.pairwise_cipher),
694 	};
695 
696 	if (!iwl_mei_cache.ops ||
697 	    conn_info.ssid_len > ARRAY_SIZE(conn_info.ssid))
698 		return;
699 
700 	memcpy(conn_info.ssid, status->conn_info.ssid, conn_info.ssid_len);
701 	ether_addr_copy(conn_info.bssid, status->conn_info.bssid);
702 
703 	iwl_mei_cache.ops->me_conn_status(iwl_mei_cache.priv, &conn_info);
704 
705 	mei->link_prot_state = status->link_prot_state;
706 
707 	/*
708 	 * Update the Rfkill state in case the host does not own the device:
709 	 * if we are in Link Protection, ask to not touch the device, else,
710 	 * unblock rfkill.
711 	 * If the host owns the device, inform the user space whether it can
712 	 * roam.
713 	 */
714 	if (mei->got_ownership)
715 		iwl_mei_cache.ops->roaming_forbidden(iwl_mei_cache.priv,
716 						     status->link_prot_state);
717 	else
718 		iwl_mei_cache.ops->rfkill(iwl_mei_cache.priv,
719 					  status->link_prot_state);
720 }
721 
722 static void iwl_mei_set_init_conf(struct iwl_mei *mei)
723 {
724 	struct iwl_sap_notif_host_link_up link_msg = {
725 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_HOST_LINK_UP),
726 		.hdr.len = cpu_to_le16(sizeof(link_msg) - sizeof(link_msg.hdr)),
727 	};
728 	struct iwl_sap_notif_country_code mcc_msg = {
729 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_COUNTRY_CODE),
730 		.hdr.len = cpu_to_le16(sizeof(mcc_msg) - sizeof(mcc_msg.hdr)),
731 		.mcc = cpu_to_le16(iwl_mei_cache.mcc),
732 	};
733 	struct iwl_sap_notif_sar_limits sar_msg = {
734 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_SAR_LIMITS),
735 		.hdr.len = cpu_to_le16(sizeof(sar_msg) - sizeof(sar_msg.hdr)),
736 	};
737 	struct iwl_sap_notif_host_nic_info nic_info_msg = {
738 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_NIC_INFO),
739 		.hdr.len = cpu_to_le16(sizeof(nic_info_msg) - sizeof(nic_info_msg.hdr)),
740 	};
741 	struct iwl_sap_msg_dw rfkill_msg = {
742 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_RADIO_STATE),
743 		.hdr.len = cpu_to_le16(sizeof(rfkill_msg) - sizeof(rfkill_msg.hdr)),
744 		.val = cpu_to_le32(iwl_mei_cache.rf_kill),
745 	};
746 
747 	/* wifi driver has registered already */
748 	if (iwl_mei_cache.ops) {
749 		iwl_mei_send_sap_msg(mei->cldev,
750 				     SAP_MSG_NOTIF_WIFIDR_UP);
751 		iwl_mei_cache.ops->sap_connected(iwl_mei_cache.priv);
752 	}
753 
754 	iwl_mei_send_sap_msg(mei->cldev, SAP_MSG_NOTIF_WHO_OWNS_NIC);
755 
756 	if (iwl_mei_cache.conn_info) {
757 		link_msg.conn_info = *iwl_mei_cache.conn_info;
758 		iwl_mei_send_sap_msg_payload(mei->cldev, &link_msg.hdr);
759 	}
760 
761 	iwl_mei_send_sap_msg_payload(mei->cldev, &mcc_msg.hdr);
762 
763 	if (iwl_mei_cache.power_limit) {
764 		memcpy(sar_msg.sar_chain_info_table, iwl_mei_cache.power_limit,
765 		       sizeof(sar_msg.sar_chain_info_table));
766 		iwl_mei_send_sap_msg_payload(mei->cldev, &sar_msg.hdr);
767 	}
768 
769 	ether_addr_copy(nic_info_msg.mac_address, iwl_mei_cache.mac_address);
770 	ether_addr_copy(nic_info_msg.nvm_address, iwl_mei_cache.nvm_address);
771 	iwl_mei_send_sap_msg_payload(mei->cldev, &nic_info_msg.hdr);
772 
773 	iwl_mei_send_sap_msg_payload(mei->cldev, &rfkill_msg.hdr);
774 }
775 
776 static void iwl_mei_handle_amt_state(struct mei_cl_device *cldev,
777 				     const struct iwl_sap_msg_dw *dw)
778 {
779 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
780 
781 	mutex_lock(&iwl_mei_mutex);
782 
783 	if (mei->amt_enabled == !!le32_to_cpu(dw->val))
784 		goto out;
785 
786 	mei->amt_enabled = dw->val;
787 
788 	if (mei->amt_enabled)
789 		iwl_mei_set_init_conf(mei);
790 	else if (iwl_mei_cache.ops)
791 		iwl_mei_cache.ops->rfkill(iwl_mei_cache.priv, false, false);
792 
793 	schedule_work(&mei->netdev_work);
794 
795 out:
796 	mutex_unlock(&iwl_mei_mutex);
797 }
798 
799 static void iwl_mei_handle_nic_owner(struct mei_cl_device *cldev,
800 				     const struct iwl_sap_msg_dw *dw)
801 {
802 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
803 
804 	mei->got_ownership = dw->val != cpu_to_le32(SAP_NIC_OWNER_ME);
805 }
806 
807 static void iwl_mei_handle_can_release_ownership(struct mei_cl_device *cldev,
808 						 const void *payload)
809 {
810 	/* We can get ownership and driver is registered, go ahead */
811 	if (iwl_mei_cache.ops)
812 		iwl_mei_send_sap_msg(cldev,
813 				     SAP_MSG_NOTIF_HOST_ASKS_FOR_NIC_OWNERSHIP);
814 }
815 
816 static void iwl_mei_handle_csme_taking_ownership(struct mei_cl_device *cldev,
817 						 const void *payload)
818 {
819 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
820 
821 	dev_info(&cldev->dev, "CSME takes ownership\n");
822 
823 	mei->got_ownership = false;
824 
825 	if (iwl_mei_cache.ops && !mei->device_down) {
826 		/*
827 		 * Remember to send CSME_OWNERSHIP_CONFIRMED when the wifi
828 		 * driver is finished taking the device down.
829 		 */
830 		mei->csme_taking_ownership = true;
831 
832 		iwl_mei_cache.ops->rfkill(iwl_mei_cache.priv, true, true);
833 	} else {
834 		iwl_mei_send_sap_msg(cldev,
835 				     SAP_MSG_NOTIF_CSME_OWNERSHIP_CONFIRMED);
836 	}
837 }
838 
839 static void iwl_mei_handle_nvm(struct mei_cl_device *cldev,
840 			       const struct iwl_sap_nvm *sap_nvm)
841 {
842 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
843 	const struct iwl_mei_nvm *mei_nvm = (const void *)sap_nvm;
844 	int i;
845 
846 	kfree(mei->nvm);
847 	mei->nvm = kzalloc(sizeof(*mei_nvm), GFP_KERNEL);
848 	if (!mei->nvm)
849 		return;
850 
851 	ether_addr_copy(mei->nvm->hw_addr, sap_nvm->hw_addr);
852 	mei->nvm->n_hw_addrs = sap_nvm->n_hw_addrs;
853 	mei->nvm->radio_cfg = le32_to_cpu(sap_nvm->radio_cfg);
854 	mei->nvm->caps = le32_to_cpu(sap_nvm->caps);
855 	mei->nvm->nvm_version = le32_to_cpu(sap_nvm->nvm_version);
856 
857 	for (i = 0; i < ARRAY_SIZE(mei->nvm->channels); i++)
858 		mei->nvm->channels[i] = le32_to_cpu(sap_nvm->channels[i]);
859 
860 	wake_up_all(&mei->get_nvm_wq);
861 }
862 
863 static void iwl_mei_handle_rx_host_own_req(struct mei_cl_device *cldev,
864 					   const struct iwl_sap_msg_dw *dw)
865 {
866 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
867 
868 	/*
869 	 * This means that we can't use the wifi device right now, CSME is not
870 	 * ready to let us use it.
871 	 */
872 	if (!dw->val) {
873 		dev_info(&cldev->dev, "Ownership req denied\n");
874 		return;
875 	}
876 
877 	mei->got_ownership = true;
878 	wake_up_all(&mei->get_ownership_wq);
879 
880 	iwl_mei_send_sap_msg(cldev,
881 			     SAP_MSG_NOTIF_HOST_OWNERSHIP_CONFIRMED);
882 
883 	/* We can now start the connection, unblock rfkill */
884 	if (iwl_mei_cache.ops)
885 		iwl_mei_cache.ops->rfkill(iwl_mei_cache.priv, false);
886 }
887 
888 static void iwl_mei_handle_pldr_ack(struct mei_cl_device *cldev,
889 				    const struct iwl_sap_pldr_ack_data *ack)
890 {
891 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
892 
893 	mei->pldr_active = le32_to_cpu(ack->status) == SAP_PLDR_STATUS_SUCCESS;
894 	wake_up_all(&mei->pldr_wq);
895 }
896 
897 static void iwl_mei_handle_ping(struct mei_cl_device *cldev,
898 				const struct iwl_sap_hdr *hdr)
899 {
900 	iwl_mei_send_sap_msg(cldev, SAP_MSG_NOTIF_PONG);
901 }
902 
903 static void iwl_mei_handle_sap_msg(struct mei_cl_device *cldev,
904 				   const struct iwl_sap_hdr *hdr)
905 {
906 	u16 len = le16_to_cpu(hdr->len) + sizeof(*hdr);
907 	u16 type = le16_to_cpu(hdr->type);
908 
909 	dev_dbg(&cldev->dev,
910 		"Got a new SAP message: type %d, len %d, seq %d\n",
911 		le16_to_cpu(hdr->type), len,
912 		le32_to_cpu(hdr->seq_num));
913 
914 #define SAP_MSG_HANDLER(_cmd, _handler, _sz)				\
915 	case SAP_MSG_NOTIF_ ## _cmd:					\
916 		if (len < _sz) {					\
917 			dev_err(&cldev->dev,				\
918 				"Bad size for %d: %u < %u\n",		\
919 				le16_to_cpu(hdr->type),			\
920 				(unsigned int)len,			\
921 				(unsigned int)_sz);			\
922 			break;						\
923 		}							\
924 		mutex_lock(&iwl_mei_mutex);				\
925 		_handler(cldev, (const void *)hdr);			\
926 		mutex_unlock(&iwl_mei_mutex);				\
927 		break
928 
929 #define SAP_MSG_HANDLER_NO_LOCK(_cmd, _handler, _sz)			\
930 	case SAP_MSG_NOTIF_ ## _cmd:					\
931 		if (len < _sz) {					\
932 			dev_err(&cldev->dev,				\
933 				"Bad size for %d: %u < %u\n",		\
934 				le16_to_cpu(hdr->type),			\
935 				(unsigned int)len,			\
936 				(unsigned int)_sz);			\
937 			break;						\
938 		}							\
939 		_handler(cldev, (const void *)hdr);			\
940 		break
941 
942 #define SAP_MSG_HANDLER_NO_HANDLER(_cmd, _sz)				\
943 	case SAP_MSG_NOTIF_ ## _cmd:					\
944 		if (len < _sz) {					\
945 			dev_err(&cldev->dev,				\
946 				"Bad size for %d: %u < %u\n",		\
947 				le16_to_cpu(hdr->type),			\
948 				(unsigned int)len,			\
949 				(unsigned int)_sz);			\
950 			break;						\
951 		}							\
952 		break
953 
954 	switch (type) {
955 	SAP_MSG_HANDLER(PING, iwl_mei_handle_ping, 0);
956 	SAP_MSG_HANDLER(CSME_FILTERS,
957 			iwl_mei_handle_csme_filters,
958 			sizeof(struct iwl_sap_csme_filters));
959 	SAP_MSG_HANDLER(CSME_CONN_STATUS,
960 			iwl_mei_handle_conn_status,
961 			sizeof(struct iwl_sap_notif_conn_status));
962 	SAP_MSG_HANDLER_NO_LOCK(AMT_STATE,
963 				iwl_mei_handle_amt_state,
964 				sizeof(struct iwl_sap_msg_dw));
965 	SAP_MSG_HANDLER_NO_HANDLER(PONG, 0);
966 	SAP_MSG_HANDLER(NVM, iwl_mei_handle_nvm,
967 			sizeof(struct iwl_sap_nvm));
968 	SAP_MSG_HANDLER(CSME_REPLY_TO_HOST_OWNERSHIP_REQ,
969 			iwl_mei_handle_rx_host_own_req,
970 			sizeof(struct iwl_sap_msg_dw));
971 	SAP_MSG_HANDLER(NIC_OWNER, iwl_mei_handle_nic_owner,
972 			sizeof(struct iwl_sap_msg_dw));
973 	SAP_MSG_HANDLER(CSME_CAN_RELEASE_OWNERSHIP,
974 			iwl_mei_handle_can_release_ownership, 0);
975 	SAP_MSG_HANDLER(CSME_TAKING_OWNERSHIP,
976 			iwl_mei_handle_csme_taking_ownership, 0);
977 	SAP_MSG_HANDLER(PLDR_ACK, iwl_mei_handle_pldr_ack,
978 			sizeof(struct iwl_sap_pldr_ack_data));
979 	default:
980 	/*
981 	 * This is not really an error, there are message that we decided
982 	 * to ignore, yet, it is useful to be able to leave a note if debug
983 	 * is enabled.
984 	 */
985 	dev_dbg(&cldev->dev, "Unsupported message: type %d, len %d\n",
986 		le16_to_cpu(hdr->type), len);
987 	}
988 
989 #undef SAP_MSG_HANDLER
990 #undef SAP_MSG_HANDLER_NO_LOCK
991 }
992 
993 static void iwl_mei_read_from_q(const u8 *q_head, u32 q_sz,
994 				u32 *_rd, u32 wr,
995 				void *_buf, u32 len)
996 {
997 	u8 *buf = _buf;
998 	u32 rd = *_rd;
999 
1000 	if (rd + len <= q_sz) {
1001 		memcpy(buf, q_head + rd, len);
1002 		rd += len;
1003 	} else {
1004 		memcpy(buf, q_head + rd, q_sz - rd);
1005 		memcpy(buf + q_sz - rd, q_head, len - (q_sz - rd));
1006 		rd = len - (q_sz - rd);
1007 	}
1008 
1009 	*_rd = rd;
1010 }
1011 
1012 #define QOS_HDR_IV_SNAP_LEN (sizeof(struct ieee80211_qos_hdr) +      \
1013 			     IEEE80211_TKIP_IV_LEN +                 \
1014 			     sizeof(rfc1042_header) + ETH_TLEN)
1015 
1016 static void iwl_mei_handle_sap_data(struct mei_cl_device *cldev,
1017 				    const u8 *q_head, u32 q_sz,
1018 				    u32 rd, u32 wr, ssize_t valid_rx_sz,
1019 				    struct sk_buff_head *tx_skbs)
1020 {
1021 	struct iwl_sap_hdr hdr;
1022 	struct net_device *netdev =
1023 		rcu_dereference_protected(iwl_mei_cache.netdev,
1024 					  lockdep_is_held(&iwl_mei_mutex));
1025 
1026 	if (!netdev)
1027 		return;
1028 
1029 	while (valid_rx_sz >= sizeof(hdr)) {
1030 		struct ethhdr *ethhdr;
1031 		unsigned char *data;
1032 		struct sk_buff *skb;
1033 		u16 len;
1034 
1035 		iwl_mei_read_from_q(q_head, q_sz, &rd, wr, &hdr, sizeof(hdr));
1036 		valid_rx_sz -= sizeof(hdr);
1037 		len = le16_to_cpu(hdr.len);
1038 
1039 		if (valid_rx_sz < len) {
1040 			dev_err(&cldev->dev,
1041 				"Data queue is corrupted: valid data len %zd, len %d\n",
1042 				valid_rx_sz, len);
1043 			break;
1044 		}
1045 
1046 		if (len < sizeof(*ethhdr)) {
1047 			dev_err(&cldev->dev,
1048 				"Data len is smaller than an ethernet header? len = %d\n",
1049 				len);
1050 		}
1051 
1052 		valid_rx_sz -= len;
1053 
1054 		if (le16_to_cpu(hdr.type) != SAP_MSG_DATA_PACKET) {
1055 			dev_err(&cldev->dev, "Unsupported Rx data: type %d, len %d\n",
1056 				le16_to_cpu(hdr.type), len);
1057 			continue;
1058 		}
1059 
1060 		/* We need enough room for the WiFi header + SNAP + IV */
1061 		skb = netdev_alloc_skb(netdev, len + QOS_HDR_IV_SNAP_LEN);
1062 		if (!skb)
1063 			continue;
1064 
1065 		skb_reserve(skb, QOS_HDR_IV_SNAP_LEN);
1066 		ethhdr = skb_push(skb, sizeof(*ethhdr));
1067 
1068 		iwl_mei_read_from_q(q_head, q_sz, &rd, wr,
1069 				    ethhdr, sizeof(*ethhdr));
1070 		len -= sizeof(*ethhdr);
1071 
1072 		skb_reset_mac_header(skb);
1073 		skb_reset_network_header(skb);
1074 		skb->protocol = ethhdr->h_proto;
1075 
1076 		data = skb_put(skb, len);
1077 		iwl_mei_read_from_q(q_head, q_sz, &rd, wr, data, len);
1078 
1079 		/*
1080 		 * Enqueue the skb here so that it can be sent later when we
1081 		 * do not hold the mutex. TX'ing a packet with a mutex held is
1082 		 * possible, but it wouldn't be nice to forbid the TX path to
1083 		 * call any of iwlmei's functions, since every API from iwlmei
1084 		 * needs the mutex.
1085 		 */
1086 		__skb_queue_tail(tx_skbs, skb);
1087 	}
1088 }
1089 
1090 static void iwl_mei_handle_sap_rx_cmd(struct mei_cl_device *cldev,
1091 				      const u8 *q_head, u32 q_sz,
1092 				      u32 rd, u32 wr, ssize_t valid_rx_sz)
1093 {
1094 	struct page *p = alloc_page(GFP_KERNEL);
1095 	struct iwl_sap_hdr *hdr;
1096 
1097 	if (!p)
1098 		return;
1099 
1100 	hdr = page_address(p);
1101 
1102 	while (valid_rx_sz >= sizeof(*hdr)) {
1103 		u16 len;
1104 
1105 		iwl_mei_read_from_q(q_head, q_sz, &rd, wr, hdr, sizeof(*hdr));
1106 		valid_rx_sz -= sizeof(*hdr);
1107 		len = le16_to_cpu(hdr->len);
1108 
1109 		if (valid_rx_sz < len)
1110 			break;
1111 
1112 		iwl_mei_read_from_q(q_head, q_sz, &rd, wr, hdr + 1, len);
1113 
1114 		trace_iwlmei_sap_cmd(hdr, false);
1115 		iwl_mei_handle_sap_msg(cldev, hdr);
1116 		valid_rx_sz -= len;
1117 	}
1118 
1119 	/* valid_rx_sz must be 0 now... */
1120 	if (valid_rx_sz)
1121 		dev_err(&cldev->dev,
1122 			"More data in the buffer although we read it all\n");
1123 
1124 	__free_page(p);
1125 }
1126 
1127 static void iwl_mei_handle_sap_rx(struct mei_cl_device *cldev,
1128 				  struct iwl_sap_q_ctrl_blk *notif_q,
1129 				  const u8 *q_head,
1130 				  struct sk_buff_head *skbs,
1131 				  u32 q_sz)
1132 {
1133 	u32 rd = le32_to_cpu(READ_ONCE(notif_q->rd_ptr));
1134 	u32 wr = le32_to_cpu(READ_ONCE(notif_q->wr_ptr));
1135 	ssize_t valid_rx_sz;
1136 
1137 	if (rd > q_sz || wr > q_sz) {
1138 		dev_err(&cldev->dev,
1139 			"Pointers are past the buffer limit\n");
1140 		return;
1141 	}
1142 
1143 	if (rd == wr)
1144 		return;
1145 
1146 	valid_rx_sz = wr > rd ? wr - rd : q_sz - rd + wr;
1147 
1148 	if (skbs)
1149 		iwl_mei_handle_sap_data(cldev, q_head, q_sz, rd, wr,
1150 					valid_rx_sz, skbs);
1151 	else
1152 		iwl_mei_handle_sap_rx_cmd(cldev, q_head, q_sz, rd, wr,
1153 					  valid_rx_sz);
1154 
1155 	/* Increment the read pointer to point to the write pointer */
1156 	WRITE_ONCE(notif_q->rd_ptr, cpu_to_le32(wr));
1157 }
1158 
1159 static void iwl_mei_handle_check_shared_area(struct mei_cl_device *cldev)
1160 {
1161 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
1162 	struct iwl_sap_q_ctrl_blk *notif_q;
1163 	struct sk_buff_head tx_skbs;
1164 	struct iwl_sap_dir *dir;
1165 	void *q_head;
1166 	u32 q_sz;
1167 
1168 	if (!mei->shared_mem.ctrl)
1169 		return;
1170 
1171 	dir = &mei->shared_mem.ctrl->dir[SAP_DIRECTION_ME_TO_HOST];
1172 	notif_q = &dir->q_ctrl_blk[SAP_QUEUE_IDX_NOTIF];
1173 	q_head = mei->shared_mem.q_head[SAP_DIRECTION_ME_TO_HOST][SAP_QUEUE_IDX_NOTIF];
1174 	q_sz = mei->shared_mem.q_size[SAP_DIRECTION_ME_TO_HOST][SAP_QUEUE_IDX_NOTIF];
1175 
1176 	/*
1177 	 * Do not hold the mutex here, but rather each and every message
1178 	 * handler takes it.
1179 	 * This allows message handlers to take it at a certain time.
1180 	 */
1181 	iwl_mei_handle_sap_rx(cldev, notif_q, q_head, NULL, q_sz);
1182 
1183 	mutex_lock(&iwl_mei_mutex);
1184 	dir = &mei->shared_mem.ctrl->dir[SAP_DIRECTION_ME_TO_HOST];
1185 	notif_q = &dir->q_ctrl_blk[SAP_QUEUE_IDX_DATA];
1186 	q_head = mei->shared_mem.q_head[SAP_DIRECTION_ME_TO_HOST][SAP_QUEUE_IDX_DATA];
1187 	q_sz = mei->shared_mem.q_size[SAP_DIRECTION_ME_TO_HOST][SAP_QUEUE_IDX_DATA];
1188 
1189 	__skb_queue_head_init(&tx_skbs);
1190 
1191 	iwl_mei_handle_sap_rx(cldev, notif_q, q_head, &tx_skbs, q_sz);
1192 
1193 	if (skb_queue_empty(&tx_skbs)) {
1194 		mutex_unlock(&iwl_mei_mutex);
1195 		return;
1196 	}
1197 
1198 	/*
1199 	 * Take the RCU read lock before we unlock the mutex to make sure that
1200 	 * even if the netdev is replaced by another non-NULL netdev right after
1201 	 * we unlock the mutex, the old netdev will still be valid when we
1202 	 * transmit the frames. We can't allow to replace the netdev here because
1203 	 * the skbs hold a pointer to the netdev.
1204 	 */
1205 	rcu_read_lock();
1206 
1207 	mutex_unlock(&iwl_mei_mutex);
1208 
1209 	if (!rcu_access_pointer(iwl_mei_cache.netdev)) {
1210 		dev_err(&cldev->dev, "Can't Tx without a netdev\n");
1211 		skb_queue_purge(&tx_skbs);
1212 		goto out;
1213 	}
1214 
1215 	while (!skb_queue_empty(&tx_skbs)) {
1216 		struct sk_buff *skb = __skb_dequeue(&tx_skbs);
1217 
1218 		trace_iwlmei_sap_data(skb, IWL_SAP_RX_DATA_TO_AIR);
1219 		dev_queue_xmit(skb);
1220 	}
1221 
1222 out:
1223 	rcu_read_unlock();
1224 }
1225 
1226 static void iwl_mei_rx(struct mei_cl_device *cldev)
1227 {
1228 	struct iwl_sap_me_msg_hdr *hdr;
1229 	u8 msg[100];
1230 	ssize_t ret;
1231 
1232 	ret = mei_cldev_recv(cldev, (u8 *)&msg, sizeof(msg));
1233 	if (ret < 0) {
1234 		dev_err(&cldev->dev, "failed to receive data: %zd\n", ret);
1235 		return;
1236 	}
1237 
1238 	if (ret == 0) {
1239 		dev_err(&cldev->dev, "got an empty response\n");
1240 		return;
1241 	}
1242 
1243 	hdr = (void *)msg;
1244 	trace_iwlmei_me_msg(hdr, false);
1245 
1246 	switch (le32_to_cpu(hdr->type)) {
1247 	case SAP_ME_MSG_START_OK:
1248 		BUILD_BUG_ON(sizeof(struct iwl_sap_me_msg_start_ok) >
1249 			     sizeof(msg));
1250 
1251 		iwl_mei_handle_rx_start_ok(cldev, (void *)msg, ret);
1252 		break;
1253 	case SAP_ME_MSG_CHECK_SHARED_AREA:
1254 		iwl_mei_handle_check_shared_area(cldev);
1255 		break;
1256 	default:
1257 		dev_err(&cldev->dev, "got a RX notification: %d\n",
1258 			le32_to_cpu(hdr->type));
1259 		break;
1260 	}
1261 }
1262 
1263 static int iwl_mei_send_start(struct mei_cl_device *cldev)
1264 {
1265 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
1266 	struct iwl_sap_me_msg_start msg = {
1267 		.hdr.type = cpu_to_le32(SAP_ME_MSG_START),
1268 		.hdr.seq_num = cpu_to_le32(atomic_inc_return(&mei->seq_no)),
1269 		.hdr.len = cpu_to_le32(sizeof(msg)),
1270 		.supported_versions[0] = SAP_VERSION,
1271 		.init_data_seq_num = cpu_to_le16(0x100),
1272 		.init_notif_seq_num = cpu_to_le16(0x800),
1273 	};
1274 	int ret;
1275 
1276 	trace_iwlmei_me_msg(&msg.hdr, true);
1277 	ret = mei_cldev_send(cldev, (void *)&msg, sizeof(msg));
1278 	if (ret != sizeof(msg)) {
1279 		dev_err(&cldev->dev,
1280 			"failed to send the SAP_ME_MSG_START message %d\n",
1281 			ret);
1282 		return ret;
1283 	}
1284 
1285 	return 0;
1286 }
1287 
1288 static int iwl_mei_enable(struct mei_cl_device *cldev)
1289 {
1290 	int ret;
1291 
1292 	ret = mei_cldev_enable(cldev);
1293 	if (ret < 0) {
1294 		dev_err(&cldev->dev, "failed to enable the device: %d\n", ret);
1295 		return ret;
1296 	}
1297 
1298 	ret = mei_cldev_register_rx_cb(cldev, iwl_mei_rx);
1299 	if (ret) {
1300 		dev_err(&cldev->dev,
1301 			"failed to register to the rx cb: %d\n", ret);
1302 		mei_cldev_disable(cldev);
1303 		return ret;
1304 	}
1305 
1306 	return 0;
1307 }
1308 
1309 struct iwl_mei_nvm *iwl_mei_get_nvm(void)
1310 {
1311 	struct iwl_mei_nvm *nvm = NULL;
1312 	struct iwl_mei *mei;
1313 	int ret;
1314 
1315 	mutex_lock(&iwl_mei_mutex);
1316 
1317 	if (!iwl_mei_is_connected())
1318 		goto out;
1319 
1320 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1321 
1322 	if (!mei)
1323 		goto out;
1324 
1325 	ret = iwl_mei_send_sap_msg(iwl_mei_global_cldev,
1326 				   SAP_MSG_NOTIF_GET_NVM);
1327 	if (ret)
1328 		goto out;
1329 
1330 	mutex_unlock(&iwl_mei_mutex);
1331 
1332 	ret = wait_event_timeout(mei->get_nvm_wq, mei->nvm, 2 * HZ);
1333 	if (!ret)
1334 		return NULL;
1335 
1336 	mutex_lock(&iwl_mei_mutex);
1337 
1338 	if (!iwl_mei_is_connected())
1339 		goto out;
1340 
1341 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1342 
1343 	if (!mei)
1344 		goto out;
1345 
1346 	if (mei->nvm)
1347 		nvm = kmemdup(mei->nvm, sizeof(*mei->nvm), GFP_KERNEL);
1348 
1349 out:
1350 	mutex_unlock(&iwl_mei_mutex);
1351 	return nvm;
1352 }
1353 EXPORT_SYMBOL_GPL(iwl_mei_get_nvm);
1354 
1355 #define IWL_MEI_PLDR_NUM_RETRIES	3
1356 
1357 int iwl_mei_pldr_req(void)
1358 {
1359 	struct iwl_mei *mei;
1360 	int ret;
1361 	struct iwl_sap_pldr_data msg = {
1362 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_PLDR),
1363 		.hdr.len = cpu_to_le16(sizeof(msg) - sizeof(msg.hdr)),
1364 	};
1365 	int i;
1366 
1367 	mutex_lock(&iwl_mei_mutex);
1368 
1369 	/* In case we didn't have a bind */
1370 	if (!iwl_mei_is_connected()) {
1371 		ret = 0;
1372 		goto out;
1373 	}
1374 
1375 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1376 
1377 	if (!mei) {
1378 		ret = -ENODEV;
1379 		goto out;
1380 	}
1381 
1382 	if (!mei->amt_enabled) {
1383 		ret = 0;
1384 		goto out;
1385 	}
1386 
1387 	for (i = 0; i < IWL_MEI_PLDR_NUM_RETRIES; i++) {
1388 		ret = iwl_mei_send_sap_msg_payload(mei->cldev, &msg.hdr);
1389 		mutex_unlock(&iwl_mei_mutex);
1390 		if (ret)
1391 			return ret;
1392 
1393 		ret = wait_event_timeout(mei->pldr_wq, mei->pldr_active, HZ / 2);
1394 		if (ret)
1395 			break;
1396 
1397 		/* Take the mutex for the next iteration */
1398 		mutex_lock(&iwl_mei_mutex);
1399 	}
1400 
1401 	if (ret)
1402 		return 0;
1403 
1404 	ret = -ETIMEDOUT;
1405 out:
1406 	mutex_unlock(&iwl_mei_mutex);
1407 	return ret;
1408 }
1409 EXPORT_SYMBOL_GPL(iwl_mei_pldr_req);
1410 
1411 int iwl_mei_get_ownership(void)
1412 {
1413 	struct iwl_mei *mei;
1414 	int ret;
1415 
1416 	mutex_lock(&iwl_mei_mutex);
1417 
1418 	/* In case we didn't have a bind */
1419 	if (!iwl_mei_is_connected()) {
1420 		ret = 0;
1421 		goto out;
1422 	}
1423 
1424 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1425 
1426 	if (!mei) {
1427 		ret = -ENODEV;
1428 		goto out;
1429 	}
1430 
1431 	if (!mei->amt_enabled) {
1432 		ret = 0;
1433 		goto out;
1434 	}
1435 
1436 	if (mei->got_ownership) {
1437 		ret = 0;
1438 		goto out;
1439 	}
1440 
1441 	ret = iwl_mei_send_sap_msg(mei->cldev,
1442 				   SAP_MSG_NOTIF_HOST_ASKS_FOR_NIC_OWNERSHIP);
1443 	if (ret)
1444 		goto out;
1445 
1446 	mutex_unlock(&iwl_mei_mutex);
1447 
1448 	ret = wait_event_timeout(mei->get_ownership_wq,
1449 				 mei->got_ownership, HZ / 2);
1450 	return (!ret) ? -ETIMEDOUT : 0;
1451 out:
1452 	mutex_unlock(&iwl_mei_mutex);
1453 	return ret;
1454 }
1455 EXPORT_SYMBOL_GPL(iwl_mei_get_ownership);
1456 
1457 void iwl_mei_alive_notif(bool success)
1458 {
1459 	struct iwl_mei *mei;
1460 	struct iwl_sap_pldr_end_data msg = {
1461 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_PLDR_END),
1462 		.hdr.len = cpu_to_le16(sizeof(msg) - sizeof(msg.hdr)),
1463 		.status = success ? cpu_to_le32(SAP_PLDR_STATUS_SUCCESS) :
1464 			cpu_to_le32(SAP_PLDR_STATUS_FAILURE),
1465 	};
1466 
1467 	mutex_lock(&iwl_mei_mutex);
1468 
1469 	if (!iwl_mei_is_connected())
1470 		goto out;
1471 
1472 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1473 	if (!mei || !mei->pldr_active)
1474 		goto out;
1475 
1476 	mei->pldr_active = false;
1477 
1478 	iwl_mei_send_sap_msg_payload(mei->cldev, &msg.hdr);
1479 out:
1480 	mutex_unlock(&iwl_mei_mutex);
1481 }
1482 EXPORT_SYMBOL_GPL(iwl_mei_alive_notif);
1483 
1484 void iwl_mei_host_associated(const struct iwl_mei_conn_info *conn_info,
1485 			     const struct iwl_mei_colloc_info *colloc_info)
1486 {
1487 	struct iwl_sap_notif_host_link_up msg = {
1488 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_HOST_LINK_UP),
1489 		.hdr.len = cpu_to_le16(sizeof(msg) - sizeof(msg.hdr)),
1490 		.conn_info = {
1491 			.ssid_len = cpu_to_le32(conn_info->ssid_len),
1492 			.channel = conn_info->channel,
1493 			.band = conn_info->band,
1494 			.pairwise_cipher = cpu_to_le32(conn_info->pairwise_cipher),
1495 			.auth_mode = cpu_to_le32(conn_info->auth_mode),
1496 		},
1497 	};
1498 	struct iwl_mei *mei;
1499 
1500 	if (conn_info->ssid_len > ARRAY_SIZE(msg.conn_info.ssid))
1501 		return;
1502 
1503 	memcpy(msg.conn_info.ssid, conn_info->ssid, conn_info->ssid_len);
1504 	memcpy(msg.conn_info.bssid, conn_info->bssid, ETH_ALEN);
1505 
1506 	if (colloc_info) {
1507 		msg.colloc_channel = colloc_info->channel;
1508 		msg.colloc_band = colloc_info->channel <= 14 ? 0 : 1;
1509 		memcpy(msg.colloc_bssid, colloc_info->bssid, ETH_ALEN);
1510 	}
1511 
1512 	mutex_lock(&iwl_mei_mutex);
1513 
1514 	if (!iwl_mei_is_connected())
1515 		goto out;
1516 
1517 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1518 
1519 	if (!mei && !mei->amt_enabled)
1520 		goto out;
1521 
1522 	iwl_mei_send_sap_msg_payload(mei->cldev, &msg.hdr);
1523 
1524 out:
1525 	kfree(iwl_mei_cache.conn_info);
1526 	iwl_mei_cache.conn_info =
1527 		kmemdup(&msg.conn_info, sizeof(msg.conn_info), GFP_KERNEL);
1528 	mutex_unlock(&iwl_mei_mutex);
1529 }
1530 EXPORT_SYMBOL_GPL(iwl_mei_host_associated);
1531 
1532 void iwl_mei_host_disassociated(void)
1533 {
1534 	struct iwl_mei *mei;
1535 	struct iwl_sap_notif_host_link_down msg = {
1536 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_HOST_LINK_DOWN),
1537 		.hdr.len = cpu_to_le16(sizeof(msg) - sizeof(msg.hdr)),
1538 		.type = HOST_LINK_DOWN_TYPE_TEMPORARY,
1539 	};
1540 
1541 	mutex_lock(&iwl_mei_mutex);
1542 
1543 	if (!iwl_mei_is_connected())
1544 		goto out;
1545 
1546 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1547 
1548 	if (!mei && !mei->amt_enabled)
1549 		goto out;
1550 
1551 	iwl_mei_send_sap_msg_payload(mei->cldev, &msg.hdr);
1552 
1553 out:
1554 	kfree(iwl_mei_cache.conn_info);
1555 	iwl_mei_cache.conn_info = NULL;
1556 	mutex_unlock(&iwl_mei_mutex);
1557 }
1558 EXPORT_SYMBOL_GPL(iwl_mei_host_disassociated);
1559 
1560 void iwl_mei_set_rfkill_state(bool hw_rfkill, bool sw_rfkill)
1561 {
1562 	struct iwl_mei *mei;
1563 	u32 rfkill_state = 0;
1564 	struct iwl_sap_msg_dw msg = {
1565 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_RADIO_STATE),
1566 		.hdr.len = cpu_to_le16(sizeof(msg) - sizeof(msg.hdr)),
1567 	};
1568 
1569 	if (!sw_rfkill)
1570 		rfkill_state |= SAP_SW_RFKILL_DEASSERTED;
1571 
1572 	if (!hw_rfkill)
1573 		rfkill_state |= SAP_HW_RFKILL_DEASSERTED;
1574 
1575 	mutex_lock(&iwl_mei_mutex);
1576 
1577 	if (!iwl_mei_is_connected())
1578 		goto out;
1579 
1580 	msg.val = cpu_to_le32(rfkill_state);
1581 
1582 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1583 
1584 	if (!mei && !mei->amt_enabled)
1585 		goto out;
1586 
1587 	iwl_mei_send_sap_msg_payload(mei->cldev, &msg.hdr);
1588 
1589 out:
1590 	iwl_mei_cache.rf_kill = rfkill_state;
1591 	mutex_unlock(&iwl_mei_mutex);
1592 }
1593 EXPORT_SYMBOL_GPL(iwl_mei_set_rfkill_state);
1594 
1595 void iwl_mei_set_nic_info(const u8 *mac_address, const u8 *nvm_address)
1596 {
1597 	struct iwl_mei *mei;
1598 	struct iwl_sap_notif_host_nic_info msg = {
1599 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_NIC_INFO),
1600 		.hdr.len = cpu_to_le16(sizeof(msg) - sizeof(msg.hdr)),
1601 	};
1602 
1603 	mutex_lock(&iwl_mei_mutex);
1604 
1605 	if (!iwl_mei_is_connected())
1606 		goto out;
1607 
1608 	ether_addr_copy(msg.mac_address, mac_address);
1609 	ether_addr_copy(msg.nvm_address, nvm_address);
1610 
1611 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1612 
1613 	if (!mei && !mei->amt_enabled)
1614 		goto out;
1615 
1616 	iwl_mei_send_sap_msg_payload(mei->cldev, &msg.hdr);
1617 
1618 out:
1619 	ether_addr_copy(iwl_mei_cache.mac_address, mac_address);
1620 	ether_addr_copy(iwl_mei_cache.nvm_address, nvm_address);
1621 	mutex_unlock(&iwl_mei_mutex);
1622 }
1623 EXPORT_SYMBOL_GPL(iwl_mei_set_nic_info);
1624 
1625 void iwl_mei_set_country_code(u16 mcc)
1626 {
1627 	struct iwl_mei *mei;
1628 	struct iwl_sap_notif_country_code msg = {
1629 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_COUNTRY_CODE),
1630 		.hdr.len = cpu_to_le16(sizeof(msg) - sizeof(msg.hdr)),
1631 		.mcc = cpu_to_le16(mcc),
1632 	};
1633 
1634 	mutex_lock(&iwl_mei_mutex);
1635 
1636 	if (!iwl_mei_is_connected())
1637 		goto out;
1638 
1639 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1640 
1641 	if (!mei && !mei->amt_enabled)
1642 		goto out;
1643 
1644 	iwl_mei_send_sap_msg_payload(mei->cldev, &msg.hdr);
1645 
1646 out:
1647 	iwl_mei_cache.mcc = mcc;
1648 	mutex_unlock(&iwl_mei_mutex);
1649 }
1650 EXPORT_SYMBOL_GPL(iwl_mei_set_country_code);
1651 
1652 void iwl_mei_set_power_limit(const __le16 *power_limit)
1653 {
1654 	struct iwl_mei *mei;
1655 	struct iwl_sap_notif_sar_limits msg = {
1656 		.hdr.type = cpu_to_le16(SAP_MSG_NOTIF_SAR_LIMITS),
1657 		.hdr.len = cpu_to_le16(sizeof(msg) - sizeof(msg.hdr)),
1658 	};
1659 
1660 	mutex_lock(&iwl_mei_mutex);
1661 
1662 	if (!iwl_mei_is_connected())
1663 		goto out;
1664 
1665 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1666 
1667 	if (!mei && !mei->amt_enabled)
1668 		goto out;
1669 
1670 	memcpy(msg.sar_chain_info_table, power_limit, sizeof(msg.sar_chain_info_table));
1671 
1672 	iwl_mei_send_sap_msg_payload(mei->cldev, &msg.hdr);
1673 
1674 out:
1675 	kfree(iwl_mei_cache.power_limit);
1676 	iwl_mei_cache.power_limit = kmemdup(power_limit,
1677 					    sizeof(msg.sar_chain_info_table), GFP_KERNEL);
1678 	mutex_unlock(&iwl_mei_mutex);
1679 }
1680 EXPORT_SYMBOL_GPL(iwl_mei_set_power_limit);
1681 
1682 void iwl_mei_set_netdev(struct net_device *netdev)
1683 {
1684 	struct iwl_mei *mei;
1685 
1686 	mutex_lock(&iwl_mei_mutex);
1687 
1688 	if (!iwl_mei_is_connected()) {
1689 		rcu_assign_pointer(iwl_mei_cache.netdev, netdev);
1690 		goto out;
1691 	}
1692 
1693 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1694 
1695 	if (!mei)
1696 		goto out;
1697 
1698 	if (!netdev) {
1699 		struct net_device *dev =
1700 			rcu_dereference_protected(iwl_mei_cache.netdev,
1701 						  lockdep_is_held(&iwl_mei_mutex));
1702 
1703 		if (!dev)
1704 			goto out;
1705 
1706 		netdev_rx_handler_unregister(dev);
1707 	}
1708 
1709 	rcu_assign_pointer(iwl_mei_cache.netdev, netdev);
1710 
1711 	if (netdev && mei->amt_enabled)
1712 		netdev_rx_handler_register(netdev, iwl_mei_rx_handler, mei);
1713 
1714 out:
1715 	mutex_unlock(&iwl_mei_mutex);
1716 }
1717 EXPORT_SYMBOL_GPL(iwl_mei_set_netdev);
1718 
1719 void iwl_mei_device_state(bool up)
1720 {
1721 	struct iwl_mei *mei;
1722 
1723 	mutex_lock(&iwl_mei_mutex);
1724 
1725 	if (!iwl_mei_is_connected())
1726 		goto out;
1727 
1728 	mei = mei_cldev_get_drvdata(iwl_mei_global_cldev);
1729 
1730 	if (!mei)
1731 		goto out;
1732 
1733 	mei->device_down = !up;
1734 
1735 	if (up || !mei->csme_taking_ownership)
1736 		goto out;
1737 
1738 	iwl_mei_send_sap_msg(mei->cldev,
1739 			     SAP_MSG_NOTIF_CSME_OWNERSHIP_CONFIRMED);
1740 	mei->csme_taking_ownership = false;
1741 out:
1742 	mutex_unlock(&iwl_mei_mutex);
1743 }
1744 EXPORT_SYMBOL_GPL(iwl_mei_device_state);
1745 
1746 int iwl_mei_register(void *priv, const struct iwl_mei_ops *ops)
1747 {
1748 	int ret;
1749 
1750 	/*
1751 	 * We must have a non-NULL priv pointer to not crash when there are
1752 	 * multiple WiFi devices.
1753 	 */
1754 	if (!priv)
1755 		return -EINVAL;
1756 
1757 	mutex_lock(&iwl_mei_mutex);
1758 
1759 	/* do not allow registration if someone else already registered */
1760 	if (iwl_mei_cache.priv || iwl_mei_cache.ops) {
1761 		ret = -EBUSY;
1762 		goto out;
1763 	}
1764 
1765 	iwl_mei_cache.priv = priv;
1766 	iwl_mei_cache.ops = ops;
1767 
1768 	if (iwl_mei_global_cldev) {
1769 		struct iwl_mei *mei =
1770 			mei_cldev_get_drvdata(iwl_mei_global_cldev);
1771 
1772 		/* we have already a SAP connection */
1773 		if (iwl_mei_is_connected()) {
1774 			if (mei->amt_enabled)
1775 				iwl_mei_send_sap_msg(mei->cldev,
1776 						     SAP_MSG_NOTIF_WIFIDR_UP);
1777 			ops->rfkill(priv, mei->link_prot_state, false);
1778 		}
1779 	}
1780 	ret = 0;
1781 
1782 out:
1783 	mutex_unlock(&iwl_mei_mutex);
1784 	return ret;
1785 }
1786 EXPORT_SYMBOL_GPL(iwl_mei_register);
1787 
1788 void iwl_mei_start_unregister(void)
1789 {
1790 	mutex_lock(&iwl_mei_mutex);
1791 
1792 	/* At this point, the wifi driver should have removed the netdev */
1793 	if (rcu_access_pointer(iwl_mei_cache.netdev))
1794 		pr_err("Still had a netdev pointer set upon unregister\n");
1795 
1796 	kfree(iwl_mei_cache.conn_info);
1797 	iwl_mei_cache.conn_info = NULL;
1798 	kfree(iwl_mei_cache.power_limit);
1799 	iwl_mei_cache.power_limit = NULL;
1800 	iwl_mei_cache.ops = NULL;
1801 	/* leave iwl_mei_cache.priv non-NULL to prevent any new registration */
1802 
1803 	mutex_unlock(&iwl_mei_mutex);
1804 }
1805 EXPORT_SYMBOL_GPL(iwl_mei_start_unregister);
1806 
1807 void iwl_mei_unregister_complete(void)
1808 {
1809 	mutex_lock(&iwl_mei_mutex);
1810 
1811 	iwl_mei_cache.priv = NULL;
1812 
1813 	if (iwl_mei_global_cldev) {
1814 		struct iwl_mei *mei =
1815 			mei_cldev_get_drvdata(iwl_mei_global_cldev);
1816 
1817 		iwl_mei_send_sap_msg(mei->cldev, SAP_MSG_NOTIF_WIFIDR_DOWN);
1818 		mei->got_ownership = false;
1819 	}
1820 
1821 	mutex_unlock(&iwl_mei_mutex);
1822 }
1823 EXPORT_SYMBOL_GPL(iwl_mei_unregister_complete);
1824 
1825 #if IS_ENABLED(CONFIG_DEBUG_FS)
1826 
1827 static ssize_t
1828 iwl_mei_dbgfs_send_start_message_write(struct file *file,
1829 				       const char __user *user_buf,
1830 				       size_t count, loff_t *ppos)
1831 {
1832 	int ret;
1833 
1834 	mutex_lock(&iwl_mei_mutex);
1835 
1836 	if (!iwl_mei_global_cldev) {
1837 		ret = -ENODEV;
1838 		goto out;
1839 	}
1840 
1841 	ret = iwl_mei_send_start(iwl_mei_global_cldev);
1842 
1843 out:
1844 	mutex_unlock(&iwl_mei_mutex);
1845 	return ret ?: count;
1846 }
1847 
1848 static const struct file_operations iwl_mei_dbgfs_send_start_message_ops = {
1849 	.write = iwl_mei_dbgfs_send_start_message_write,
1850 	.open = simple_open,
1851 	.llseek = default_llseek,
1852 };
1853 
1854 static ssize_t iwl_mei_dbgfs_req_ownership_write(struct file *file,
1855 						 const char __user *user_buf,
1856 						 size_t count, loff_t *ppos)
1857 {
1858 	iwl_mei_get_ownership();
1859 
1860 	return count;
1861 }
1862 
1863 static const struct file_operations iwl_mei_dbgfs_req_ownership_ops = {
1864 	.write = iwl_mei_dbgfs_req_ownership_write,
1865 	.open = simple_open,
1866 	.llseek = default_llseek,
1867 };
1868 
1869 static void iwl_mei_dbgfs_register(struct iwl_mei *mei)
1870 {
1871 	mei->dbgfs_dir = debugfs_create_dir(KBUILD_MODNAME, NULL);
1872 
1873 	if (!mei->dbgfs_dir)
1874 		return;
1875 
1876 	debugfs_create_ulong("status", S_IRUSR,
1877 			     mei->dbgfs_dir, &iwl_mei_status);
1878 	debugfs_create_file("send_start_message", S_IWUSR, mei->dbgfs_dir,
1879 			    mei, &iwl_mei_dbgfs_send_start_message_ops);
1880 	debugfs_create_file("req_ownership", S_IWUSR, mei->dbgfs_dir,
1881 			    mei, &iwl_mei_dbgfs_req_ownership_ops);
1882 }
1883 
1884 static void iwl_mei_dbgfs_unregister(struct iwl_mei *mei)
1885 {
1886 	debugfs_remove_recursive(mei->dbgfs_dir);
1887 	mei->dbgfs_dir = NULL;
1888 }
1889 
1890 #else
1891 
1892 static void iwl_mei_dbgfs_register(struct iwl_mei *mei) {}
1893 static void iwl_mei_dbgfs_unregister(struct iwl_mei *mei) {}
1894 
1895 #endif /* CONFIG_DEBUG_FS */
1896 
1897 #define ALLOC_SHARED_MEM_RETRY_MAX_NUM	3
1898 
1899 /*
1900  * iwl_mei_probe - the probe function called by the mei bus enumeration
1901  *
1902  * This allocates the data needed by iwlmei and sets a pointer to this data
1903  * into the mei_cl_device's drvdata.
1904  * It starts the SAP protocol by sending the SAP_ME_MSG_START without
1905  * waiting for the answer. The answer will be caught later by the Rx callback.
1906  */
1907 static int iwl_mei_probe(struct mei_cl_device *cldev,
1908 			 const struct mei_cl_device_id *id)
1909 {
1910 	int alloc_retry = ALLOC_SHARED_MEM_RETRY_MAX_NUM;
1911 	struct iwl_mei *mei;
1912 	int ret;
1913 
1914 	mei = devm_kzalloc(&cldev->dev, sizeof(*mei), GFP_KERNEL);
1915 	if (!mei)
1916 		return -ENOMEM;
1917 
1918 	init_waitqueue_head(&mei->get_nvm_wq);
1919 	INIT_WORK(&mei->send_csa_msg_wk, iwl_mei_send_csa_msg_wk);
1920 	INIT_DELAYED_WORK(&mei->csa_throttle_end_wk,
1921 			  iwl_mei_csa_throttle_end_wk);
1922 	init_waitqueue_head(&mei->get_ownership_wq);
1923 	init_waitqueue_head(&mei->pldr_wq);
1924 	spin_lock_init(&mei->data_q_lock);
1925 	INIT_WORK(&mei->netdev_work, iwl_mei_netdev_work);
1926 
1927 	mei_cldev_set_drvdata(cldev, mei);
1928 	mei->cldev = cldev;
1929 	mei->device_down = true;
1930 
1931 	do {
1932 		ret = iwl_mei_alloc_shared_mem(cldev);
1933 		if (!ret)
1934 			break;
1935 		/*
1936 		 * The CSME firmware needs to boot the internal WLAN client.
1937 		 * This can take time in certain configurations (usually
1938 		 * upon resume and when the whole CSME firmware is shut down
1939 		 * during suspend).
1940 		 *
1941 		 * Wait a bit before retrying and hope we'll succeed next time.
1942 		 */
1943 
1944 		dev_dbg(&cldev->dev,
1945 			"Couldn't allocate the shared memory: %d, attempt %d / %d\n",
1946 			ret, alloc_retry, ALLOC_SHARED_MEM_RETRY_MAX_NUM);
1947 		msleep(100);
1948 		alloc_retry--;
1949 	} while (alloc_retry);
1950 
1951 	if (ret) {
1952 		dev_err(&cldev->dev, "Couldn't allocate the shared memory: %d\n",
1953 			ret);
1954 		goto free;
1955 	}
1956 
1957 	iwl_mei_init_shared_mem(mei);
1958 
1959 	ret = iwl_mei_enable(cldev);
1960 	if (ret)
1961 		goto free_shared_mem;
1962 
1963 	iwl_mei_dbgfs_register(mei);
1964 
1965 	/*
1966 	 * We now have a Rx function in place, start the SAP procotol
1967 	 * we expect to get the SAP_ME_MSG_START_OK response later on.
1968 	 */
1969 	mutex_lock(&iwl_mei_mutex);
1970 	ret = iwl_mei_send_start(cldev);
1971 	mutex_unlock(&iwl_mei_mutex);
1972 	if (ret)
1973 		goto debugfs_unregister;
1974 
1975 	/* must be last */
1976 	iwl_mei_global_cldev = cldev;
1977 
1978 	return 0;
1979 
1980 debugfs_unregister:
1981 	iwl_mei_dbgfs_unregister(mei);
1982 	mei_cldev_disable(cldev);
1983 free_shared_mem:
1984 	iwl_mei_free_shared_mem(cldev);
1985 free:
1986 	mei_cldev_set_drvdata(cldev, NULL);
1987 	devm_kfree(&cldev->dev, mei);
1988 
1989 	return ret;
1990 }
1991 
1992 #define SEND_SAP_MAX_WAIT_ITERATION 10
1993 #define IWLMEI_DEVICE_DOWN_WAIT_ITERATION 50
1994 
1995 static void iwl_mei_remove(struct mei_cl_device *cldev)
1996 {
1997 	struct iwl_mei *mei = mei_cldev_get_drvdata(cldev);
1998 	int i;
1999 
2000 	/*
2001 	 * We are being removed while the bus is active, it means we are
2002 	 * going to suspend/ shutdown, so the NIC will disappear.
2003 	 */
2004 	if (mei_cldev_enabled(cldev) && iwl_mei_cache.ops) {
2005 		unsigned int iter = IWLMEI_DEVICE_DOWN_WAIT_ITERATION;
2006 		bool down = false;
2007 
2008 		/*
2009 		 * In case of suspend, wait for the mac to stop and don't remove
2010 		 * the interface. This will allow the interface to come back
2011 		 * on resume.
2012 		 */
2013 		while (!down && iter--) {
2014 			mdelay(1);
2015 
2016 			mutex_lock(&iwl_mei_mutex);
2017 			down = mei->device_down;
2018 			mutex_unlock(&iwl_mei_mutex);
2019 		}
2020 
2021 		if (!down)
2022 			iwl_mei_cache.ops->nic_stolen(iwl_mei_cache.priv);
2023 	}
2024 
2025 	if (rcu_access_pointer(iwl_mei_cache.netdev)) {
2026 		struct net_device *dev;
2027 
2028 		/*
2029 		 * First take rtnl and only then the mutex to avoid an ABBA
2030 		 * with iwl_mei_set_netdev()
2031 		 */
2032 		rtnl_lock();
2033 		mutex_lock(&iwl_mei_mutex);
2034 
2035 		/*
2036 		 * If we are suspending and the wifi driver hasn't removed it's netdev
2037 		 * yet, do it now. In any case, don't change the cache.netdev pointer.
2038 		 */
2039 		dev = rcu_dereference_protected(iwl_mei_cache.netdev,
2040 						lockdep_is_held(&iwl_mei_mutex));
2041 
2042 		netdev_rx_handler_unregister(dev);
2043 		mutex_unlock(&iwl_mei_mutex);
2044 		rtnl_unlock();
2045 	}
2046 
2047 	mutex_lock(&iwl_mei_mutex);
2048 
2049 	if (mei->amt_enabled) {
2050 		/*
2051 		 * Tell CSME that we are going down so that it won't access the
2052 		 * memory anymore, make sure this message goes through immediately.
2053 		 */
2054 		mei->csa_throttled = false;
2055 		iwl_mei_send_sap_msg(mei->cldev,
2056 				     SAP_MSG_NOTIF_HOST_GOES_DOWN);
2057 
2058 		for (i = 0; i < SEND_SAP_MAX_WAIT_ITERATION; i++) {
2059 			if (!iwl_mei_host_to_me_data_pending(mei))
2060 				break;
2061 
2062 			msleep(20);
2063 		}
2064 
2065 		/*
2066 		 * If we couldn't make sure that CSME saw the HOST_GOES_DOWN
2067 		 * message, it means that it will probably keep reading memory
2068 		 * that we are going to unmap and free, expect IOMMU error
2069 		 * messages.
2070 		 */
2071 		if (i == SEND_SAP_MAX_WAIT_ITERATION)
2072 			dev_err(&mei->cldev->dev,
2073 				"Couldn't get ACK from CSME on HOST_GOES_DOWN message\n");
2074 	}
2075 
2076 	mutex_unlock(&iwl_mei_mutex);
2077 
2078 	/*
2079 	 * This looks strange, but this lock is taken here to make sure that
2080 	 * iwl_mei_add_data_to_ring called from the Tx path sees that we
2081 	 * clear the IWL_MEI_STATUS_SAP_CONNECTED bit.
2082 	 * Rx isn't a problem because the rx_handler can't be called after
2083 	 * having been unregistered.
2084 	 */
2085 	spin_lock_bh(&mei->data_q_lock);
2086 	clear_bit(IWL_MEI_STATUS_SAP_CONNECTED, &iwl_mei_status);
2087 	spin_unlock_bh(&mei->data_q_lock);
2088 
2089 	if (iwl_mei_cache.ops)
2090 		iwl_mei_cache.ops->rfkill(iwl_mei_cache.priv, false);
2091 
2092 	/*
2093 	 * mei_cldev_disable will return only after all the MEI Rx is done.
2094 	 * It must be called when iwl_mei_mutex is *not* held, since it waits
2095 	 * for our Rx handler to complete.
2096 	 * After it returns, no new Rx will start.
2097 	 */
2098 	mei_cldev_disable(cldev);
2099 
2100 	/*
2101 	 * Since the netdev was already removed and the netdev's removal
2102 	 * includes a call to synchronize_net() so that we know there won't be
2103 	 * any new Rx that will trigger the following workers.
2104 	 */
2105 	cancel_work_sync(&mei->send_csa_msg_wk);
2106 	cancel_delayed_work_sync(&mei->csa_throttle_end_wk);
2107 	cancel_work_sync(&mei->netdev_work);
2108 
2109 	/*
2110 	 * If someone waits for the ownership, let him know that we are going
2111 	 * down and that we are not connected anymore. He'll be able to take
2112 	 * the device.
2113 	 */
2114 	wake_up_all(&mei->get_ownership_wq);
2115 	wake_up_all(&mei->pldr_wq);
2116 
2117 	mutex_lock(&iwl_mei_mutex);
2118 
2119 	iwl_mei_global_cldev = NULL;
2120 
2121 	wake_up_all(&mei->get_nvm_wq);
2122 
2123 	iwl_mei_free_shared_mem(cldev);
2124 
2125 	iwl_mei_dbgfs_unregister(mei);
2126 
2127 	mei_cldev_set_drvdata(cldev, NULL);
2128 
2129 	kfree(mei->nvm);
2130 
2131 	kfree(rcu_access_pointer(mei->filters));
2132 
2133 	devm_kfree(&cldev->dev, mei);
2134 
2135 	mutex_unlock(&iwl_mei_mutex);
2136 }
2137 
2138 static const struct mei_cl_device_id iwl_mei_tbl[] = {
2139 	{
2140 		.name = KBUILD_MODNAME,
2141 		.uuid = MEI_WLAN_UUID,
2142 		.version = MEI_CL_VERSION_ANY,
2143 	},
2144 
2145 	/* required last entry */
2146 	{ }
2147 };
2148 
2149 /*
2150  * Do not export the device table because this module is loaded by
2151  * iwlwifi's dependency.
2152  */
2153 
2154 static struct mei_cl_driver iwl_mei_cl_driver = {
2155 	.id_table = iwl_mei_tbl,
2156 	.name = KBUILD_MODNAME,
2157 	.probe = iwl_mei_probe,
2158 	.remove = iwl_mei_remove,
2159 };
2160 
2161 module_mei_cl_driver(iwl_mei_cl_driver);
2162