1 // SPDX-License-Identifier: GPL-2.0+
2 /* Copyright (c) 2018 Quantenna Communications, Inc. All rights reserved. */
4 #include <linux/module.h>
5 #include <linux/printk.h>
7 #include <linux/spinlock.h>
8 #include <linux/mutex.h>
9 #include <linux/netdevice.h>
10 #include <linux/seq_file.h>
11 #include <linux/workqueue.h>
12 #include <linux/completion.h>
14 #include "pcie_priv.h"
20 #include "qtn_hw_ids.h"
22 #define QTN_SYSCTL_BAR 0
23 #define QTN_SHMEM_BAR 2
26 #define QTN_PCIE_MAX_FW_BUFSZ (1 * 1024 * 1024)
28 static bool use_msi
= true;
29 module_param(use_msi
, bool, 0644);
30 MODULE_PARM_DESC(use_msi
, "set 0 to use legacy interrupt");
32 static unsigned int tx_bd_size_param
;
33 module_param(tx_bd_size_param
, uint
, 0644);
34 MODULE_PARM_DESC(tx_bd_size_param
, "Tx descriptors queue size");
36 static unsigned int rx_bd_size_param
;
37 module_param(rx_bd_size_param
, uint
, 0644);
38 MODULE_PARM_DESC(rx_bd_size_param
, "Rx descriptors queue size");
40 static u8 flashboot
= 1;
41 module_param(flashboot
, byte
, 0644);
42 MODULE_PARM_DESC(flashboot
, "set to 0 to use FW binary file on FS");
44 static unsigned int fw_blksize_param
= QTN_PCIE_MAX_FW_BUFSZ
;
45 module_param(fw_blksize_param
, uint
, 0644);
46 MODULE_PARM_DESC(fw_blksize_param
, "firmware loading block size in bytes");
48 #define DRV_NAME "qtnfmac_pcie"
50 int qtnf_pcie_control_tx(struct qtnf_bus
*bus
, struct sk_buff
*skb
)
52 struct qtnf_pcie_bus_priv
*priv
= get_bus_priv(bus
);
55 ret
= qtnf_shm_ipc_send(&priv
->shm_ipc_ep_in
, skb
->data
, skb
->len
);
57 if (ret
== -ETIMEDOUT
) {
58 pr_err("EP firmware is dead\n");
59 bus
->fw_state
= QTNF_FW_STATE_DEAD
;
65 int qtnf_pcie_alloc_skb_array(struct qtnf_pcie_bus_priv
*priv
)
67 struct sk_buff
**vaddr
;
70 len
= priv
->tx_bd_num
* sizeof(*priv
->tx_skb
) +
71 priv
->rx_bd_num
* sizeof(*priv
->rx_skb
);
72 vaddr
= devm_kzalloc(&priv
->pdev
->dev
, len
, GFP_KERNEL
);
79 vaddr
+= priv
->tx_bd_num
;
85 static void qtnf_pcie_bringup_fw_async(struct qtnf_bus
*bus
)
87 struct qtnf_pcie_bus_priv
*priv
= get_bus_priv(bus
);
88 struct pci_dev
*pdev
= priv
->pdev
;
90 get_device(&pdev
->dev
);
91 schedule_work(&bus
->fw_work
);
94 static int qtnf_dbg_mps_show(struct seq_file
*s
, void *data
)
96 struct qtnf_bus
*bus
= dev_get_drvdata(s
->private);
97 struct qtnf_pcie_bus_priv
*priv
= get_bus_priv(bus
);
99 seq_printf(s
, "%d\n", pcie_get_mps(priv
->pdev
));
104 static int qtnf_dbg_msi_show(struct seq_file
*s
, void *data
)
106 struct qtnf_bus
*bus
= dev_get_drvdata(s
->private);
107 struct qtnf_pcie_bus_priv
*priv
= get_bus_priv(bus
);
109 seq_printf(s
, "%u\n", priv
->msi_enabled
);
114 static int qtnf_dbg_shm_stats(struct seq_file
*s
, void *data
)
116 struct qtnf_bus
*bus
= dev_get_drvdata(s
->private);
117 struct qtnf_pcie_bus_priv
*priv
= get_bus_priv(bus
);
119 seq_printf(s
, "shm_ipc_ep_in.tx_packet_count(%zu)\n",
120 priv
->shm_ipc_ep_in
.tx_packet_count
);
121 seq_printf(s
, "shm_ipc_ep_in.rx_packet_count(%zu)\n",
122 priv
->shm_ipc_ep_in
.rx_packet_count
);
123 seq_printf(s
, "shm_ipc_ep_out.tx_packet_count(%zu)\n",
124 priv
->shm_ipc_ep_out
.tx_timeout_count
);
125 seq_printf(s
, "shm_ipc_ep_out.rx_packet_count(%zu)\n",
126 priv
->shm_ipc_ep_out
.rx_packet_count
);
131 int qtnf_pcie_fw_boot_done(struct qtnf_bus
*bus
)
133 struct qtnf_pcie_bus_priv
*priv
= get_bus_priv(bus
);
137 bus
->fw_state
= QTNF_FW_STATE_BOOT_DONE
;
138 ret
= qtnf_core_attach(bus
);
140 pr_err("failed to attach core\n");
142 snprintf(card_id
, sizeof(card_id
), "%s:%s",
143 DRV_NAME
, pci_name(priv
->pdev
));
144 qtnf_debugfs_init(bus
, card_id
);
145 qtnf_debugfs_add_entry(bus
, "mps", qtnf_dbg_mps_show
);
146 qtnf_debugfs_add_entry(bus
, "msi_enabled", qtnf_dbg_msi_show
);
147 qtnf_debugfs_add_entry(bus
, "shm_stats", qtnf_dbg_shm_stats
);
153 static void qtnf_tune_pcie_mps(struct pci_dev
*pdev
)
155 struct pci_dev
*parent
;
156 int mps_p
, mps_o
, mps_m
, mps
;
160 mps_o
= pcie_get_mps(pdev
);
162 /* maximum supported mps */
163 mps_m
= 128 << pdev
->pcie_mpss
;
165 /* suggested new mps value */
168 if (pdev
->bus
&& pdev
->bus
->self
) {
169 /* parent (bus) mps */
170 parent
= pdev
->bus
->self
;
172 if (pci_is_pcie(parent
)) {
173 mps_p
= pcie_get_mps(parent
);
174 mps
= min(mps_m
, mps_p
);
178 ret
= pcie_set_mps(pdev
, mps
);
180 pr_err("failed to set mps to %d, keep using current %d\n",
185 pr_debug("set mps to %d (was %d, max %d)\n", mps
, mps_o
, mps_m
);
188 static void qtnf_pcie_init_irq(struct qtnf_pcie_bus_priv
*priv
, bool use_msi
)
190 struct pci_dev
*pdev
= priv
->pdev
;
192 /* fall back to legacy INTx interrupts by default */
193 priv
->msi_enabled
= 0;
195 /* check if MSI capability is available */
197 if (!pci_enable_msi(pdev
)) {
198 pr_debug("enabled MSI interrupt\n");
199 priv
->msi_enabled
= 1;
201 pr_warn("failed to enable MSI interrupts");
205 if (!priv
->msi_enabled
) {
206 pr_warn("legacy PCIE interrupts enabled\n");
211 static void __iomem
*qtnf_map_bar(struct pci_dev
*pdev
, u8 index
)
218 ret
= pcim_iomap_regions(pdev
, 1 << index
, "qtnfmac_pcie");
220 return IOMEM_ERR_PTR(ret
);
222 busaddr
= pci_resource_start(pdev
, index
);
223 len
= pci_resource_len(pdev
, index
);
224 vaddr
= pcim_iomap_table(pdev
)[index
];
226 return IOMEM_ERR_PTR(-ENOMEM
);
228 pr_debug("BAR%u vaddr=0x%p busaddr=%pad len=%u\n",
229 index
, vaddr
, &busaddr
, (int)len
);
234 static void qtnf_pcie_control_rx_callback(void *arg
, const u8 __iomem
*buf
,
237 struct qtnf_pcie_bus_priv
*priv
= arg
;
238 struct qtnf_bus
*bus
= pci_get_drvdata(priv
->pdev
);
241 if (unlikely(len
== 0)) {
242 pr_warn("zero length packet received\n");
246 skb
= __dev_alloc_skb(len
, GFP_KERNEL
);
248 if (unlikely(!skb
)) {
249 pr_err("failed to allocate skb\n");
253 memcpy_fromio(skb_put(skb
, len
), buf
, len
);
255 qtnf_trans_handle_rx_ctl_packet(bus
, skb
);
258 void qtnf_pcie_init_shm_ipc(struct qtnf_pcie_bus_priv
*priv
,
259 struct qtnf_shm_ipc_region __iomem
*ipc_tx_reg
,
260 struct qtnf_shm_ipc_region __iomem
*ipc_rx_reg
,
261 const struct qtnf_shm_ipc_int
*ipc_int
)
263 const struct qtnf_shm_ipc_rx_callback rx_callback
= {
264 qtnf_pcie_control_rx_callback
, priv
};
266 qtnf_shm_ipc_init(&priv
->shm_ipc_ep_in
, QTNF_SHM_IPC_OUTBOUND
,
267 ipc_tx_reg
, priv
->workqueue
,
268 ipc_int
, &rx_callback
);
269 qtnf_shm_ipc_init(&priv
->shm_ipc_ep_out
, QTNF_SHM_IPC_INBOUND
,
270 ipc_rx_reg
, priv
->workqueue
,
271 ipc_int
, &rx_callback
);
274 static int qtnf_pcie_probe(struct pci_dev
*pdev
, const struct pci_device_id
*id
)
276 struct qtnf_pcie_bus_priv
*pcie_priv
;
277 struct qtnf_bus
*bus
;
278 void __iomem
*sysctl_bar
;
279 void __iomem
*epmem_bar
;
280 void __iomem
*dmareg_bar
;
284 if (!pci_is_pcie(pdev
)) {
285 pr_err("device %s is not PCI Express\n", pci_name(pdev
));
289 qtnf_tune_pcie_mps(pdev
);
291 ret
= pcim_enable_device(pdev
);
293 pr_err("failed to init PCI device %x\n", pdev
->device
);
297 pci_set_master(pdev
);
299 sysctl_bar
= qtnf_map_bar(pdev
, QTN_SYSCTL_BAR
);
300 if (IS_ERR(sysctl_bar
)) {
301 pr_err("failed to map BAR%u\n", QTN_SYSCTL_BAR
);
302 return PTR_ERR(sysctl_bar
);
305 dmareg_bar
= qtnf_map_bar(pdev
, QTN_DMA_BAR
);
306 if (IS_ERR(dmareg_bar
)) {
307 pr_err("failed to map BAR%u\n", QTN_DMA_BAR
);
308 return PTR_ERR(dmareg_bar
);
311 epmem_bar
= qtnf_map_bar(pdev
, QTN_SHMEM_BAR
);
312 if (IS_ERR(epmem_bar
)) {
313 pr_err("failed to map BAR%u\n", QTN_SHMEM_BAR
);
314 return PTR_ERR(epmem_bar
);
317 chipid
= qtnf_chip_id_get(sysctl_bar
);
319 pr_info("identified device: %s\n", qtnf_chipid_to_string(chipid
));
322 case QTN_CHIP_ID_PEARL
:
323 case QTN_CHIP_ID_PEARL_B
:
324 case QTN_CHIP_ID_PEARL_C
:
325 bus
= qtnf_pcie_pearl_alloc(pdev
);
327 case QTN_CHIP_ID_TOPAZ
:
328 bus
= qtnf_pcie_topaz_alloc(pdev
);
331 pr_err("unsupported chip ID 0x%x\n", chipid
);
338 pcie_priv
= get_bus_priv(bus
);
339 pci_set_drvdata(pdev
, bus
);
340 bus
->dev
= &pdev
->dev
;
341 bus
->fw_state
= QTNF_FW_STATE_DETACHED
;
342 pcie_priv
->pdev
= pdev
;
343 pcie_priv
->tx_stopped
= 0;
344 pcie_priv
->flashboot
= flashboot
;
346 if (fw_blksize_param
> QTN_PCIE_MAX_FW_BUFSZ
)
347 pcie_priv
->fw_blksize
= QTN_PCIE_MAX_FW_BUFSZ
;
349 pcie_priv
->fw_blksize
= fw_blksize_param
;
351 mutex_init(&bus
->bus_lock
);
352 spin_lock_init(&pcie_priv
->tx_lock
);
353 spin_lock_init(&pcie_priv
->tx_reclaim_lock
);
355 pcie_priv
->tx_full_count
= 0;
356 pcie_priv
->tx_done_count
= 0;
357 pcie_priv
->pcie_irq_count
= 0;
358 pcie_priv
->tx_reclaim_done
= 0;
359 pcie_priv
->tx_reclaim_req
= 0;
361 pcie_priv
->workqueue
= create_singlethread_workqueue("QTNF_PCIE");
362 if (!pcie_priv
->workqueue
) {
363 pr_err("failed to alloc bus workqueue\n");
367 ret
= dma_set_mask_and_coherent(&pdev
->dev
,
368 pcie_priv
->dma_mask_get_cb());
370 pr_err("PCIE DMA coherent mask init failed 0x%llx\n",
371 pcie_priv
->dma_mask_get_cb());
375 bus
->mux_dev
= alloc_netdev_dummy(0);
381 qtnf_pcie_init_irq(pcie_priv
, use_msi
);
382 pcie_priv
->sysctl_bar
= sysctl_bar
;
383 pcie_priv
->dmareg_bar
= dmareg_bar
;
384 pcie_priv
->epmem_bar
= epmem_bar
;
385 pci_save_state(pdev
);
387 ret
= pcie_priv
->probe_cb(bus
, tx_bd_size_param
, rx_bd_size_param
);
391 qtnf_pcie_bringup_fw_async(bus
);
395 free_netdev(bus
->mux_dev
);
397 destroy_workqueue(pcie_priv
->workqueue
);
398 pci_set_drvdata(pdev
, NULL
);
402 static void qtnf_pcie_free_shm_ipc(struct qtnf_pcie_bus_priv
*priv
)
404 qtnf_shm_ipc_free(&priv
->shm_ipc_ep_in
);
405 qtnf_shm_ipc_free(&priv
->shm_ipc_ep_out
);
408 static void qtnf_pcie_remove(struct pci_dev
*dev
)
410 struct qtnf_pcie_bus_priv
*priv
;
411 struct qtnf_bus
*bus
;
413 bus
= pci_get_drvdata(dev
);
417 priv
= get_bus_priv(bus
);
419 cancel_work_sync(&bus
->fw_work
);
421 if (qtnf_fw_is_attached(bus
))
422 qtnf_core_detach(bus
);
424 netif_napi_del(&bus
->mux_napi
);
425 destroy_workqueue(priv
->workqueue
);
426 tasklet_kill(&priv
->reclaim_tq
);
427 free_netdev(bus
->mux_dev
);
429 qtnf_pcie_free_shm_ipc(priv
);
430 qtnf_debugfs_remove(bus
);
431 priv
->remove_cb(bus
);
432 pci_set_drvdata(priv
->pdev
, NULL
);
435 #ifdef CONFIG_PM_SLEEP
436 static int qtnf_pcie_suspend(struct device
*dev
)
438 struct qtnf_pcie_bus_priv
*priv
;
439 struct qtnf_bus
*bus
;
441 bus
= dev_get_drvdata(dev
);
445 priv
= get_bus_priv(bus
);
446 return priv
->suspend_cb(bus
);
449 static int qtnf_pcie_resume(struct device
*dev
)
451 struct qtnf_pcie_bus_priv
*priv
;
452 struct qtnf_bus
*bus
;
454 bus
= dev_get_drvdata(dev
);
458 priv
= get_bus_priv(bus
);
459 return priv
->resume_cb(bus
);
462 /* Power Management Hooks */
463 static SIMPLE_DEV_PM_OPS(qtnf_pcie_pm_ops
, qtnf_pcie_suspend
,
467 static const struct pci_device_id qtnf_pcie_devid_table
[] = {
469 PCIE_VENDOR_ID_QUANTENNA
, PCIE_DEVICE_ID_QSR
,
470 PCI_ANY_ID
, PCI_ANY_ID
, 0, 0,
475 MODULE_DEVICE_TABLE(pci
, qtnf_pcie_devid_table
);
477 static struct pci_driver qtnf_pcie_drv_data
= {
479 .id_table
= qtnf_pcie_devid_table
,
480 .probe
= qtnf_pcie_probe
,
481 .remove
= qtnf_pcie_remove
,
482 #ifdef CONFIG_PM_SLEEP
484 .pm
= &qtnf_pcie_pm_ops
,
489 module_pci_driver(qtnf_pcie_drv_data
)
491 MODULE_AUTHOR("Quantenna Communications");
492 MODULE_DESCRIPTION("Quantenna PCIe bus driver for 802.11 wireless LAN.");
493 MODULE_LICENSE("GPL");