 27c9d80f51
			
		
	
	27c9d80f51
	
	
		
			
	
		
	
	
		
			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
				
			
		
			
				
	
	
		
			59 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 88a0fd5927b7c2c7aecd6dc747d898eb38043d2b Mon Sep 17 00:00:00 2001
 | |
| From: Felix Fietkau <nbd@nbd.name>
 | |
| Date: Thu, 20 Apr 2023 22:06:42 +0100
 | |
| Subject: [PATCH 093/250] net: mtk_eth_soc: mediatek: fix ppe flow accounting
 | |
|  for v1 hardware
 | |
| 
 | |
| Older chips (like MT7622) use a different bit in ib2 to enable hardware
 | |
| counter support. Add macros for both and select the appropriate bit.
 | |
| 
 | |
| Fixes: 3fbe4d8c0e53 ("net: ethernet: mtk_eth_soc: ppe: add support for flow accounting")
 | |
| Signed-off-by: Felix Fietkau <nbd@nbd.name>
 | |
| Signed-off-by: Daniel Golle <daniel@makrotopia.org>
 | |
| Signed-off-by: David S. Miller <davem@davemloft.net>
 | |
| ---
 | |
|  drivers/net/ethernet/mediatek/mtk_ppe.c | 10 ++++++++--
 | |
|  drivers/net/ethernet/mediatek/mtk_ppe.h |  3 ++-
 | |
|  2 files changed, 10 insertions(+), 3 deletions(-)
 | |
| 
 | |
| --- a/drivers/net/ethernet/mediatek/mtk_ppe.c
 | |
| +++ b/drivers/net/ethernet/mediatek/mtk_ppe.c
 | |
| @@ -599,6 +599,7 @@ __mtk_foe_entry_commit(struct mtk_ppe *p
 | |
|  	struct mtk_eth *eth = ppe->eth;
 | |
|  	u16 timestamp = mtk_eth_timestamp(eth);
 | |
|  	struct mtk_foe_entry *hwe;
 | |
| +	u32 val;
 | |
|  
 | |
|  	if (MTK_HAS_CAPS(eth->soc->caps, MTK_NETSYS_V2)) {
 | |
|  		entry->ib1 &= ~MTK_FOE_IB1_BIND_TIMESTAMP_V2;
 | |
| @@ -615,8 +616,13 @@ __mtk_foe_entry_commit(struct mtk_ppe *p
 | |
|  	wmb();
 | |
|  	hwe->ib1 = entry->ib1;
 | |
|  
 | |
| -	if (ppe->accounting)
 | |
| -		*mtk_foe_entry_ib2(eth, hwe) |= MTK_FOE_IB2_MIB_CNT;
 | |
| +	if (ppe->accounting) {
 | |
| +		if (MTK_HAS_CAPS(eth->soc->caps, MTK_NETSYS_V2))
 | |
| +			val = MTK_FOE_IB2_MIB_CNT_V2;
 | |
| +		else
 | |
| +			val = MTK_FOE_IB2_MIB_CNT;
 | |
| +		*mtk_foe_entry_ib2(eth, hwe) |= val;
 | |
| +	}
 | |
|  
 | |
|  	dma_wmb();
 | |
|  
 | |
| --- a/drivers/net/ethernet/mediatek/mtk_ppe.h
 | |
| +++ b/drivers/net/ethernet/mediatek/mtk_ppe.h
 | |
| @@ -55,9 +55,10 @@ enum {
 | |
|  #define MTK_FOE_IB2_PSE_QOS		BIT(4)
 | |
|  #define MTK_FOE_IB2_DEST_PORT		GENMASK(7, 5)
 | |
|  #define MTK_FOE_IB2_MULTICAST		BIT(8)
 | |
| +#define MTK_FOE_IB2_MIB_CNT		BIT(10)
 | |
|  
 | |
|  #define MTK_FOE_IB2_WDMA_QID2		GENMASK(13, 12)
 | |
| -#define MTK_FOE_IB2_MIB_CNT		BIT(15)
 | |
| +#define MTK_FOE_IB2_MIB_CNT_V2		BIT(15)
 | |
|  #define MTK_FOE_IB2_WDMA_DEVIDX		BIT(16)
 | |
|  #define MTK_FOE_IB2_WDMA_WINFO		BIT(17)
 | |
|  
 |