mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-11-01 09:13:37 +00:00 
			
		
		
		
	qlge: bugfix: Increase filter on inbound csum.
Chip does not do UDP checksum when fragmentation occurs. Signed-off-by: Ron Mercer <ron.mercer@qlogic.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									9fae6c3f64
								
							
						
					
					
						commit
						c3c6496dc3
					
				
					 2 changed files with 27 additions and 12 deletions
				
			
		| 
						 | 
					@ -927,6 +927,7 @@ struct ib_mac_iocb_rsp {
 | 
				
			||||||
	u8 flags1;
 | 
						u8 flags1;
 | 
				
			||||||
#define IB_MAC_IOCB_RSP_OI	0x01	/* Overide intr delay */
 | 
					#define IB_MAC_IOCB_RSP_OI	0x01	/* Overide intr delay */
 | 
				
			||||||
#define IB_MAC_IOCB_RSP_I	0x02	/* Disble Intr Generation */
 | 
					#define IB_MAC_IOCB_RSP_I	0x02	/* Disble Intr Generation */
 | 
				
			||||||
 | 
					#define IB_MAC_CSUM_ERR_MASK 0x1c	/* A mask to use for csum errs */
 | 
				
			||||||
#define IB_MAC_IOCB_RSP_TE	0x04	/* Checksum error */
 | 
					#define IB_MAC_IOCB_RSP_TE	0x04	/* Checksum error */
 | 
				
			||||||
#define IB_MAC_IOCB_RSP_NU	0x08	/* No checksum rcvd */
 | 
					#define IB_MAC_IOCB_RSP_NU	0x08	/* No checksum rcvd */
 | 
				
			||||||
#define IB_MAC_IOCB_RSP_IE	0x10	/* IPv4 checksum error */
 | 
					#define IB_MAC_IOCB_RSP_IE	0x10	/* IPv4 checksum error */
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1436,18 +1436,32 @@ static void ql_process_mac_rx_intr(struct ql_adapter *qdev,
 | 
				
			||||||
	if (ib_mac_rsp->flags2 & IB_MAC_IOCB_RSP_P) {
 | 
						if (ib_mac_rsp->flags2 & IB_MAC_IOCB_RSP_P) {
 | 
				
			||||||
		QPRINTK(qdev, RX_STATUS, DEBUG, "Promiscuous Packet.\n");
 | 
							QPRINTK(qdev, RX_STATUS, DEBUG, "Promiscuous Packet.\n");
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if (ib_mac_rsp->flags1 & (IB_MAC_IOCB_RSP_IE | IB_MAC_IOCB_RSP_TE)) {
 | 
					
 | 
				
			||||||
		QPRINTK(qdev, RX_STATUS, ERR,
 | 
						skb->protocol = eth_type_trans(skb, ndev);
 | 
				
			||||||
			"Bad checksum for this %s packet.\n",
 | 
						skb->ip_summed = CHECKSUM_NONE;
 | 
				
			||||||
			((ib_mac_rsp->
 | 
					
 | 
				
			||||||
			  flags2 & IB_MAC_IOCB_RSP_T) ? "TCP" : "UDP"));
 | 
						/* If rx checksum is on, and there are no
 | 
				
			||||||
		skb->ip_summed = CHECKSUM_NONE;
 | 
						 * csum or frame errors.
 | 
				
			||||||
	} else if (qdev->rx_csum &&
 | 
						 */
 | 
				
			||||||
		   ((ib_mac_rsp->flags2 & IB_MAC_IOCB_RSP_T) ||
 | 
						if (qdev->rx_csum &&
 | 
				
			||||||
		    ((ib_mac_rsp->flags2 & IB_MAC_IOCB_RSP_U) &&
 | 
							!(ib_mac_rsp->flags2 & IB_MAC_IOCB_RSP_ERR_MASK) &&
 | 
				
			||||||
		     !(ib_mac_rsp->flags1 & IB_MAC_IOCB_RSP_NU)))) {
 | 
							!(ib_mac_rsp->flags1 & IB_MAC_CSUM_ERR_MASK)) {
 | 
				
			||||||
		QPRINTK(qdev, RX_STATUS, DEBUG, "RX checksum done!\n");
 | 
							/* TCP frame. */
 | 
				
			||||||
		skb->ip_summed = CHECKSUM_UNNECESSARY;
 | 
							if (ib_mac_rsp->flags2 & IB_MAC_IOCB_RSP_T) {
 | 
				
			||||||
 | 
								QPRINTK(qdev, RX_STATUS, DEBUG,
 | 
				
			||||||
 | 
										"TCP checksum done!\n");
 | 
				
			||||||
 | 
								skb->ip_summed = CHECKSUM_UNNECESSARY;
 | 
				
			||||||
 | 
							} else if ((ib_mac_rsp->flags2 & IB_MAC_IOCB_RSP_U) &&
 | 
				
			||||||
 | 
									(ib_mac_rsp->flags3 & IB_MAC_IOCB_RSP_V4)) {
 | 
				
			||||||
 | 
							/* Unfragmented ipv4 UDP frame. */
 | 
				
			||||||
 | 
								struct iphdr *iph = (struct iphdr *) skb->data;
 | 
				
			||||||
 | 
								if (!(iph->frag_off &
 | 
				
			||||||
 | 
									cpu_to_be16(IP_MF|IP_OFFSET))) {
 | 
				
			||||||
 | 
									skb->ip_summed = CHECKSUM_UNNECESSARY;
 | 
				
			||||||
 | 
									QPRINTK(qdev, RX_STATUS, DEBUG,
 | 
				
			||||||
 | 
											"TCP checksum done!\n");
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	qdev->stats.rx_packets++;
 | 
						qdev->stats.rx_packets++;
 | 
				
			||||||
	qdev->stats.rx_bytes += skb->len;
 | 
						qdev->stats.rx_bytes += skb->len;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		
		Reference in a new issue