Initial commit
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			
		
			
				
	
				Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			
		
			
				
	
				Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			
		
			
				
	
				Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			
		
			
				
	
				Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			
		
			
				
	
				Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
		
	
	
				
					
				
			
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			This commit is contained in:
		
							
								
								
									
										917
									
								
								package/kernel/lantiq/vrx518_tc/patches/100-compat.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										917
									
								
								package/kernel/lantiq/vrx518_tc/patches/100-compat.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,917 @@ | ||||
| --- a/dcdp/atm_tc.c | ||||
| +++ b/dcdp/atm_tc.c | ||||
| @@ -44,9 +44,9 @@ | ||||
|  #include <linux/atmioc.h> | ||||
|  #include <linux/skbuff.h> | ||||
|  #include "inc/dsl_tc.h" | ||||
| -#include <net/datapath_proc_api.h> | ||||
| +// #include <net/datapath_proc_api.h> | ||||
|  #include <linux/atm.h> | ||||
| -#include <net/datapath_api.h> | ||||
| +// #include <net/datapath_api.h> | ||||
|  #include <net/dc_ep.h> | ||||
|  #include<linux/sched.h> | ||||
|  #include<linux/kthread.h> | ||||
| @@ -730,20 +730,16 @@ static void atm_aca_init(struct atm_priv | ||||
|  		ACA_TXOUT_EN | ACA_RXIN_EN | ACA_RXOUT_EN, 1); | ||||
|  } | ||||
|   | ||||
| -static int print_datetime(char *buffer, const struct timespec *datetime) | ||||
| +static int print_datetime(char *buffer, const struct timespec64 *datetime) | ||||
|  { | ||||
| -	struct timeval tv; | ||||
|  	struct tm nowtm; | ||||
|  	char tmbuf[64]; | ||||
| -	s64 nsec; | ||||
|   | ||||
|  	if (buffer == NULL || datetime == NULL) { | ||||
|  		pr_err("%s : Invalid arguments\n", __func__); | ||||
|  		return -1; | ||||
|  	} | ||||
| -	nsec = timespec_to_ns(datetime); | ||||
| -	tv = ns_to_timeval(nsec); | ||||
| -	time_to_tm(tv.tv_sec, 0, &nowtm); | ||||
| +	time64_to_tm(datetime->tv_sec, 0, &nowtm); | ||||
|  	memset(tmbuf, 0, 64); | ||||
|   | ||||
|  	snprintf(tmbuf, sizeof(tmbuf), "%ld-%d-%d %d:%d:%d", | ||||
| @@ -753,7 +749,7 @@ static int print_datetime(char *buffer, | ||||
|  			nowtm.tm_hour, | ||||
|  			nowtm.tm_min, | ||||
|  			nowtm.tm_sec); | ||||
| -	snprintf(buffer, sizeof(buffer), "%s.%06d", tmbuf, (int)tv.tv_usec); | ||||
| +	snprintf(buffer, sizeof(buffer), "%s.%06d", tmbuf, (int)datetime->tv_nsec / 1000); | ||||
|   | ||||
|  	return 0; | ||||
|  } | ||||
| @@ -1313,7 +1309,7 @@ static int ppe_send(struct atm_vcc *vcc, | ||||
|  	/* assume LLC header + Ethernet ID: 6+2 */ | ||||
|      if ((priv->conn[conn].mpoa_type == MPOA_TYPE_EOA_WO_FCS) || | ||||
|  		(priv->conn[conn].mpoa_type == MPOA_TYPE_EOA_W_FCS)) { | ||||
| -        if (__skb_put_padto(skb, ETH_ZLEN + 8)) | ||||
| +        if (__skb_put_padto(skb, ETH_ZLEN + 8, false)) | ||||
|  		    goto CHECK_SHOWTIME_FAIL; | ||||
|  	} | ||||
|   | ||||
| @@ -1418,7 +1414,7 @@ int ppe_send_oam(struct atm_vcc *vcc, vo | ||||
|  	struct atm_priv *priv = g_atm_tc; | ||||
|  	struct sk_buff *skb; | ||||
|  	unsigned int conn; | ||||
| -	dp_subif_t dp_id; | ||||
| +// 	dp_subif_t dp_id; | ||||
|  #ifdef OAM_FIX_GRX750 | ||||
|  	unsigned char *dest_cell; | ||||
|  #endif | ||||
| @@ -1465,8 +1461,8 @@ int ppe_send_oam(struct atm_vcc *vcc, vo | ||||
|  		priv->tc_priv->param.oam_prio = 0; | ||||
|  	qid = priv->conn[conn].prio_queue_map[priv->tc_priv->param.oam_prio]; | ||||
|  	vid = priv->conn[conn].subif_id; | ||||
| -	dp_id.subif = (vid & (~0x7f)) | | ||||
| -		ATM_DESC_SUBIF_ID(qid, mpoa_pt, mpoa_type); | ||||
| +// 	dp_id.subif = (vid & (~0x7f)) | | ||||
| +// 		ATM_DESC_SUBIF_ID(qid, mpoa_pt, mpoa_type); | ||||
|  #ifdef OAM_FIX_GRX750 | ||||
|  	dest_cell = kmalloc(CELL_SIZE, GFP_KERNEL); | ||||
|  	if (dest_cell == NULL) { | ||||
| @@ -1494,18 +1490,18 @@ int ppe_send_oam(struct atm_vcc *vcc, vo | ||||
|  #else | ||||
|  	memcpy(skb->data, cell, CELL_SIZE); | ||||
|  #endif | ||||
| -	/* SET SUBIFID */ | ||||
| -	skb->DW0 = (skb->DW0 & ~0x7FFF) | dp_id.subif; | ||||
| -	skb->dev = priv->conn[conn].dev; | ||||
| -	tc_dbg(priv->tc_priv, MSG_TX, "conn: %d, dev name: %s, qid: 0x%x len:%d\n", | ||||
| -		conn, skb->dev->name, dp_id.subif, skb->len); | ||||
| -	#ifdef OAM_FIX_GRX750 | ||||
| -	if (priv->tc_priv->tc_ops.send(NULL, | ||||
| -			skb, dp_id.subif, ATM_OAM_PKT) == 0) { | ||||
| -	#else | ||||
| +// 	/* SET SUBIFID */ | ||||
| +// 	skb->DW0 = (skb->DW0 & ~0x7FFF) | dp_id.subif; | ||||
| +// 	skb->dev = priv->conn[conn].dev; | ||||
| +// 	tc_dbg(priv->tc_priv, MSG_TX, "conn: %d, dev name: %s, qid: 0x%x len:%d\n", | ||||
| +// 		conn, skb->dev->name, dp_id.subif, skb->len); | ||||
| +// 	#ifdef OAM_FIX_GRX750 | ||||
| +// 	if (priv->tc_priv->tc_ops.send(NULL, | ||||
| +// 			skb, dp_id.subif, ATM_OAM_PKT) == 0) { | ||||
| +// 	#else | ||||
|  	if (priv->tc_priv->tc_ops.send(NULL, | ||||
|  			skb, qid, ATM_OAM_PKT) == 0) { | ||||
| -	#endif | ||||
| +// 	#endif | ||||
|  		priv->stats.oam_tx_pkts++; | ||||
|  		priv->stats.oam_tx_bytes += skb->len; | ||||
|  		priv->conn[conn].stats.oam_tx_pkts++; | ||||
| @@ -1604,7 +1600,7 @@ static void oam_push(struct atm_priv *pr | ||||
|  		conn = -1; /* invalid */ | ||||
|  	if (conn_valid(conn) && priv->conn[conn].vcc != NULL) { | ||||
|  		vcc = priv->conn[conn].vcc; | ||||
| -		priv->conn[conn].access_time = current_kernel_time(); | ||||
| +		ktime_get_coarse_ts64(&priv->conn[conn].access_time); | ||||
|   | ||||
|  		tc_dbg(priv->tc_priv, MSG_OAM_RX, "conn=%d, vpi: %d, vci:%d\n", | ||||
|  			conn, header->vpi, header->vci); | ||||
| @@ -2547,30 +2543,29 @@ static void ppe_atm_fw_hw_init(struct at | ||||
|  static int atm_dev_init(struct atm_priv *atm_priv, int ep_id) | ||||
|  { | ||||
|  	int i, err; | ||||
| -	struct atm_dev *dev; | ||||
| -	dev = atm_dev_register(g_atm_dev_name, | ||||
| -		atm_priv->tc_priv->ep_dev[ep_id].dev, | ||||
| -		&g_ppe_atm_ops, -1, NULL); | ||||
| -	if (!dev) { | ||||
| -		err = -EIO; | ||||
| -		goto ATM_DEV_REGISTER_FAIL; | ||||
| -	} | ||||
| -	dev->ci_range.vpi_bits = 8; | ||||
| -	dev->ci_range.vci_bits = 16; | ||||
| -	/* assume 3200 cell rate | ||||
| -	 * before get real information | ||||
| -	 */ | ||||
| -	dev->link_rate = | ||||
| -		DEFAULT_CELL_RATE; | ||||
| -	dev->dev_data = atm_priv; | ||||
| -	dev->phy_data = | ||||
| -		(void *)(unsigned long)0; | ||||
|   | ||||
|  	for (i = 0; i < ATM_PORT_NUMBER; i++) { | ||||
|  		if (atm_priv->port[i].dev) | ||||
|  			continue; | ||||
|  		atm_priv->port[i].tx_max_cell_rate = DEFAULT_CELL_RATE; | ||||
| -		atm_priv->port[i].dev = dev; | ||||
| +		atm_priv->port[i].dev = atm_dev_register(g_atm_dev_name, | ||||
| +				atm_priv->tc_priv->ep_dev[ep_id].dev, | ||||
| +				&g_ppe_atm_ops, -1, NULL); | ||||
| +		if (!atm_priv->port[i].dev) { | ||||
| +			err = -EIO; | ||||
| +			goto ATM_DEV_REGISTER_FAIL; | ||||
| +		} else { | ||||
| +			atm_priv->port[i].dev->ci_range.vpi_bits = 8; | ||||
| +			atm_priv->port[i].dev->ci_range.vci_bits = 16; | ||||
| +			/* assume 3200 cell rate | ||||
| +			 * before get real information | ||||
| +			 */ | ||||
| +			atm_priv->port[i].dev->link_rate = | ||||
| +				DEFAULT_CELL_RATE; | ||||
| +			atm_priv->port[i].dev->dev_data = atm_priv; | ||||
| +			atm_priv->port[i].dev->phy_data = | ||||
| +				(void *)(unsigned long)i; | ||||
| +		} | ||||
|  	} | ||||
|  	//TODO : check for SoC PMAC, current fix | ||||
|  #ifdef CONFIG_SOC_TYPE_XWAY | ||||
| @@ -2985,7 +2980,8 @@ static unsigned int atm_get_pvc_id(struc | ||||
|  		return -EINVAL; | ||||
|  	} | ||||
|   | ||||
| -	return (skb->DW0 >> 3) & 0xF; | ||||
| +// 	return (skb->DW0 >> 3) & 0xF; | ||||
| +	return 1; | ||||
|  } | ||||
|   | ||||
|  static int atm_get_qid_by_vcc(struct net_device *dev, struct sk_buff *skb, | ||||
| @@ -3292,7 +3288,7 @@ static void atm_push(struct net_device * | ||||
|  					+= skb->len; | ||||
|  			} else | ||||
|  				priv->stats.aal5_rx_errors++; | ||||
| -			priv->conn[conn].access_time = current_kernel_time(); | ||||
| +			ktime_get_coarse_ts64(&priv->conn[conn].access_time); | ||||
|  			spin_unlock_bh(&priv->atm_lock); | ||||
|   | ||||
|  			vcc->push(vcc, skb); | ||||
| --- a/dcdp/inc/atm_tc.h | ||||
| +++ b/dcdp/inc/atm_tc.h | ||||
| @@ -449,7 +449,7 @@ struct atm_port { | ||||
|  struct atm_pvc { | ||||
|  	struct atm_vcc *vcc; /* opened VCC */ | ||||
|  	struct net_device *dev; /* net device associated with atm VCC */ | ||||
| -	struct timespec access_time; /* time when last user cell arrived */ | ||||
| +	struct timespec64 access_time; /* time when last user cell arrived */ | ||||
|  	int prio_queue_map[ATM_PRIO_Q_NUM]; | ||||
|  	unsigned int prio_tx_packets[ATM_PRIO_Q_NUM]; | ||||
|  	struct atm_stats stats; | ||||
| --- a/dcdp/inc/tc_api.h | ||||
| +++ b/dcdp/inc/tc_api.h | ||||
| @@ -196,19 +196,6 @@ static inline void aca_ring_addr_init(st | ||||
|  	ring->aca_cnt_phyaddr = ep_dev->phy_membase + addr; | ||||
|  } | ||||
|   | ||||
| -static inline int __skb_put_padto(struct sk_buff *skb, unsigned int len) | ||||
| -{ | ||||
| -	unsigned int size = skb->len; | ||||
| - | ||||
| -	if (unlikely(size < len)) { | ||||
| -		len -= size; | ||||
| -		if (skb_pad(skb, len)) | ||||
| -			return -ENOMEM; | ||||
| -		__skb_put(skb, len); | ||||
| -	} | ||||
| -	return 0; | ||||
| -} | ||||
| - | ||||
|  extern int showtime_stat(struct tc_priv *); | ||||
|  extern void dump_skb_info(struct tc_priv *, struct sk_buff *, u32); | ||||
|  extern void *tc_buf_alloc(void *, size_t, u32 *, | ||||
| --- a/dcdp/inc/tc_proc.h | ||||
| +++ b/dcdp/inc/tc_proc.h | ||||
| @@ -23,6 +23,8 @@ | ||||
|  #ifndef __TC_PROC_H__ | ||||
|  #define __TC_PROC_H__ | ||||
|   | ||||
| +#include <linux/version.h> | ||||
| + | ||||
|  #define TC_PROC_DIR "driver/vrx518" | ||||
|  #define TC_PROC_ATM_DIR "atm" | ||||
|  #define TC_PROC_PTM_DIR "ptm" | ||||
| @@ -41,7 +43,7 @@ enum { | ||||
|  struct tc_proc_list { | ||||
|  	char proc_name[32]; | ||||
|  	umode_t mode; | ||||
| -	const struct file_operations *fops; | ||||
| +	const struct proc_ops *fops; | ||||
|  	int is_folder; | ||||
|  }; | ||||
|   | ||||
| --- a/dcdp/ptm_tc.c | ||||
| +++ b/dcdp/ptm_tc.c | ||||
| @@ -39,7 +39,7 @@ | ||||
|  #include <linux/seq_file.h> | ||||
|  #include <linux/printk.h> | ||||
|  #include <linux/etherdevice.h> | ||||
| -#include <net/datapath_proc_api.h> | ||||
| +// #include <net/datapath_proc_api.h> | ||||
|   | ||||
|  #include "inc/tc_main.h" | ||||
|  #include "inc/reg_addr.h" | ||||
| @@ -62,6 +62,9 @@ | ||||
|  #include "inc/fw/vrx518_addr_def.h" | ||||
|  #include "inc/fw/vrx518_ppe_fw.h" | ||||
|   | ||||
| +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(5,17,0)) | ||||
| +#define PDE_DATA pde_data | ||||
| +#endif | ||||
|   | ||||
|  static struct ptm_priv *g_ptm_priv; | ||||
|  static struct ptm_ep_priv g_ep_priv[BOND_MAX]; | ||||
| @@ -84,6 +87,7 @@ static int ptm_erb_addr_get(const unsign | ||||
|  	unsigned int *data_addr, unsigned int *desc_addr); | ||||
|   | ||||
|   | ||||
| +#if (LINUX_VERSION_CODE < KERNEL_VERSION(5,16,0)) | ||||
|  static inline void tc_ether_addr_copy(u8 *dst, const u8 *src) | ||||
|  { | ||||
|  #if defined(CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS) | ||||
| @@ -98,6 +102,7 @@ static inline void tc_ether_addr_copy(u8 | ||||
|  	a[2] = b[2]; | ||||
|  #endif | ||||
|  } | ||||
| +#endif | ||||
|   | ||||
|  static inline int is_ptm_sl(struct ptm_ep_priv *priv) | ||||
|  { | ||||
| @@ -182,8 +187,8 @@ static int ptm_get_qid(struct net_device | ||||
|  	return qid; | ||||
|  } | ||||
|   | ||||
| -static struct rtnl_link_stats64 *ptm_get_stats(struct net_device *dev, | ||||
| -					struct rtnl_link_stats64 *storage) | ||||
| +static void ptm_get_stats(struct net_device *dev, | ||||
| +			  struct rtnl_link_stats64 *storage) | ||||
|  { | ||||
|  	struct ptm_priv *ptm_tc = netdev_priv(dev); | ||||
|   | ||||
| @@ -191,8 +196,6 @@ static struct rtnl_link_stats64 *ptm_get | ||||
|  		memcpy(storage, &ptm_tc->stats64, sizeof(ptm_tc->stats64)); | ||||
|  	else | ||||
|  		storage->tx_errors += ptm_tc->stats64.tx_errors; | ||||
| - | ||||
| -	return storage; | ||||
|  } | ||||
|   | ||||
|  static int ptm_set_mac_address(struct net_device *dev, void *p) | ||||
| @@ -204,12 +207,16 @@ static int ptm_set_mac_address(struct ne | ||||
|  		return -EBUSY; | ||||
|   | ||||
|  	tc_info(ptm_tc->tc_priv, MSG_EVENT, "ptm mac address update!\n"); | ||||
| +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(5,16,0)) | ||||
| +	eth_hw_addr_set(dev, addr->sa_data); | ||||
| +#else | ||||
|  	tc_ether_addr_copy(dev->dev_addr, addr->sa_data); | ||||
| +#endif | ||||
|   | ||||
|  	return 0; | ||||
|  } | ||||
|   | ||||
| -static void ptm_tx_timeout(struct net_device *dev) | ||||
| +static void ptm_tx_timeout(struct net_device *dev, unsigned int txqueue) | ||||
|  { | ||||
|  	struct ptm_priv *ptm_tc = netdev_priv(dev); | ||||
|   | ||||
| @@ -503,7 +510,7 @@ static int ptm_xmit(struct sk_buff *skb, | ||||
|  	if (!showtime_stat(ptm_tc->tc_priv)) | ||||
|  		goto PTM_XMIT_DROP; | ||||
|   | ||||
| -	if (__skb_put_padto(skb, ETH_ZLEN)) | ||||
| +	if (__skb_put_padto(skb, ETH_ZLEN, false)) | ||||
|  		goto PTM_XMIT_DROP; | ||||
|   | ||||
|  	dump_skb_info(ptm_tc->tc_priv, skb, (MSG_TX | MSG_TXDATA)); | ||||
| @@ -632,11 +639,8 @@ static int ptm_dev_init(struct tc_priv * | ||||
|  	struct ptm_priv *ptm_tc; | ||||
|  	const char macaddr[ETH_ALEN] | ||||
|  		= {0xAC, 0x9A, 0x96, 0x11, 0x22, 0x33}; | ||||
| -#if LINUX_VERSION_CODE < KERNEL_VERSION(4,8,0) | ||||
| -	dev = alloc_netdev_mq(sizeof(*ptm_tc), "ptm%d", ptm_setup, 4); | ||||
| -#else | ||||
| -	dev = alloc_netdev_mq(sizeof(*ptm_tc), "ptm%d",  NET_NAME_ENUM, ptm_setup, 4); | ||||
| -#endif | ||||
| + | ||||
| +	dev = alloc_netdev_mq(sizeof(*ptm_tc), "dsl%d",  NET_NAME_ENUM, ptm_setup, 4); | ||||
|  	if (!dev) { | ||||
|  		tc_dbg(tc_priv, MSG_INIT, "Cannot alloc net device\n"); | ||||
|  		return -ENOMEM; | ||||
| @@ -644,7 +648,11 @@ static int ptm_dev_init(struct tc_priv * | ||||
|  	ptm_tc = netdev_priv(dev); | ||||
|  	ptm_tc->dev = dev; | ||||
|  	ptm_tc->tc_priv = tc_priv; | ||||
| +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(5,16,0)) | ||||
| +	eth_hw_addr_set(dev, macaddr); | ||||
| +#else | ||||
|  	tc_ether_addr_copy(dev->dev_addr, macaddr); | ||||
| +#endif | ||||
|  	spin_lock_init(&ptm_tc->ptm_lock); | ||||
|  	memcpy(ptm_tc->outq_map, def_outq_map, sizeof(def_outq_map)); | ||||
|  	SET_NETDEV_DEV(ptm_tc->dev, tc_priv->ep_dev[id].dev); | ||||
| @@ -2103,7 +2111,6 @@ static int ptm_showtime_exit(const unsig | ||||
|  	struct ptm_ep_priv *priv = tc_ep_priv(idx); | ||||
|  	u32 stop = ACA_TXIN_EN; | ||||
|  	struct dc_ep_dev *ep; | ||||
| -	int i = 0; | ||||
|   | ||||
|  	tc_info(priv->tc_priv, MSG_EVENT, "Line[%d]: show time exit!\n", idx); | ||||
|  	ep = priv->ep; | ||||
| --- a/dcdp/tc_api.c | ||||
| +++ b/dcdp/tc_api.c | ||||
| @@ -52,18 +52,24 @@ static const char ppe_fw_name[] = "ppe_f | ||||
|  #define VRX518_PPE_FW_ID		0xB | ||||
|  #define MD5_LEN				16 | ||||
|   | ||||
| +enum tc_multicast_groups { | ||||
| +	TC_MCGRP, | ||||
| +}; | ||||
| + | ||||
| +/* TC message multicast group */ | ||||
| +static const struct genl_multicast_group tc_ml_grps[] = { | ||||
| +	[TC_MCGRP] = { .name = TC_MCAST_GRP_NAME, }, | ||||
| +}; | ||||
| + | ||||
|  /* TC message genelink family */ | ||||
|  static struct genl_family tc_gnl_family = { | ||||
| -	.id = GENL_ID_GENERATE,	/* To generate an id for the family*/ | ||||
| +// 	.id = GENL_ID_GENERATE,	/* To generate an id for the family*/ | ||||
|  	.hdrsize = 0, | ||||
|  	.name = TC_FAMILY_NAME,	/*family name, used by userspace application*/ | ||||
|  	.version = 1,		/*version number  */ | ||||
|  	.maxattr = TC_A_MAX - 1, | ||||
| -}; | ||||
| - | ||||
| -/* TC message multicast group */ | ||||
| -static struct genl_multicast_group tc_ml_grp = { | ||||
| -	.name = TC_MCAST_GRP_NAME, | ||||
| +	.mcgrps = tc_ml_grps, | ||||
| +	.n_mcgrps = ARRAY_SIZE(tc_ml_grps), | ||||
|  }; | ||||
|   | ||||
|  /** | ||||
| @@ -568,7 +574,8 @@ int tc_ntlk_msg_send(struct tc_priv *pri | ||||
|  	nla_put_u32(skb, TC_A_LINENO, ln_no); | ||||
|   | ||||
|  	genlmsg_end(skb, msg_head); | ||||
| -	ret = genlmsg_multicast(skb, pid, tc_ml_grp.id, GFP_KERNEL); | ||||
| +	ret = genlmsg_multicast(&tc_gnl_family, skb, pid, TC_MCGRP, | ||||
| +				GFP_KERNEL); | ||||
|  	if (ret) { | ||||
|  		tc_err(priv, MSG_EVENT, "Sent TC multicast message Fail!\n"); | ||||
|  		goto err1; | ||||
| @@ -590,21 +597,11 @@ int tc_gentlk_init(struct tc_priv *priv) | ||||
|  		return ret; | ||||
|  	} | ||||
|   | ||||
| -	ret = genl_register_mc_group(&tc_gnl_family, &tc_ml_grp); | ||||
| -	if (ret) { | ||||
| -		tc_err(priv, MSG_EVENT, "register mc group fail: %i, grp name: %s\n", | ||||
| -			ret, tc_ml_grp.name); | ||||
| -		genl_unregister_family(&tc_gnl_family); | ||||
| -		return ret; | ||||
| -	} | ||||
| - | ||||
|  	return 0; | ||||
|  } | ||||
|   | ||||
|  void tc_gentlk_exit(void) | ||||
|  { | ||||
| -	/* unregister mc groups */ | ||||
| -	genl_unregister_mc_group(&tc_gnl_family, &tc_ml_grp); | ||||
|  	/*unregister the family*/ | ||||
|  	genl_unregister_family(&tc_gnl_family); | ||||
|  } | ||||
| @@ -666,7 +663,7 @@ void dump_skb_info(struct tc_priv *tcpri | ||||
|  		(u32)skb->end, skb->len); | ||||
|  	tc_dbg(tcpriv, type, | ||||
|  		"skb: clone: %d, users: %d\n", | ||||
| -		skb->cloned, atomic_read(&skb->users)); | ||||
| +		skb->cloned, refcount_read(&skb->users)); | ||||
|  	tc_dbg(tcpriv, type, | ||||
|  		"skb: nfrag: %d\n", skb_shinfo(skb)->nr_frags); | ||||
|   | ||||
| @@ -936,7 +933,6 @@ static int fw_md5_check(struct tc_priv * | ||||
|  	} | ||||
|   | ||||
|  	desc->tfm = md5; | ||||
| -	desc->flags = 0; | ||||
|   | ||||
|  	ret = crypto_shash_init(desc); | ||||
|  	if (ret) { | ||||
| --- a/dcdp/tc_proc.c | ||||
| +++ b/dcdp/tc_proc.c | ||||
| @@ -22,7 +22,9 @@ | ||||
|  *******************************************************************************/ | ||||
|  #include <linux/fs.h> | ||||
|  #include <linux/seq_file.h> | ||||
| -#include <net/datapath_api.h> | ||||
| +// #include <net/datapath_api.h> | ||||
| +#include <linux/etherdevice.h> | ||||
| +#include <linux/atmdev.h> | ||||
|  #include <net/genetlink.h> | ||||
|  #include <linux/time.h> | ||||
|  #include "inc/tc_main.h" | ||||
| @@ -35,6 +37,10 @@ | ||||
|  #include "inc/platform.h" | ||||
|  #include "inc/dsl_tc.h" | ||||
|   | ||||
| +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(5,17,0)) | ||||
| +#define PDE_DATA pde_data | ||||
| +#endif | ||||
| + | ||||
|  #define ATM_HEADER_SIZE (ATM_CELL_SIZE - ATM_CELL_PAYLOAD) | ||||
|  static char *dbg_flag_str[] = { | ||||
|  	"rx", | ||||
| @@ -353,7 +359,7 @@ static ssize_t mem_proc_write(struct fil | ||||
|  	} | ||||
|  	addr = set_val = repeat_cnt = 0; | ||||
|   | ||||
| -	if (!access_ok(VERIFY_READ, buf, count)) | ||||
| +	if (!access_ok(buf, count)) | ||||
|  		return -EFAULT; | ||||
|   | ||||
|  	len = count < sizeof(str) ? count : sizeof(str) - 1; | ||||
| @@ -450,13 +456,12 @@ static int proc_read_mem_seq_open(struct | ||||
|  	return single_open(file, proc_read_mem, NULL); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations mem_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_mem_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| -	.write		= mem_proc_write, | ||||
| +static const struct proc_ops mem_proc_fops = { | ||||
| +	.proc_open	= proc_read_mem_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
| +	.proc_write	= mem_proc_write, | ||||
|  }; | ||||
|   | ||||
|  static ssize_t pp32_proc_write(struct file *file, const char __user *buf, | ||||
| @@ -748,13 +753,12 @@ static int proc_read_pp32_seq_open(struc | ||||
|  	return single_open(file, proc_read_pp32, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations pp32_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_pp32_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| -	.write		= pp32_proc_write, | ||||
| +static const struct proc_ops pp32_proc_fops = { | ||||
| +	.proc_open	= proc_read_pp32_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
| +	.proc_write	= pp32_proc_write, | ||||
|  }; | ||||
|   | ||||
|  static int proc_read_tc_cfg(struct seq_file *seq, void *v) | ||||
| @@ -865,13 +869,12 @@ static int proc_read_tc_cfg_seq_open(str | ||||
|  	return single_open(file, proc_read_tc_cfg, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations tc_cfg_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_tc_cfg_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| -	.write		= proc_write_cfg, | ||||
| +static const struct proc_ops tc_cfg_proc_fops = { | ||||
| +	.proc_open	= proc_read_tc_cfg_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
| +	.proc_write	= proc_write_cfg, | ||||
|  }; | ||||
|   | ||||
|  static ssize_t proc_write_dbg(struct file *file, const char __user *buf, | ||||
| @@ -951,13 +954,12 @@ static int proc_read_dbg_seq_open(struct | ||||
|  	return single_open(file, proc_read_dbg, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations tc_dbg_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_dbg_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.write		= proc_write_dbg, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops tc_dbg_proc_fops = { | ||||
| +	.proc_open	= proc_read_dbg_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_write	= proc_write_dbg, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  static ssize_t proc_write_tc_switch(struct file *file, const char __user *buf, | ||||
| @@ -1018,11 +1020,11 @@ proc_tc_switch_help: | ||||
|  	return count; | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations tc_switch_proc_fops = { | ||||
| -	.owner      = THIS_MODULE, | ||||
| -	.write      = proc_write_tc_switch, | ||||
| -	.llseek     = noop_llseek, | ||||
| +static const struct proc_ops tc_switch_proc_fops = { | ||||
| +	.proc_write = proc_write_tc_switch, | ||||
| +	.proc_lseek = noop_llseek, | ||||
|  }; | ||||
| + | ||||
|  static ssize_t proc_write_show_time(struct file *file, const char __user *buf, | ||||
|  			size_t count, loff_t *data) | ||||
|  { | ||||
| @@ -1077,10 +1079,9 @@ proc_show_time_help: | ||||
|  	return count; | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations tc_show_time_proc_fops = { | ||||
| -	.owner      = THIS_MODULE, | ||||
| -	.write      = proc_write_show_time, | ||||
| -	.llseek     = noop_llseek, | ||||
| +static const struct proc_ops tc_show_time_proc_fops = { | ||||
| +	.proc_write = proc_write_show_time, | ||||
| +	.proc_lseek = noop_llseek, | ||||
|  }; | ||||
|   | ||||
|  static int proc_read_ver(struct seq_file *seq, void *v) | ||||
| @@ -1128,12 +1129,11 @@ static int proc_read_ver_seq_open(struct | ||||
|  	return single_open(file, proc_read_ver, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations tc_ver_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_ver_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops tc_ver_proc_fops = { | ||||
| +	.proc_open	= proc_read_ver_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  static int proc_read_soc(struct seq_file *seq, void *v) | ||||
| @@ -1142,20 +1142,18 @@ static int proc_read_soc(struct seq_file | ||||
|   | ||||
|  	tcpriv = (struct tc_priv *)seq->private; | ||||
|   | ||||
| -#if 0 | ||||
|  	seq_printf(seq, "TXIN Base: 0x%08x, TXIN num: %d\n", | ||||
| -			tcpriv->cfg.txin_dbase, | ||||
| -			tcpriv->cfg.txin_dnum); | ||||
| +			tcpriv->cfg.txin.soc_phydbase, | ||||
| +			tcpriv->cfg.txin.soc_dnum); | ||||
|  	seq_printf(seq, "TXOUT Base: 0x%08x, TXOUT num: %d\n", | ||||
| -			tcpriv->cfg.txout_dbase, | ||||
| -			tcpriv->cfg.txout_dnum); | ||||
| +			tcpriv->cfg.txout.soc_phydbase, | ||||
| +			tcpriv->cfg.txout.soc_dnum); | ||||
|  	seq_printf(seq, "RXIN Base: 0x%08x, RXIN num: %d\n", | ||||
| -			tcpriv->cfg.rxin_dbase, | ||||
| -			tcpriv->cfg.rxin_dnum); | ||||
| +			tcpriv->cfg.rxin.soc_phydbase, | ||||
| +			tcpriv->cfg.rxin.soc_dnum); | ||||
|  	seq_printf(seq, "RXOUT Base: 0x%08x, RXOUT num: %d\n", | ||||
| -			tcpriv->cfg.rxout_dbase, | ||||
| -			tcpriv->cfg.rxout_dnum); | ||||
| -#endif | ||||
| +			tcpriv->cfg.rxout.soc_phydbase, | ||||
| +			tcpriv->cfg.rxout.soc_dnum); | ||||
|   | ||||
|  	return 0; | ||||
|  } | ||||
| @@ -1165,15 +1163,13 @@ static int proc_read_soc_seq_open(struct | ||||
|  	return single_open(file, proc_read_soc, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations tc_soc_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_soc_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops tc_soc_proc_fops = { | ||||
| +	.proc_open	= proc_read_soc_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
| - | ||||
|  static struct tc_proc_list tc_procs[] = { | ||||
|  	{TC_PROC_DIR,	0,	NULL,			1}, | ||||
|  	{"cfg",		0644, &tc_cfg_proc_fops,	0}, | ||||
| @@ -1241,13 +1237,12 @@ static int proc_read_ptm_wanmib_seq_open | ||||
|  	return single_open(file, proc_read_ptm_wanmib, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations ptm_wanmib_proc_fops = { | ||||
| -	.owner      = THIS_MODULE, | ||||
| -	.open       = proc_read_ptm_wanmib_seq_open, | ||||
| -	.read       = seq_read, | ||||
| -	.write      = proc_write_ptm_wanmib, | ||||
| -	.llseek     = seq_lseek, | ||||
| -	.release    = single_release, | ||||
| +static const struct proc_ops ptm_wanmib_proc_fops = { | ||||
| +	.proc_open    = proc_read_ptm_wanmib_seq_open, | ||||
| +	.proc_read    = seq_read, | ||||
| +	.proc_write   = proc_write_ptm_wanmib, | ||||
| +	.proc_lseek   = seq_lseek, | ||||
| +	.proc_release = single_release, | ||||
|  }; | ||||
|   | ||||
|  static int proc_ptm_read_cfg(struct seq_file *seq, void *v) | ||||
| @@ -1300,7 +1295,7 @@ static ssize_t ptm_cfg_proc_write(struct | ||||
|  		return -EINVAL; | ||||
|  	} | ||||
|   | ||||
| -	if (!access_ok(VERIFY_READ, buf, count)) | ||||
| +	if (!access_ok(buf, count)) | ||||
|  		return -EFAULT; | ||||
|   | ||||
|  	len = count < sizeof(str) ? count : sizeof(str) - 1; | ||||
| @@ -1343,13 +1338,12 @@ proc_ptm_cfg_help: | ||||
|  } | ||||
|   | ||||
|   | ||||
| -static const struct file_operations ptm_cfg_proc_fops = { | ||||
| -	.owner = THIS_MODULE, | ||||
| -	.open = proc_read_cfg_seq_open, | ||||
| -	.read = seq_read, | ||||
| -	.llseek = seq_lseek, | ||||
| -	.write = ptm_cfg_proc_write, | ||||
| -	.release = single_release, | ||||
| +static const struct proc_ops ptm_cfg_proc_fops = { | ||||
| +	.proc_open = proc_read_cfg_seq_open, | ||||
| +	.proc_read = seq_read, | ||||
| +	.proc_lseek = seq_lseek, | ||||
| +	.proc_write = ptm_cfg_proc_write, | ||||
| +	.proc_release = single_release, | ||||
|  }; | ||||
|   | ||||
|  static ssize_t proc_ptm_write_prio(struct file *file, const char __user *buf, | ||||
| @@ -1455,13 +1449,12 @@ static int proc_ptm_read_prio_seq_open(s | ||||
|  	return single_open(file, proc_ptm_read_prio, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations ptm_prio_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_ptm_read_prio_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.write		= proc_ptm_write_prio, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops ptm_prio_proc_fops = { | ||||
| +	.proc_open	= proc_ptm_read_prio_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_write	= proc_ptm_write_prio, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  static int proc_ptm_read_bond_seq_open(struct inode *inode, struct file *file) | ||||
| @@ -1469,12 +1462,11 @@ static int proc_ptm_read_bond_seq_open(s | ||||
|  	return single_open(file, proc_ptm_read_bond, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations ptm_bond_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_ptm_read_bond_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops ptm_bond_proc_fops = { | ||||
| +	.proc_open	= proc_ptm_read_bond_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  static int proc_ptm_read_bondmib_seq_open(struct inode *inode, | ||||
| @@ -1483,13 +1475,12 @@ static int proc_ptm_read_bondmib_seq_ope | ||||
|  	return single_open(file, proc_ptm_read_bondmib, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations ptm_bondmib_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_ptm_read_bondmib_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.write		= proc_ptm_write_bondmib, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops ptm_bondmib_proc_fops = { | ||||
| +	.proc_open	= proc_ptm_read_bondmib_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_write	= proc_ptm_write_bondmib, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  struct fwdbg_t { | ||||
| @@ -1910,14 +1901,14 @@ static int proc_read_fwdbg_seq_open(stru | ||||
|  { | ||||
|  	return single_open(file, proc_read_fwdbg, NULL); | ||||
|  } | ||||
| -static const struct file_operations fwdbg_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_fwdbg_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.write		= proc_write_fwdbg_seq, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops fwdbg_proc_fops = { | ||||
| +	.proc_open	= proc_read_fwdbg_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_write	= proc_write_fwdbg_seq, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
| + | ||||
|  static struct tc_proc_list ptm_sl_procs[] = { | ||||
|  	{TC_PROC_PTM_DIR, 0,	NULL,			1}, | ||||
|  	{"mem",		0644,	&mem_proc_fops,		0}, | ||||
| @@ -2077,7 +2068,7 @@ static ssize_t atm_cfg_proc_write(struct | ||||
|   | ||||
|  	priv = (struct atm_priv *)PDE_DATA(file_inode(file)); | ||||
|   | ||||
| -	if (!access_ok(VERIFY_READ, buf, count)) | ||||
| +	if (!access_ok(buf, count)) | ||||
|  		return -EFAULT; | ||||
|   | ||||
|  	len = count < sizeof(str) ? count : sizeof(str) - 1; | ||||
| @@ -2119,13 +2110,12 @@ proc_atm_cfg_help: | ||||
|  	return count; | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations atm_cfg_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_atm_cfg_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.write		= atm_cfg_proc_write, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops atm_cfg_proc_fops = { | ||||
| +	.proc_open	= proc_read_atm_cfg_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_write	= atm_cfg_proc_write, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  static ssize_t proc_write_atm_wanmib(struct file *file, const char __user *buf, | ||||
| @@ -2173,13 +2163,12 @@ static int proc_read_atm_wanmib_seq_open | ||||
|   | ||||
|   | ||||
|   | ||||
| -static const struct file_operations atm_wanmib_proc_fops = { | ||||
| -	.owner      = THIS_MODULE, | ||||
| -	.open       = proc_read_atm_wanmib_seq_open, | ||||
| -	.read       = seq_read, | ||||
| -	.write      = proc_write_atm_wanmib, | ||||
| -	.llseek     = seq_lseek, | ||||
| -	.release    = single_release, | ||||
| +static const struct proc_ops atm_wanmib_proc_fops = { | ||||
| +	.proc_open    = proc_read_atm_wanmib_seq_open, | ||||
| +	.proc_read    = seq_read, | ||||
| +	.proc_write   = proc_write_atm_wanmib, | ||||
| +	.proc_lseek   = seq_lseek, | ||||
| +	.proc_release = single_release, | ||||
|  }; | ||||
|   | ||||
|  static int proc_read_htu_seq_open(struct inode *inode, struct file *file) | ||||
| @@ -2187,12 +2176,11 @@ static int proc_read_htu_seq_open(struct | ||||
|  	return single_open(file, proc_read_htu, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations htu_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_htu_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops htu_proc_fops = { | ||||
| +	.proc_open	= proc_read_htu_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  static int proc_read_queue_seq_open(struct inode *inode, struct file *file) | ||||
| @@ -2200,12 +2188,11 @@ static int proc_read_queue_seq_open(stru | ||||
|  	return single_open(file, proc_read_queue, PDE_DATA(inode)); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations queue_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_queue_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops queue_proc_fops = { | ||||
| +	.proc_open	= proc_read_queue_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  static void set_q_prio(struct atm_priv *priv, | ||||
| @@ -2428,13 +2415,12 @@ static const struct seq_operations pvc_m | ||||
|  	.show = pvc_mib_seq_show, | ||||
|  }; | ||||
|   | ||||
| -static const struct file_operations atm_prio_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_atm_read_prio_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.write		= proc_atm_write_prio, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops atm_prio_proc_fops = { | ||||
| +	.proc_open	= proc_atm_read_prio_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_write	= proc_atm_write_prio, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  static int proc_read_pvc_mib_seq_open(struct inode *inode, struct file *file) | ||||
| @@ -2447,12 +2433,11 @@ static int proc_read_pvc_mib_seq_open(st | ||||
|  	return ret; | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations atm_pvc_mib_proc_fops = { | ||||
| -	.owner	= THIS_MODULE, | ||||
| -	.open	= proc_read_pvc_mib_seq_open, | ||||
| -	.read	= seq_read, | ||||
| -	.llseek	= seq_lseek, | ||||
| -	.release = seq_release, | ||||
| +static const struct proc_ops atm_pvc_mib_proc_fops = { | ||||
| +	.proc_open	= proc_read_pvc_mib_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= seq_release, | ||||
|  }; | ||||
|   | ||||
|  static ssize_t proc_write_cell(struct file *file, | ||||
| @@ -2592,13 +2577,12 @@ static int proc_read_cell_seq_open(struc | ||||
|  	return single_open(file, proc_read_cell, NULL); | ||||
|  } | ||||
|   | ||||
| -static const struct file_operations atm_cell_proc_fops = { | ||||
| -	.owner		= THIS_MODULE, | ||||
| -	.open		= proc_read_cell_seq_open, | ||||
| -	.read		= seq_read, | ||||
| -	.write		= proc_write_cell, | ||||
| -	.llseek		= seq_lseek, | ||||
| -	.release	= single_release, | ||||
| +static const struct proc_ops atm_cell_proc_fops = { | ||||
| +	.proc_open	= proc_read_cell_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_write	= proc_write_cell, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
|  static struct tc_proc_list atm_procs[] = { | ||||
							
								
								
									
										1356
									
								
								package/kernel/lantiq/vrx518_tc/patches/200-swplat.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1356
									
								
								package/kernel/lantiq/vrx518_tc/patches/200-swplat.patch
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										342
									
								
								package/kernel/lantiq/vrx518_tc/patches/201-desc-length.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										342
									
								
								package/kernel/lantiq/vrx518_tc/patches/201-desc-length.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,342 @@ | ||||
| Port FEATURE_CONF_DESC_LENGTH from the grx500 variant of the driver. | ||||
| This also reduces the default length of some descriptors, resulting in | ||||
| significantly lower latencies when the line is saturated. | ||||
|  | ||||
| --- a/dcdp/inc/tc_common.h | ||||
| +++ b/dcdp/inc/tc_common.h | ||||
| @@ -27,7 +27,11 @@ | ||||
|  #define UMT_DEF_PERIOD		400	/* microseconds */ | ||||
|   | ||||
|  #define MAX_MTU			(DMA_PACKET_SZ - ETH_HLEN - HD_RSRV_SZ) | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +#define QOSQ_NUM		8 | ||||
| +#else | ||||
|  #define QOSQ_NUM		2 | ||||
| +#endif | ||||
|  #define FW_STOP_TIMEOUT		20	/* millisecond */ | ||||
|  #define QOS_DISPATCH_OWN	0 | ||||
|  #define ACA_TXIN_POLL_INTVAL	10	/* millisecond */ | ||||
| --- a/dcdp/inc/tc_main.h | ||||
| +++ b/dcdp/inc/tc_main.h | ||||
| @@ -30,6 +30,7 @@ | ||||
|  #define TCPRIV_ALIGN	32 | ||||
|  #define DMA_PACKET_SZ	2048 | ||||
|   | ||||
| +#define FEATURE_CONF_DESC_LENGTH 1 | ||||
|  #define FEATURE_POWER_DOWN 1 | ||||
|   | ||||
|  enum { | ||||
| @@ -157,6 +158,25 @@ struct tc_param { | ||||
|  	unsigned int txout_dnum; | ||||
|  	unsigned int rxin_dnum; | ||||
|  	unsigned int rxout_dnum; | ||||
| + | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	/* __US_FAST_PATH_DES_LIST_NUM:64 | ||||
| +	 * __ACA_TX_IN_PD_LIST_NUM | ||||
| +	 * __ACA_TX_OUT_PD_LIST_NUM | ||||
| +	 * */ | ||||
| +	u32 conf_us_fp_desq_len; | ||||
| +	/* | ||||
| +	 * Number of queue per QoS queue: QOS_DES_NUM / QOSQ_NUM | ||||
| +	 * */ | ||||
| +	u32 conf_us_qos_queue_len; | ||||
| +	/* __US_OUTQ0_DES_LIST_NUM: 32 | ||||
| +	 * __US_OUTQ1_DES_LIST_NUM: 32 | ||||
| +	 * OUTQ_DESC_PER_Q | ||||
| +	 * */ | ||||
| +	u32 conf_us_outq_len; | ||||
| +	/**/ | ||||
| +	u32 conf_us_local_q0_desq_len; | ||||
| +#endif | ||||
|  }; | ||||
|   | ||||
|  struct cdma { | ||||
| --- a/dcdp/ptm_tc.c | ||||
| +++ b/dcdp/ptm_tc.c | ||||
| @@ -78,7 +78,11 @@ static const u32 tx_kvec[] = { | ||||
|  	0x30B1B233, 0xB43536B7, 0xB8393ABB, 0x3CBDBE3F, | ||||
|  	0xC04142C3, 0x44C5C647, 0x48C9CA4B, 0xCC4D4ECF | ||||
|  }; | ||||
| +#ifndef FEATURE_CONF_DESC_LENGTH | ||||
|  static const u32 def_outq_map[OUTQ_PNUM] = {0x1, 0xFE}; | ||||
| +#else | ||||
| +static const u32 def_outq_map[OUTQ_PNUM] = {0x0, 0xFF}; | ||||
| +#endif | ||||
|  static const char ptm_drv_name[] = "PTM SL"; | ||||
|  static const char ptm_bond_name[][IFNAMSIZ] = {"PTM US BOND", "PTM DS BOND"}; | ||||
|   | ||||
| @@ -1018,6 +1022,10 @@ static void us_fp_desq_cfg_ctxt_init(str | ||||
|  	int i; | ||||
|  	u32 desc_addr; | ||||
|  	rx_descriptor_t desc; | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	struct tc_priv *tc_priv; | ||||
| +	tc_priv = priv->tc_priv; | ||||
| +#endif | ||||
|   | ||||
|  	memset(&desq_cfg, 0, sizeof(desq_cfg)); | ||||
|  	/* Initialize US Fast-Path Descriptor Queue Config/Context */ | ||||
| @@ -1025,7 +1033,11 @@ static void us_fp_desq_cfg_ctxt_init(str | ||||
|  	desq_cfg.fast_path	= 1; | ||||
|  	desq_cfg.mbox_int_en	= 0; | ||||
|  	desq_cfg.des_sync_needed = 0; | ||||
| +#ifndef FEATURE_CONF_DESC_LENGTH | ||||
|  	desq_cfg.des_num	= __US_FAST_PATH_DES_LIST_NUM; | ||||
| +#else | ||||
| +	desq_cfg.des_num	= tc_priv->param.conf_us_fp_desq_len; | ||||
| +#endif | ||||
|  	desq_cfg.des_base_addr	= __US_FAST_PATH_DES_LIST_BASE; | ||||
|   | ||||
|  	tc_mem_write(priv, fpi_addr(__US_FP_INQ_DES_CFG_CTXT), | ||||
| @@ -1049,12 +1061,20 @@ static void us_qos_desq_cfg_ctxt_init(st | ||||
|  	int offset, i; | ||||
|  	rx_descriptor_t desc; | ||||
|  	u32 phy_addr; | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	struct tc_priv *tc_priv; | ||||
| +	tc_priv = priv->tc_priv; | ||||
| +#endif | ||||
|   | ||||
|  	/* Setup QoSQ_CFG_CTXT */ | ||||
|  	memset(&qosq_cfg_ctxt, 0, sizeof(qosq_cfg_ctxt)); | ||||
|   | ||||
|  	qosq_cfg_ctxt.threshold = 8; | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	qosq_cfg_ctxt.des_num	= tc_priv->param.conf_us_qos_queue_len; | ||||
| +#else | ||||
|  	qosq_cfg_ctxt.des_num	= QOS_DES_NUM / QOSQ_NUM; | ||||
| +#endif | ||||
|   | ||||
|  	offset = 0; | ||||
|  	for (i = 0; i < QOSQ_NUM; i++) { | ||||
| @@ -1093,6 +1113,10 @@ static void us_outq_desq_cfg_ctxt_init(s | ||||
|  	u32 phy_addr; | ||||
|  	int i; | ||||
|  	u32 offset; | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	struct tc_priv *tc_priv; | ||||
| +	tc_priv = priv->tc_priv; | ||||
| +#endif | ||||
|   | ||||
|  	/* Setup OUTQ_QoS_CFG_CTXT */ | ||||
|  	/* NOTE: By default, Shaping & WFQ both are DISABLED!! */ | ||||
| @@ -1121,7 +1145,11 @@ static void us_outq_desq_cfg_ctxt_init(s | ||||
|  	desq_cfg.des_in_own_val	= US_OUTQ_DES_OWN; | ||||
|  	desq_cfg.mbox_int_en	= 0; | ||||
|  	desq_cfg.des_sync_needed = 0; | ||||
| -	desq_cfg.des_num	= 32; | ||||
| +#ifndef FEATURE_CONF_DESC_LENGTH | ||||
| +	desq_cfg.des_num	= OUTQ_DESC_PER_Q; | ||||
| +#else | ||||
| +	desq_cfg.des_num	= tc_priv->param.conf_us_outq_len; | ||||
| +#endif | ||||
|  	/** | ||||
|  	* Only BC0 is used in VRX518 | ||||
|  	*/ | ||||
| @@ -1187,7 +1215,11 @@ static void us_qos_cfg_init(struct ptm_e | ||||
|  	/* Set QoS NO DROP */ | ||||
|  	sb_w32(1, __QOSQ_NO_DROP); | ||||
|  	/* Enable Preemption function/Disable QoS by default */ | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	sb_w32(0, _CHK_PREEMP_MAP); | ||||
| +#else | ||||
|  	sb_w32(1, _CHK_PREEMP_MAP); | ||||
| +#endif | ||||
|  	/* By default, all qid mappint to non-preemption queue */ | ||||
|  	sb_w32(0x0, _QID2PREEMP_MAP); | ||||
|   | ||||
| @@ -1389,6 +1421,11 @@ static void ptm_local_desq_cfg_ctxt_init | ||||
|  	u32 dcnt, addr, pdbram_base; | ||||
|  	unsigned int us_des_alloc[] = { | ||||
|  		__US_TC_LOCAL_Q0_DES_LIST_NUM, __US_TC_LOCAL_Q1_DES_LIST_NUM}; | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	struct tc_priv *tc_priv; | ||||
| +	tc_priv = priv->tc_priv; | ||||
| +	us_des_alloc[0] = tc_priv->param.conf_us_local_q0_desq_len; | ||||
| +#endif | ||||
|   | ||||
|  	/* Setup the Local DESQ Configuration/Context for UpStream Queues */ | ||||
|  	memset(&desq_cfg, 0, sizeof(desq_cfg)); | ||||
| @@ -2334,6 +2371,10 @@ static void ptm_aca_init(struct ptm_ep_p | ||||
|  	u32 phybase = priv->ep->phy_membase; | ||||
|  	u32 start; | ||||
|  	u32 type; | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	struct tc_priv *tc_priv; | ||||
| +	tc_priv = priv->tc_priv; | ||||
| +#endif | ||||
|   | ||||
|  	priv->tc_priv->tc_ops.soc_cfg_get(&priv->tc_priv->cfg, ptm_id(priv)); | ||||
|  	memset(¶m, 0, sizeof(param)); | ||||
| @@ -2347,7 +2388,11 @@ static void ptm_aca_init(struct ptm_ep_p | ||||
|  #endif | ||||
|  	txin->hd_size_in_dw = cfg->txin.soc_desc_dwsz; | ||||
|  	txin->pd_desc_base = SB_XBAR_ADDR(__ACA_TX_IN_PD_LIST_BASE); | ||||
| +#ifndef FEATURE_CONF_DESC_LENGTH | ||||
|  	txin->pd_desc_num = __ACA_TX_IN_PD_LIST_NUM; | ||||
| +#else | ||||
| +	txin->pd_desc_num = tc_priv->param.conf_us_fp_desq_len; | ||||
| +#endif | ||||
|  	txin->pd_size_in_dw = DESC_DWSZ; | ||||
|  	txin->soc_desc_base = cfg->txin.soc_phydbase; | ||||
|  	txin->soc_desc_num = cfg->txin.soc_dnum; | ||||
| --- a/dcdp/tc_main.c | ||||
| +++ b/dcdp/tc_main.c | ||||
| @@ -182,6 +182,12 @@ static inline void init_local_param(stru | ||||
|  	priv->param.txout_dnum = txout_num; | ||||
|  	priv->param.rxin_dnum = rxin_num; | ||||
|  	priv->param.rxout_dnum = rxout_num; | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	priv->param.conf_us_fp_desq_len = 32; | ||||
| +	priv->param.conf_us_qos_queue_len = 32; | ||||
| +	priv->param.conf_us_outq_len = 32; | ||||
| +	priv->param.conf_us_local_q0_desq_len = 16; | ||||
| +#endif | ||||
|  	priv->tc_mode = TC_NONE_MODE; | ||||
|  	priv->tc_stat = NO_TC; | ||||
|   | ||||
| --- a/dcdp/tc_proc.c | ||||
| +++ b/dcdp/tc_proc.c | ||||
| @@ -1118,6 +1118,9 @@ static int proc_read_ver(struct seq_file | ||||
|  		(date >> 16) & 0xff, | ||||
|  		(date & 0xffff)); | ||||
|   | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	seq_puts(seq, " + Support QoS and Configurable descriptor length\n"); | ||||
| +#endif | ||||
|  #ifdef FEATURE_POWER_DOWN | ||||
|  	seq_puts(seq, " + Support Power Down enhancement feature\n"); | ||||
|  #endif | ||||
| @@ -1170,6 +1173,113 @@ static const struct proc_ops tc_soc_proc | ||||
|  	.proc_release	= single_release, | ||||
|  }; | ||||
|   | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +static ssize_t proc_write_desc_conf(struct file *file, const char __user *buf, | ||||
| +			size_t count, loff_t *data) | ||||
| +{ | ||||
| +	struct tc_priv *priv; | ||||
| +	char str[32]; | ||||
| +	int len, rlen, temp; | ||||
| +	int num, temp_num; | ||||
| +	char *param_list[20]; | ||||
| +	len = count < sizeof(str) ? count : sizeof(str) - 1; | ||||
| +	rlen = len - copy_from_user(str, buf, len); | ||||
| +	str[rlen] = 0; | ||||
| + | ||||
| +	if (!capable(CAP_SYS_ADMIN)) | ||||
| +		return -EPERM; | ||||
| + | ||||
| +	priv = (struct tc_priv *)PDE_DATA(file_inode(file)); | ||||
| +	if (priv == NULL) | ||||
| +		return count; | ||||
| + | ||||
| +	num = vrx_split_buffer(str, param_list, ARRAY_SIZE(param_list)); | ||||
| +	if (num < 1 || num > 4) | ||||
| +		goto proc_dbg_desc_conf; | ||||
| + | ||||
| +	temp_num = num; | ||||
| +	if (num-- != 0) { | ||||
| +		temp = vrx_atoi(param_list[0]); | ||||
| +		if (temp < 1 || temp > 128) { | ||||
| +			pr_info("Fastpath valid range: 1 -> 128\n"); | ||||
| +			goto proc_dbg_desc_conf; | ||||
| +		} | ||||
| +	} | ||||
| +	if (num-- != 0) { | ||||
| +		temp = vrx_atoi(param_list[1]); | ||||
| +		if (temp < 1 || temp > 63) { | ||||
| +			pr_info("QoS valid range: 1 -> 63\n"); | ||||
| +			goto proc_dbg_desc_conf; | ||||
| +		} | ||||
| +	} | ||||
| +	if (num-- != 0) { | ||||
| +		temp = vrx_atoi(param_list[2]); | ||||
| +		if (temp < 1 || temp > 128) { | ||||
| +			pr_info("OutQ valid range: 1 -> 128\n"); | ||||
| +			goto proc_dbg_desc_conf; | ||||
| +		} | ||||
| +	} | ||||
| +	if (num-- != 0) { | ||||
| +		temp = vrx_atoi(param_list[3]); | ||||
| +		if (temp < 4 || temp > 16) { | ||||
| +			pr_info("Local Q0 valid range: 4 -> 16\n"); | ||||
| +			goto proc_dbg_desc_conf; | ||||
| +		} | ||||
| +	} | ||||
| +	num = temp_num; | ||||
| +	if (num-- != 0) { | ||||
| +		priv->param.conf_us_fp_desq_len = vrx_atoi(param_list[0]); | ||||
| +	} | ||||
| +	if (num-- != 0) { | ||||
| +		priv->param.conf_us_qos_queue_len = vrx_atoi(param_list[1]); | ||||
| +	} | ||||
| +	if (num-- != 0) { | ||||
| +		priv->param.conf_us_outq_len = vrx_atoi(param_list[2]); | ||||
| +	} | ||||
| +	if (num-- != 0) { | ||||
| +		priv->param.conf_us_local_q0_desq_len = vrx_atoi(param_list[3]); | ||||
| +	} | ||||
| + | ||||
| +	return count; | ||||
| + | ||||
| +proc_dbg_desc_conf: | ||||
| +	pr_info("echo [FP] [QoS] [OutQ] [LocalQ0]> desc_conf\n"); | ||||
| +	return count; | ||||
| +} | ||||
| + | ||||
| +static int proc_read_desc_conf(struct seq_file *seq, void *v) | ||||
| +{ | ||||
| +	struct tc_priv *priv; | ||||
| +	priv = (struct tc_priv *)seq->private; | ||||
| +	if (priv == NULL) | ||||
| +		return -1; | ||||
| +	seq_puts(seq, "Upstream descriptor length information:\n"); | ||||
| +	seq_printf(seq, " - Fastpath: %d\n", | ||||
| +		priv->param.conf_us_fp_desq_len); | ||||
| +	seq_printf(seq, " - QoS: %d\n", | ||||
| +		priv->param.conf_us_qos_queue_len); | ||||
| +	seq_printf(seq, " - OutQ: %d\n", | ||||
| +		priv->param.conf_us_outq_len); | ||||
| +	seq_printf(seq, " - Local Q0: %d\n", | ||||
| +		priv->param.conf_us_local_q0_desq_len); | ||||
| +	seq_puts(seq, "\n"); | ||||
| +	return 0; | ||||
| +} | ||||
| + | ||||
| +static int proc_read_desc_conf_seq_open(struct inode *inode, struct file *file) | ||||
| +{ | ||||
| +	return single_open(file, proc_read_desc_conf, PDE_DATA(inode)); | ||||
| +} | ||||
| +#endif | ||||
| + | ||||
| +static const struct proc_ops tc_desc_conf_proc_fops = { | ||||
| +	.proc_open	= proc_read_desc_conf_seq_open, | ||||
| +	.proc_read	= seq_read, | ||||
| +	.proc_write	= proc_write_desc_conf, | ||||
| +	.proc_lseek	= seq_lseek, | ||||
| +	.proc_release	= single_release, | ||||
| +}; | ||||
| + | ||||
|  static struct tc_proc_list tc_procs[] = { | ||||
|  	{TC_PROC_DIR,	0,	NULL,			1}, | ||||
|  	{"cfg",		0644, &tc_cfg_proc_fops,	0}, | ||||
| @@ -1178,6 +1288,9 @@ static struct tc_proc_list tc_procs[] = | ||||
|  	{"showtime",	0200, &tc_show_time_proc_fops,	0}, | ||||
|  	{"ver",		0644, &tc_ver_proc_fops,	0}, | ||||
|  	{"soc",		0644, &tc_soc_proc_fops,	0}, | ||||
| +#ifdef FEATURE_CONF_DESC_LENGTH | ||||
| +	{"desc_conf",	0644, &tc_desc_conf_proc_fops,	0}, | ||||
| +#endif | ||||
|  }; | ||||
|   | ||||
|  int tc_proc_init(struct tc_priv *priv) | ||||
| @@ -1337,7 +1450,6 @@ proc_ptm_cfg_help: | ||||
|  	return count; | ||||
|  } | ||||
|   | ||||
| - | ||||
|  static const struct proc_ops ptm_cfg_proc_fops = { | ||||
|  	.proc_open = proc_read_cfg_seq_open, | ||||
|  	.proc_read = seq_read, | ||||
							
								
								
									
										428
									
								
								package/kernel/lantiq/vrx518_tc/patches/202-napi.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										428
									
								
								package/kernel/lantiq/vrx518_tc/patches/202-napi.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,428 @@ | ||||
| --- a/dcdp/platform/sw_plat.c | ||||
| +++ b/dcdp/platform/sw_plat.c | ||||
| @@ -208,6 +208,8 @@ struct plat_priv { | ||||
|  	struct tc_req req_work; | ||||
|  	struct aca_ring_grp soc_rings; | ||||
|  	struct net_device *netdev; | ||||
| +	struct napi_struct *napi_tx; | ||||
| +	struct napi_struct *napi_rx; | ||||
|  	DECLARE_HASHTABLE(mem_map, 8); | ||||
|  }; | ||||
|   | ||||
| @@ -472,7 +474,7 @@ err2: | ||||
|  	return -1; | ||||
|  } | ||||
|   | ||||
| -static void txout_action(struct tc_priv *priv, struct aca_ring *txout) | ||||
| +static int txout_action(struct tc_priv *priv, struct aca_ring *txout, int budget) | ||||
|  { | ||||
|  	struct aca_ring *txin = &g_plat_priv->soc_rings.txin; | ||||
|  	struct tx_list *txlist = &g_plat_priv->soc_rings.txlist; | ||||
| @@ -490,7 +492,10 @@ static void txout_action(struct tc_priv | ||||
|  		spin_lock_irqsave(&tx_spinlock, flags); | ||||
|  	} | ||||
|   | ||||
| -	for (i = 0; i < txout->dnum; i++) { | ||||
| +	if (budget == 0 || budget > txout->dnum) | ||||
| +		budget = txout->dnum; | ||||
| + | ||||
| +	for (i = 0; i < budget; i++) { | ||||
|  		desc = txout->dbase_mem; | ||||
|  		desc += txout->idx; | ||||
|   | ||||
| @@ -540,6 +545,8 @@ static void txout_action(struct tc_priv | ||||
|  	if (cnt && g_plat_priv->netdev && netif_queue_stopped(g_plat_priv->netdev)) { | ||||
|  		netif_wake_queue(g_plat_priv->netdev); | ||||
|  	} | ||||
| + | ||||
| +	return cnt; | ||||
|  } | ||||
|   | ||||
|  static void rxin_action(struct tc_priv *priv, | ||||
| @@ -549,7 +556,7 @@ static void rxin_action(struct tc_priv * | ||||
|  	writel(cnt, rxin->umt_dst); | ||||
|  } | ||||
|   | ||||
| -static int rxout_action(struct tc_priv *priv, struct aca_ring *rxout) | ||||
| +static int rxout_action(struct tc_priv *priv, struct aca_ring *rxout, int budget) | ||||
|  { | ||||
|  	struct device *pdev = priv->ep_dev[0].dev; | ||||
|  	int i, cnt; | ||||
| @@ -559,8 +566,11 @@ static int rxout_action(struct tc_priv * | ||||
|  	size_t len; | ||||
|  	struct sk_buff *skb; | ||||
|   | ||||
| +	if (budget == 0 || budget > rxout->dnum) | ||||
| +		budget = rxout->dnum; | ||||
| + | ||||
|  	cnt = 0; | ||||
| -	for (i = 0; i < rxout->dnum; i++) { | ||||
| +	for (i = 0; i < budget; i++) { | ||||
|  		desc = rxout->dbase_mem; | ||||
|  		desc += rxout->idx; | ||||
|   | ||||
| @@ -593,14 +603,30 @@ static int rxout_action(struct tc_priv * | ||||
|  		ring_idx_inc(rxout); | ||||
|  	} | ||||
|   | ||||
| -	if (!cnt) | ||||
| -		tc_err(priv, MSG_RX, "RXOUT spurious interrupt\n"); | ||||
| -	else | ||||
| +	if (cnt) | ||||
|  		writel(cnt, rxout->umt_dst+0x28); // RXOUT_HD_ACCUM_SUB instead of RXOUT_HD_ACCUM_ADD | ||||
|   | ||||
|  	return cnt; | ||||
|  } | ||||
|   | ||||
| +static int plat_txout_napi(struct napi_struct *napi, int budget) | ||||
| +{ | ||||
| +	struct plat_priv *priv = g_plat_priv; | ||||
| +	struct tc_priv *tcpriv = plat_to_tcpriv(); | ||||
| +	struct aca_ring *txout = &priv->soc_rings.txout; | ||||
| +	struct dc_ep_dev *ep_dev = &tcpriv->ep_dev[txout->ep_dev_idx]; | ||||
| +	int cnt; | ||||
| + | ||||
| +	cnt = txout_action(tcpriv, txout, budget); | ||||
| + | ||||
| +	if (cnt < budget) { | ||||
| +		if (napi_complete_done(napi, cnt)) | ||||
| +			ep_dev->hw_ops->icu_en(ep_dev, ACA_HOSTIF_TX); | ||||
| +	} | ||||
| + | ||||
| +	return cnt; | ||||
| +} | ||||
| + | ||||
|  static void plat_txout_tasklet(unsigned long arg) | ||||
|  { | ||||
|  	struct plat_priv *priv = g_plat_priv; | ||||
| @@ -608,12 +634,33 @@ static void plat_txout_tasklet(unsigned | ||||
|  	struct aca_ring *txout = &priv->soc_rings.txout; | ||||
|  	struct dc_ep_dev *ep_dev = &tcpriv->ep_dev[txout->ep_dev_idx]; | ||||
|   | ||||
| -	txout_action(tcpriv, txout); | ||||
| +	txout_action(tcpriv, txout, 0); | ||||
|   | ||||
|  	/* Enable interrupt */ | ||||
|  	ep_dev->hw_ops->icu_en(ep_dev, ACA_HOSTIF_TX); | ||||
|  } | ||||
|   | ||||
| +static int plat_rxout_napi(struct napi_struct *napi, int budget) | ||||
| +{ | ||||
| +	struct plat_priv *priv = g_plat_priv; | ||||
| +	struct tc_priv *tcpriv = plat_to_tcpriv(); | ||||
| +	struct aca_ring *rxout = &priv->soc_rings.rxout; | ||||
| +	struct aca_ring *rxin = &priv->soc_rings.rxin; | ||||
| +	struct dc_ep_dev *ep_dev = &tcpriv->ep_dev[rxout->ep_dev_idx]; | ||||
| +	int cnt; | ||||
| + | ||||
| +	cnt = rxout_action(tcpriv, rxout, budget); | ||||
| +	if (cnt) | ||||
| +		rxin_action(tcpriv, rxin, DMA_PACKET_SZ, cnt); | ||||
| + | ||||
| +	if (cnt < budget) { | ||||
| +		if (napi_complete_done(napi, cnt)) | ||||
| +			ep_dev->hw_ops->icu_en(ep_dev, ACA_HOSTIF_RX); | ||||
| +	} | ||||
| + | ||||
| +	return cnt; | ||||
| +} | ||||
| + | ||||
|  static void plat_rxout_tasklet(unsigned long arg) | ||||
|  { | ||||
|  	struct plat_priv *priv = g_plat_priv; | ||||
| @@ -623,7 +670,7 @@ static void plat_rxout_tasklet(unsigned | ||||
|  	struct dc_ep_dev *ep_dev = &tcpriv->ep_dev[rxout->ep_dev_idx]; | ||||
|  	int cnt; | ||||
|   | ||||
| -	cnt = rxout_action(tcpriv, rxout); | ||||
| +	cnt = rxout_action(tcpriv, rxout, 0); | ||||
|  	if (cnt) | ||||
|  		rxin_action(tcpriv, rxin, DMA_PACKET_SZ, cnt); | ||||
|   | ||||
| @@ -783,11 +830,22 @@ static irqreturn_t aca_rx_irq_handler(in | ||||
|  { | ||||
|  	struct dc_ep_dev *ep_dev = dev_id; | ||||
|   | ||||
| -	/* Disable IRQ in IMCU */ | ||||
| -	ep_dev->hw_ops->icu_mask(ep_dev, ACA_HOSTIF_RX); | ||||
| +	if (g_plat_priv->napi_rx) { | ||||
| + | ||||
| +		if (napi_schedule_prep(g_plat_priv->napi_rx)) { | ||||
| +			ep_dev->hw_ops->icu_mask(ep_dev, ACA_HOSTIF_RX); | ||||
| +			__napi_schedule(g_plat_priv->napi_rx); | ||||
| +		} | ||||
| + | ||||
| +	} else { | ||||
| + | ||||
| +		/* Disable IRQ in IMCU */ | ||||
| +		ep_dev->hw_ops->icu_mask(ep_dev, ACA_HOSTIF_RX); | ||||
|   | ||||
| -	/* Start tasklet */ | ||||
| -	tasklet_schedule(&rxout_task); | ||||
| +		/* Start tasklet */ | ||||
| +		tasklet_schedule(&rxout_task); | ||||
| + | ||||
| +	} | ||||
|   | ||||
|  	return IRQ_HANDLED; | ||||
|  } | ||||
| @@ -796,15 +854,62 @@ static irqreturn_t aca_tx_irq_handler(in | ||||
|  { | ||||
|  	struct dc_ep_dev *ep_dev = dev_id; | ||||
|   | ||||
| -	/* Disable IRQ in IMCU */ | ||||
| -	ep_dev->hw_ops->icu_mask(ep_dev, ACA_HOSTIF_TX); | ||||
| +	if (g_plat_priv->napi_tx) { | ||||
|   | ||||
| -	/* Start tasklet */ | ||||
| -	tasklet_schedule(&txout_task); | ||||
| +		if (napi_schedule_prep(g_plat_priv->napi_tx)) { | ||||
| +			ep_dev->hw_ops->icu_mask(ep_dev, ACA_HOSTIF_TX); | ||||
| +			__napi_schedule(g_plat_priv->napi_tx); | ||||
| +		} | ||||
| + | ||||
| +	} else { | ||||
| + | ||||
| +		/* Disable IRQ in IMCU */ | ||||
| +		ep_dev->hw_ops->icu_mask(ep_dev, ACA_HOSTIF_TX); | ||||
| + | ||||
| +		/* Start tasklet */ | ||||
| +		tasklet_schedule(&txout_task); | ||||
| + | ||||
| +	} | ||||
|   | ||||
|  	return IRQ_HANDLED; | ||||
|  } | ||||
|   | ||||
| +static void plat_net_open(void) | ||||
| +{ | ||||
| +	struct plat_priv *priv = g_plat_priv; | ||||
| +	struct tc_priv *tcpriv = plat_to_tcpriv(); | ||||
| +	struct aca_ring *rxout = &priv->soc_rings.rxout; | ||||
| +	struct aca_ring *txout = &priv->soc_rings.txout; | ||||
| +	struct dc_ep_dev *ep_dev_rx = &tcpriv->ep_dev[rxout->ep_dev_idx]; | ||||
| +	struct dc_ep_dev *ep_dev_tx = &tcpriv->ep_dev[txout->ep_dev_idx]; | ||||
| + | ||||
| +	if (priv->napi_rx) | ||||
| +		napi_enable(priv->napi_rx); | ||||
| +	ep_dev_rx->hw_ops->icu_en(ep_dev_rx, ACA_HOSTIF_RX); | ||||
| + | ||||
| +	if (priv->napi_tx) | ||||
| +		napi_enable(priv->napi_tx); | ||||
| +	ep_dev_tx->hw_ops->icu_en(ep_dev_tx, ACA_HOSTIF_TX); | ||||
| +} | ||||
| + | ||||
| +static void plat_net_stop(void) | ||||
| +{ | ||||
| +	struct plat_priv *priv = g_plat_priv; | ||||
| +	struct tc_priv *tcpriv = plat_to_tcpriv(); | ||||
| +	struct aca_ring *rxout = &priv->soc_rings.rxout; | ||||
| +	struct aca_ring *txout = &priv->soc_rings.txout; | ||||
| +	struct dc_ep_dev *ep_dev_rx = &tcpriv->ep_dev[rxout->ep_dev_idx]; | ||||
| +	struct dc_ep_dev *ep_dev_tx = &tcpriv->ep_dev[txout->ep_dev_idx]; | ||||
| + | ||||
| +	if (priv->napi_tx) | ||||
| +		napi_disable(priv->napi_tx); | ||||
| +	ep_dev_tx->hw_ops->icu_mask(ep_dev_tx, ACA_HOSTIF_TX); | ||||
| + | ||||
| +	if (priv->napi_rx) | ||||
| +		napi_disable(priv->napi_rx); | ||||
| +	ep_dev_rx->hw_ops->icu_mask(ep_dev_rx, ACA_HOSTIF_RX); | ||||
| +} | ||||
| + | ||||
|  static void plat_irq_init(struct tc_priv *priv, const char *dev_name) | ||||
|  { | ||||
|  	int ret; | ||||
| @@ -988,17 +1093,49 @@ static int plat_soc_cfg_get(struct soc_c | ||||
|  } | ||||
|   | ||||
|  static int plat_open(struct net_device *pdev, const char *dev_name, | ||||
| +		struct napi_struct *napi_tx, struct napi_struct *napi_rx, | ||||
|  		int id, int flag) | ||||
|  { | ||||
| +	struct tc_priv *priv = g_plat_priv->tc_priv; | ||||
| +	int i; | ||||
| + | ||||
| +	for (i = 0; i < EP_MAX_NUM && i < priv->ep_num; i++) { | ||||
| +		disable_irq(priv->ep_dev[i].aca_rx_irq); | ||||
| +		disable_irq(priv->ep_dev[i].aca_tx_irq); | ||||
| +	} | ||||
| + | ||||
|  	g_plat_priv->netdev = pdev; | ||||
| +	g_plat_priv->napi_tx = napi_tx; | ||||
| +	g_plat_priv->napi_rx = napi_rx; | ||||
| + | ||||
| +	for (i = 0; i < EP_MAX_NUM && i < priv->ep_num; i++) { | ||||
| +		enable_irq(priv->ep_dev[i].aca_rx_irq); | ||||
| +		enable_irq(priv->ep_dev[i].aca_tx_irq); | ||||
| +	} | ||||
|   | ||||
|  	return 0; | ||||
|  } | ||||
|   | ||||
|  static void plat_close(struct net_device *pdev, const char *dev_name, | ||||
| +		struct napi_struct *napi_tx, struct napi_struct *napi_rx, | ||||
|  		int flag) | ||||
|  { | ||||
| +	struct tc_priv *priv = g_plat_priv->tc_priv; | ||||
| +	int i; | ||||
| + | ||||
| +	for (i = 0; i < EP_MAX_NUM && i < priv->ep_num; i++) { | ||||
| +		disable_irq(priv->ep_dev[i].aca_rx_irq); | ||||
| +		disable_irq(priv->ep_dev[i].aca_tx_irq); | ||||
| +	} | ||||
| + | ||||
|  	g_plat_priv->netdev = NULL; | ||||
| +	g_plat_priv->napi_tx = NULL; | ||||
| +	g_plat_priv->napi_rx = NULL; | ||||
| + | ||||
| +	for (i = 0; i < EP_MAX_NUM && i < priv->ep_num; i++) { | ||||
| +		enable_irq(priv->ep_dev[i].aca_rx_irq); | ||||
| +		enable_irq(priv->ep_dev[i].aca_tx_irq); | ||||
| +	} | ||||
|   | ||||
|  	return; | ||||
|  } | ||||
| @@ -1084,6 +1221,10 @@ static void plat_tc_ops_setup(struct tc_ | ||||
|  	priv->tc_ops.free = plat_mem_free; | ||||
|  	priv->tc_ops.dev_reg = plat_open; | ||||
|  	priv->tc_ops.dev_unreg = plat_close; | ||||
| +	priv->tc_ops.net_open = plat_net_open; | ||||
| +	priv->tc_ops.net_stop = plat_net_stop; | ||||
| +	priv->tc_ops.napi_tx = plat_txout_napi; | ||||
| +	priv->tc_ops.napi_rx = plat_rxout_napi; | ||||
|  	priv->tc_ops.umt_init = plat_umt_init; | ||||
|  	priv->tc_ops.umt_exit = plat_umt_exit; | ||||
|  	priv->tc_ops.umt_start = plat_umt_start; | ||||
| --- a/dcdp/atm_tc.c | ||||
| +++ b/dcdp/atm_tc.c | ||||
| @@ -3650,7 +3650,7 @@ static void atm_aca_ring_config_init(str | ||||
|  static int atm_ring_init(struct atm_priv *priv) | ||||
|  { | ||||
|  	atm_aca_ring_config_init(priv); | ||||
| -	return priv->tc_priv->tc_ops.dev_reg(NULL, g_atm_dev_name, 0, 0); | ||||
| +	return priv->tc_priv->tc_ops.dev_reg(NULL, g_atm_dev_name, NULL, NULL, 0, 0); | ||||
|  } | ||||
|   | ||||
|  static int atm_init(struct tc_priv *tcpriv, u32 ep_id) | ||||
| @@ -4020,7 +4020,7 @@ void atm_tc_unload(void) | ||||
|  	/* unregister device */ | ||||
|  	if (priv->tc_priv->tc_ops.dev_unreg != NULL) | ||||
|  		priv->tc_priv->tc_ops.dev_unreg(NULL, | ||||
| -			g_atm_dev_name, 0); | ||||
| +			g_atm_dev_name, NULL, NULL, 0); | ||||
|   | ||||
|  	/* atm_dev_deinit(priv); */ | ||||
|  	/* modem module power off */ | ||||
| --- a/dcdp/inc/tc_main.h | ||||
| +++ b/dcdp/inc/tc_main.h | ||||
| @@ -209,9 +209,15 @@ struct tc_hw_ops { | ||||
|  	void (*subif_unreg)(struct net_device *pdev, const char *dev_name, | ||||
|  			int subif_id, int flag); | ||||
|  	int (*dev_reg)(struct net_device *pdev, const char *dev_name, | ||||
| +			struct napi_struct *napi_tx, struct napi_struct *napi_rx, | ||||
|  			int id, int flag); | ||||
|  	void (*dev_unreg)(struct net_device *pdev, const char *dev_name, | ||||
| +			struct napi_struct *napi_tx, struct napi_struct *napi_rx, | ||||
|  			int flag); | ||||
| +	void (*net_open)(void); | ||||
| +	void (*net_stop)(void); | ||||
| +	int (*napi_tx)(struct napi_struct *napi, int budget); | ||||
| +	int (*napi_rx)(struct napi_struct *napi, int budget); | ||||
|   | ||||
|  	/*umt init/exit including the corresponding DMA init/exit */ | ||||
|  	int (*umt_init)(u32 umt_id, u32 umt_period, u32 umt_dst); | ||||
| --- a/dcdp/ptm_tc.c | ||||
| +++ b/dcdp/ptm_tc.c | ||||
| @@ -146,7 +146,11 @@ static int ptm_open(struct net_device *d | ||||
|  	struct ptm_priv *ptm_tc = netdev_priv(dev); | ||||
|   | ||||
|  	tc_info(ptm_tc->tc_priv, MSG_EVENT, "ptm open\n"); | ||||
| + | ||||
| +	ptm_tc->tc_priv->tc_ops.net_open(); | ||||
| + | ||||
|  	netif_tx_start_all_queues(dev); | ||||
| + | ||||
|  #ifdef CONFIG_SOC_TYPE_XWAY | ||||
|  	xet_phy_wan_port(7, NULL, 1, 1); | ||||
|  	if (ppa_hook_ppa_phys_port_add_fn) | ||||
| @@ -163,7 +167,11 @@ static int ptm_stop(struct net_device *d | ||||
|  	struct ptm_priv *ptm_tc = netdev_priv(dev); | ||||
|   | ||||
|  	tc_info(ptm_tc->tc_priv, MSG_EVENT, "ptm stop\n"); | ||||
| + | ||||
|  	netif_tx_stop_all_queues(dev); | ||||
| + | ||||
| +	ptm_tc->tc_priv->tc_ops.net_stop(); | ||||
| + | ||||
|  #ifdef CONFIG_SOC_TYPE_XWAY | ||||
|      if (ppa_drv_datapath_mac_entry_setting) | ||||
|          ppa_drv_datapath_mac_entry_setting(dev->dev_addr, 0, 6, 10, 1, 2); | ||||
| @@ -564,7 +572,7 @@ static void ptm_rx(struct net_device *de | ||||
|  	ptm_tc->stats64.rx_packets++; | ||||
|  	ptm_tc->stats64.rx_bytes += skb->len; | ||||
|   | ||||
| -	if (netif_rx(skb) == NET_RX_DROP) | ||||
| +	if (netif_receive_skb(skb) == NET_RX_DROP) | ||||
|  		ptm_tc->stats64.rx_dropped++; | ||||
|   | ||||
|  	return; | ||||
| @@ -664,6 +672,14 @@ static int ptm_dev_init(struct tc_priv * | ||||
|  	memcpy(ptm_tc->outq_map, def_outq_map, sizeof(def_outq_map)); | ||||
|  	SET_NETDEV_DEV(ptm_tc->dev, tc_priv->ep_dev[id].dev); | ||||
|   | ||||
| +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(5,17,0)) | ||||
| +	netif_napi_add(ptm_tc->dev, &ptm_tc->napi_rx, tc_priv->tc_ops.napi_rx); | ||||
| +	netif_napi_add_tx(ptm_tc->dev, &ptm_tc->napi_tx, tc_priv->tc_ops.napi_tx); | ||||
| +#else | ||||
| +	netif_napi_add(ptm_tc->dev, &ptm_tc->napi_rx, tc_priv->tc_ops.napi_rx, NAPI_POLL_WEIGHT); | ||||
| +	netif_tx_napi_add(ptm_tc->dev, &ptm_tc->napi_tx, tc_priv->tc_ops.napi_tx, NAPI_POLL_WEIGHT); | ||||
| + | ||||
| +#endif | ||||
|  	err = register_netdev(ptm_tc->dev); | ||||
|  	if (err) | ||||
|  		goto err1; | ||||
| @@ -2618,7 +2634,9 @@ static int ptm_ring_init(struct ptm_ep_p | ||||
|  { | ||||
|  	ptm_aca_ring_config_init(priv, id, bonding); | ||||
|  	return priv->tc_priv->tc_ops.dev_reg(priv->ptm_tc->dev, | ||||
| -		priv->ptm_tc->dev->name, id, bonding); | ||||
| +		priv->ptm_tc->dev->name, | ||||
| +		&priv->ptm_tc->napi_tx, &priv->ptm_tc->napi_rx, | ||||
| +		id, bonding); | ||||
|  } | ||||
|   | ||||
|  /** | ||||
| @@ -2973,7 +2991,9 @@ void ptm_tc_unload(enum dsl_tc_mode tc_m | ||||
|  	/* unregister device */ | ||||
|  	if (ptm_tc->tc_priv->tc_ops.dev_unreg != NULL) | ||||
|  		ptm_tc->tc_priv->tc_ops.dev_unreg(ptm_tc->dev, | ||||
| -			ptm_tc->dev->name, 0); | ||||
| +			ptm_tc->dev->name, | ||||
| +			&priv->ptm_tc->napi_tx, &priv->ptm_tc->napi_rx, | ||||
| +			0); | ||||
|   | ||||
|  	/* remove PTM callback function */ | ||||
|  	ptm_cb_setup(ptm_tc, 0); | ||||
| @@ -2991,6 +3011,10 @@ void ptm_exit(void) | ||||
|   | ||||
|  	if (!priv) | ||||
|  		return; | ||||
| + | ||||
| +	netif_napi_del(&priv->napi_tx); | ||||
| +	netif_napi_del(&priv->napi_rx); | ||||
| + | ||||
|  	unregister_netdev(priv->dev); | ||||
|  	free_netdev(priv->dev); | ||||
|   | ||||
| --- a/dcdp/inc/ptm_tc.h | ||||
| +++ b/dcdp/inc/ptm_tc.h | ||||
| @@ -119,6 +119,8 @@ struct ptm_priv { | ||||
|  	u32 ep_id; | ||||
|  	struct ppe_fw fw; | ||||
|  	struct net_device *dev; | ||||
| +	struct napi_struct napi_tx; | ||||
| +	struct napi_struct napi_rx; | ||||
|  	spinlock_t ptm_lock; | ||||
|  	struct rtnl_link_stats64 stats64; | ||||
|  	int subif_id; | ||||
							
								
								
									
										120
									
								
								package/kernel/lantiq/vrx518_tc/patches/203-dbg.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								package/kernel/lantiq/vrx518_tc/patches/203-dbg.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,120 @@ | ||||
| --- a/dcdp/platform/sw_plat.c | ||||
| +++ b/dcdp/platform/sw_plat.c | ||||
| @@ -85,6 +85,7 @@ struct aca_ring { | ||||
|  	u32 dnum; | ||||
|  	u32 dsize; | ||||
|  	int idx; /* SoC RX/TX index */ | ||||
| +	u64 cnt; | ||||
|  	int ep_dev_idx; | ||||
|  }; | ||||
|   | ||||
| @@ -210,6 +211,8 @@ struct plat_priv { | ||||
|  	struct net_device *netdev; | ||||
|  	struct napi_struct *napi_tx; | ||||
|  	struct napi_struct *napi_rx; | ||||
| +	u64 napi_tx_stats[NAPI_POLL_WEIGHT+1]; | ||||
| +	u64 napi_rx_stats[NAPI_POLL_WEIGHT+1]; | ||||
|  	DECLARE_HASHTABLE(mem_map, 8); | ||||
|  }; | ||||
|   | ||||
| @@ -362,6 +365,7 @@ static void txlist_free(struct tx_list * | ||||
|  static inline void ring_idx_inc(struct aca_ring *ring) | ||||
|  { | ||||
|  	ring->idx = (ring->idx + 1) % ring->dnum; | ||||
| +	ring->cnt += 1; | ||||
|  } | ||||
|   | ||||
|  static struct sk_buff *txin_skb_prepare(struct sk_buff *skb) | ||||
| @@ -619,6 +623,8 @@ static int plat_txout_napi(struct napi_s | ||||
|   | ||||
|  	cnt = txout_action(tcpriv, txout, budget); | ||||
|   | ||||
| +	priv->napi_tx_stats[cnt] += 1; | ||||
| + | ||||
|  	if (cnt < budget) { | ||||
|  		if (napi_complete_done(napi, cnt)) | ||||
|  			ep_dev->hw_ops->icu_en(ep_dev, ACA_HOSTIF_TX); | ||||
| @@ -653,6 +659,8 @@ static int plat_rxout_napi(struct napi_s | ||||
|  	if (cnt) | ||||
|  		rxin_action(tcpriv, rxin, DMA_PACKET_SZ, cnt); | ||||
|   | ||||
| +	priv->napi_rx_stats[cnt] += 1; | ||||
| + | ||||
|  	if (cnt < budget) { | ||||
|  		if (napi_complete_done(napi, cnt)) | ||||
|  			ep_dev->hw_ops->icu_en(ep_dev, ACA_HOSTIF_RX); | ||||
| @@ -1092,6 +1100,56 @@ static int plat_soc_cfg_get(struct soc_c | ||||
|  	return 0; | ||||
|  } | ||||
|   | ||||
| +static struct proc_dir_entry *g_proc_entry; | ||||
| + | ||||
| +static int proc_show(struct seq_file *m, void *p) | ||||
| +{ | ||||
| +	struct aca_ring *txin = &g_plat_priv->soc_rings.txin; | ||||
| +	struct aca_ring *txout = &g_plat_priv->soc_rings.txout; | ||||
| +	struct aca_ring *rxin = &g_plat_priv->soc_rings.rxin; | ||||
| +	struct aca_ring *rxout = &g_plat_priv->soc_rings.rxout; | ||||
| +	int i; | ||||
| + | ||||
| +	seq_printf(m, "napi_tx_stats: "); | ||||
| +	for (i = 0; i < sizeof(g_plat_priv->napi_tx_stats) / sizeof(g_plat_priv->napi_tx_stats[0]); i++) { | ||||
| +		if (i == 0) { | ||||
| +			seq_printf(m, "%llu", g_plat_priv->napi_tx_stats[i]); | ||||
| +		} else { | ||||
| +			seq_printf(m, ", %llu", g_plat_priv->napi_tx_stats[i]); | ||||
| +		} | ||||
| +	} | ||||
| +	seq_printf(m, "\n"); | ||||
| + | ||||
| +	seq_printf(m, "napi_rx_stats: "); | ||||
| +	for (i = 0; i < sizeof(g_plat_priv->napi_rx_stats) / sizeof(g_plat_priv->napi_rx_stats[0]); i++) { | ||||
| +		if (i == 0) { | ||||
| +			seq_printf(m, "%llu", g_plat_priv->napi_rx_stats[i]); | ||||
| +		} else { | ||||
| +			seq_printf(m, ", %llu", g_plat_priv->napi_rx_stats[i]); | ||||
| +		} | ||||
| +	} | ||||
| +	seq_printf(m, "\n"); | ||||
| + | ||||
| +	seq_printf(m, "txin: %d/%u, %llu\n", txin->idx, txin->dnum, txin->cnt); | ||||
| +	seq_printf(m, "txout: %d/%u, %llu\n", txout->idx, txout->dnum, txout->cnt); | ||||
| +	seq_printf(m, "rxin: %d/%u, %llu\n", rxin->idx, rxin->dnum, rxin->cnt); | ||||
| +	seq_printf(m, "rxout: %d/%u, %llu\n", rxout->idx, rxout->dnum, rxout->cnt); | ||||
| + | ||||
| +	return 0; | ||||
| +} | ||||
| + | ||||
| +static int proc_open(struct inode *inode, struct file *file) | ||||
| +{ | ||||
| +	return single_open(file, proc_show, NULL); | ||||
| +} | ||||
| + | ||||
| +static struct proc_ops proc_operations = { | ||||
| +        .proc_open    = proc_open, | ||||
| +        .proc_read    = seq_read, | ||||
| +        .proc_lseek   = seq_lseek, | ||||
| +        .proc_release = single_release | ||||
| +}; | ||||
| + | ||||
|  static int plat_open(struct net_device *pdev, const char *dev_name, | ||||
|  		struct napi_struct *napi_tx, struct napi_struct *napi_rx, | ||||
|  		int id, int flag) | ||||
| @@ -1099,6 +1157,8 @@ static int plat_open(struct net_device * | ||||
|  	struct tc_priv *priv = g_plat_priv->tc_priv; | ||||
|  	int i; | ||||
|   | ||||
| +	g_proc_entry = proc_create("swplat", 0600, priv->proc_dir, &proc_operations); | ||||
| + | ||||
|  	for (i = 0; i < EP_MAX_NUM && i < priv->ep_num; i++) { | ||||
|  		disable_irq(priv->ep_dev[i].aca_rx_irq); | ||||
|  		disable_irq(priv->ep_dev[i].aca_tx_irq); | ||||
| @@ -1137,6 +1197,8 @@ static void plat_close(struct net_device | ||||
|  		enable_irq(priv->ep_dev[i].aca_tx_irq); | ||||
|  	} | ||||
|   | ||||
| +	proc_remove(g_proc_entry); | ||||
| + | ||||
|  	return; | ||||
|  } | ||||
|   | ||||
| @@ -0,0 +1,31 @@ | ||||
| --- a/dcdp/atm_tc.c | ||||
| +++ b/dcdp/atm_tc.c | ||||
| @@ -746,7 +746,8 @@ static void atm_aca_init(struct atm_priv | ||||
|  		ACA_TXOUT_EN | ACA_RXIN_EN | ACA_RXOUT_EN, 1); | ||||
|  } | ||||
|   | ||||
| -static int print_datetime(char *buffer, const struct timespec64 *datetime) | ||||
| +static int print_datetime(char *buffer, int buffer_size, | ||||
| +			  const struct timespec64 *datetime) | ||||
|  { | ||||
|  	struct tm nowtm; | ||||
|  	char tmbuf[64]; | ||||
| @@ -765,7 +766,8 @@ static int print_datetime(char *buffer, | ||||
|  			nowtm.tm_hour, | ||||
|  			nowtm.tm_min, | ||||
|  			nowtm.tm_sec); | ||||
| -	snprintf(buffer, sizeof(buffer), "%s.%06d", tmbuf, (int)datetime->tv_nsec / 1000); | ||||
| +	snprintf(buffer, sizeof(tmbuf)+buffer_size, "%s.%06d", | ||||
| +		 tmbuf, (int)datetime->tv_nsec / 1000); | ||||
|   | ||||
|  	return 0; | ||||
|  } | ||||
| @@ -967,7 +969,7 @@ void show_atm_pvc(struct seq_file *seq, | ||||
|  	char buf[64]; | ||||
|   | ||||
|  	seq_printf(seq, "\tNet device: %s\n", pvc->dev->name); | ||||
| -	print_datetime(buf, &(pvc->access_time)); | ||||
| +	print_datetime(buf, sizeof(buf), &(pvc->access_time)); | ||||
|  	seq_printf(seq, "\tLast user cell: %s\n", buf); | ||||
|  	seq_printf(seq, "\tPort: %d\n", pvc->port); | ||||
|  	seq_printf(seq, "\tSoftware TX Queue: %u\n", pvc->sw_txq_tbl); | ||||
| @@ -0,0 +1,206 @@ | ||||
| --- a/dcdp/ptm_tc.c | ||||
| +++ b/dcdp/ptm_tc.c | ||||
| @@ -307,15 +307,19 @@ static int ptm_tc_get_stats(struct ptm_e | ||||
|  ) | ||||
|  { | ||||
|  	struct rtnl_link_stats64 *stat; | ||||
| -	struct wan_rx_mib_table rx_mib; | ||||
| +	struct wan_rx_mib_table *rx_mib; | ||||
|  	unsigned int cur_cnt, last_cnt; | ||||
|  	struct intel_tc_ptm_sl_stats *ptm_sl_stats; | ||||
|  	struct ptm_priv *ptm_tc; | ||||
| +	int ret = 0; | ||||
|  	if (!priv || !stats) | ||||
|  		return -EFAULT; | ||||
|  	ptm_tc = priv->ptm_tc; | ||||
|  	if (!ptm_tc) | ||||
|  		return -EFAULT; | ||||
| +	rx_mib = kzalloc(sizeof(*rx_mib), GFP_KERNEL); | ||||
| +	if (!rx_mib) | ||||
| +		return -ENOMEM; | ||||
|  	if (bonding) | ||||
|  		stats->tc_info = TC_PTM_BND_MODE; | ||||
|  	else | ||||
| @@ -349,11 +353,11 @@ static int ptm_tc_get_stats(struct ptm_e | ||||
|  		? cur_cnt - last_cnt | ||||
|  		: cur_cnt + ((unsigned int)(-1) - last_cnt); | ||||
|   | ||||
| -	tc_mem_read(priv, &rx_mib, | ||||
| +	tc_mem_read(priv, rx_mib, | ||||
|  		fpi_addr(__RX_GIF_MIB_BASE), | ||||
| -		sizeof(rx_mib) | ||||
| +		sizeof(*rx_mib) | ||||
|  	); | ||||
| -	ptm_sl_stats->wrx_gif_drop_pdu = rx_mib.wrx_dropdes_pdu; | ||||
| +	ptm_sl_stats->wrx_gif_drop_pdu = rx_mib->wrx_dropdes_pdu; | ||||
|   | ||||
|  	cur_cnt = tc_r32(GIF0_RX_CRC_ERR_CNT); | ||||
|  	last_cnt = priv->ptm_mib.rx_crc_err_pdu[0]; | ||||
| @@ -367,7 +371,7 @@ static int ptm_tc_get_stats(struct ptm_e | ||||
|  		? cur_cnt - last_cnt | ||||
|  		: cur_cnt + ((unsigned int)(-1) - last_cnt); | ||||
|   | ||||
| -	ptm_sl_stats->wrx_gif_total_bytes = rx_mib.wrx_total_bytes; | ||||
| +	ptm_sl_stats->wrx_gif_total_bytes = rx_mib->wrx_total_bytes; | ||||
|  	cur_cnt = sb_r32(__US_TC_LOCAL_Q_CFG_CTXT_BASE + | ||||
|  		offsetof(desq_cfg_ctxt_t, deq_pkt_cnt) / 4); | ||||
|  	last_cnt = priv->ptm_mib.tx_total_pdu[0]; | ||||
| @@ -385,90 +389,108 @@ static int ptm_tc_get_stats(struct ptm_e | ||||
|  	/* For bonding information */ | ||||
|  	if (bonding) { | ||||
|  		int i; | ||||
| -		struct intel_tc_ptm_bonding_stats ptm_ds; | ||||
| -		struct intel_tc_ptm_bonding_stats ptm_us; | ||||
| +		struct intel_tc_ptm_bonding_stats *ptm_ds; | ||||
| +		struct intel_tc_ptm_bonding_stats *ptm_us; | ||||
|  		struct intel_tc_ptm_bonding_stats *ptm_bonding_stats; | ||||
| + | ||||
| +		ptm_ds = kzalloc(sizeof(*ptm_ds), GFP_KERNEL); | ||||
| +		if (!ptm_ds) { | ||||
| +			ret = -ENOMEM; | ||||
| +			goto free_rx_mib; | ||||
| +		} | ||||
| +		 | ||||
| +		ptm_us = kzalloc(sizeof(*ptm_us), GFP_KERNEL); | ||||
| +		if (!ptm_us) { | ||||
| +			ret = -ENOMEM; | ||||
| +			goto free_ptm_ds; | ||||
| +		} | ||||
| + | ||||
|  		priv = tc_ep_priv(0); | ||||
| -		ptm_tc_bond_get_stats(priv, &ptm_ds); | ||||
| +		ptm_tc_bond_get_stats(priv, ptm_ds); | ||||
|  		priv = tc_ep_priv(1); | ||||
| -		ptm_tc_bond_get_stats(priv, &ptm_us); | ||||
| +		ptm_tc_bond_get_stats(priv, ptm_us); | ||||
|  		ptm_bonding_stats = | ||||
|  			&(stats->stats.ptm_tc_stats.pmt_bonding_stats); | ||||
|  		for (i = 0; i < 8; i++) | ||||
|  			ptm_bonding_stats->us_gif_mib[i] = | ||||
| -				ptm_ds.us_gif_mib[i] + ptm_us.us_gif_mib[i]; | ||||
| +				ptm_ds->us_gif_mib[i] + ptm_us->us_gif_mib[i]; | ||||
|  		for (i = 0; i < 8; i++) { | ||||
|  			ptm_bonding_stats->ds_gif_mib[i].rx_frag_byte_cnt = | ||||
| -				ptm_ds.ds_gif_mib[i].rx_frag_byte_cnt | ||||
| -				+ ptm_us.ds_gif_mib[i].rx_frag_byte_cnt; | ||||
| +				ptm_ds->ds_gif_mib[i].rx_frag_byte_cnt | ||||
| +				+ ptm_us->ds_gif_mib[i].rx_frag_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_gif_mib[i].rx_byte_cnt = | ||||
| -				ptm_ds.ds_gif_mib[i].rx_byte_cnt | ||||
| -				+ ptm_us.ds_gif_mib[i].rx_byte_cnt; | ||||
| +				ptm_ds->ds_gif_mib[i].rx_byte_cnt | ||||
| +				+ ptm_us->ds_gif_mib[i].rx_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_gif_mib[i].rx_of_frag_byte_cnt = | ||||
| -				ptm_ds.ds_gif_mib[i].rx_of_frag_byte_cnt | ||||
| -				+ ptm_us.ds_gif_mib[i].rx_of_frag_byte_cnt; | ||||
| +				ptm_ds->ds_gif_mib[i].rx_of_frag_byte_cnt | ||||
| +				+ ptm_us->ds_gif_mib[i].rx_of_frag_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_gif_mib[i].rx_of_byte_cnt = | ||||
| -				ptm_ds.ds_gif_mib[i].rx_of_byte_cnt | ||||
| -				+ ptm_us.ds_gif_mib[i].rx_of_byte_cnt; | ||||
| +				ptm_ds->ds_gif_mib[i].rx_of_byte_cnt | ||||
| +				+ ptm_us->ds_gif_mib[i].rx_of_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_gif_mib[i].rx_oor_frag_byte_cnt = | ||||
| -				ptm_ds.ds_gif_mib[i].rx_oor_frag_byte_cnt | ||||
| -				+ ptm_us.ds_gif_mib[i].rx_oor_frag_byte_cnt; | ||||
| +				ptm_ds->ds_gif_mib[i].rx_oor_frag_byte_cnt | ||||
| +				+ ptm_us->ds_gif_mib[i].rx_oor_frag_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_gif_mib[i].rx_miss_frag_byte_cnt = | ||||
| -				ptm_ds.ds_gif_mib[i].rx_miss_frag_byte_cnt | ||||
| -				+ ptm_us.ds_gif_mib[i].rx_miss_frag_byte_cnt; | ||||
| +				ptm_ds->ds_gif_mib[i].rx_miss_frag_byte_cnt | ||||
| +				+ ptm_us->ds_gif_mib[i].rx_miss_frag_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_gif_mib[i].rx_to_frag_byte_cnt = | ||||
| -				ptm_ds.ds_gif_mib[i].rx_to_frag_byte_cnt | ||||
| -				+ ptm_us.ds_gif_mib[i].rx_to_frag_byte_cnt; | ||||
| +				ptm_ds->ds_gif_mib[i].rx_to_frag_byte_cnt | ||||
| +				+ ptm_us->ds_gif_mib[i].rx_to_frag_byte_cnt; | ||||
|  		} | ||||
|  		for (i = 0; i < 4; i++) { | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].conform_pkt_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].conform_pkt_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].conform_pkt_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].conform_pkt_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].conform_pkt_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].conform_frag_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].conform_frag_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].conform_frag_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].conform_frag_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].conform_frag_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].conform_byte_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].conform_byte_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].conform_byte_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].conform_byte_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].conform_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].no_sop_pkt_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].no_sop_pkt_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].no_sop_pkt_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].no_sop_pkt_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].no_sop_pkt_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].no_sop_frag_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].no_sop_frag_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].no_sop_frag_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].no_sop_frag_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].no_sop_frag_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].no_sop_byte_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].no_sop_byte_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].no_sop_byte_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].no_sop_byte_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].no_sop_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].no_eop_pkt_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].no_eop_pkt_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].no_eop_pkt_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].no_eop_pkt_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].no_eop_pkt_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].no_eop_frag_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].no_eop_frag_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].no_eop_frag_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].no_eop_frag_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].no_eop_frag_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].no_eop_byte_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].no_eop_byte_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].no_eop_byte_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].no_eop_byte_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].no_eop_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].oversize_pkt_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].oversize_pkt_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].oversize_pkt_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].oversize_pkt_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].oversize_pkt_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].oversize_frag_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].oversize_frag_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].oversize_frag_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].oversize_frag_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].oversize_frag_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].oversize_byte_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].oversize_byte_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].oversize_byte_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].oversize_byte_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].oversize_byte_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].noncosec_pkt_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].noncosec_pkt_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].noncosec_pkt_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].noncosec_pkt_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].noncosec_pkt_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].noncosec_frag_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].noncosec_frag_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].noncosec_frag_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].noncosec_frag_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].noncosec_frag_cnt; | ||||
|  			ptm_bonding_stats->ds_bg_mib[i].noncosec_byte_cnt = | ||||
| -				ptm_ds.ds_bg_mib[i].noncosec_byte_cnt | ||||
| -				+ ptm_us.ds_bg_mib[i].noncosec_byte_cnt; | ||||
| +				ptm_ds->ds_bg_mib[i].noncosec_byte_cnt | ||||
| +				+ ptm_us->ds_bg_mib[i].noncosec_byte_cnt; | ||||
|  		} | ||||
| +		kfree(ptm_us); | ||||
| +free_ptm_ds: | ||||
| +		kfree(ptm_ds); | ||||
|  	} | ||||
| -	return 0; | ||||
| +free_rx_mib: | ||||
| +	kfree(rx_mib); | ||||
| +	return ret; | ||||
|  } | ||||
|  static int ptm_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) | ||||
|  { | ||||
		Reference in New Issue
	
	Block a user
	 domenico
					domenico