1 /* SPDX-License-Identifier: GPL-2.0-only
2  *
3  * Copyright (c) 2021, MediaTek Inc.
4  * Copyright (c) 2021-2022, Intel Corporation.
5  *
6  * Authors:
7  *  Haijun Liu <haijun.liu@mediatek.com>
8  *  Moises Veleta <moises.veleta@intel.com>
9  *
10  * Contributors:
11  *  Amir Hanania <amir.hanania@intel.com>
12  *  Chiranjeevi Rapolu <chiranjeevi.rapolu@intel.com>
13  *  Ricardo Martinez <ricardo.martinez@linux.intel.com>
14  */
15 
16 #ifndef __T7XX_NETDEV_H__
17 #define __T7XX_NETDEV_H__
18 
19 #include <linux/bits.h>
20 #include <linux/netdevice.h>
21 #include <linux/types.h>
22 
23 #include "t7xx_hif_dpmaif.h"
24 #include "t7xx_pci.h"
25 #include "t7xx_state_monitor.h"
26 
27 #define RXQ_NUM				DPMAIF_RXQ_NUM
28 #define NIC_DEV_MAX			21
29 #define NIC_DEV_DEFAULT			2
30 
31 #define CCMNI_NETDEV_WDT_TO		(1 * HZ)
32 #define CCMNI_MTU_MAX			3000
33 #define NIC_NAPI_POLL_BUDGET		128
34 
35 struct t7xx_ccmni {
36 	u8				index;
37 	atomic_t			usage;
38 	struct net_device		*dev;
39 	struct t7xx_ccmni_ctrl		*ctlb;
40 };
41 
42 struct t7xx_ccmni_ctrl {
43 	struct t7xx_pci_dev		*t7xx_dev;
44 	struct dpmaif_ctrl		*hif_ctrl;
45 	struct t7xx_ccmni		*ccmni_inst[NIC_DEV_MAX];
46 	struct dpmaif_callbacks		callbacks;
47 	unsigned int			nic_dev_num;
48 	unsigned int			md_sta;
49 	struct t7xx_fsm_notifier	md_status_notify;
50 	bool				wwan_is_registered;
51 	struct net_device		dummy_dev;
52 	struct napi_struct		*napi[RXQ_NUM];
53 	atomic_t			napi_usr_refcnt;
54 	bool				is_napi_en;
55 };
56 
57 int t7xx_ccmni_init(struct t7xx_pci_dev *t7xx_dev);
58 void t7xx_ccmni_exit(struct t7xx_pci_dev *t7xx_dev);
59 
60 #endif /* __T7XX_NETDEV_H__ */
61