mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-25 19:14:26 -04:00 
			
		
		
		
	Qualcomm NSS-DP is as its name says Qualcomms ethernet driver for the NSS subsystem (Networking subsystem) built-into various Qualcomm SoCs. It has 2 modes of operation: * Without NSS FW and rest of code required for offloading This is the one that we will use as the amount of kernel patching required for NSS offloading and the fact that its not upstreamable at all makes it unusable for us. Driver in this mode is rather basic, it currently only offers NAPI GRO (Added by us as part of the fixup) and basically relies on the powerfull CPU to get good throughput. * With NSS FW and rest of code required for offloading In this mode, driver just registers the interfaces and hooks them into NSS-ECM to allow offloading. This mode is not viable for use in OpenWrt due to reasons already described above. This driver is required for ipq807x to have wired networking until a better one is available, so lets add the fixed-up version for 5.15 for now. Signed-off-by: Robert Marko <robimarko@gmail.com>
		
			
				
	
	
		
			32 lines
		
	
	
		
			1015 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			1015 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From d74920e2a7c413ef40eed72f9cf287cf6fbd5fb8 Mon Sep 17 00:00:00 2001
 | |
| From: Robert Marko <robimarko@gmail.com>
 | |
| Date: Thu, 20 May 2021 14:56:46 +0200
 | |
| Subject: [PATCH 1/2] EDMA: Fix NAPI packet counting
 | |
| 
 | |
| There is a bug in the NAPI packet counting that will
 | |
| cause NAPI over budget warnings.
 | |
| 
 | |
| Signed-off-by: Baruch Siach <baruch@tkos.co.il>
 | |
| Signed-off-by: Robert Marko <robimarko@gmail.com>
 | |
| ---
 | |
|  hal/dp_ops/edma_dp/edma_v1/edma_tx_rx.c | 4 ++--
 | |
|  1 file changed, 2 insertions(+), 2 deletions(-)
 | |
| 
 | |
| --- a/hal/dp_ops/edma_dp/edma_v1/edma_tx_rx.c
 | |
| +++ b/hal/dp_ops/edma_dp/edma_v1/edma_tx_rx.c
 | |
| @@ -459,12 +459,12 @@ int edma_napi(struct napi_struct *napi,
 | |
|  
 | |
|  	for (i = 0; i < ehw->txcmpl_rings; i++) {
 | |
|  		txcmpl_ring = &ehw->txcmpl_ring[i];
 | |
| -		work_done += edma_clean_tx(ehw, txcmpl_ring);
 | |
| +		edma_clean_tx(ehw, txcmpl_ring);
 | |
|  	}
 | |
|  
 | |
|  	for (i = 0; i < ehw->rxfill_rings; i++) {
 | |
|  		rxfill_ring = &ehw->rxfill_ring[i];
 | |
| -		work_done += edma_alloc_rx_buffer(ehw, rxfill_ring);
 | |
| +		edma_alloc_rx_buffer(ehw, rxfill_ring);
 | |
|  	}
 | |
|  
 | |
|  	/*
 |