xref: /openbmc/linux/drivers/net/wireless/marvell/mwifiex/pcie.c (revision f7af616c632ee2ac3af0876fe33bf9e0232e665a)
1 /*
2  * NXP Wireless LAN device driver: PCIE specific handling
3  *
4  * Copyright 2011-2020 NXP
5  *
6  * This software file (the "File") is distributed by NXP
7  * under the terms of the GNU General Public License Version 2, June 1991
8  * (the "License").  You may use, redistribute and/or modify this File in
9  * accordance with the terms and conditions of the License, a copy of which
10  * is available by writing to the Free Software Foundation, Inc.,
11  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA or on the
12  * worldwide web at http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt.
13  *
14  * THE FILE IS DISTRIBUTED AS-IS, WITHOUT WARRANTY OF ANY KIND, AND THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE
16  * ARE EXPRESSLY DISCLAIMED.  The License provides additional details about
17  * this warranty disclaimer.
18  */
19 
20 #include <linux/firmware.h>
21 
22 #include "decl.h"
23 #include "ioctl.h"
24 #include "util.h"
25 #include "fw.h"
26 #include "main.h"
27 #include "wmm.h"
28 #include "11n.h"
29 #include "pcie.h"
30 
31 #define PCIE_VERSION	"1.0"
32 #define DRV_NAME        "Marvell mwifiex PCIe"
33 
34 static struct mwifiex_if_ops pcie_ops;
35 
36 static const struct mwifiex_pcie_card_reg mwifiex_reg_8766 = {
37 	.cmd_addr_lo = PCIE_SCRATCH_0_REG,
38 	.cmd_addr_hi = PCIE_SCRATCH_1_REG,
39 	.cmd_size = PCIE_SCRATCH_2_REG,
40 	.fw_status = PCIE_SCRATCH_3_REG,
41 	.cmdrsp_addr_lo = PCIE_SCRATCH_4_REG,
42 	.cmdrsp_addr_hi = PCIE_SCRATCH_5_REG,
43 	.tx_rdptr = PCIE_SCRATCH_6_REG,
44 	.tx_wrptr = PCIE_SCRATCH_7_REG,
45 	.rx_rdptr = PCIE_SCRATCH_8_REG,
46 	.rx_wrptr = PCIE_SCRATCH_9_REG,
47 	.evt_rdptr = PCIE_SCRATCH_10_REG,
48 	.evt_wrptr = PCIE_SCRATCH_11_REG,
49 	.drv_rdy = PCIE_SCRATCH_12_REG,
50 	.tx_start_ptr = 0,
51 	.tx_mask = MWIFIEX_TXBD_MASK,
52 	.tx_wrap_mask = 0,
53 	.rx_mask = MWIFIEX_RXBD_MASK,
54 	.rx_wrap_mask = 0,
55 	.tx_rollover_ind = MWIFIEX_BD_FLAG_ROLLOVER_IND,
56 	.rx_rollover_ind = MWIFIEX_BD_FLAG_ROLLOVER_IND,
57 	.evt_rollover_ind = MWIFIEX_BD_FLAG_ROLLOVER_IND,
58 	.ring_flag_sop = 0,
59 	.ring_flag_eop = 0,
60 	.ring_flag_xs_sop = 0,
61 	.ring_flag_xs_eop = 0,
62 	.ring_tx_start_ptr = 0,
63 	.pfu_enabled = 0,
64 	.sleep_cookie = 1,
65 	.msix_support = 0,
66 };
67 
68 static const struct mwifiex_pcie_card_reg mwifiex_reg_8897 = {
69 	.cmd_addr_lo = PCIE_SCRATCH_0_REG,
70 	.cmd_addr_hi = PCIE_SCRATCH_1_REG,
71 	.cmd_size = PCIE_SCRATCH_2_REG,
72 	.fw_status = PCIE_SCRATCH_3_REG,
73 	.cmdrsp_addr_lo = PCIE_SCRATCH_4_REG,
74 	.cmdrsp_addr_hi = PCIE_SCRATCH_5_REG,
75 	.tx_rdptr = PCIE_RD_DATA_PTR_Q0_Q1,
76 	.tx_wrptr = PCIE_WR_DATA_PTR_Q0_Q1,
77 	.rx_rdptr = PCIE_WR_DATA_PTR_Q0_Q1,
78 	.rx_wrptr = PCIE_RD_DATA_PTR_Q0_Q1,
79 	.evt_rdptr = PCIE_SCRATCH_10_REG,
80 	.evt_wrptr = PCIE_SCRATCH_11_REG,
81 	.drv_rdy = PCIE_SCRATCH_12_REG,
82 	.tx_start_ptr = 16,
83 	.tx_mask = 0x03FF0000,
84 	.tx_wrap_mask = 0x07FF0000,
85 	.rx_mask = 0x000003FF,
86 	.rx_wrap_mask = 0x000007FF,
87 	.tx_rollover_ind = MWIFIEX_BD_FLAG_TX_ROLLOVER_IND,
88 	.rx_rollover_ind = MWIFIEX_BD_FLAG_RX_ROLLOVER_IND,
89 	.evt_rollover_ind = MWIFIEX_BD_FLAG_EVT_ROLLOVER_IND,
90 	.ring_flag_sop = MWIFIEX_BD_FLAG_SOP,
91 	.ring_flag_eop = MWIFIEX_BD_FLAG_EOP,
92 	.ring_flag_xs_sop = MWIFIEX_BD_FLAG_XS_SOP,
93 	.ring_flag_xs_eop = MWIFIEX_BD_FLAG_XS_EOP,
94 	.ring_tx_start_ptr = MWIFIEX_BD_FLAG_TX_START_PTR,
95 	.pfu_enabled = 1,
96 	.sleep_cookie = 0,
97 	.fw_dump_ctrl = PCIE_SCRATCH_13_REG,
98 	.fw_dump_start = PCIE_SCRATCH_14_REG,
99 	.fw_dump_end = 0xcff,
100 	.fw_dump_host_ready = 0xee,
101 	.fw_dump_read_done = 0xfe,
102 	.msix_support = 0,
103 };
104 
105 static const struct mwifiex_pcie_card_reg mwifiex_reg_8997 = {
106 	.cmd_addr_lo = PCIE_SCRATCH_0_REG,
107 	.cmd_addr_hi = PCIE_SCRATCH_1_REG,
108 	.cmd_size = PCIE_SCRATCH_2_REG,
109 	.fw_status = PCIE_SCRATCH_3_REG,
110 	.cmdrsp_addr_lo = PCIE_SCRATCH_4_REG,
111 	.cmdrsp_addr_hi = PCIE_SCRATCH_5_REG,
112 	.tx_rdptr = 0xC1A4,
113 	.tx_wrptr = 0xC174,
114 	.rx_rdptr = 0xC174,
115 	.rx_wrptr = 0xC1A4,
116 	.evt_rdptr = PCIE_SCRATCH_10_REG,
117 	.evt_wrptr = PCIE_SCRATCH_11_REG,
118 	.drv_rdy = PCIE_SCRATCH_12_REG,
119 	.tx_start_ptr = 16,
120 	.tx_mask = 0x0FFF0000,
121 	.tx_wrap_mask = 0x1FFF0000,
122 	.rx_mask = 0x00000FFF,
123 	.rx_wrap_mask = 0x00001FFF,
124 	.tx_rollover_ind = BIT(28),
125 	.rx_rollover_ind = BIT(12),
126 	.evt_rollover_ind = MWIFIEX_BD_FLAG_EVT_ROLLOVER_IND,
127 	.ring_flag_sop = MWIFIEX_BD_FLAG_SOP,
128 	.ring_flag_eop = MWIFIEX_BD_FLAG_EOP,
129 	.ring_flag_xs_sop = MWIFIEX_BD_FLAG_XS_SOP,
130 	.ring_flag_xs_eop = MWIFIEX_BD_FLAG_XS_EOP,
131 	.ring_tx_start_ptr = MWIFIEX_BD_FLAG_TX_START_PTR,
132 	.pfu_enabled = 1,
133 	.sleep_cookie = 0,
134 	.fw_dump_ctrl = PCIE_SCRATCH_13_REG,
135 	.fw_dump_start = PCIE_SCRATCH_14_REG,
136 	.fw_dump_end = 0xcff,
137 	.fw_dump_host_ready = 0xcc,
138 	.fw_dump_read_done = 0xdd,
139 	.msix_support = 0,
140 };
141 
142 static struct memory_type_mapping mem_type_mapping_tbl_w8897[] = {
143 	{"ITCM", NULL, 0, 0xF0},
144 	{"DTCM", NULL, 0, 0xF1},
145 	{"SQRAM", NULL, 0, 0xF2},
146 	{"IRAM", NULL, 0, 0xF3},
147 	{"APU", NULL, 0, 0xF4},
148 	{"CIU", NULL, 0, 0xF5},
149 	{"ICU", NULL, 0, 0xF6},
150 	{"MAC", NULL, 0, 0xF7},
151 };
152 
153 static struct memory_type_mapping mem_type_mapping_tbl_w8997[] = {
154 	{"DUMP", NULL, 0, 0xDD},
155 };
156 
157 static const struct mwifiex_pcie_device mwifiex_pcie8766 = {
158 	.reg            = &mwifiex_reg_8766,
159 	.blksz_fw_dl = MWIFIEX_PCIE_BLOCK_SIZE_FW_DNLD,
160 	.tx_buf_size = MWIFIEX_TX_DATA_BUF_SIZE_2K,
161 	.can_dump_fw = false,
162 	.can_ext_scan = true,
163 };
164 
165 static const struct mwifiex_pcie_device mwifiex_pcie8897 = {
166 	.reg            = &mwifiex_reg_8897,
167 	.blksz_fw_dl = MWIFIEX_PCIE_BLOCK_SIZE_FW_DNLD,
168 	.tx_buf_size = MWIFIEX_TX_DATA_BUF_SIZE_4K,
169 	.can_dump_fw = true,
170 	.mem_type_mapping_tbl = mem_type_mapping_tbl_w8897,
171 	.num_mem_types = ARRAY_SIZE(mem_type_mapping_tbl_w8897),
172 	.can_ext_scan = true,
173 };
174 
175 static const struct mwifiex_pcie_device mwifiex_pcie8997 = {
176 	.reg            = &mwifiex_reg_8997,
177 	.blksz_fw_dl = MWIFIEX_PCIE_BLOCK_SIZE_FW_DNLD,
178 	.tx_buf_size = MWIFIEX_TX_DATA_BUF_SIZE_4K,
179 	.can_dump_fw = true,
180 	.mem_type_mapping_tbl = mem_type_mapping_tbl_w8997,
181 	.num_mem_types = ARRAY_SIZE(mem_type_mapping_tbl_w8997),
182 	.can_ext_scan = true,
183 };
184 
185 static const struct of_device_id mwifiex_pcie_of_match_table[] = {
186 	{ .compatible = "pci11ab,2b42" },
187 	{ .compatible = "pci1b4b,2b42" },
188 	{ }
189 };
190 
191 static int mwifiex_pcie_probe_of(struct device *dev)
192 {
193 	if (!of_match_node(mwifiex_pcie_of_match_table, dev->of_node)) {
194 		dev_err(dev, "required compatible string missing\n");
195 		return -EINVAL;
196 	}
197 
198 	return 0;
199 }
200 
201 static void mwifiex_pcie_work(struct work_struct *work);
202 
203 static int
204 mwifiex_map_pci_memory(struct mwifiex_adapter *adapter, struct sk_buff *skb,
205 		       size_t size, int flags)
206 {
207 	struct pcie_service_card *card = adapter->card;
208 	struct mwifiex_dma_mapping mapping;
209 
210 	mapping.addr = dma_map_single(&card->dev->dev, skb->data, size, flags);
211 	if (dma_mapping_error(&card->dev->dev, mapping.addr)) {
212 		mwifiex_dbg(adapter, ERROR, "failed to map pci memory!\n");
213 		return -1;
214 	}
215 	mapping.len = size;
216 	mwifiex_store_mapping(skb, &mapping);
217 	return 0;
218 }
219 
220 static void mwifiex_unmap_pci_memory(struct mwifiex_adapter *adapter,
221 				     struct sk_buff *skb, int flags)
222 {
223 	struct pcie_service_card *card = adapter->card;
224 	struct mwifiex_dma_mapping mapping;
225 
226 	mwifiex_get_mapping(skb, &mapping);
227 	dma_unmap_single(&card->dev->dev, mapping.addr, mapping.len, flags);
228 }
229 
230 /*
231  * This function writes data into PCIE card register.
232  */
233 static int mwifiex_write_reg(struct mwifiex_adapter *adapter, int reg, u32 data)
234 {
235 	struct pcie_service_card *card = adapter->card;
236 
237 	iowrite32(data, card->pci_mmap1 + reg);
238 
239 	return 0;
240 }
241 
242 /* This function reads data from PCIE card register.
243  */
244 static int mwifiex_read_reg(struct mwifiex_adapter *adapter, int reg, u32 *data)
245 {
246 	struct pcie_service_card *card = adapter->card;
247 
248 	*data = ioread32(card->pci_mmap1 + reg);
249 	if (*data == 0xffffffff)
250 		return 0xffffffff;
251 
252 	return 0;
253 }
254 
255 /* This function reads u8 data from PCIE card register. */
256 static int mwifiex_read_reg_byte(struct mwifiex_adapter *adapter,
257 				 int reg, u8 *data)
258 {
259 	struct pcie_service_card *card = adapter->card;
260 
261 	*data = ioread8(card->pci_mmap1 + reg);
262 
263 	return 0;
264 }
265 
266 /*
267  * This function reads sleep cookie and checks if FW is ready
268  */
269 static bool mwifiex_pcie_ok_to_access_hw(struct mwifiex_adapter *adapter)
270 {
271 	u32 cookie_value;
272 	struct pcie_service_card *card = adapter->card;
273 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
274 
275 	if (!reg->sleep_cookie)
276 		return true;
277 
278 	if (card->sleep_cookie_vbase) {
279 		cookie_value = get_unaligned_le32(card->sleep_cookie_vbase);
280 		mwifiex_dbg(adapter, INFO,
281 			    "info: ACCESS_HW: sleep cookie=0x%x\n",
282 			    cookie_value);
283 		if (cookie_value == FW_AWAKE_COOKIE)
284 			return true;
285 	}
286 
287 	return false;
288 }
289 
290 #ifdef CONFIG_PM_SLEEP
291 /*
292  * Kernel needs to suspend all functions separately. Therefore all
293  * registered functions must have drivers with suspend and resume
294  * methods. Failing that the kernel simply removes the whole card.
295  *
296  * If already not suspended, this function allocates and sends a host
297  * sleep activate request to the firmware and turns off the traffic.
298  */
299 static int mwifiex_pcie_suspend(struct device *dev)
300 {
301 	struct mwifiex_adapter *adapter;
302 	struct pcie_service_card *card = dev_get_drvdata(dev);
303 
304 
305 	/* Might still be loading firmware */
306 	wait_for_completion(&card->fw_done);
307 
308 	adapter = card->adapter;
309 	if (!adapter) {
310 		dev_err(dev, "adapter is not valid\n");
311 		return 0;
312 	}
313 
314 	mwifiex_enable_wake(adapter);
315 
316 	/* Enable the Host Sleep */
317 	if (!mwifiex_enable_hs(adapter)) {
318 		mwifiex_dbg(adapter, ERROR,
319 			    "cmd: failed to suspend\n");
320 		clear_bit(MWIFIEX_IS_HS_ENABLING, &adapter->work_flags);
321 		mwifiex_disable_wake(adapter);
322 		return -EFAULT;
323 	}
324 
325 	flush_workqueue(adapter->workqueue);
326 
327 	/* Indicate device suspended */
328 	set_bit(MWIFIEX_IS_SUSPENDED, &adapter->work_flags);
329 	clear_bit(MWIFIEX_IS_HS_ENABLING, &adapter->work_flags);
330 
331 	return 0;
332 }
333 
334 /*
335  * Kernel needs to suspend all functions separately. Therefore all
336  * registered functions must have drivers with suspend and resume
337  * methods. Failing that the kernel simply removes the whole card.
338  *
339  * If already not resumed, this function turns on the traffic and
340  * sends a host sleep cancel request to the firmware.
341  */
342 static int mwifiex_pcie_resume(struct device *dev)
343 {
344 	struct mwifiex_adapter *adapter;
345 	struct pcie_service_card *card = dev_get_drvdata(dev);
346 
347 
348 	if (!card->adapter) {
349 		dev_err(dev, "adapter structure is not valid\n");
350 		return 0;
351 	}
352 
353 	adapter = card->adapter;
354 
355 	if (!test_bit(MWIFIEX_IS_SUSPENDED, &adapter->work_flags)) {
356 		mwifiex_dbg(adapter, WARN,
357 			    "Device already resumed\n");
358 		return 0;
359 	}
360 
361 	clear_bit(MWIFIEX_IS_SUSPENDED, &adapter->work_flags);
362 
363 	mwifiex_cancel_hs(mwifiex_get_priv(adapter, MWIFIEX_BSS_ROLE_STA),
364 			  MWIFIEX_ASYNC_CMD);
365 	mwifiex_disable_wake(adapter);
366 
367 	return 0;
368 }
369 #endif
370 
371 /*
372  * This function probes an mwifiex device and registers it. It allocates
373  * the card structure, enables PCIE function number and initiates the
374  * device registration and initialization procedure by adding a logical
375  * interface.
376  */
377 static int mwifiex_pcie_probe(struct pci_dev *pdev,
378 					const struct pci_device_id *ent)
379 {
380 	struct pcie_service_card *card;
381 	int ret;
382 
383 	pr_debug("info: vendor=0x%4.04X device=0x%4.04X rev=%d\n",
384 		 pdev->vendor, pdev->device, pdev->revision);
385 
386 	card = devm_kzalloc(&pdev->dev, sizeof(*card), GFP_KERNEL);
387 	if (!card)
388 		return -ENOMEM;
389 
390 	init_completion(&card->fw_done);
391 
392 	card->dev = pdev;
393 
394 	if (ent->driver_data) {
395 		struct mwifiex_pcie_device *data = (void *)ent->driver_data;
396 		card->pcie.reg = data->reg;
397 		card->pcie.blksz_fw_dl = data->blksz_fw_dl;
398 		card->pcie.tx_buf_size = data->tx_buf_size;
399 		card->pcie.can_dump_fw = data->can_dump_fw;
400 		card->pcie.mem_type_mapping_tbl = data->mem_type_mapping_tbl;
401 		card->pcie.num_mem_types = data->num_mem_types;
402 		card->pcie.can_ext_scan = data->can_ext_scan;
403 		INIT_WORK(&card->work, mwifiex_pcie_work);
404 	}
405 
406 	/* device tree node parsing and platform specific configuration*/
407 	if (pdev->dev.of_node) {
408 		ret = mwifiex_pcie_probe_of(&pdev->dev);
409 		if (ret)
410 			return ret;
411 	}
412 
413 	if (mwifiex_add_card(card, &card->fw_done, &pcie_ops,
414 			     MWIFIEX_PCIE, &pdev->dev)) {
415 		pr_err("%s failed\n", __func__);
416 		return -1;
417 	}
418 
419 	return 0;
420 }
421 
422 /*
423  * This function removes the interface and frees up the card structure.
424  */
425 static void mwifiex_pcie_remove(struct pci_dev *pdev)
426 {
427 	struct pcie_service_card *card;
428 	struct mwifiex_adapter *adapter;
429 	struct mwifiex_private *priv;
430 	const struct mwifiex_pcie_card_reg *reg;
431 	u32 fw_status;
432 
433 	card = pci_get_drvdata(pdev);
434 
435 	wait_for_completion(&card->fw_done);
436 
437 	adapter = card->adapter;
438 	if (!adapter || !adapter->priv_num)
439 		return;
440 
441 	reg = card->pcie.reg;
442 	if (reg)
443 		mwifiex_read_reg(adapter, reg->fw_status, &fw_status);
444 	else
445 		fw_status = -1;
446 
447 	if (fw_status == FIRMWARE_READY_PCIE && !adapter->mfg_mode) {
448 		mwifiex_deauthenticate_all(adapter);
449 
450 		priv = mwifiex_get_priv(adapter, MWIFIEX_BSS_ROLE_ANY);
451 
452 		mwifiex_disable_auto_ds(priv);
453 
454 		mwifiex_init_shutdown_fw(priv, MWIFIEX_FUNC_SHUTDOWN);
455 	}
456 
457 	mwifiex_remove_card(adapter);
458 }
459 
460 static void mwifiex_pcie_shutdown(struct pci_dev *pdev)
461 {
462 	mwifiex_pcie_remove(pdev);
463 
464 	return;
465 }
466 
467 static void mwifiex_pcie_coredump(struct device *dev)
468 {
469 	struct pci_dev *pdev;
470 	struct pcie_service_card *card;
471 
472 	pdev = container_of(dev, struct pci_dev, dev);
473 	card = pci_get_drvdata(pdev);
474 
475 	if (!test_and_set_bit(MWIFIEX_IFACE_WORK_DEVICE_DUMP,
476 			      &card->work_flags))
477 		schedule_work(&card->work);
478 }
479 
480 static const struct pci_device_id mwifiex_ids[] = {
481 	{
482 		PCIE_VENDOR_ID_MARVELL, PCIE_DEVICE_ID_MARVELL_88W8766P,
483 		PCI_ANY_ID, PCI_ANY_ID, 0, 0,
484 		.driver_data = (unsigned long)&mwifiex_pcie8766,
485 	},
486 	{
487 		PCIE_VENDOR_ID_MARVELL, PCIE_DEVICE_ID_MARVELL_88W8897,
488 		PCI_ANY_ID, PCI_ANY_ID, 0, 0,
489 		.driver_data = (unsigned long)&mwifiex_pcie8897,
490 	},
491 	{
492 		PCIE_VENDOR_ID_MARVELL, PCIE_DEVICE_ID_MARVELL_88W8997,
493 		PCI_ANY_ID, PCI_ANY_ID, 0, 0,
494 		.driver_data = (unsigned long)&mwifiex_pcie8997,
495 	},
496 	{
497 		PCIE_VENDOR_ID_V2_MARVELL, PCIE_DEVICE_ID_MARVELL_88W8997,
498 		PCI_ANY_ID, PCI_ANY_ID, 0, 0,
499 		.driver_data = (unsigned long)&mwifiex_pcie8997,
500 	},
501 	{},
502 };
503 
504 MODULE_DEVICE_TABLE(pci, mwifiex_ids);
505 
506 /*
507  * Cleanup all software without cleaning anything related to PCIe and HW.
508  */
509 static void mwifiex_pcie_reset_prepare(struct pci_dev *pdev)
510 {
511 	struct pcie_service_card *card = pci_get_drvdata(pdev);
512 	struct mwifiex_adapter *adapter = card->adapter;
513 
514 	if (!adapter) {
515 		dev_err(&pdev->dev, "%s: adapter structure is not valid\n",
516 			__func__);
517 		return;
518 	}
519 
520 	mwifiex_dbg(adapter, INFO,
521 		    "%s: vendor=0x%4.04x device=0x%4.04x rev=%d Pre-FLR\n",
522 		    __func__, pdev->vendor, pdev->device, pdev->revision);
523 
524 	mwifiex_shutdown_sw(adapter);
525 	clear_bit(MWIFIEX_IFACE_WORK_DEVICE_DUMP, &card->work_flags);
526 	clear_bit(MWIFIEX_IFACE_WORK_CARD_RESET, &card->work_flags);
527 	mwifiex_dbg(adapter, INFO, "%s, successful\n", __func__);
528 
529 	card->pci_reset_ongoing = true;
530 }
531 
532 /*
533  * Kernel stores and restores PCIe function context before and after performing
534  * FLR respectively. Reconfigure the software and firmware including firmware
535  * redownload.
536  */
537 static void mwifiex_pcie_reset_done(struct pci_dev *pdev)
538 {
539 	struct pcie_service_card *card = pci_get_drvdata(pdev);
540 	struct mwifiex_adapter *adapter = card->adapter;
541 	int ret;
542 
543 	if (!adapter) {
544 		dev_err(&pdev->dev, "%s: adapter structure is not valid\n",
545 			__func__);
546 		return;
547 	}
548 
549 	mwifiex_dbg(adapter, INFO,
550 		    "%s: vendor=0x%4.04x device=0x%4.04x rev=%d Post-FLR\n",
551 		    __func__, pdev->vendor, pdev->device, pdev->revision);
552 
553 	ret = mwifiex_reinit_sw(adapter);
554 	if (ret)
555 		dev_err(&pdev->dev, "reinit failed: %d\n", ret);
556 	else
557 		mwifiex_dbg(adapter, INFO, "%s, successful\n", __func__);
558 
559 	card->pci_reset_ongoing = false;
560 }
561 
562 static const struct pci_error_handlers mwifiex_pcie_err_handler = {
563 	.reset_prepare		= mwifiex_pcie_reset_prepare,
564 	.reset_done		= mwifiex_pcie_reset_done,
565 };
566 
567 #ifdef CONFIG_PM_SLEEP
568 /* Power Management Hooks */
569 static SIMPLE_DEV_PM_OPS(mwifiex_pcie_pm_ops, mwifiex_pcie_suspend,
570 				mwifiex_pcie_resume);
571 #endif
572 
573 /* PCI Device Driver */
574 static struct pci_driver mwifiex_pcie = {
575 	.name     = "mwifiex_pcie",
576 	.id_table = mwifiex_ids,
577 	.probe    = mwifiex_pcie_probe,
578 	.remove   = mwifiex_pcie_remove,
579 	.driver   = {
580 		.coredump = mwifiex_pcie_coredump,
581 #ifdef CONFIG_PM_SLEEP
582 		.pm = &mwifiex_pcie_pm_ops,
583 #endif
584 	},
585 	.shutdown = mwifiex_pcie_shutdown,
586 	.err_handler = &mwifiex_pcie_err_handler,
587 };
588 
589 /*
590  * This function adds delay loop to ensure FW is awake before proceeding.
591  */
592 static void mwifiex_pcie_dev_wakeup_delay(struct mwifiex_adapter *adapter)
593 {
594 	int i = 0;
595 
596 	while (mwifiex_pcie_ok_to_access_hw(adapter)) {
597 		i++;
598 		usleep_range(10, 20);
599 		/* 50ms max wait */
600 		if (i == 5000)
601 			break;
602 	}
603 
604 	return;
605 }
606 
607 static void mwifiex_delay_for_sleep_cookie(struct mwifiex_adapter *adapter,
608 					   u32 max_delay_loop_cnt)
609 {
610 	struct pcie_service_card *card = adapter->card;
611 	u8 *buffer;
612 	u32 sleep_cookie, count;
613 	struct sk_buff *cmdrsp = card->cmdrsp_buf;
614 
615 	for (count = 0; count < max_delay_loop_cnt; count++) {
616 		dma_sync_single_for_cpu(&card->dev->dev,
617 					MWIFIEX_SKB_DMA_ADDR(cmdrsp),
618 					sizeof(sleep_cookie), DMA_FROM_DEVICE);
619 		buffer = cmdrsp->data;
620 		sleep_cookie = get_unaligned_le32(buffer);
621 
622 		if (sleep_cookie == MWIFIEX_DEF_SLEEP_COOKIE) {
623 			mwifiex_dbg(adapter, INFO,
624 				    "sleep cookie found at count %d\n", count);
625 			break;
626 		}
627 		dma_sync_single_for_device(&card->dev->dev,
628 					   MWIFIEX_SKB_DMA_ADDR(cmdrsp),
629 					   sizeof(sleep_cookie),
630 					   DMA_FROM_DEVICE);
631 		usleep_range(20, 30);
632 	}
633 
634 	if (count >= max_delay_loop_cnt)
635 		mwifiex_dbg(adapter, INFO,
636 			    "max count reached while accessing sleep cookie\n");
637 }
638 
639 /* This function wakes up the card by reading fw_status register. */
640 static int mwifiex_pm_wakeup_card(struct mwifiex_adapter *adapter)
641 {
642 	struct pcie_service_card *card = adapter->card;
643 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
644 
645 	mwifiex_dbg(adapter, EVENT,
646 		    "event: Wakeup device...\n");
647 
648 	if (reg->sleep_cookie)
649 		mwifiex_pcie_dev_wakeup_delay(adapter);
650 
651 	/* Accessing fw_status register will wakeup device */
652 	if (mwifiex_write_reg(adapter, reg->fw_status, FIRMWARE_READY_PCIE)) {
653 		mwifiex_dbg(adapter, ERROR,
654 			    "Writing fw_status register failed\n");
655 		return -1;
656 	}
657 
658 	if (reg->sleep_cookie) {
659 		mwifiex_pcie_dev_wakeup_delay(adapter);
660 		mwifiex_dbg(adapter, INFO,
661 			    "PCIE wakeup: Setting PS_STATE_AWAKE\n");
662 		adapter->ps_state = PS_STATE_AWAKE;
663 	}
664 
665 	return 0;
666 }
667 
668 /*
669  * This function is called after the card has woken up.
670  *
671  * The card configuration register is reset.
672  */
673 static int mwifiex_pm_wakeup_card_complete(struct mwifiex_adapter *adapter)
674 {
675 	mwifiex_dbg(adapter, CMD,
676 		    "cmd: Wakeup device completed\n");
677 
678 	return 0;
679 }
680 
681 /*
682  * This function disables the host interrupt.
683  *
684  * The host interrupt mask is read, the disable bit is reset and
685  * written back to the card host interrupt mask register.
686  */
687 static int mwifiex_pcie_disable_host_int(struct mwifiex_adapter *adapter)
688 {
689 	if (mwifiex_pcie_ok_to_access_hw(adapter)) {
690 		if (mwifiex_write_reg(adapter, PCIE_HOST_INT_MASK,
691 				      0x00000000)) {
692 			mwifiex_dbg(adapter, ERROR,
693 				    "Disable host interrupt failed\n");
694 			return -1;
695 		}
696 	}
697 
698 	atomic_set(&adapter->tx_hw_pending, 0);
699 	return 0;
700 }
701 
702 static void mwifiex_pcie_disable_host_int_noerr(struct mwifiex_adapter *adapter)
703 {
704 	WARN_ON(mwifiex_pcie_disable_host_int(adapter));
705 }
706 
707 /*
708  * This function enables the host interrupt.
709  *
710  * The host interrupt enable mask is written to the card
711  * host interrupt mask register.
712  */
713 static int mwifiex_pcie_enable_host_int(struct mwifiex_adapter *adapter)
714 {
715 	if (mwifiex_pcie_ok_to_access_hw(adapter)) {
716 		/* Simply write the mask to the register */
717 		if (mwifiex_write_reg(adapter, PCIE_HOST_INT_MASK,
718 				      HOST_INTR_MASK)) {
719 			mwifiex_dbg(adapter, ERROR,
720 				    "Enable host interrupt failed\n");
721 			return -1;
722 		}
723 	}
724 
725 	return 0;
726 }
727 
728 /*
729  * This function initializes TX buffer ring descriptors
730  */
731 static int mwifiex_init_txq_ring(struct mwifiex_adapter *adapter)
732 {
733 	struct pcie_service_card *card = adapter->card;
734 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
735 	struct mwifiex_pcie_buf_desc *desc;
736 	struct mwifiex_pfu_buf_desc *desc2;
737 	int i;
738 
739 	for (i = 0; i < MWIFIEX_MAX_TXRX_BD; i++) {
740 		card->tx_buf_list[i] = NULL;
741 		if (reg->pfu_enabled) {
742 			card->txbd_ring[i] = (void *)card->txbd_ring_vbase +
743 					     (sizeof(*desc2) * i);
744 			desc2 = card->txbd_ring[i];
745 			memset(desc2, 0, sizeof(*desc2));
746 		} else {
747 			card->txbd_ring[i] = (void *)card->txbd_ring_vbase +
748 					     (sizeof(*desc) * i);
749 			desc = card->txbd_ring[i];
750 			memset(desc, 0, sizeof(*desc));
751 		}
752 	}
753 
754 	return 0;
755 }
756 
757 /* This function initializes RX buffer ring descriptors. Each SKB is allocated
758  * here and after mapping PCI memory, its physical address is assigned to
759  * PCIE Rx buffer descriptor's physical address.
760  */
761 static int mwifiex_init_rxq_ring(struct mwifiex_adapter *adapter)
762 {
763 	struct pcie_service_card *card = adapter->card;
764 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
765 	struct sk_buff *skb;
766 	struct mwifiex_pcie_buf_desc *desc;
767 	struct mwifiex_pfu_buf_desc *desc2;
768 	dma_addr_t buf_pa;
769 	int i;
770 
771 	for (i = 0; i < MWIFIEX_MAX_TXRX_BD; i++) {
772 		/* Allocate skb here so that firmware can DMA data from it */
773 		skb = mwifiex_alloc_dma_align_buf(MWIFIEX_RX_DATA_BUF_SIZE,
774 						  GFP_KERNEL);
775 		if (!skb) {
776 			mwifiex_dbg(adapter, ERROR,
777 				    "Unable to allocate skb for RX ring.\n");
778 			kfree(card->rxbd_ring_vbase);
779 			return -ENOMEM;
780 		}
781 
782 		if (mwifiex_map_pci_memory(adapter, skb,
783 					   MWIFIEX_RX_DATA_BUF_SIZE,
784 					   DMA_FROM_DEVICE))
785 			return -1;
786 
787 		buf_pa = MWIFIEX_SKB_DMA_ADDR(skb);
788 
789 		mwifiex_dbg(adapter, INFO,
790 			    "info: RX ring: skb=%p len=%d data=%p buf_pa=%#x:%x\n",
791 			    skb, skb->len, skb->data, (u32)buf_pa,
792 			    (u32)((u64)buf_pa >> 32));
793 
794 		card->rx_buf_list[i] = skb;
795 		if (reg->pfu_enabled) {
796 			card->rxbd_ring[i] = (void *)card->rxbd_ring_vbase +
797 					     (sizeof(*desc2) * i);
798 			desc2 = card->rxbd_ring[i];
799 			desc2->paddr = buf_pa;
800 			desc2->len = (u16)skb->len;
801 			desc2->frag_len = (u16)skb->len;
802 			desc2->flags = reg->ring_flag_eop | reg->ring_flag_sop;
803 			desc2->offset = 0;
804 		} else {
805 			card->rxbd_ring[i] = (void *)(card->rxbd_ring_vbase +
806 					     (sizeof(*desc) * i));
807 			desc = card->rxbd_ring[i];
808 			desc->paddr = buf_pa;
809 			desc->len = (u16)skb->len;
810 			desc->flags = 0;
811 		}
812 	}
813 
814 	return 0;
815 }
816 
817 /* This function initializes event buffer ring descriptors. Each SKB is
818  * allocated here and after mapping PCI memory, its physical address is assigned
819  * to PCIE Rx buffer descriptor's physical address
820  */
821 static int mwifiex_pcie_init_evt_ring(struct mwifiex_adapter *adapter)
822 {
823 	struct pcie_service_card *card = adapter->card;
824 	struct mwifiex_evt_buf_desc *desc;
825 	struct sk_buff *skb;
826 	dma_addr_t buf_pa;
827 	int i;
828 
829 	for (i = 0; i < MWIFIEX_MAX_EVT_BD; i++) {
830 		/* Allocate skb here so that firmware can DMA data from it */
831 		skb = dev_alloc_skb(MAX_EVENT_SIZE);
832 		if (!skb) {
833 			mwifiex_dbg(adapter, ERROR,
834 				    "Unable to allocate skb for EVENT buf.\n");
835 			kfree(card->evtbd_ring_vbase);
836 			return -ENOMEM;
837 		}
838 		skb_put(skb, MAX_EVENT_SIZE);
839 
840 		if (mwifiex_map_pci_memory(adapter, skb, MAX_EVENT_SIZE,
841 					   DMA_FROM_DEVICE)) {
842 			kfree_skb(skb);
843 			kfree(card->evtbd_ring_vbase);
844 			return -1;
845 		}
846 
847 		buf_pa = MWIFIEX_SKB_DMA_ADDR(skb);
848 
849 		mwifiex_dbg(adapter, EVENT,
850 			    "info: EVT ring: skb=%p len=%d data=%p buf_pa=%#x:%x\n",
851 			    skb, skb->len, skb->data, (u32)buf_pa,
852 			    (u32)((u64)buf_pa >> 32));
853 
854 		card->evt_buf_list[i] = skb;
855 		card->evtbd_ring[i] = (void *)(card->evtbd_ring_vbase +
856 				      (sizeof(*desc) * i));
857 		desc = card->evtbd_ring[i];
858 		desc->paddr = buf_pa;
859 		desc->len = (u16)skb->len;
860 		desc->flags = 0;
861 	}
862 
863 	return 0;
864 }
865 
866 /* This function cleans up TX buffer rings. If any of the buffer list has valid
867  * SKB address, associated SKB is freed.
868  */
869 static void mwifiex_cleanup_txq_ring(struct mwifiex_adapter *adapter)
870 {
871 	struct pcie_service_card *card = adapter->card;
872 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
873 	struct sk_buff *skb;
874 	struct mwifiex_pcie_buf_desc *desc;
875 	struct mwifiex_pfu_buf_desc *desc2;
876 	int i;
877 
878 	for (i = 0; i < MWIFIEX_MAX_TXRX_BD; i++) {
879 		if (reg->pfu_enabled) {
880 			desc2 = card->txbd_ring[i];
881 			if (card->tx_buf_list[i]) {
882 				skb = card->tx_buf_list[i];
883 				mwifiex_unmap_pci_memory(adapter, skb,
884 							 DMA_TO_DEVICE);
885 				dev_kfree_skb_any(skb);
886 			}
887 			memset(desc2, 0, sizeof(*desc2));
888 		} else {
889 			desc = card->txbd_ring[i];
890 			if (card->tx_buf_list[i]) {
891 				skb = card->tx_buf_list[i];
892 				mwifiex_unmap_pci_memory(adapter, skb,
893 							 DMA_TO_DEVICE);
894 				dev_kfree_skb_any(skb);
895 			}
896 			memset(desc, 0, sizeof(*desc));
897 		}
898 		card->tx_buf_list[i] = NULL;
899 	}
900 
901 	atomic_set(&adapter->tx_hw_pending, 0);
902 	return;
903 }
904 
905 /* This function cleans up RX buffer rings. If any of the buffer list has valid
906  * SKB address, associated SKB is freed.
907  */
908 static void mwifiex_cleanup_rxq_ring(struct mwifiex_adapter *adapter)
909 {
910 	struct pcie_service_card *card = adapter->card;
911 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
912 	struct mwifiex_pcie_buf_desc *desc;
913 	struct mwifiex_pfu_buf_desc *desc2;
914 	struct sk_buff *skb;
915 	int i;
916 
917 	for (i = 0; i < MWIFIEX_MAX_TXRX_BD; i++) {
918 		if (reg->pfu_enabled) {
919 			desc2 = card->rxbd_ring[i];
920 			if (card->rx_buf_list[i]) {
921 				skb = card->rx_buf_list[i];
922 				mwifiex_unmap_pci_memory(adapter, skb,
923 							 DMA_FROM_DEVICE);
924 				dev_kfree_skb_any(skb);
925 			}
926 			memset(desc2, 0, sizeof(*desc2));
927 		} else {
928 			desc = card->rxbd_ring[i];
929 			if (card->rx_buf_list[i]) {
930 				skb = card->rx_buf_list[i];
931 				mwifiex_unmap_pci_memory(adapter, skb,
932 							 DMA_FROM_DEVICE);
933 				dev_kfree_skb_any(skb);
934 			}
935 			memset(desc, 0, sizeof(*desc));
936 		}
937 		card->rx_buf_list[i] = NULL;
938 	}
939 
940 	return;
941 }
942 
943 /* This function cleans up event buffer rings. If any of the buffer list has
944  * valid SKB address, associated SKB is freed.
945  */
946 static void mwifiex_cleanup_evt_ring(struct mwifiex_adapter *adapter)
947 {
948 	struct pcie_service_card *card = adapter->card;
949 	struct mwifiex_evt_buf_desc *desc;
950 	struct sk_buff *skb;
951 	int i;
952 
953 	for (i = 0; i < MWIFIEX_MAX_EVT_BD; i++) {
954 		desc = card->evtbd_ring[i];
955 		if (card->evt_buf_list[i]) {
956 			skb = card->evt_buf_list[i];
957 			mwifiex_unmap_pci_memory(adapter, skb,
958 						 DMA_FROM_DEVICE);
959 			dev_kfree_skb_any(skb);
960 		}
961 		card->evt_buf_list[i] = NULL;
962 		memset(desc, 0, sizeof(*desc));
963 	}
964 
965 	return;
966 }
967 
968 /* This function creates buffer descriptor ring for TX
969  */
970 static int mwifiex_pcie_create_txbd_ring(struct mwifiex_adapter *adapter)
971 {
972 	struct pcie_service_card *card = adapter->card;
973 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
974 
975 	/*
976 	 * driver maintaines the write pointer and firmware maintaines the read
977 	 * pointer. The write pointer starts at 0 (zero) while the read pointer
978 	 * starts at zero with rollover bit set
979 	 */
980 	card->txbd_wrptr = 0;
981 
982 	if (reg->pfu_enabled)
983 		card->txbd_rdptr = 0;
984 	else
985 		card->txbd_rdptr |= reg->tx_rollover_ind;
986 
987 	/* allocate shared memory for the BD ring and divide the same in to
988 	   several descriptors */
989 	if (reg->pfu_enabled)
990 		card->txbd_ring_size = sizeof(struct mwifiex_pfu_buf_desc) *
991 				       MWIFIEX_MAX_TXRX_BD;
992 	else
993 		card->txbd_ring_size = sizeof(struct mwifiex_pcie_buf_desc) *
994 				       MWIFIEX_MAX_TXRX_BD;
995 
996 	mwifiex_dbg(adapter, INFO,
997 		    "info: txbd_ring: Allocating %d bytes\n",
998 		    card->txbd_ring_size);
999 	card->txbd_ring_vbase = dma_alloc_coherent(&card->dev->dev,
1000 						   card->txbd_ring_size,
1001 						   &card->txbd_ring_pbase,
1002 						   GFP_KERNEL);
1003 	if (!card->txbd_ring_vbase) {
1004 		mwifiex_dbg(adapter, ERROR,
1005 			    "allocate coherent memory (%d bytes) failed!\n",
1006 			    card->txbd_ring_size);
1007 		return -ENOMEM;
1008 	}
1009 
1010 	mwifiex_dbg(adapter, DATA,
1011 		    "info: txbd_ring - base: %p, pbase: %#x:%x, len: %#x\n",
1012 		    card->txbd_ring_vbase, (u32)card->txbd_ring_pbase,
1013 		    (u32)((u64)card->txbd_ring_pbase >> 32),
1014 		    card->txbd_ring_size);
1015 
1016 	return mwifiex_init_txq_ring(adapter);
1017 }
1018 
1019 static int mwifiex_pcie_delete_txbd_ring(struct mwifiex_adapter *adapter)
1020 {
1021 	struct pcie_service_card *card = adapter->card;
1022 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1023 
1024 	mwifiex_cleanup_txq_ring(adapter);
1025 
1026 	if (card->txbd_ring_vbase)
1027 		dma_free_coherent(&card->dev->dev, card->txbd_ring_size,
1028 				  card->txbd_ring_vbase,
1029 				  card->txbd_ring_pbase);
1030 	card->txbd_ring_size = 0;
1031 	card->txbd_wrptr = 0;
1032 	card->txbd_rdptr = 0 | reg->tx_rollover_ind;
1033 	card->txbd_ring_vbase = NULL;
1034 	card->txbd_ring_pbase = 0;
1035 
1036 	return 0;
1037 }
1038 
1039 /*
1040  * This function creates buffer descriptor ring for RX
1041  */
1042 static int mwifiex_pcie_create_rxbd_ring(struct mwifiex_adapter *adapter)
1043 {
1044 	struct pcie_service_card *card = adapter->card;
1045 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1046 
1047 	/*
1048 	 * driver maintaines the read pointer and firmware maintaines the write
1049 	 * pointer. The write pointer starts at 0 (zero) while the read pointer
1050 	 * starts at zero with rollover bit set
1051 	 */
1052 	card->rxbd_wrptr = 0;
1053 	card->rxbd_rdptr = reg->rx_rollover_ind;
1054 
1055 	if (reg->pfu_enabled)
1056 		card->rxbd_ring_size = sizeof(struct mwifiex_pfu_buf_desc) *
1057 				       MWIFIEX_MAX_TXRX_BD;
1058 	else
1059 		card->rxbd_ring_size = sizeof(struct mwifiex_pcie_buf_desc) *
1060 				       MWIFIEX_MAX_TXRX_BD;
1061 
1062 	mwifiex_dbg(adapter, INFO,
1063 		    "info: rxbd_ring: Allocating %d bytes\n",
1064 		    card->rxbd_ring_size);
1065 	card->rxbd_ring_vbase = dma_alloc_coherent(&card->dev->dev,
1066 						   card->rxbd_ring_size,
1067 						   &card->rxbd_ring_pbase,
1068 						   GFP_KERNEL);
1069 	if (!card->rxbd_ring_vbase) {
1070 		mwifiex_dbg(adapter, ERROR,
1071 			    "allocate coherent memory (%d bytes) failed!\n",
1072 			    card->rxbd_ring_size);
1073 		return -ENOMEM;
1074 	}
1075 
1076 	mwifiex_dbg(adapter, DATA,
1077 		    "info: rxbd_ring - base: %p, pbase: %#x:%x, len: %#x\n",
1078 		    card->rxbd_ring_vbase, (u32)card->rxbd_ring_pbase,
1079 		    (u32)((u64)card->rxbd_ring_pbase >> 32),
1080 		    card->rxbd_ring_size);
1081 
1082 	return mwifiex_init_rxq_ring(adapter);
1083 }
1084 
1085 /*
1086  * This function deletes Buffer descriptor ring for RX
1087  */
1088 static int mwifiex_pcie_delete_rxbd_ring(struct mwifiex_adapter *adapter)
1089 {
1090 	struct pcie_service_card *card = adapter->card;
1091 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1092 
1093 	mwifiex_cleanup_rxq_ring(adapter);
1094 
1095 	if (card->rxbd_ring_vbase)
1096 		dma_free_coherent(&card->dev->dev, card->rxbd_ring_size,
1097 				  card->rxbd_ring_vbase,
1098 				  card->rxbd_ring_pbase);
1099 	card->rxbd_ring_size = 0;
1100 	card->rxbd_wrptr = 0;
1101 	card->rxbd_rdptr = 0 | reg->rx_rollover_ind;
1102 	card->rxbd_ring_vbase = NULL;
1103 	card->rxbd_ring_pbase = 0;
1104 
1105 	return 0;
1106 }
1107 
1108 /*
1109  * This function creates buffer descriptor ring for Events
1110  */
1111 static int mwifiex_pcie_create_evtbd_ring(struct mwifiex_adapter *adapter)
1112 {
1113 	struct pcie_service_card *card = adapter->card;
1114 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1115 
1116 	/*
1117 	 * driver maintaines the read pointer and firmware maintaines the write
1118 	 * pointer. The write pointer starts at 0 (zero) while the read pointer
1119 	 * starts at zero with rollover bit set
1120 	 */
1121 	card->evtbd_wrptr = 0;
1122 	card->evtbd_rdptr = reg->evt_rollover_ind;
1123 
1124 	card->evtbd_ring_size = sizeof(struct mwifiex_evt_buf_desc) *
1125 				MWIFIEX_MAX_EVT_BD;
1126 
1127 	mwifiex_dbg(adapter, INFO,
1128 		    "info: evtbd_ring: Allocating %d bytes\n",
1129 		    card->evtbd_ring_size);
1130 	card->evtbd_ring_vbase = dma_alloc_coherent(&card->dev->dev,
1131 						    card->evtbd_ring_size,
1132 						    &card->evtbd_ring_pbase,
1133 						    GFP_KERNEL);
1134 	if (!card->evtbd_ring_vbase) {
1135 		mwifiex_dbg(adapter, ERROR,
1136 			    "allocate coherent memory (%d bytes) failed!\n",
1137 			    card->evtbd_ring_size);
1138 		return -ENOMEM;
1139 	}
1140 
1141 	mwifiex_dbg(adapter, EVENT,
1142 		    "info: CMDRSP/EVT bd_ring - base: %p pbase: %#x:%x len: %#x\n",
1143 		    card->evtbd_ring_vbase, (u32)card->evtbd_ring_pbase,
1144 		    (u32)((u64)card->evtbd_ring_pbase >> 32),
1145 		    card->evtbd_ring_size);
1146 
1147 	return mwifiex_pcie_init_evt_ring(adapter);
1148 }
1149 
1150 /*
1151  * This function deletes Buffer descriptor ring for Events
1152  */
1153 static int mwifiex_pcie_delete_evtbd_ring(struct mwifiex_adapter *adapter)
1154 {
1155 	struct pcie_service_card *card = adapter->card;
1156 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1157 
1158 	mwifiex_cleanup_evt_ring(adapter);
1159 
1160 	if (card->evtbd_ring_vbase)
1161 		dma_free_coherent(&card->dev->dev, card->evtbd_ring_size,
1162 				  card->evtbd_ring_vbase,
1163 				  card->evtbd_ring_pbase);
1164 	card->evtbd_wrptr = 0;
1165 	card->evtbd_rdptr = 0 | reg->evt_rollover_ind;
1166 	card->evtbd_ring_size = 0;
1167 	card->evtbd_ring_vbase = NULL;
1168 	card->evtbd_ring_pbase = 0;
1169 
1170 	return 0;
1171 }
1172 
1173 /*
1174  * This function allocates a buffer for CMDRSP
1175  */
1176 static int mwifiex_pcie_alloc_cmdrsp_buf(struct mwifiex_adapter *adapter)
1177 {
1178 	struct pcie_service_card *card = adapter->card;
1179 	struct sk_buff *skb;
1180 
1181 	/* Allocate memory for receiving command response data */
1182 	skb = dev_alloc_skb(MWIFIEX_UPLD_SIZE);
1183 	if (!skb) {
1184 		mwifiex_dbg(adapter, ERROR,
1185 			    "Unable to allocate skb for command response data.\n");
1186 		return -ENOMEM;
1187 	}
1188 	skb_put(skb, MWIFIEX_UPLD_SIZE);
1189 	if (mwifiex_map_pci_memory(adapter, skb, MWIFIEX_UPLD_SIZE,
1190 				   DMA_FROM_DEVICE)) {
1191 		kfree_skb(skb);
1192 		return -1;
1193 	}
1194 
1195 	card->cmdrsp_buf = skb;
1196 
1197 	return 0;
1198 }
1199 
1200 /*
1201  * This function deletes a buffer for CMDRSP
1202  */
1203 static int mwifiex_pcie_delete_cmdrsp_buf(struct mwifiex_adapter *adapter)
1204 {
1205 	struct pcie_service_card *card;
1206 
1207 	if (!adapter)
1208 		return 0;
1209 
1210 	card = adapter->card;
1211 
1212 	if (card && card->cmdrsp_buf) {
1213 		mwifiex_unmap_pci_memory(adapter, card->cmdrsp_buf,
1214 					 DMA_FROM_DEVICE);
1215 		dev_kfree_skb_any(card->cmdrsp_buf);
1216 		card->cmdrsp_buf = NULL;
1217 	}
1218 
1219 	if (card && card->cmd_buf) {
1220 		mwifiex_unmap_pci_memory(adapter, card->cmd_buf,
1221 					 DMA_TO_DEVICE);
1222 		dev_kfree_skb_any(card->cmd_buf);
1223 		card->cmd_buf = NULL;
1224 	}
1225 	return 0;
1226 }
1227 
1228 /*
1229  * This function allocates a buffer for sleep cookie
1230  */
1231 static int mwifiex_pcie_alloc_sleep_cookie_buf(struct mwifiex_adapter *adapter)
1232 {
1233 	struct pcie_service_card *card = adapter->card;
1234 	u32 tmp;
1235 
1236 	card->sleep_cookie_vbase = dma_alloc_coherent(&card->dev->dev,
1237 						      sizeof(u32),
1238 						      &card->sleep_cookie_pbase,
1239 						      GFP_KERNEL);
1240 	if (!card->sleep_cookie_vbase) {
1241 		mwifiex_dbg(adapter, ERROR,
1242 			    "dma_alloc_coherent failed!\n");
1243 		return -ENOMEM;
1244 	}
1245 	/* Init val of Sleep Cookie */
1246 	tmp = FW_AWAKE_COOKIE;
1247 	put_unaligned(tmp, card->sleep_cookie_vbase);
1248 
1249 	mwifiex_dbg(adapter, INFO,
1250 		    "alloc_scook: sleep cookie=0x%x\n",
1251 		    get_unaligned(card->sleep_cookie_vbase));
1252 
1253 	return 0;
1254 }
1255 
1256 /*
1257  * This function deletes buffer for sleep cookie
1258  */
1259 static int mwifiex_pcie_delete_sleep_cookie_buf(struct mwifiex_adapter *adapter)
1260 {
1261 	struct pcie_service_card *card;
1262 
1263 	if (!adapter)
1264 		return 0;
1265 
1266 	card = adapter->card;
1267 
1268 	if (card && card->sleep_cookie_vbase) {
1269 		dma_free_coherent(&card->dev->dev, sizeof(u32),
1270 				  card->sleep_cookie_vbase,
1271 				  card->sleep_cookie_pbase);
1272 		card->sleep_cookie_vbase = NULL;
1273 	}
1274 
1275 	return 0;
1276 }
1277 
1278 /* This function flushes the TX buffer descriptor ring
1279  * This function defined as handler is also called while cleaning TXRX
1280  * during disconnect/ bss stop.
1281  */
1282 static int mwifiex_clean_pcie_ring_buf(struct mwifiex_adapter *adapter)
1283 {
1284 	struct pcie_service_card *card = adapter->card;
1285 
1286 	if (!mwifiex_pcie_txbd_empty(card, card->txbd_rdptr)) {
1287 		card->txbd_flush = 1;
1288 		/* write pointer already set at last send
1289 		 * send dnld-rdy intr again, wait for completion.
1290 		 */
1291 		if (mwifiex_write_reg(adapter, PCIE_CPU_INT_EVENT,
1292 				      CPU_INTR_DNLD_RDY)) {
1293 			mwifiex_dbg(adapter, ERROR,
1294 				    "failed to assert dnld-rdy interrupt.\n");
1295 			return -1;
1296 		}
1297 	}
1298 	return 0;
1299 }
1300 
1301 /*
1302  * This function unmaps and frees downloaded data buffer
1303  */
1304 static int mwifiex_pcie_send_data_complete(struct mwifiex_adapter *adapter)
1305 {
1306 	struct sk_buff *skb;
1307 	u32 wrdoneidx, rdptr, num_tx_buffs, unmap_count = 0;
1308 	struct mwifiex_pcie_buf_desc *desc;
1309 	struct mwifiex_pfu_buf_desc *desc2;
1310 	struct pcie_service_card *card = adapter->card;
1311 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1312 
1313 	if (!mwifiex_pcie_ok_to_access_hw(adapter))
1314 		mwifiex_pm_wakeup_card(adapter);
1315 
1316 	/* Read the TX ring read pointer set by firmware */
1317 	if (mwifiex_read_reg(adapter, reg->tx_rdptr, &rdptr)) {
1318 		mwifiex_dbg(adapter, ERROR,
1319 			    "SEND COMP: failed to read reg->tx_rdptr\n");
1320 		return -1;
1321 	}
1322 
1323 	mwifiex_dbg(adapter, DATA,
1324 		    "SEND COMP: rdptr_prev=0x%x, rdptr=0x%x\n",
1325 		    card->txbd_rdptr, rdptr);
1326 
1327 	num_tx_buffs = MWIFIEX_MAX_TXRX_BD << reg->tx_start_ptr;
1328 	/* free from previous txbd_rdptr to current txbd_rdptr */
1329 	while (((card->txbd_rdptr & reg->tx_mask) !=
1330 		(rdptr & reg->tx_mask)) ||
1331 	       ((card->txbd_rdptr & reg->tx_rollover_ind) !=
1332 		(rdptr & reg->tx_rollover_ind))) {
1333 		wrdoneidx = (card->txbd_rdptr & reg->tx_mask) >>
1334 			    reg->tx_start_ptr;
1335 
1336 		skb = card->tx_buf_list[wrdoneidx];
1337 
1338 		if (skb) {
1339 			mwifiex_dbg(adapter, DATA,
1340 				    "SEND COMP: Detach skb %p at txbd_rdidx=%d\n",
1341 				    skb, wrdoneidx);
1342 			mwifiex_unmap_pci_memory(adapter, skb,
1343 						 DMA_TO_DEVICE);
1344 
1345 			unmap_count++;
1346 
1347 			if (card->txbd_flush)
1348 				mwifiex_write_data_complete(adapter, skb, 0,
1349 							    -1);
1350 			else
1351 				mwifiex_write_data_complete(adapter, skb, 0, 0);
1352 			atomic_dec(&adapter->tx_hw_pending);
1353 		}
1354 
1355 		card->tx_buf_list[wrdoneidx] = NULL;
1356 
1357 		if (reg->pfu_enabled) {
1358 			desc2 = card->txbd_ring[wrdoneidx];
1359 			memset(desc2, 0, sizeof(*desc2));
1360 		} else {
1361 			desc = card->txbd_ring[wrdoneidx];
1362 			memset(desc, 0, sizeof(*desc));
1363 		}
1364 		switch (card->dev->device) {
1365 		case PCIE_DEVICE_ID_MARVELL_88W8766P:
1366 			card->txbd_rdptr++;
1367 			break;
1368 		case PCIE_DEVICE_ID_MARVELL_88W8897:
1369 		case PCIE_DEVICE_ID_MARVELL_88W8997:
1370 			card->txbd_rdptr += reg->ring_tx_start_ptr;
1371 			break;
1372 		}
1373 
1374 
1375 		if ((card->txbd_rdptr & reg->tx_mask) == num_tx_buffs)
1376 			card->txbd_rdptr = ((card->txbd_rdptr &
1377 					     reg->tx_rollover_ind) ^
1378 					     reg->tx_rollover_ind);
1379 	}
1380 
1381 	if (unmap_count)
1382 		adapter->data_sent = false;
1383 
1384 	if (card->txbd_flush) {
1385 		if (mwifiex_pcie_txbd_empty(card, card->txbd_rdptr))
1386 			card->txbd_flush = 0;
1387 		else
1388 			mwifiex_clean_pcie_ring_buf(adapter);
1389 	}
1390 
1391 	return 0;
1392 }
1393 
1394 /* This function sends data buffer to device. First 4 bytes of payload
1395  * are filled with payload length and payload type. Then this payload
1396  * is mapped to PCI device memory. Tx ring pointers are advanced accordingly.
1397  * Download ready interrupt to FW is deffered if Tx ring is not full and
1398  * additional payload can be accomodated.
1399  * Caller must ensure tx_param parameter to this function is not NULL.
1400  */
1401 static int
1402 mwifiex_pcie_send_data(struct mwifiex_adapter *adapter, struct sk_buff *skb,
1403 		       struct mwifiex_tx_param *tx_param)
1404 {
1405 	struct pcie_service_card *card = adapter->card;
1406 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1407 	u32 wrindx, num_tx_buffs, rx_val;
1408 	int ret;
1409 	dma_addr_t buf_pa;
1410 	struct mwifiex_pcie_buf_desc *desc = NULL;
1411 	struct mwifiex_pfu_buf_desc *desc2 = NULL;
1412 
1413 	if (!(skb->data && skb->len)) {
1414 		mwifiex_dbg(adapter, ERROR,
1415 			    "%s(): invalid parameter <%p, %#x>\n",
1416 			    __func__, skb->data, skb->len);
1417 		return -1;
1418 	}
1419 
1420 	if (!mwifiex_pcie_ok_to_access_hw(adapter))
1421 		mwifiex_pm_wakeup_card(adapter);
1422 
1423 	num_tx_buffs = MWIFIEX_MAX_TXRX_BD << reg->tx_start_ptr;
1424 	mwifiex_dbg(adapter, DATA,
1425 		    "info: SEND DATA: <Rd: %#x, Wr: %#x>\n",
1426 		card->txbd_rdptr, card->txbd_wrptr);
1427 	if (mwifiex_pcie_txbd_not_full(card)) {
1428 		u8 *payload;
1429 
1430 		adapter->data_sent = true;
1431 		payload = skb->data;
1432 		put_unaligned_le16((u16)skb->len, payload + 0);
1433 		put_unaligned_le16(MWIFIEX_TYPE_DATA, payload + 2);
1434 
1435 		if (mwifiex_map_pci_memory(adapter, skb, skb->len,
1436 					   DMA_TO_DEVICE))
1437 			return -1;
1438 
1439 		wrindx = (card->txbd_wrptr & reg->tx_mask) >> reg->tx_start_ptr;
1440 		buf_pa = MWIFIEX_SKB_DMA_ADDR(skb);
1441 		card->tx_buf_list[wrindx] = skb;
1442 		atomic_inc(&adapter->tx_hw_pending);
1443 
1444 		if (reg->pfu_enabled) {
1445 			desc2 = card->txbd_ring[wrindx];
1446 			desc2->paddr = buf_pa;
1447 			desc2->len = (u16)skb->len;
1448 			desc2->frag_len = (u16)skb->len;
1449 			desc2->offset = 0;
1450 			desc2->flags = MWIFIEX_BD_FLAG_FIRST_DESC |
1451 					 MWIFIEX_BD_FLAG_LAST_DESC;
1452 		} else {
1453 			desc = card->txbd_ring[wrindx];
1454 			desc->paddr = buf_pa;
1455 			desc->len = (u16)skb->len;
1456 			desc->flags = MWIFIEX_BD_FLAG_FIRST_DESC |
1457 				      MWIFIEX_BD_FLAG_LAST_DESC;
1458 		}
1459 
1460 		switch (card->dev->device) {
1461 		case PCIE_DEVICE_ID_MARVELL_88W8766P:
1462 			card->txbd_wrptr++;
1463 			break;
1464 		case PCIE_DEVICE_ID_MARVELL_88W8897:
1465 		case PCIE_DEVICE_ID_MARVELL_88W8997:
1466 			card->txbd_wrptr += reg->ring_tx_start_ptr;
1467 			break;
1468 		}
1469 
1470 		if ((card->txbd_wrptr & reg->tx_mask) == num_tx_buffs)
1471 			card->txbd_wrptr = ((card->txbd_wrptr &
1472 						reg->tx_rollover_ind) ^
1473 						reg->tx_rollover_ind);
1474 
1475 		rx_val = card->rxbd_rdptr & reg->rx_wrap_mask;
1476 		/* Write the TX ring write pointer in to reg->tx_wrptr */
1477 		if (mwifiex_write_reg(adapter, reg->tx_wrptr,
1478 				      card->txbd_wrptr | rx_val)) {
1479 			mwifiex_dbg(adapter, ERROR,
1480 				    "SEND DATA: failed to write reg->tx_wrptr\n");
1481 			ret = -1;
1482 			goto done_unmap;
1483 		}
1484 		if ((mwifiex_pcie_txbd_not_full(card)) &&
1485 		    tx_param->next_pkt_len) {
1486 			/* have more packets and TxBD still can hold more */
1487 			mwifiex_dbg(adapter, DATA,
1488 				    "SEND DATA: delay dnld-rdy interrupt.\n");
1489 			adapter->data_sent = false;
1490 		} else {
1491 			/* Send the TX ready interrupt */
1492 			if (mwifiex_write_reg(adapter, PCIE_CPU_INT_EVENT,
1493 					      CPU_INTR_DNLD_RDY)) {
1494 				mwifiex_dbg(adapter, ERROR,
1495 					    "SEND DATA: failed to assert dnld-rdy interrupt.\n");
1496 				ret = -1;
1497 				goto done_unmap;
1498 			}
1499 		}
1500 		mwifiex_dbg(adapter, DATA,
1501 			    "info: SEND DATA: Updated <Rd: %#x, Wr:\t"
1502 			    "%#x> and sent packet to firmware successfully\n",
1503 			    card->txbd_rdptr, card->txbd_wrptr);
1504 	} else {
1505 		mwifiex_dbg(adapter, DATA,
1506 			    "info: TX Ring full, can't send packets to fw\n");
1507 		adapter->data_sent = true;
1508 		/* Send the TX ready interrupt */
1509 		if (mwifiex_write_reg(adapter, PCIE_CPU_INT_EVENT,
1510 				      CPU_INTR_DNLD_RDY))
1511 			mwifiex_dbg(adapter, ERROR,
1512 				    "SEND DATA: failed to assert door-bell intr\n");
1513 		return -EBUSY;
1514 	}
1515 
1516 	return -EINPROGRESS;
1517 done_unmap:
1518 	mwifiex_unmap_pci_memory(adapter, skb, DMA_TO_DEVICE);
1519 	card->tx_buf_list[wrindx] = NULL;
1520 	atomic_dec(&adapter->tx_hw_pending);
1521 	if (reg->pfu_enabled)
1522 		memset(desc2, 0, sizeof(*desc2));
1523 	else
1524 		memset(desc, 0, sizeof(*desc));
1525 
1526 	return ret;
1527 }
1528 
1529 /*
1530  * This function handles received buffer ring and
1531  * dispatches packets to upper
1532  */
1533 static int mwifiex_pcie_process_recv_data(struct mwifiex_adapter *adapter)
1534 {
1535 	struct pcie_service_card *card = adapter->card;
1536 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1537 	u32 wrptr, rd_index, tx_val;
1538 	dma_addr_t buf_pa;
1539 	int ret = 0;
1540 	struct sk_buff *skb_tmp = NULL;
1541 	struct mwifiex_pcie_buf_desc *desc;
1542 	struct mwifiex_pfu_buf_desc *desc2;
1543 
1544 	if (!mwifiex_pcie_ok_to_access_hw(adapter))
1545 		mwifiex_pm_wakeup_card(adapter);
1546 
1547 	/* Read the RX ring Write pointer set by firmware */
1548 	if (mwifiex_read_reg(adapter, reg->rx_wrptr, &wrptr)) {
1549 		mwifiex_dbg(adapter, ERROR,
1550 			    "RECV DATA: failed to read reg->rx_wrptr\n");
1551 		ret = -1;
1552 		goto done;
1553 	}
1554 	card->rxbd_wrptr = wrptr;
1555 
1556 	while (((wrptr & reg->rx_mask) !=
1557 		(card->rxbd_rdptr & reg->rx_mask)) ||
1558 	       ((wrptr & reg->rx_rollover_ind) ==
1559 		(card->rxbd_rdptr & reg->rx_rollover_ind))) {
1560 		struct sk_buff *skb_data;
1561 		u16 rx_len;
1562 
1563 		rd_index = card->rxbd_rdptr & reg->rx_mask;
1564 		skb_data = card->rx_buf_list[rd_index];
1565 
1566 		/* If skb allocation was failed earlier for Rx packet,
1567 		 * rx_buf_list[rd_index] would have been left with a NULL.
1568 		 */
1569 		if (!skb_data)
1570 			return -ENOMEM;
1571 
1572 		mwifiex_unmap_pci_memory(adapter, skb_data, DMA_FROM_DEVICE);
1573 		card->rx_buf_list[rd_index] = NULL;
1574 
1575 		/* Get data length from interface header -
1576 		 * first 2 bytes for len, next 2 bytes is for type
1577 		 */
1578 		rx_len = get_unaligned_le16(skb_data->data);
1579 		if (WARN_ON(rx_len <= adapter->intf_hdr_len ||
1580 			    rx_len > MWIFIEX_RX_DATA_BUF_SIZE)) {
1581 			mwifiex_dbg(adapter, ERROR,
1582 				    "Invalid RX len %d, Rd=%#x, Wr=%#x\n",
1583 				    rx_len, card->rxbd_rdptr, wrptr);
1584 			dev_kfree_skb_any(skb_data);
1585 		} else {
1586 			skb_put(skb_data, rx_len);
1587 			mwifiex_dbg(adapter, DATA,
1588 				    "info: RECV DATA: Rd=%#x, Wr=%#x, Len=%d\n",
1589 				    card->rxbd_rdptr, wrptr, rx_len);
1590 			skb_pull(skb_data, adapter->intf_hdr_len);
1591 			if (adapter->rx_work_enabled) {
1592 				skb_queue_tail(&adapter->rx_data_q, skb_data);
1593 				adapter->data_received = true;
1594 				atomic_inc(&adapter->rx_pending);
1595 			} else {
1596 				mwifiex_handle_rx_packet(adapter, skb_data);
1597 			}
1598 		}
1599 
1600 		skb_tmp = mwifiex_alloc_dma_align_buf(MWIFIEX_RX_DATA_BUF_SIZE,
1601 						      GFP_KERNEL);
1602 		if (!skb_tmp) {
1603 			mwifiex_dbg(adapter, ERROR,
1604 				    "Unable to allocate skb.\n");
1605 			return -ENOMEM;
1606 		}
1607 
1608 		if (mwifiex_map_pci_memory(adapter, skb_tmp,
1609 					   MWIFIEX_RX_DATA_BUF_SIZE,
1610 					   DMA_FROM_DEVICE))
1611 			return -1;
1612 
1613 		buf_pa = MWIFIEX_SKB_DMA_ADDR(skb_tmp);
1614 
1615 		mwifiex_dbg(adapter, INFO,
1616 			    "RECV DATA: Attach new sk_buff %p at rxbd_rdidx=%d\n",
1617 			    skb_tmp, rd_index);
1618 		card->rx_buf_list[rd_index] = skb_tmp;
1619 
1620 		if (reg->pfu_enabled) {
1621 			desc2 = card->rxbd_ring[rd_index];
1622 			desc2->paddr = buf_pa;
1623 			desc2->len = skb_tmp->len;
1624 			desc2->frag_len = skb_tmp->len;
1625 			desc2->offset = 0;
1626 			desc2->flags = reg->ring_flag_sop | reg->ring_flag_eop;
1627 		} else {
1628 			desc = card->rxbd_ring[rd_index];
1629 			desc->paddr = buf_pa;
1630 			desc->len = skb_tmp->len;
1631 			desc->flags = 0;
1632 		}
1633 
1634 		if ((++card->rxbd_rdptr & reg->rx_mask) ==
1635 							MWIFIEX_MAX_TXRX_BD) {
1636 			card->rxbd_rdptr = ((card->rxbd_rdptr &
1637 					     reg->rx_rollover_ind) ^
1638 					     reg->rx_rollover_ind);
1639 		}
1640 		mwifiex_dbg(adapter, DATA,
1641 			    "info: RECV DATA: <Rd: %#x, Wr: %#x>\n",
1642 			    card->rxbd_rdptr, wrptr);
1643 
1644 		tx_val = card->txbd_wrptr & reg->tx_wrap_mask;
1645 		/* Write the RX ring read pointer in to reg->rx_rdptr */
1646 		if (mwifiex_write_reg(adapter, reg->rx_rdptr,
1647 				      card->rxbd_rdptr | tx_val)) {
1648 			mwifiex_dbg(adapter, DATA,
1649 				    "RECV DATA: failed to write reg->rx_rdptr\n");
1650 			ret = -1;
1651 			goto done;
1652 		}
1653 
1654 		/* Read the RX ring Write pointer set by firmware */
1655 		if (mwifiex_read_reg(adapter, reg->rx_wrptr, &wrptr)) {
1656 			mwifiex_dbg(adapter, ERROR,
1657 				    "RECV DATA: failed to read reg->rx_wrptr\n");
1658 			ret = -1;
1659 			goto done;
1660 		}
1661 		mwifiex_dbg(adapter, DATA,
1662 			    "info: RECV DATA: Rcvd packet from fw successfully\n");
1663 		card->rxbd_wrptr = wrptr;
1664 	}
1665 
1666 done:
1667 	return ret;
1668 }
1669 
1670 /*
1671  * This function downloads the boot command to device
1672  */
1673 static int
1674 mwifiex_pcie_send_boot_cmd(struct mwifiex_adapter *adapter, struct sk_buff *skb)
1675 {
1676 	dma_addr_t buf_pa;
1677 	struct pcie_service_card *card = adapter->card;
1678 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1679 
1680 	if (!(skb->data && skb->len)) {
1681 		mwifiex_dbg(adapter, ERROR,
1682 			    "Invalid parameter in %s <%p. len %d>\n",
1683 			    __func__, skb->data, skb->len);
1684 		return -1;
1685 	}
1686 
1687 	if (mwifiex_map_pci_memory(adapter, skb, skb->len, DMA_TO_DEVICE))
1688 		return -1;
1689 
1690 	buf_pa = MWIFIEX_SKB_DMA_ADDR(skb);
1691 
1692 	/* Write the lower 32bits of the physical address to low command
1693 	 * address scratch register
1694 	 */
1695 	if (mwifiex_write_reg(adapter, reg->cmd_addr_lo, (u32)buf_pa)) {
1696 		mwifiex_dbg(adapter, ERROR,
1697 			    "%s: failed to write download command to boot code.\n",
1698 			    __func__);
1699 		mwifiex_unmap_pci_memory(adapter, skb, DMA_TO_DEVICE);
1700 		return -1;
1701 	}
1702 
1703 	/* Write the upper 32bits of the physical address to high command
1704 	 * address scratch register
1705 	 */
1706 	if (mwifiex_write_reg(adapter, reg->cmd_addr_hi,
1707 			      (u32)((u64)buf_pa >> 32))) {
1708 		mwifiex_dbg(adapter, ERROR,
1709 			    "%s: failed to write download command to boot code.\n",
1710 			    __func__);
1711 		mwifiex_unmap_pci_memory(adapter, skb, DMA_TO_DEVICE);
1712 		return -1;
1713 	}
1714 
1715 	/* Write the command length to cmd_size scratch register */
1716 	if (mwifiex_write_reg(adapter, reg->cmd_size, skb->len)) {
1717 		mwifiex_dbg(adapter, ERROR,
1718 			    "%s: failed to write command len to cmd_size scratch reg\n",
1719 			    __func__);
1720 		mwifiex_unmap_pci_memory(adapter, skb, DMA_TO_DEVICE);
1721 		return -1;
1722 	}
1723 
1724 	/* Ring the door bell */
1725 	if (mwifiex_write_reg(adapter, PCIE_CPU_INT_EVENT,
1726 			      CPU_INTR_DOOR_BELL)) {
1727 		mwifiex_dbg(adapter, ERROR,
1728 			    "%s: failed to assert door-bell intr\n", __func__);
1729 		mwifiex_unmap_pci_memory(adapter, skb, DMA_TO_DEVICE);
1730 		return -1;
1731 	}
1732 
1733 	return 0;
1734 }
1735 
1736 /* This function init rx port in firmware which in turn enables to receive data
1737  * from device before transmitting any packet.
1738  */
1739 static int mwifiex_pcie_init_fw_port(struct mwifiex_adapter *adapter)
1740 {
1741 	struct pcie_service_card *card = adapter->card;
1742 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1743 	int tx_wrap = card->txbd_wrptr & reg->tx_wrap_mask;
1744 
1745 	/* Write the RX ring read pointer in to reg->rx_rdptr */
1746 	if (mwifiex_write_reg(adapter, reg->rx_rdptr, card->rxbd_rdptr |
1747 			      tx_wrap)) {
1748 		mwifiex_dbg(adapter, ERROR,
1749 			    "RECV DATA: failed to write reg->rx_rdptr\n");
1750 		return -1;
1751 	}
1752 	return 0;
1753 }
1754 
1755 /* This function downloads commands to the device
1756  */
1757 static int
1758 mwifiex_pcie_send_cmd(struct mwifiex_adapter *adapter, struct sk_buff *skb)
1759 {
1760 	struct pcie_service_card *card = adapter->card;
1761 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1762 	int ret = 0;
1763 	dma_addr_t cmd_buf_pa, cmdrsp_buf_pa;
1764 	u8 *payload = (u8 *)skb->data;
1765 
1766 	if (!(skb->data && skb->len)) {
1767 		mwifiex_dbg(adapter, ERROR,
1768 			    "Invalid parameter in %s <%p, %#x>\n",
1769 			    __func__, skb->data, skb->len);
1770 		return -1;
1771 	}
1772 
1773 	/* Make sure a command response buffer is available */
1774 	if (!card->cmdrsp_buf) {
1775 		mwifiex_dbg(adapter, ERROR,
1776 			    "No response buffer available, send command failed\n");
1777 		return -EBUSY;
1778 	}
1779 
1780 	if (!mwifiex_pcie_ok_to_access_hw(adapter))
1781 		mwifiex_pm_wakeup_card(adapter);
1782 
1783 	adapter->cmd_sent = true;
1784 
1785 	put_unaligned_le16((u16)skb->len, &payload[0]);
1786 	put_unaligned_le16(MWIFIEX_TYPE_CMD, &payload[2]);
1787 
1788 	if (mwifiex_map_pci_memory(adapter, skb, skb->len, DMA_TO_DEVICE))
1789 		return -1;
1790 
1791 	card->cmd_buf = skb;
1792 	/*
1793 	 * Need to keep a reference, since core driver might free up this
1794 	 * buffer before we've unmapped it.
1795 	 */
1796 	skb_get(skb);
1797 
1798 	/* To send a command, the driver will:
1799 		1. Write the 64bit physical address of the data buffer to
1800 		   cmd response address low  + cmd response address high
1801 		2. Ring the door bell (i.e. set the door bell interrupt)
1802 
1803 		In response to door bell interrupt, the firmware will perform
1804 		the DMA of the command packet (first header to obtain the total
1805 		length and then rest of the command).
1806 	*/
1807 
1808 	if (card->cmdrsp_buf) {
1809 		cmdrsp_buf_pa = MWIFIEX_SKB_DMA_ADDR(card->cmdrsp_buf);
1810 		/* Write the lower 32bits of the cmdrsp buffer physical
1811 		   address */
1812 		if (mwifiex_write_reg(adapter, reg->cmdrsp_addr_lo,
1813 				      (u32)cmdrsp_buf_pa)) {
1814 			mwifiex_dbg(adapter, ERROR,
1815 				    "Failed to write download cmd to boot code.\n");
1816 			ret = -1;
1817 			goto done;
1818 		}
1819 		/* Write the upper 32bits of the cmdrsp buffer physical
1820 		   address */
1821 		if (mwifiex_write_reg(adapter, reg->cmdrsp_addr_hi,
1822 				      (u32)((u64)cmdrsp_buf_pa >> 32))) {
1823 			mwifiex_dbg(adapter, ERROR,
1824 				    "Failed to write download cmd to boot code.\n");
1825 			ret = -1;
1826 			goto done;
1827 		}
1828 	}
1829 
1830 	cmd_buf_pa = MWIFIEX_SKB_DMA_ADDR(card->cmd_buf);
1831 	/* Write the lower 32bits of the physical address to reg->cmd_addr_lo */
1832 	if (mwifiex_write_reg(adapter, reg->cmd_addr_lo,
1833 			      (u32)cmd_buf_pa)) {
1834 		mwifiex_dbg(adapter, ERROR,
1835 			    "Failed to write download cmd to boot code.\n");
1836 		ret = -1;
1837 		goto done;
1838 	}
1839 	/* Write the upper 32bits of the physical address to reg->cmd_addr_hi */
1840 	if (mwifiex_write_reg(adapter, reg->cmd_addr_hi,
1841 			      (u32)((u64)cmd_buf_pa >> 32))) {
1842 		mwifiex_dbg(adapter, ERROR,
1843 			    "Failed to write download cmd to boot code.\n");
1844 		ret = -1;
1845 		goto done;
1846 	}
1847 
1848 	/* Write the command length to reg->cmd_size */
1849 	if (mwifiex_write_reg(adapter, reg->cmd_size,
1850 			      card->cmd_buf->len)) {
1851 		mwifiex_dbg(adapter, ERROR,
1852 			    "Failed to write cmd len to reg->cmd_size\n");
1853 		ret = -1;
1854 		goto done;
1855 	}
1856 
1857 	/* Ring the door bell */
1858 	if (mwifiex_write_reg(adapter, PCIE_CPU_INT_EVENT,
1859 			      CPU_INTR_DOOR_BELL)) {
1860 		mwifiex_dbg(adapter, ERROR,
1861 			    "Failed to assert door-bell intr\n");
1862 		ret = -1;
1863 		goto done;
1864 	}
1865 
1866 done:
1867 	if (ret)
1868 		adapter->cmd_sent = false;
1869 
1870 	return 0;
1871 }
1872 
1873 /*
1874  * This function handles command complete interrupt
1875  */
1876 static int mwifiex_pcie_process_cmd_complete(struct mwifiex_adapter *adapter)
1877 {
1878 	struct pcie_service_card *card = adapter->card;
1879 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1880 	struct sk_buff *skb = card->cmdrsp_buf;
1881 	int count = 0;
1882 	u16 rx_len;
1883 
1884 	mwifiex_dbg(adapter, CMD,
1885 		    "info: Rx CMD Response\n");
1886 
1887 	if (adapter->curr_cmd)
1888 		mwifiex_unmap_pci_memory(adapter, skb, DMA_FROM_DEVICE);
1889 	else
1890 		dma_sync_single_for_cpu(&card->dev->dev,
1891 					MWIFIEX_SKB_DMA_ADDR(skb),
1892 					MWIFIEX_UPLD_SIZE, DMA_FROM_DEVICE);
1893 
1894 	/* Unmap the command as a response has been received. */
1895 	if (card->cmd_buf) {
1896 		mwifiex_unmap_pci_memory(adapter, card->cmd_buf,
1897 					 DMA_TO_DEVICE);
1898 		dev_kfree_skb_any(card->cmd_buf);
1899 		card->cmd_buf = NULL;
1900 	}
1901 
1902 	rx_len = get_unaligned_le16(skb->data);
1903 	skb_put(skb, MWIFIEX_UPLD_SIZE - skb->len);
1904 	skb_trim(skb, rx_len);
1905 
1906 	if (!adapter->curr_cmd) {
1907 		if (adapter->ps_state == PS_STATE_SLEEP_CFM) {
1908 			dma_sync_single_for_device(&card->dev->dev,
1909 						   MWIFIEX_SKB_DMA_ADDR(skb),
1910 						   MWIFIEX_SLEEP_COOKIE_SIZE,
1911 						   DMA_FROM_DEVICE);
1912 			if (mwifiex_write_reg(adapter,
1913 					      PCIE_CPU_INT_EVENT,
1914 					      CPU_INTR_SLEEP_CFM_DONE)) {
1915 				mwifiex_dbg(adapter, ERROR,
1916 					    "Write register failed\n");
1917 				return -1;
1918 			}
1919 			mwifiex_delay_for_sleep_cookie(adapter,
1920 						       MWIFIEX_MAX_DELAY_COUNT);
1921 			mwifiex_unmap_pci_memory(adapter, skb,
1922 						 DMA_FROM_DEVICE);
1923 			skb_pull(skb, adapter->intf_hdr_len);
1924 			while (reg->sleep_cookie && (count++ < 10) &&
1925 			       mwifiex_pcie_ok_to_access_hw(adapter))
1926 				usleep_range(50, 60);
1927 			mwifiex_pcie_enable_host_int(adapter);
1928 			mwifiex_process_sleep_confirm_resp(adapter, skb->data,
1929 							   skb->len);
1930 		} else {
1931 			mwifiex_dbg(adapter, ERROR,
1932 				    "There is no command but got cmdrsp\n");
1933 		}
1934 		memcpy(adapter->upld_buf, skb->data,
1935 		       min_t(u32, MWIFIEX_SIZE_OF_CMD_BUFFER, skb->len));
1936 		skb_push(skb, adapter->intf_hdr_len);
1937 		if (mwifiex_map_pci_memory(adapter, skb, MWIFIEX_UPLD_SIZE,
1938 					   DMA_FROM_DEVICE))
1939 			return -1;
1940 	} else if (mwifiex_pcie_ok_to_access_hw(adapter)) {
1941 		skb_pull(skb, adapter->intf_hdr_len);
1942 		adapter->curr_cmd->resp_skb = skb;
1943 		adapter->cmd_resp_received = true;
1944 		/* Take the pointer and set it to CMD node and will
1945 		   return in the response complete callback */
1946 		card->cmdrsp_buf = NULL;
1947 
1948 		/* Clear the cmd-rsp buffer address in scratch registers. This
1949 		   will prevent firmware from writing to the same response
1950 		   buffer again. */
1951 		if (mwifiex_write_reg(adapter, reg->cmdrsp_addr_lo, 0)) {
1952 			mwifiex_dbg(adapter, ERROR,
1953 				    "cmd_done: failed to clear cmd_rsp_addr_lo\n");
1954 			return -1;
1955 		}
1956 		/* Write the upper 32bits of the cmdrsp buffer physical
1957 		   address */
1958 		if (mwifiex_write_reg(adapter, reg->cmdrsp_addr_hi, 0)) {
1959 			mwifiex_dbg(adapter, ERROR,
1960 				    "cmd_done: failed to clear cmd_rsp_addr_hi\n");
1961 			return -1;
1962 		}
1963 	}
1964 
1965 	return 0;
1966 }
1967 
1968 /*
1969  * Command Response processing complete handler
1970  */
1971 static int mwifiex_pcie_cmdrsp_complete(struct mwifiex_adapter *adapter,
1972 					struct sk_buff *skb)
1973 {
1974 	struct pcie_service_card *card = adapter->card;
1975 
1976 	if (skb) {
1977 		card->cmdrsp_buf = skb;
1978 		skb_push(card->cmdrsp_buf, adapter->intf_hdr_len);
1979 		if (mwifiex_map_pci_memory(adapter, skb, MWIFIEX_UPLD_SIZE,
1980 					   DMA_FROM_DEVICE))
1981 			return -1;
1982 	}
1983 
1984 	return 0;
1985 }
1986 
1987 /*
1988  * This function handles firmware event ready interrupt
1989  */
1990 static int mwifiex_pcie_process_event_ready(struct mwifiex_adapter *adapter)
1991 {
1992 	struct pcie_service_card *card = adapter->card;
1993 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
1994 	u32 rdptr = card->evtbd_rdptr & MWIFIEX_EVTBD_MASK;
1995 	u32 wrptr, event;
1996 	struct mwifiex_evt_buf_desc *desc;
1997 
1998 	if (!mwifiex_pcie_ok_to_access_hw(adapter))
1999 		mwifiex_pm_wakeup_card(adapter);
2000 
2001 	if (adapter->event_received) {
2002 		mwifiex_dbg(adapter, EVENT,
2003 			    "info: Event being processed,\t"
2004 			    "do not process this interrupt just yet\n");
2005 		return 0;
2006 	}
2007 
2008 	if (rdptr >= MWIFIEX_MAX_EVT_BD) {
2009 		mwifiex_dbg(adapter, ERROR,
2010 			    "info: Invalid read pointer...\n");
2011 		return -1;
2012 	}
2013 
2014 	/* Read the event ring write pointer set by firmware */
2015 	if (mwifiex_read_reg(adapter, reg->evt_wrptr, &wrptr)) {
2016 		mwifiex_dbg(adapter, ERROR,
2017 			    "EventReady: failed to read reg->evt_wrptr\n");
2018 		return -1;
2019 	}
2020 
2021 	mwifiex_dbg(adapter, EVENT,
2022 		    "info: EventReady: Initial <Rd: 0x%x, Wr: 0x%x>",
2023 		    card->evtbd_rdptr, wrptr);
2024 	if (((wrptr & MWIFIEX_EVTBD_MASK) != (card->evtbd_rdptr
2025 					      & MWIFIEX_EVTBD_MASK)) ||
2026 	    ((wrptr & reg->evt_rollover_ind) ==
2027 	     (card->evtbd_rdptr & reg->evt_rollover_ind))) {
2028 		struct sk_buff *skb_cmd;
2029 		__le16 data_len = 0;
2030 		u16 evt_len;
2031 
2032 		mwifiex_dbg(adapter, INFO,
2033 			    "info: Read Index: %d\n", rdptr);
2034 		skb_cmd = card->evt_buf_list[rdptr];
2035 		mwifiex_unmap_pci_memory(adapter, skb_cmd, DMA_FROM_DEVICE);
2036 
2037 		/* Take the pointer and set it to event pointer in adapter
2038 		   and will return back after event handling callback */
2039 		card->evt_buf_list[rdptr] = NULL;
2040 		desc = card->evtbd_ring[rdptr];
2041 		memset(desc, 0, sizeof(*desc));
2042 
2043 		event = get_unaligned_le32(
2044 			&skb_cmd->data[adapter->intf_hdr_len]);
2045 		adapter->event_cause = event;
2046 		/* The first 4bytes will be the event transfer header
2047 		   len is 2 bytes followed by type which is 2 bytes */
2048 		memcpy(&data_len, skb_cmd->data, sizeof(__le16));
2049 		evt_len = le16_to_cpu(data_len);
2050 		skb_trim(skb_cmd, evt_len);
2051 		skb_pull(skb_cmd, adapter->intf_hdr_len);
2052 		mwifiex_dbg(adapter, EVENT,
2053 			    "info: Event length: %d\n", evt_len);
2054 
2055 		if (evt_len > MWIFIEX_EVENT_HEADER_LEN &&
2056 		    evt_len < MAX_EVENT_SIZE)
2057 			memcpy(adapter->event_body, skb_cmd->data +
2058 			       MWIFIEX_EVENT_HEADER_LEN, evt_len -
2059 			       MWIFIEX_EVENT_HEADER_LEN);
2060 
2061 		adapter->event_received = true;
2062 		adapter->event_skb = skb_cmd;
2063 
2064 		/* Do not update the event read pointer here, wait till the
2065 		   buffer is released. This is just to make things simpler,
2066 		   we need to find a better method of managing these buffers.
2067 		*/
2068 	} else {
2069 		if (mwifiex_write_reg(adapter, PCIE_CPU_INT_EVENT,
2070 				      CPU_INTR_EVENT_DONE)) {
2071 			mwifiex_dbg(adapter, ERROR,
2072 				    "Write register failed\n");
2073 			return -1;
2074 		}
2075 	}
2076 
2077 	return 0;
2078 }
2079 
2080 /*
2081  * Event processing complete handler
2082  */
2083 static int mwifiex_pcie_event_complete(struct mwifiex_adapter *adapter,
2084 				       struct sk_buff *skb)
2085 {
2086 	struct pcie_service_card *card = adapter->card;
2087 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
2088 	int ret = 0;
2089 	u32 rdptr = card->evtbd_rdptr & MWIFIEX_EVTBD_MASK;
2090 	u32 wrptr;
2091 	struct mwifiex_evt_buf_desc *desc;
2092 
2093 	if (!skb)
2094 		return 0;
2095 
2096 	if (rdptr >= MWIFIEX_MAX_EVT_BD) {
2097 		mwifiex_dbg(adapter, ERROR,
2098 			    "event_complete: Invalid rdptr 0x%x\n",
2099 			    rdptr);
2100 		return -EINVAL;
2101 	}
2102 
2103 	/* Read the event ring write pointer set by firmware */
2104 	if (mwifiex_read_reg(adapter, reg->evt_wrptr, &wrptr)) {
2105 		mwifiex_dbg(adapter, ERROR,
2106 			    "event_complete: failed to read reg->evt_wrptr\n");
2107 		return -1;
2108 	}
2109 
2110 	if (!card->evt_buf_list[rdptr]) {
2111 		skb_push(skb, adapter->intf_hdr_len);
2112 		skb_put(skb, MAX_EVENT_SIZE - skb->len);
2113 		if (mwifiex_map_pci_memory(adapter, skb,
2114 					   MAX_EVENT_SIZE,
2115 					   DMA_FROM_DEVICE))
2116 			return -1;
2117 		card->evt_buf_list[rdptr] = skb;
2118 		desc = card->evtbd_ring[rdptr];
2119 		desc->paddr = MWIFIEX_SKB_DMA_ADDR(skb);
2120 		desc->len = (u16)skb->len;
2121 		desc->flags = 0;
2122 		skb = NULL;
2123 	} else {
2124 		mwifiex_dbg(adapter, ERROR,
2125 			    "info: ERROR: buf still valid at index %d, <%p, %p>\n",
2126 			    rdptr, card->evt_buf_list[rdptr], skb);
2127 	}
2128 
2129 	if ((++card->evtbd_rdptr & MWIFIEX_EVTBD_MASK) == MWIFIEX_MAX_EVT_BD) {
2130 		card->evtbd_rdptr = ((card->evtbd_rdptr &
2131 					reg->evt_rollover_ind) ^
2132 					reg->evt_rollover_ind);
2133 	}
2134 
2135 	mwifiex_dbg(adapter, EVENT,
2136 		    "info: Updated <Rd: 0x%x, Wr: 0x%x>",
2137 		    card->evtbd_rdptr, wrptr);
2138 
2139 	/* Write the event ring read pointer in to reg->evt_rdptr */
2140 	if (mwifiex_write_reg(adapter, reg->evt_rdptr,
2141 			      card->evtbd_rdptr)) {
2142 		mwifiex_dbg(adapter, ERROR,
2143 			    "event_complete: failed to read reg->evt_rdptr\n");
2144 		return -1;
2145 	}
2146 
2147 	mwifiex_dbg(adapter, EVENT,
2148 		    "info: Check Events Again\n");
2149 	ret = mwifiex_pcie_process_event_ready(adapter);
2150 
2151 	return ret;
2152 }
2153 
2154 /* Combo firmware image is a combination of
2155  * (1) combo crc heaer, start with CMD5
2156  * (2) bluetooth image, start with CMD7, end with CMD6, data wrapped in CMD1.
2157  * (3) wifi image.
2158  *
2159  * This function bypass the header and bluetooth part, return
2160  * the offset of tail wifi-only part. If the image is already wifi-only,
2161  * that is start with CMD1, return 0.
2162  */
2163 
2164 static int mwifiex_extract_wifi_fw(struct mwifiex_adapter *adapter,
2165 				   const void *firmware, u32 firmware_len) {
2166 	const struct mwifiex_fw_data *fwdata;
2167 	u32 offset = 0, data_len, dnld_cmd;
2168 	int ret = 0;
2169 	bool cmd7_before = false, first_cmd = false;
2170 
2171 	while (1) {
2172 		/* Check for integer and buffer overflow */
2173 		if (offset + sizeof(fwdata->header) < sizeof(fwdata->header) ||
2174 		    offset + sizeof(fwdata->header) >= firmware_len) {
2175 			mwifiex_dbg(adapter, ERROR,
2176 				    "extract wifi-only fw failure!\n");
2177 			ret = -1;
2178 			goto done;
2179 		}
2180 
2181 		fwdata = firmware + offset;
2182 		dnld_cmd = le32_to_cpu(fwdata->header.dnld_cmd);
2183 		data_len = le32_to_cpu(fwdata->header.data_length);
2184 
2185 		/* Skip past header */
2186 		offset += sizeof(fwdata->header);
2187 
2188 		switch (dnld_cmd) {
2189 		case MWIFIEX_FW_DNLD_CMD_1:
2190 			if (offset + data_len < data_len) {
2191 				mwifiex_dbg(adapter, ERROR, "bad FW parse\n");
2192 				ret = -1;
2193 				goto done;
2194 			}
2195 
2196 			/* Image start with cmd1, already wifi-only firmware */
2197 			if (!first_cmd) {
2198 				mwifiex_dbg(adapter, MSG,
2199 					    "input wifi-only firmware\n");
2200 				return 0;
2201 			}
2202 
2203 			if (!cmd7_before) {
2204 				mwifiex_dbg(adapter, ERROR,
2205 					    "no cmd7 before cmd1!\n");
2206 				ret = -1;
2207 				goto done;
2208 			}
2209 			offset += data_len;
2210 			break;
2211 		case MWIFIEX_FW_DNLD_CMD_5:
2212 			first_cmd = true;
2213 			/* Check for integer overflow */
2214 			if (offset + data_len < data_len) {
2215 				mwifiex_dbg(adapter, ERROR, "bad FW parse\n");
2216 				ret = -1;
2217 				goto done;
2218 			}
2219 			offset += data_len;
2220 			break;
2221 		case MWIFIEX_FW_DNLD_CMD_6:
2222 			first_cmd = true;
2223 			/* Check for integer overflow */
2224 			if (offset + data_len < data_len) {
2225 				mwifiex_dbg(adapter, ERROR, "bad FW parse\n");
2226 				ret = -1;
2227 				goto done;
2228 			}
2229 			offset += data_len;
2230 			if (offset >= firmware_len) {
2231 				mwifiex_dbg(adapter, ERROR,
2232 					    "extract wifi-only fw failure!\n");
2233 				ret = -1;
2234 			} else {
2235 				ret = offset;
2236 			}
2237 			goto done;
2238 		case MWIFIEX_FW_DNLD_CMD_7:
2239 			first_cmd = true;
2240 			cmd7_before = true;
2241 			break;
2242 		default:
2243 			mwifiex_dbg(adapter, ERROR, "unknown dnld_cmd %d\n",
2244 				    dnld_cmd);
2245 			ret = -1;
2246 			goto done;
2247 		}
2248 	}
2249 
2250 done:
2251 	return ret;
2252 }
2253 
2254 /*
2255  * This function downloads the firmware to the card.
2256  *
2257  * Firmware is downloaded to the card in blocks. Every block download
2258  * is tested for CRC errors, and retried a number of times before
2259  * returning failure.
2260  */
2261 static int mwifiex_prog_fw_w_helper(struct mwifiex_adapter *adapter,
2262 				    struct mwifiex_fw_image *fw)
2263 {
2264 	int ret;
2265 	u8 *firmware = fw->fw_buf;
2266 	u32 firmware_len = fw->fw_len;
2267 	u32 offset = 0;
2268 	struct sk_buff *skb;
2269 	u32 txlen, tx_blocks = 0, tries, len, val;
2270 	u32 block_retry_cnt = 0;
2271 	struct pcie_service_card *card = adapter->card;
2272 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
2273 
2274 	if (!firmware || !firmware_len) {
2275 		mwifiex_dbg(adapter, ERROR,
2276 			    "No firmware image found! Terminating download\n");
2277 		return -1;
2278 	}
2279 
2280 	mwifiex_dbg(adapter, INFO,
2281 		    "info: Downloading FW image (%d bytes)\n",
2282 		    firmware_len);
2283 
2284 	if (mwifiex_pcie_disable_host_int(adapter)) {
2285 		mwifiex_dbg(adapter, ERROR,
2286 			    "%s: Disabling interrupts failed.\n", __func__);
2287 		return -1;
2288 	}
2289 
2290 	skb = dev_alloc_skb(MWIFIEX_UPLD_SIZE);
2291 	if (!skb) {
2292 		ret = -ENOMEM;
2293 		goto done;
2294 	}
2295 
2296 	ret = mwifiex_read_reg(adapter, PCIE_SCRATCH_13_REG, &val);
2297 	if (ret) {
2298 		mwifiex_dbg(adapter, FATAL, "Failed to read scratch register 13\n");
2299 		goto done;
2300 	}
2301 
2302 	/* PCIE FLR case: extract wifi part from combo firmware*/
2303 	if (val == MWIFIEX_PCIE_FLR_HAPPENS) {
2304 		ret = mwifiex_extract_wifi_fw(adapter, firmware, firmware_len);
2305 		if (ret < 0) {
2306 			mwifiex_dbg(adapter, ERROR, "Failed to extract wifi fw\n");
2307 			goto done;
2308 		}
2309 		offset = ret;
2310 		mwifiex_dbg(adapter, MSG,
2311 			    "info: dnld wifi firmware from %d bytes\n", offset);
2312 	}
2313 
2314 	/* Perform firmware data transfer */
2315 	do {
2316 		u32 ireg_intr = 0;
2317 
2318 		/* More data? */
2319 		if (offset >= firmware_len)
2320 			break;
2321 
2322 		for (tries = 0; tries < MAX_POLL_TRIES; tries++) {
2323 			ret = mwifiex_read_reg(adapter, reg->cmd_size,
2324 					       &len);
2325 			if (ret) {
2326 				mwifiex_dbg(adapter, FATAL,
2327 					    "Failed reading len from boot code\n");
2328 				goto done;
2329 			}
2330 			if (len)
2331 				break;
2332 			usleep_range(10, 20);
2333 		}
2334 
2335 		if (!len) {
2336 			break;
2337 		} else if (len > MWIFIEX_UPLD_SIZE) {
2338 			mwifiex_dbg(adapter, ERROR,
2339 				    "FW download failure @ %d, invalid length %d\n",
2340 				    offset, len);
2341 			ret = -1;
2342 			goto done;
2343 		}
2344 
2345 		txlen = len;
2346 
2347 		if (len & BIT(0)) {
2348 			block_retry_cnt++;
2349 			if (block_retry_cnt > MAX_WRITE_IOMEM_RETRY) {
2350 				mwifiex_dbg(adapter, ERROR,
2351 					    "FW download failure @ %d, over max\t"
2352 					    "retry count\n", offset);
2353 				ret = -1;
2354 				goto done;
2355 			}
2356 			mwifiex_dbg(adapter, ERROR,
2357 				    "FW CRC error indicated by the\t"
2358 				    "helper: len = 0x%04X, txlen = %d\n",
2359 				    len, txlen);
2360 			len &= ~BIT(0);
2361 			/* Setting this to 0 to resend from same offset */
2362 			txlen = 0;
2363 		} else {
2364 			block_retry_cnt = 0;
2365 			/* Set blocksize to transfer - checking for
2366 			   last block */
2367 			if (firmware_len - offset < txlen)
2368 				txlen = firmware_len - offset;
2369 
2370 			tx_blocks = (txlen + card->pcie.blksz_fw_dl - 1) /
2371 				    card->pcie.blksz_fw_dl;
2372 
2373 			/* Copy payload to buffer */
2374 			memmove(skb->data, &firmware[offset], txlen);
2375 		}
2376 
2377 		skb_put(skb, MWIFIEX_UPLD_SIZE - skb->len);
2378 		skb_trim(skb, tx_blocks * card->pcie.blksz_fw_dl);
2379 
2380 		/* Send the boot command to device */
2381 		if (mwifiex_pcie_send_boot_cmd(adapter, skb)) {
2382 			mwifiex_dbg(adapter, ERROR,
2383 				    "Failed to send firmware download command\n");
2384 			ret = -1;
2385 			goto done;
2386 		}
2387 
2388 		/* Wait for the command done interrupt */
2389 		for (tries = 0; tries < MAX_POLL_TRIES; tries++) {
2390 			if (mwifiex_read_reg(adapter, PCIE_CPU_INT_STATUS,
2391 					     &ireg_intr)) {
2392 				mwifiex_dbg(adapter, ERROR,
2393 					    "%s: Failed to read\t"
2394 					    "interrupt status during fw dnld.\n",
2395 					    __func__);
2396 				mwifiex_unmap_pci_memory(adapter, skb,
2397 							 DMA_TO_DEVICE);
2398 				ret = -1;
2399 				goto done;
2400 			}
2401 			if (!(ireg_intr & CPU_INTR_DOOR_BELL))
2402 				break;
2403 			usleep_range(10, 20);
2404 		}
2405 		if (ireg_intr & CPU_INTR_DOOR_BELL) {
2406 			mwifiex_dbg(adapter, ERROR, "%s: Card failed to ACK download\n",
2407 				    __func__);
2408 			mwifiex_unmap_pci_memory(adapter, skb,
2409 						 DMA_TO_DEVICE);
2410 			ret = -1;
2411 			goto done;
2412 		}
2413 
2414 		mwifiex_unmap_pci_memory(adapter, skb, DMA_TO_DEVICE);
2415 
2416 		offset += txlen;
2417 	} while (true);
2418 
2419 	mwifiex_dbg(adapter, MSG,
2420 		    "info: FW download over, size %d bytes\n", offset);
2421 
2422 	ret = 0;
2423 
2424 done:
2425 	dev_kfree_skb_any(skb);
2426 	return ret;
2427 }
2428 
2429 /*
2430  * This function checks the firmware status in card.
2431  */
2432 static int
2433 mwifiex_check_fw_status(struct mwifiex_adapter *adapter, u32 poll_num)
2434 {
2435 	int ret = 0;
2436 	u32 firmware_stat;
2437 	struct pcie_service_card *card = adapter->card;
2438 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
2439 	u32 tries;
2440 
2441 	/* Mask spurios interrupts */
2442 	if (mwifiex_write_reg(adapter, PCIE_HOST_INT_STATUS_MASK,
2443 			      HOST_INTR_MASK)) {
2444 		mwifiex_dbg(adapter, ERROR,
2445 			    "Write register failed\n");
2446 		return -1;
2447 	}
2448 
2449 	mwifiex_dbg(adapter, INFO,
2450 		    "Setting driver ready signature\n");
2451 	if (mwifiex_write_reg(adapter, reg->drv_rdy,
2452 			      FIRMWARE_READY_PCIE)) {
2453 		mwifiex_dbg(adapter, ERROR,
2454 			    "Failed to write driver ready signature\n");
2455 		return -1;
2456 	}
2457 
2458 	/* Wait for firmware initialization event */
2459 	for (tries = 0; tries < poll_num; tries++) {
2460 		if (mwifiex_read_reg(adapter, reg->fw_status,
2461 				     &firmware_stat))
2462 			ret = -1;
2463 		else
2464 			ret = 0;
2465 
2466 		mwifiex_dbg(adapter, INFO, "Try %d if FW is ready <%d,%#x>",
2467 			    tries, ret, firmware_stat);
2468 
2469 		if (ret)
2470 			continue;
2471 		if (firmware_stat == FIRMWARE_READY_PCIE) {
2472 			ret = 0;
2473 			break;
2474 		} else {
2475 			msleep(100);
2476 			ret = -1;
2477 		}
2478 	}
2479 
2480 	return ret;
2481 }
2482 
2483 /* This function checks if WLAN is the winner.
2484  */
2485 static int
2486 mwifiex_check_winner_status(struct mwifiex_adapter *adapter)
2487 {
2488 	u32 winner = 0;
2489 	int ret = 0;
2490 	struct pcie_service_card *card = adapter->card;
2491 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
2492 
2493 	if (mwifiex_read_reg(adapter, reg->fw_status, &winner)) {
2494 		ret = -1;
2495 	} else if (!winner) {
2496 		mwifiex_dbg(adapter, INFO, "PCI-E is the winner\n");
2497 		adapter->winner = 1;
2498 	} else {
2499 		mwifiex_dbg(adapter, ERROR,
2500 			    "PCI-E is not the winner <%#x>", winner);
2501 	}
2502 
2503 	return ret;
2504 }
2505 
2506 /*
2507  * This function reads the interrupt status from card.
2508  */
2509 static void mwifiex_interrupt_status(struct mwifiex_adapter *adapter,
2510 				     int msg_id)
2511 {
2512 	u32 pcie_ireg;
2513 	unsigned long flags;
2514 	struct pcie_service_card *card = adapter->card;
2515 
2516 	if (card->msi_enable) {
2517 		spin_lock_irqsave(&adapter->int_lock, flags);
2518 		adapter->int_status = 1;
2519 		spin_unlock_irqrestore(&adapter->int_lock, flags);
2520 		return;
2521 	}
2522 
2523 	if (!mwifiex_pcie_ok_to_access_hw(adapter))
2524 		return;
2525 
2526 	if (card->msix_enable && msg_id >= 0) {
2527 		pcie_ireg = BIT(msg_id);
2528 	} else {
2529 		if (mwifiex_read_reg(adapter, PCIE_HOST_INT_STATUS,
2530 				     &pcie_ireg)) {
2531 			mwifiex_dbg(adapter, ERROR, "Read register failed\n");
2532 			return;
2533 		}
2534 
2535 		if ((pcie_ireg == 0xFFFFFFFF) || !pcie_ireg)
2536 			return;
2537 
2538 
2539 		mwifiex_pcie_disable_host_int(adapter);
2540 
2541 		/* Clear the pending interrupts */
2542 		if (mwifiex_write_reg(adapter, PCIE_HOST_INT_STATUS,
2543 				      ~pcie_ireg)) {
2544 			mwifiex_dbg(adapter, ERROR,
2545 				    "Write register failed\n");
2546 			return;
2547 		}
2548 	}
2549 
2550 	if (!adapter->pps_uapsd_mode &&
2551 	    adapter->ps_state == PS_STATE_SLEEP &&
2552 	    mwifiex_pcie_ok_to_access_hw(adapter)) {
2553 		/* Potentially for PCIe we could get other
2554 		 * interrupts like shared. Don't change power
2555 		 * state until cookie is set
2556 		 */
2557 		adapter->ps_state = PS_STATE_AWAKE;
2558 		adapter->pm_wakeup_fw_try = false;
2559 		del_timer(&adapter->wakeup_timer);
2560 	}
2561 
2562 	spin_lock_irqsave(&adapter->int_lock, flags);
2563 	adapter->int_status |= pcie_ireg;
2564 	spin_unlock_irqrestore(&adapter->int_lock, flags);
2565 	mwifiex_dbg(adapter, INTR, "ireg: 0x%08x\n", pcie_ireg);
2566 }
2567 
2568 /*
2569  * Interrupt handler for PCIe root port
2570  *
2571  * This function reads the interrupt status from firmware and assigns
2572  * the main process in workqueue which will handle the interrupt.
2573  */
2574 static irqreturn_t mwifiex_pcie_interrupt(int irq, void *context)
2575 {
2576 	struct mwifiex_msix_context *ctx = context;
2577 	struct pci_dev *pdev = ctx->dev;
2578 	struct pcie_service_card *card;
2579 	struct mwifiex_adapter *adapter;
2580 
2581 	card = pci_get_drvdata(pdev);
2582 
2583 	if (!card->adapter) {
2584 		pr_err("info: %s: card=%p adapter=%p\n", __func__, card,
2585 		       card ? card->adapter : NULL);
2586 		goto exit;
2587 	}
2588 	adapter = card->adapter;
2589 
2590 	if (test_bit(MWIFIEX_SURPRISE_REMOVED, &adapter->work_flags))
2591 		goto exit;
2592 
2593 	if (card->msix_enable)
2594 		mwifiex_interrupt_status(adapter, ctx->msg_id);
2595 	else
2596 		mwifiex_interrupt_status(adapter, -1);
2597 
2598 	mwifiex_queue_main_work(adapter);
2599 
2600 exit:
2601 	return IRQ_HANDLED;
2602 }
2603 
2604 /*
2605  * This function checks the current interrupt status.
2606  *
2607  * The following interrupts are checked and handled by this function -
2608  *      - Data sent
2609  *      - Command sent
2610  *      - Command received
2611  *      - Packets received
2612  *      - Events received
2613  *
2614  * In case of Rx packets received, the packets are uploaded from card to
2615  * host and processed accordingly.
2616  */
2617 static int mwifiex_process_int_status(struct mwifiex_adapter *adapter)
2618 {
2619 	int ret;
2620 	u32 pcie_ireg = 0;
2621 	unsigned long flags;
2622 	struct pcie_service_card *card = adapter->card;
2623 
2624 	spin_lock_irqsave(&adapter->int_lock, flags);
2625 	if (!card->msi_enable) {
2626 		/* Clear out unused interrupts */
2627 		pcie_ireg = adapter->int_status;
2628 	}
2629 	adapter->int_status = 0;
2630 	spin_unlock_irqrestore(&adapter->int_lock, flags);
2631 
2632 	if (card->msi_enable) {
2633 		if (mwifiex_pcie_ok_to_access_hw(adapter)) {
2634 			if (mwifiex_read_reg(adapter, PCIE_HOST_INT_STATUS,
2635 					     &pcie_ireg)) {
2636 				mwifiex_dbg(adapter, ERROR,
2637 					    "Read register failed\n");
2638 				return -1;
2639 			}
2640 
2641 			if ((pcie_ireg != 0xFFFFFFFF) && (pcie_ireg)) {
2642 				if (mwifiex_write_reg(adapter,
2643 						      PCIE_HOST_INT_STATUS,
2644 						      ~pcie_ireg)) {
2645 					mwifiex_dbg(adapter, ERROR,
2646 						    "Write register failed\n");
2647 					return -1;
2648 				}
2649 				if (!adapter->pps_uapsd_mode &&
2650 				    adapter->ps_state == PS_STATE_SLEEP) {
2651 					adapter->ps_state = PS_STATE_AWAKE;
2652 					adapter->pm_wakeup_fw_try = false;
2653 					del_timer(&adapter->wakeup_timer);
2654 				}
2655 			}
2656 		}
2657 	}
2658 
2659 	if (pcie_ireg & HOST_INTR_DNLD_DONE) {
2660 		mwifiex_dbg(adapter, INTR, "info: TX DNLD Done\n");
2661 		ret = mwifiex_pcie_send_data_complete(adapter);
2662 		if (ret)
2663 			return ret;
2664 	}
2665 	if (pcie_ireg & HOST_INTR_UPLD_RDY) {
2666 		mwifiex_dbg(adapter, INTR, "info: Rx DATA\n");
2667 		ret = mwifiex_pcie_process_recv_data(adapter);
2668 		if (ret)
2669 			return ret;
2670 	}
2671 	if (pcie_ireg & HOST_INTR_EVENT_RDY) {
2672 		mwifiex_dbg(adapter, INTR, "info: Rx EVENT\n");
2673 		ret = mwifiex_pcie_process_event_ready(adapter);
2674 		if (ret)
2675 			return ret;
2676 	}
2677 	if (pcie_ireg & HOST_INTR_CMD_DONE) {
2678 		if (adapter->cmd_sent) {
2679 			mwifiex_dbg(adapter, INTR,
2680 				    "info: CMD sent Interrupt\n");
2681 			adapter->cmd_sent = false;
2682 		}
2683 		/* Handle command response */
2684 		ret = mwifiex_pcie_process_cmd_complete(adapter);
2685 		if (ret)
2686 			return ret;
2687 	}
2688 
2689 	mwifiex_dbg(adapter, INTR,
2690 		    "info: cmd_sent=%d data_sent=%d\n",
2691 		    adapter->cmd_sent, adapter->data_sent);
2692 	if (!card->msi_enable && !card->msix_enable &&
2693 				 adapter->ps_state != PS_STATE_SLEEP)
2694 		mwifiex_pcie_enable_host_int(adapter);
2695 
2696 	return 0;
2697 }
2698 
2699 /*
2700  * This function downloads data from driver to card.
2701  *
2702  * Both commands and data packets are transferred to the card by this
2703  * function.
2704  *
2705  * This function adds the PCIE specific header to the front of the buffer
2706  * before transferring. The header contains the length of the packet and
2707  * the type. The firmware handles the packets based upon this set type.
2708  */
2709 static int mwifiex_pcie_host_to_card(struct mwifiex_adapter *adapter, u8 type,
2710 				     struct sk_buff *skb,
2711 				     struct mwifiex_tx_param *tx_param)
2712 {
2713 	if (!skb) {
2714 		mwifiex_dbg(adapter, ERROR,
2715 			    "Passed NULL skb to %s\n", __func__);
2716 		return -1;
2717 	}
2718 
2719 	if (type == MWIFIEX_TYPE_DATA)
2720 		return mwifiex_pcie_send_data(adapter, skb, tx_param);
2721 	else if (type == MWIFIEX_TYPE_CMD)
2722 		return mwifiex_pcie_send_cmd(adapter, skb);
2723 
2724 	return 0;
2725 }
2726 
2727 /* Function to dump PCIE scratch registers in case of FW crash
2728  */
2729 static int
2730 mwifiex_pcie_reg_dump(struct mwifiex_adapter *adapter, char *drv_buf)
2731 {
2732 	char *p = drv_buf;
2733 	char buf[256], *ptr;
2734 	int i;
2735 	u32 value;
2736 	struct pcie_service_card *card = adapter->card;
2737 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
2738 	int pcie_scratch_reg[] = {PCIE_SCRATCH_12_REG,
2739 				  PCIE_SCRATCH_14_REG,
2740 				  PCIE_SCRATCH_15_REG};
2741 
2742 	if (!p)
2743 		return 0;
2744 
2745 	mwifiex_dbg(adapter, MSG, "PCIE register dump start\n");
2746 
2747 	if (mwifiex_read_reg(adapter, reg->fw_status, &value)) {
2748 		mwifiex_dbg(adapter, ERROR, "failed to read firmware status");
2749 		return 0;
2750 	}
2751 
2752 	ptr = buf;
2753 	mwifiex_dbg(adapter, MSG, "pcie scratch register:");
2754 	for (i = 0; i < ARRAY_SIZE(pcie_scratch_reg); i++) {
2755 		mwifiex_read_reg(adapter, pcie_scratch_reg[i], &value);
2756 		ptr += sprintf(ptr, "reg:0x%x, value=0x%x\n",
2757 			       pcie_scratch_reg[i], value);
2758 	}
2759 
2760 	mwifiex_dbg(adapter, MSG, "%s\n", buf);
2761 	p += sprintf(p, "%s\n", buf);
2762 
2763 	mwifiex_dbg(adapter, MSG, "PCIE register dump end\n");
2764 
2765 	return p - drv_buf;
2766 }
2767 
2768 /* This function read/write firmware */
2769 static enum rdwr_status
2770 mwifiex_pcie_rdwr_firmware(struct mwifiex_adapter *adapter, u8 doneflag)
2771 {
2772 	int ret, tries;
2773 	u8 ctrl_data;
2774 	u32 fw_status;
2775 	struct pcie_service_card *card = adapter->card;
2776 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
2777 
2778 	if (mwifiex_read_reg(adapter, reg->fw_status, &fw_status))
2779 		return RDWR_STATUS_FAILURE;
2780 
2781 	ret = mwifiex_write_reg(adapter, reg->fw_dump_ctrl,
2782 				reg->fw_dump_host_ready);
2783 	if (ret) {
2784 		mwifiex_dbg(adapter, ERROR,
2785 			    "PCIE write err\n");
2786 		return RDWR_STATUS_FAILURE;
2787 	}
2788 
2789 	for (tries = 0; tries < MAX_POLL_TRIES; tries++) {
2790 		mwifiex_read_reg_byte(adapter, reg->fw_dump_ctrl, &ctrl_data);
2791 		if (ctrl_data == FW_DUMP_DONE)
2792 			return RDWR_STATUS_SUCCESS;
2793 		if (doneflag && ctrl_data == doneflag)
2794 			return RDWR_STATUS_DONE;
2795 		if (ctrl_data != reg->fw_dump_host_ready) {
2796 			mwifiex_dbg(adapter, WARN,
2797 				    "The ctrl reg was changed, re-try again!\n");
2798 			ret = mwifiex_write_reg(adapter, reg->fw_dump_ctrl,
2799 						reg->fw_dump_host_ready);
2800 			if (ret) {
2801 				mwifiex_dbg(adapter, ERROR,
2802 					    "PCIE write err\n");
2803 				return RDWR_STATUS_FAILURE;
2804 			}
2805 		}
2806 		usleep_range(100, 200);
2807 	}
2808 
2809 	mwifiex_dbg(adapter, ERROR, "Fail to pull ctrl_data\n");
2810 	return RDWR_STATUS_FAILURE;
2811 }
2812 
2813 /* This function dump firmware memory to file */
2814 static void mwifiex_pcie_fw_dump(struct mwifiex_adapter *adapter)
2815 {
2816 	struct pcie_service_card *card = adapter->card;
2817 	const struct mwifiex_pcie_card_reg *creg = card->pcie.reg;
2818 	unsigned int reg, reg_start, reg_end;
2819 	u8 *dbg_ptr, *end_ptr, *tmp_ptr, fw_dump_num, dump_num;
2820 	u8 idx, i, read_reg, doneflag = 0;
2821 	enum rdwr_status stat;
2822 	u32 memory_size;
2823 	int ret;
2824 
2825 	if (!card->pcie.can_dump_fw)
2826 		return;
2827 
2828 	for (idx = 0; idx < adapter->num_mem_types; idx++) {
2829 		struct memory_type_mapping *entry =
2830 				&adapter->mem_type_mapping_tbl[idx];
2831 
2832 		if (entry->mem_ptr) {
2833 			vfree(entry->mem_ptr);
2834 			entry->mem_ptr = NULL;
2835 		}
2836 		entry->mem_size = 0;
2837 	}
2838 
2839 	mwifiex_dbg(adapter, MSG, "== mwifiex firmware dump start ==\n");
2840 
2841 	/* Read the number of the memories which will dump */
2842 	stat = mwifiex_pcie_rdwr_firmware(adapter, doneflag);
2843 	if (stat == RDWR_STATUS_FAILURE)
2844 		return;
2845 
2846 	reg = creg->fw_dump_start;
2847 	mwifiex_read_reg_byte(adapter, reg, &fw_dump_num);
2848 
2849 	/* W8997 chipset firmware dump will be restore in single region*/
2850 	if (fw_dump_num == 0)
2851 		dump_num = 1;
2852 	else
2853 		dump_num = fw_dump_num;
2854 
2855 	/* Read the length of every memory which will dump */
2856 	for (idx = 0; idx < dump_num; idx++) {
2857 		struct memory_type_mapping *entry =
2858 				&adapter->mem_type_mapping_tbl[idx];
2859 		memory_size = 0;
2860 		if (fw_dump_num != 0) {
2861 			stat = mwifiex_pcie_rdwr_firmware(adapter, doneflag);
2862 			if (stat == RDWR_STATUS_FAILURE)
2863 				return;
2864 
2865 			reg = creg->fw_dump_start;
2866 			for (i = 0; i < 4; i++) {
2867 				mwifiex_read_reg_byte(adapter, reg, &read_reg);
2868 				memory_size |= (read_reg << (i * 8));
2869 				reg++;
2870 			}
2871 		} else {
2872 			memory_size = MWIFIEX_FW_DUMP_MAX_MEMSIZE;
2873 		}
2874 
2875 		if (memory_size == 0) {
2876 			mwifiex_dbg(adapter, MSG, "Firmware dump Finished!\n");
2877 			ret = mwifiex_write_reg(adapter, creg->fw_dump_ctrl,
2878 						creg->fw_dump_read_done);
2879 			if (ret) {
2880 				mwifiex_dbg(adapter, ERROR, "PCIE write err\n");
2881 				return;
2882 			}
2883 			break;
2884 		}
2885 
2886 		mwifiex_dbg(adapter, DUMP,
2887 			    "%s_SIZE=0x%x\n", entry->mem_name, memory_size);
2888 		entry->mem_ptr = vmalloc(memory_size + 1);
2889 		entry->mem_size = memory_size;
2890 		if (!entry->mem_ptr) {
2891 			mwifiex_dbg(adapter, ERROR,
2892 				    "Vmalloc %s failed\n", entry->mem_name);
2893 			return;
2894 		}
2895 		dbg_ptr = entry->mem_ptr;
2896 		end_ptr = dbg_ptr + memory_size;
2897 
2898 		doneflag = entry->done_flag;
2899 		mwifiex_dbg(adapter, DUMP, "Start %s output, please wait...\n",
2900 			    entry->mem_name);
2901 
2902 		do {
2903 			stat = mwifiex_pcie_rdwr_firmware(adapter, doneflag);
2904 			if (RDWR_STATUS_FAILURE == stat)
2905 				return;
2906 
2907 			reg_start = creg->fw_dump_start;
2908 			reg_end = creg->fw_dump_end;
2909 			for (reg = reg_start; reg <= reg_end; reg++) {
2910 				mwifiex_read_reg_byte(adapter, reg, dbg_ptr);
2911 				if (dbg_ptr < end_ptr) {
2912 					dbg_ptr++;
2913 					continue;
2914 				}
2915 				mwifiex_dbg(adapter, ERROR,
2916 					    "pre-allocated buf not enough\n");
2917 				tmp_ptr =
2918 					vzalloc(memory_size + MWIFIEX_SIZE_4K);
2919 				if (!tmp_ptr)
2920 					return;
2921 				memcpy(tmp_ptr, entry->mem_ptr, memory_size);
2922 				vfree(entry->mem_ptr);
2923 				entry->mem_ptr = tmp_ptr;
2924 				tmp_ptr = NULL;
2925 				dbg_ptr = entry->mem_ptr + memory_size;
2926 				memory_size += MWIFIEX_SIZE_4K;
2927 				end_ptr = entry->mem_ptr + memory_size;
2928 			}
2929 
2930 			if (stat != RDWR_STATUS_DONE)
2931 				continue;
2932 
2933 			mwifiex_dbg(adapter, DUMP,
2934 				    "%s done: size=0x%tx\n",
2935 				    entry->mem_name, dbg_ptr - entry->mem_ptr);
2936 			break;
2937 		} while (true);
2938 	}
2939 	mwifiex_dbg(adapter, MSG, "== mwifiex firmware dump end ==\n");
2940 }
2941 
2942 static void mwifiex_pcie_device_dump_work(struct mwifiex_adapter *adapter)
2943 {
2944 	adapter->devdump_data = vzalloc(MWIFIEX_FW_DUMP_SIZE);
2945 	if (!adapter->devdump_data) {
2946 		mwifiex_dbg(adapter, ERROR,
2947 			    "vzalloc devdump data failure!\n");
2948 		return;
2949 	}
2950 
2951 	mwifiex_drv_info_dump(adapter);
2952 	mwifiex_pcie_fw_dump(adapter);
2953 	mwifiex_prepare_fw_dump_info(adapter);
2954 	mwifiex_upload_device_dump(adapter);
2955 }
2956 
2957 static void mwifiex_pcie_card_reset_work(struct mwifiex_adapter *adapter)
2958 {
2959 	struct pcie_service_card *card = adapter->card;
2960 
2961 	/* We can't afford to wait here; remove() might be waiting on us. If we
2962 	 * can't grab the device lock, maybe we'll get another chance later.
2963 	 */
2964 	pci_try_reset_function(card->dev);
2965 }
2966 
2967 static void mwifiex_pcie_work(struct work_struct *work)
2968 {
2969 	struct pcie_service_card *card =
2970 		container_of(work, struct pcie_service_card, work);
2971 
2972 	if (test_and_clear_bit(MWIFIEX_IFACE_WORK_DEVICE_DUMP,
2973 			       &card->work_flags))
2974 		mwifiex_pcie_device_dump_work(card->adapter);
2975 	if (test_and_clear_bit(MWIFIEX_IFACE_WORK_CARD_RESET,
2976 			       &card->work_flags))
2977 		mwifiex_pcie_card_reset_work(card->adapter);
2978 }
2979 
2980 /* This function dumps FW information */
2981 static void mwifiex_pcie_device_dump(struct mwifiex_adapter *adapter)
2982 {
2983 	struct pcie_service_card *card = adapter->card;
2984 
2985 	if (!test_and_set_bit(MWIFIEX_IFACE_WORK_DEVICE_DUMP,
2986 			      &card->work_flags))
2987 		schedule_work(&card->work);
2988 }
2989 
2990 static void mwifiex_pcie_card_reset(struct mwifiex_adapter *adapter)
2991 {
2992 	struct pcie_service_card *card = adapter->card;
2993 
2994 	if (!test_and_set_bit(MWIFIEX_IFACE_WORK_CARD_RESET, &card->work_flags))
2995 		schedule_work(&card->work);
2996 }
2997 
2998 static int mwifiex_pcie_alloc_buffers(struct mwifiex_adapter *adapter)
2999 {
3000 	struct pcie_service_card *card = adapter->card;
3001 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
3002 	int ret;
3003 
3004 	card->cmdrsp_buf = NULL;
3005 	ret = mwifiex_pcie_create_txbd_ring(adapter);
3006 	if (ret) {
3007 		mwifiex_dbg(adapter, ERROR, "Failed to create txbd ring\n");
3008 		goto err_cre_txbd;
3009 	}
3010 
3011 	ret = mwifiex_pcie_create_rxbd_ring(adapter);
3012 	if (ret) {
3013 		mwifiex_dbg(adapter, ERROR, "Failed to create rxbd ring\n");
3014 		goto err_cre_rxbd;
3015 	}
3016 
3017 	ret = mwifiex_pcie_create_evtbd_ring(adapter);
3018 	if (ret) {
3019 		mwifiex_dbg(adapter, ERROR, "Failed to create evtbd ring\n");
3020 		goto err_cre_evtbd;
3021 	}
3022 
3023 	ret = mwifiex_pcie_alloc_cmdrsp_buf(adapter);
3024 	if (ret) {
3025 		mwifiex_dbg(adapter, ERROR, "Failed to allocate cmdbuf buffer\n");
3026 		goto err_alloc_cmdbuf;
3027 	}
3028 
3029 	if (reg->sleep_cookie) {
3030 		ret = mwifiex_pcie_alloc_sleep_cookie_buf(adapter);
3031 		if (ret) {
3032 			mwifiex_dbg(adapter, ERROR, "Failed to allocate sleep_cookie buffer\n");
3033 			goto err_alloc_cookie;
3034 		}
3035 	} else {
3036 		card->sleep_cookie_vbase = NULL;
3037 	}
3038 
3039 	return 0;
3040 
3041 err_alloc_cookie:
3042 	mwifiex_pcie_delete_cmdrsp_buf(adapter);
3043 err_alloc_cmdbuf:
3044 	mwifiex_pcie_delete_evtbd_ring(adapter);
3045 err_cre_evtbd:
3046 	mwifiex_pcie_delete_rxbd_ring(adapter);
3047 err_cre_rxbd:
3048 	mwifiex_pcie_delete_txbd_ring(adapter);
3049 err_cre_txbd:
3050 	return ret;
3051 }
3052 
3053 static void mwifiex_pcie_free_buffers(struct mwifiex_adapter *adapter)
3054 {
3055 	struct pcie_service_card *card = adapter->card;
3056 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
3057 
3058 	if (reg->sleep_cookie)
3059 		mwifiex_pcie_delete_sleep_cookie_buf(adapter);
3060 
3061 	mwifiex_pcie_delete_cmdrsp_buf(adapter);
3062 	mwifiex_pcie_delete_evtbd_ring(adapter);
3063 	mwifiex_pcie_delete_rxbd_ring(adapter);
3064 	mwifiex_pcie_delete_txbd_ring(adapter);
3065 }
3066 
3067 /*
3068  * This function initializes the PCI-E host memory space, WCB rings, etc.
3069  */
3070 static int mwifiex_init_pcie(struct mwifiex_adapter *adapter)
3071 {
3072 	struct pcie_service_card *card = adapter->card;
3073 	int ret;
3074 	struct pci_dev *pdev = card->dev;
3075 
3076 	pci_set_drvdata(pdev, card);
3077 
3078 	ret = pci_enable_device(pdev);
3079 	if (ret)
3080 		goto err_enable_dev;
3081 
3082 	pci_set_master(pdev);
3083 
3084 	ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32));
3085 	if (ret) {
3086 		pr_err("dma_set_mask(32) failed: %d\n", ret);
3087 		goto err_set_dma_mask;
3088 	}
3089 
3090 	ret = pci_request_region(pdev, 0, DRV_NAME);
3091 	if (ret) {
3092 		pr_err("req_reg(0) error\n");
3093 		goto err_req_region0;
3094 	}
3095 	card->pci_mmap = pci_iomap(pdev, 0, 0);
3096 	if (!card->pci_mmap) {
3097 		pr_err("iomap(0) error\n");
3098 		ret = -EIO;
3099 		goto err_iomap0;
3100 	}
3101 	ret = pci_request_region(pdev, 2, DRV_NAME);
3102 	if (ret) {
3103 		pr_err("req_reg(2) error\n");
3104 		goto err_req_region2;
3105 	}
3106 	card->pci_mmap1 = pci_iomap(pdev, 2, 0);
3107 	if (!card->pci_mmap1) {
3108 		pr_err("iomap(2) error\n");
3109 		ret = -EIO;
3110 		goto err_iomap2;
3111 	}
3112 
3113 	pr_notice("PCI memory map Virt0: %pK PCI memory map Virt2: %pK\n",
3114 		  card->pci_mmap, card->pci_mmap1);
3115 
3116 	ret = mwifiex_pcie_alloc_buffers(adapter);
3117 	if (ret)
3118 		goto err_alloc_buffers;
3119 
3120 	return 0;
3121 
3122 err_alloc_buffers:
3123 	pci_iounmap(pdev, card->pci_mmap1);
3124 err_iomap2:
3125 	pci_release_region(pdev, 2);
3126 err_req_region2:
3127 	pci_iounmap(pdev, card->pci_mmap);
3128 err_iomap0:
3129 	pci_release_region(pdev, 0);
3130 err_req_region0:
3131 err_set_dma_mask:
3132 	pci_disable_device(pdev);
3133 err_enable_dev:
3134 	return ret;
3135 }
3136 
3137 /*
3138  * This function cleans up the allocated card buffers.
3139  */
3140 static void mwifiex_cleanup_pcie(struct mwifiex_adapter *adapter)
3141 {
3142 	struct pcie_service_card *card = adapter->card;
3143 	struct pci_dev *pdev = card->dev;
3144 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
3145 	u32 fw_status;
3146 
3147 	/* Perform the cancel_work_sync() only when we're not resetting
3148 	 * the card. It's because that function never returns if we're
3149 	 * in reset path. If we're here when resetting the card, it means
3150 	 * that we failed to reset the card (reset failure path).
3151 	 */
3152 	if (!card->pci_reset_ongoing) {
3153 		mwifiex_dbg(adapter, MSG, "performing cancel_work_sync()...\n");
3154 		cancel_work_sync(&card->work);
3155 		mwifiex_dbg(adapter, MSG, "cancel_work_sync() done\n");
3156 	} else {
3157 		mwifiex_dbg(adapter, MSG,
3158 			    "skipped cancel_work_sync() because we're in card reset failure path\n");
3159 	}
3160 
3161 	mwifiex_read_reg(adapter, reg->fw_status, &fw_status);
3162 	if (fw_status == FIRMWARE_READY_PCIE) {
3163 		mwifiex_dbg(adapter, INFO,
3164 			    "Clearing driver ready signature\n");
3165 		if (mwifiex_write_reg(adapter, reg->drv_rdy, 0x00000000))
3166 			mwifiex_dbg(adapter, ERROR,
3167 				    "Failed to write driver not-ready signature\n");
3168 	}
3169 
3170 	pci_disable_device(pdev);
3171 
3172 	pci_iounmap(pdev, card->pci_mmap);
3173 	pci_iounmap(pdev, card->pci_mmap1);
3174 	pci_release_region(pdev, 2);
3175 	pci_release_region(pdev, 0);
3176 
3177 	mwifiex_pcie_free_buffers(adapter);
3178 }
3179 
3180 static int mwifiex_pcie_request_irq(struct mwifiex_adapter *adapter)
3181 {
3182 	int ret, i, j;
3183 	struct pcie_service_card *card = adapter->card;
3184 	struct pci_dev *pdev = card->dev;
3185 
3186 	if (card->pcie.reg->msix_support) {
3187 		for (i = 0; i < MWIFIEX_NUM_MSIX_VECTORS; i++)
3188 			card->msix_entries[i].entry = i;
3189 		ret = pci_enable_msix_exact(pdev, card->msix_entries,
3190 					    MWIFIEX_NUM_MSIX_VECTORS);
3191 		if (!ret) {
3192 			for (i = 0; i < MWIFIEX_NUM_MSIX_VECTORS; i++) {
3193 				card->msix_ctx[i].dev = pdev;
3194 				card->msix_ctx[i].msg_id = i;
3195 
3196 				ret = request_irq(card->msix_entries[i].vector,
3197 						  mwifiex_pcie_interrupt, 0,
3198 						  "MWIFIEX_PCIE_MSIX",
3199 						  &card->msix_ctx[i]);
3200 				if (ret)
3201 					break;
3202 			}
3203 
3204 			if (ret) {
3205 				mwifiex_dbg(adapter, INFO, "request_irq fail: %d\n",
3206 					    ret);
3207 				for (j = 0; j < i; j++)
3208 					free_irq(card->msix_entries[j].vector,
3209 						 &card->msix_ctx[i]);
3210 				pci_disable_msix(pdev);
3211 			} else {
3212 				mwifiex_dbg(adapter, MSG, "MSIx enabled!");
3213 				card->msix_enable = 1;
3214 				return 0;
3215 			}
3216 		}
3217 	}
3218 
3219 	if (pci_enable_msi(pdev) != 0)
3220 		pci_disable_msi(pdev);
3221 	else
3222 		card->msi_enable = 1;
3223 
3224 	mwifiex_dbg(adapter, INFO, "msi_enable = %d\n", card->msi_enable);
3225 
3226 	card->share_irq_ctx.dev = pdev;
3227 	card->share_irq_ctx.msg_id = -1;
3228 	ret = request_irq(pdev->irq, mwifiex_pcie_interrupt, IRQF_SHARED,
3229 			  "MRVL_PCIE", &card->share_irq_ctx);
3230 	if (ret) {
3231 		pr_err("request_irq failed: ret=%d\n", ret);
3232 		return -1;
3233 	}
3234 
3235 	return 0;
3236 }
3237 
3238 /*
3239  * This function gets the firmware name for downloading by revision id
3240  *
3241  * Read revision id register to get revision id
3242  */
3243 static void mwifiex_pcie_get_fw_name(struct mwifiex_adapter *adapter)
3244 {
3245 	int revision_id = 0;
3246 	int version, magic;
3247 	struct pcie_service_card *card = adapter->card;
3248 
3249 	switch (card->dev->device) {
3250 	case PCIE_DEVICE_ID_MARVELL_88W8766P:
3251 		strcpy(adapter->fw_name, PCIE8766_DEFAULT_FW_NAME);
3252 		break;
3253 	case PCIE_DEVICE_ID_MARVELL_88W8897:
3254 		mwifiex_write_reg(adapter, 0x0c58, 0x80c00000);
3255 		mwifiex_read_reg(adapter, 0x0c58, &revision_id);
3256 		revision_id &= 0xff00;
3257 		switch (revision_id) {
3258 		case PCIE8897_A0:
3259 			strcpy(adapter->fw_name, PCIE8897_A0_FW_NAME);
3260 			break;
3261 		case PCIE8897_B0:
3262 			strcpy(adapter->fw_name, PCIE8897_B0_FW_NAME);
3263 			break;
3264 		default:
3265 			strcpy(adapter->fw_name, PCIE8897_DEFAULT_FW_NAME);
3266 
3267 			break;
3268 		}
3269 		break;
3270 	case PCIE_DEVICE_ID_MARVELL_88W8997:
3271 		mwifiex_read_reg(adapter, 0x8, &revision_id);
3272 		mwifiex_read_reg(adapter, 0x0cd0, &version);
3273 		mwifiex_read_reg(adapter, 0x0cd4, &magic);
3274 		revision_id &= 0xff;
3275 		version &= 0x7;
3276 		magic &= 0xff;
3277 		if (revision_id == PCIE8997_A1 &&
3278 		    magic == CHIP_MAGIC_VALUE &&
3279 		    version == CHIP_VER_PCIEUART)
3280 			strcpy(adapter->fw_name, PCIEUART8997_FW_NAME_V4);
3281 		else
3282 			strcpy(adapter->fw_name, PCIEUSB8997_FW_NAME_V4);
3283 		break;
3284 	default:
3285 		break;
3286 	}
3287 }
3288 
3289 /*
3290  * This function registers the PCIE device.
3291  *
3292  * PCIE IRQ is claimed, block size is set and driver data is initialized.
3293  */
3294 static int mwifiex_register_dev(struct mwifiex_adapter *adapter)
3295 {
3296 	struct pcie_service_card *card = adapter->card;
3297 
3298 	/* save adapter pointer in card */
3299 	card->adapter = adapter;
3300 
3301 	if (mwifiex_pcie_request_irq(adapter))
3302 		return -1;
3303 
3304 	adapter->tx_buf_size = card->pcie.tx_buf_size;
3305 	adapter->mem_type_mapping_tbl = card->pcie.mem_type_mapping_tbl;
3306 	adapter->num_mem_types = card->pcie.num_mem_types;
3307 	adapter->ext_scan = card->pcie.can_ext_scan;
3308 	mwifiex_pcie_get_fw_name(adapter);
3309 
3310 	return 0;
3311 }
3312 
3313 /*
3314  * This function unregisters the PCIE device.
3315  *
3316  * The PCIE IRQ is released, the function is disabled and driver
3317  * data is set to null.
3318  */
3319 static void mwifiex_unregister_dev(struct mwifiex_adapter *adapter)
3320 {
3321 	struct pcie_service_card *card = adapter->card;
3322 	struct pci_dev *pdev = card->dev;
3323 	int i;
3324 
3325 	if (card->msix_enable) {
3326 		for (i = 0; i < MWIFIEX_NUM_MSIX_VECTORS; i++)
3327 			synchronize_irq(card->msix_entries[i].vector);
3328 
3329 		for (i = 0; i < MWIFIEX_NUM_MSIX_VECTORS; i++)
3330 			free_irq(card->msix_entries[i].vector,
3331 				 &card->msix_ctx[i]);
3332 
3333 		card->msix_enable = 0;
3334 		pci_disable_msix(pdev);
3335 	} else {
3336 		mwifiex_dbg(adapter, INFO,
3337 			    "%s(): calling free_irq()\n", __func__);
3338 	       free_irq(card->dev->irq, &card->share_irq_ctx);
3339 
3340 		if (card->msi_enable)
3341 			pci_disable_msi(pdev);
3342 	}
3343 	card->adapter = NULL;
3344 }
3345 
3346 /*
3347  * This function initializes the PCI-E host memory space, WCB rings, etc.,
3348  * similar to mwifiex_init_pcie(), but without resetting PCI-E state.
3349  */
3350 static void mwifiex_pcie_up_dev(struct mwifiex_adapter *adapter)
3351 {
3352 	struct pcie_service_card *card = adapter->card;
3353 	struct pci_dev *pdev = card->dev;
3354 
3355 	/* tx_buf_size might be changed to 3584 by firmware during
3356 	 * data transfer, we should reset it to default size.
3357 	 */
3358 	adapter->tx_buf_size = card->pcie.tx_buf_size;
3359 
3360 	mwifiex_pcie_alloc_buffers(adapter);
3361 
3362 	pci_set_master(pdev);
3363 }
3364 
3365 /* This function cleans up the PCI-E host memory space. */
3366 static void mwifiex_pcie_down_dev(struct mwifiex_adapter *adapter)
3367 {
3368 	struct pcie_service_card *card = adapter->card;
3369 	const struct mwifiex_pcie_card_reg *reg = card->pcie.reg;
3370 	struct pci_dev *pdev = card->dev;
3371 
3372 	if (mwifiex_write_reg(adapter, reg->drv_rdy, 0x00000000))
3373 		mwifiex_dbg(adapter, ERROR, "Failed to write driver not-ready signature\n");
3374 
3375 	pci_clear_master(pdev);
3376 
3377 	adapter->seq_num = 0;
3378 
3379 	mwifiex_pcie_free_buffers(adapter);
3380 }
3381 
3382 static struct mwifiex_if_ops pcie_ops = {
3383 	.init_if =			mwifiex_init_pcie,
3384 	.cleanup_if =			mwifiex_cleanup_pcie,
3385 	.check_fw_status =		mwifiex_check_fw_status,
3386 	.check_winner_status =          mwifiex_check_winner_status,
3387 	.prog_fw =			mwifiex_prog_fw_w_helper,
3388 	.register_dev =			mwifiex_register_dev,
3389 	.unregister_dev =		mwifiex_unregister_dev,
3390 	.enable_int =			mwifiex_pcie_enable_host_int,
3391 	.disable_int =			mwifiex_pcie_disable_host_int_noerr,
3392 	.process_int_status =		mwifiex_process_int_status,
3393 	.host_to_card =			mwifiex_pcie_host_to_card,
3394 	.wakeup =			mwifiex_pm_wakeup_card,
3395 	.wakeup_complete =		mwifiex_pm_wakeup_card_complete,
3396 
3397 	/* PCIE specific */
3398 	.cmdrsp_complete =		mwifiex_pcie_cmdrsp_complete,
3399 	.event_complete =		mwifiex_pcie_event_complete,
3400 	.update_mp_end_port =		NULL,
3401 	.cleanup_mpa_buf =		NULL,
3402 	.init_fw_port =			mwifiex_pcie_init_fw_port,
3403 	.clean_pcie_ring =		mwifiex_clean_pcie_ring_buf,
3404 	.card_reset =			mwifiex_pcie_card_reset,
3405 	.reg_dump =			mwifiex_pcie_reg_dump,
3406 	.device_dump =			mwifiex_pcie_device_dump,
3407 	.down_dev =			mwifiex_pcie_down_dev,
3408 	.up_dev =			mwifiex_pcie_up_dev,
3409 };
3410 
3411 module_pci_driver(mwifiex_pcie);
3412 
3413 MODULE_AUTHOR("Marvell International Ltd.");
3414 MODULE_DESCRIPTION("Marvell WiFi-Ex PCI-Express Driver version " PCIE_VERSION);
3415 MODULE_VERSION(PCIE_VERSION);
3416 MODULE_LICENSE("GPL v2");
3417