mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	bnxt_en: Improve RX consumer index validity check.
There is logic to check that the RX/TPA consumer index is the expected
index to work around a hardware problem.  However, the potentially bad
consumer index is first used to index into an array to reference an entry.
This can potentially crash if the bad consumer index is beyond legal
range.  Improve the logic to use the consumer index for dereferencing
after the validity check and log an error message.
Fixes: fa7e28127a ("bnxt_en: Add workaround to detect bad opaque in rx completion (part 2)")
Signed-off-by: Michael Chan <michael.chan@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
			
			
This commit is contained in:
		
							parent
							
								
									a62520473f
								
							
						
					
					
						commit
						a1b0e4e684
					
				| @ -1133,6 +1133,8 @@ static void bnxt_tpa_start(struct bnxt *bp, struct bnxt_rx_ring_info *rxr, | ||||
| 	tpa_info = &rxr->rx_tpa[agg_id]; | ||||
| 
 | ||||
| 	if (unlikely(cons != rxr->rx_next_cons)) { | ||||
| 		netdev_warn(bp->dev, "TPA cons %x != expected cons %x\n", | ||||
| 			    cons, rxr->rx_next_cons); | ||||
| 		bnxt_sched_reset(bp, rxr); | ||||
| 		return; | ||||
| 	} | ||||
| @ -1585,15 +1587,17 @@ static int bnxt_rx_pkt(struct bnxt *bp, struct bnxt_cp_ring_info *cpr, | ||||
| 	} | ||||
| 
 | ||||
| 	cons = rxcmp->rx_cmp_opaque; | ||||
| 	rx_buf = &rxr->rx_buf_ring[cons]; | ||||
| 	data = rx_buf->data; | ||||
| 	data_ptr = rx_buf->data_ptr; | ||||
| 	if (unlikely(cons != rxr->rx_next_cons)) { | ||||
| 		int rc1 = bnxt_discard_rx(bp, cpr, raw_cons, rxcmp); | ||||
| 
 | ||||
| 		netdev_warn(bp->dev, "RX cons %x != expected cons %x\n", | ||||
| 			    cons, rxr->rx_next_cons); | ||||
| 		bnxt_sched_reset(bp, rxr); | ||||
| 		return rc1; | ||||
| 	} | ||||
| 	rx_buf = &rxr->rx_buf_ring[cons]; | ||||
| 	data = rx_buf->data; | ||||
| 	data_ptr = rx_buf->data_ptr; | ||||
| 	prefetch(data_ptr); | ||||
| 
 | ||||
| 	misc = le32_to_cpu(rxcmp->rx_cmp_misc_v1); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Michael Chan
						Michael Chan