[kernel/f16] Add patches to fix various ibmveth driver issues (rhbz 733766)

Josh Boyer jwboyer at fedoraproject.org
Wed Sep 14 18:44:31 UTC 2011


commit 203a23e9e4d49baf8da60e8fa06396472078e96a
Author: Josh Boyer <jwboyer at redhat.com>
Date:   Wed Sep 14 14:29:35 2011 -0400

    Add patches to fix various ibmveth driver issues (rhbz 733766)

 ibmveth-Checksum-offload-is-always-disabled.patch |   70 ++++++++++++++++
 ibmveth-Fix-DMA-unmap-error.patch                 |   78 +++++++++++++++++
 ibmveth-Fix-issue-with-DMA-mapping-failure.patch  |   93 +++++++++++++++++++++
 kernel.spec                                       |   11 ++-
 4 files changed, 251 insertions(+), 1 deletions(-)
---
diff --git a/ibmveth-Checksum-offload-is-always-disabled.patch b/ibmveth-Checksum-offload-is-always-disabled.patch
new file mode 100644
index 0000000..9daee41
--- /dev/null
+++ b/ibmveth-Checksum-offload-is-always-disabled.patch
@@ -0,0 +1,70 @@
+Path: news.gmane.org!not-for-mail
+From: Anton Blanchard <anton at samba.org>
+Newsgroups: gmane.linux.network
+Subject: [PATCH 3/4] ibmveth: Checksum offload is always disabled
+Date: Thu, 08 Sep 2011 10:41:05 +1000
+Lines: 23
+Approved: news at gmane.org
+Message-ID: <20110908004121.744925909 at samba.org>
+References: <20110908004102.355674129 at samba.org>
+NNTP-Posting-Host: lo.gmane.org
+X-Trace: dough.gmane.org 1315442745 17939 80.91.229.12 (8 Sep 2011 00:45:45 GMT)
+X-Complaints-To: usenet at dough.gmane.org
+NNTP-Posting-Date: Thu, 8 Sep 2011 00:45:45 +0000 (UTC)
+Cc: netdev at vger.kernel.org
+To: Santiago Leon <santil at linux.vnet.ibm.com>,
+	brking at linux.vnet.ibm.com, rcj at linux.vnet.ibm.com,
+	mirq-linux at rere.qmqm.pl
+Original-X-From: netdev-owner at vger.kernel.org Thu Sep 08 02:45:39 2011
+Return-path: <netdev-owner at vger.kernel.org>
+Envelope-to: linux-netdev-2 at lo.gmane.org
+Original-Received: from vger.kernel.org ([209.132.180.67])
+	by lo.gmane.org with esmtp (Exim 4.69)
+	(envelope-from <netdev-owner at vger.kernel.org>)
+	id 1R1SkN-0001Tk-2c
+	for linux-netdev-2 at lo.gmane.org; Thu, 08 Sep 2011 02:45:39 +0200
+Original-Received: (majordomo at vger.kernel.org) by vger.kernel.org via listexpand
+	id S1757675Ab1IHApb (ORCPT <rfc822;linux-netdev-2 at m.gmane.org>);
+	Wed, 7 Sep 2011 20:45:31 -0400
+Original-Received: from ozlabs.org ([203.10.76.45]:45063 "EHLO ozlabs.org"
+	rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP
+	id S1757657Ab1IHAp1 (ORCPT <rfc822;netdev at vger.kernel.org>);
+	Wed, 7 Sep 2011 20:45:27 -0400
+Original-Received: from localhost (ppp121-44-79-234.lns20.syd6.internode.on.net [121.44.79.234])
+	(using TLSv1 with cipher DHE-RSA-AES128-SHA (128/128 bits))
+	(Client did not present a certificate)
+	by ozlabs.org (Postfix) with ESMTPSA id 17FFBB6F98;
+	Thu,  8 Sep 2011 10:45:26 +1000 (EST)
+X-Mailbox-Line: From anton at samba.org Thu Sep  8 10:41:21 2011
+User-Agent: quilt/0.48-1
+Content-Disposition: inline; filename=ibmveth_fix_csum.patch
+Original-Sender: netdev-owner at vger.kernel.org
+Precedence: bulk
+List-ID: <netdev.vger.kernel.org>
+X-Mailing-List: netdev at vger.kernel.org
+Xref: news.gmane.org gmane.linux.network:205929
+Archived-At: <http://permalink.gmane.org/gmane.linux.network/205929>
+
+Commit b9367bf3ee6d (net: ibmveth: convert to hw_features) reversed
+a check in ibmveth_set_csum_offload that results in checksum offload
+never being enabled.
+
+Signed-off-by: Anton Blanchard <anton at samba.org>
+Cc: <stable at kernel.org> # 3.0+
+---
+
+Index: linux-build/drivers/net/ibmveth.c
+===================================================================
+--- linux-build.orig/drivers/net/ibmveth.c	2011-09-01 16:02:12.198726425 +1000
++++ linux-build/drivers/net/ibmveth.c	2011-09-01 16:05:37.282482851 +1000
+@@ -812,7 +812,7 @@ static int ibmveth_set_csum_offload(stru
+ 		} else
+ 			adapter->fw_ipv6_csum_support = data;
+ 
+-		if (ret != H_SUCCESS || ret6 != H_SUCCESS)
++		if (ret == H_SUCCESS || ret6 == H_SUCCESS)
+ 			adapter->rx_csum = data;
+ 		else
+ 			rc1 = -EIO;
+
+
diff --git a/ibmveth-Fix-DMA-unmap-error.patch b/ibmveth-Fix-DMA-unmap-error.patch
new file mode 100644
index 0000000..b619a16
--- /dev/null
+++ b/ibmveth-Fix-DMA-unmap-error.patch
@@ -0,0 +1,78 @@
+Path: news.gmane.org!not-for-mail
+From: Anton Blanchard <anton at samba.org>
+Newsgroups: gmane.linux.network
+Subject: [PATCH 1/4] ibmveth: Fix DMA unmap error
+Date: Thu, 08 Sep 2011 10:41:03 +1000
+Lines: 32
+Approved: news at gmane.org
+Message-ID: <20110908004121.570234962 at samba.org>
+References: <20110908004102.355674129 at samba.org>
+NNTP-Posting-Host: lo.gmane.org
+X-Trace: dough.gmane.org 1315442763 18071 80.91.229.12 (8 Sep 2011 00:46:03 GMT)
+X-Complaints-To: usenet at dough.gmane.org
+NNTP-Posting-Date: Thu, 8 Sep 2011 00:46:03 +0000 (UTC)
+Cc: netdev at vger.kernel.org
+To: Santiago Leon <santil at linux.vnet.ibm.com>,
+	brking at linux.vnet.ibm.com, rcj at linux.vnet.ibm.com
+Original-X-From: netdev-owner at vger.kernel.org Thu Sep 08 02:45:56 2011
+Return-path: <netdev-owner at vger.kernel.org>
+Envelope-to: linux-netdev-2 at lo.gmane.org
+Original-Received: from vger.kernel.org ([209.132.180.67])
+	by lo.gmane.org with esmtp (Exim 4.69)
+	(envelope-from <netdev-owner at vger.kernel.org>)
+	id 1R1Ska-0001cA-40
+	for linux-netdev-2 at lo.gmane.org; Thu, 08 Sep 2011 02:45:52 +0200
+Original-Received: (majordomo at vger.kernel.org) by vger.kernel.org via listexpand
+	id S1757671Ab1IHAp3 (ORCPT <rfc822;linux-netdev-2 at m.gmane.org>);
+	Wed, 7 Sep 2011 20:45:29 -0400
+Original-Received: from ozlabs.org ([203.10.76.45]:42999 "EHLO ozlabs.org"
+	rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP
+	id S1757658Ab1IHAp1 (ORCPT <rfc822;netdev at vger.kernel.org>);
+	Wed, 7 Sep 2011 20:45:27 -0400
+Original-Received: from localhost (ppp121-44-79-234.lns20.syd6.internode.on.net [121.44.79.234])
+	(using TLSv1 with cipher DHE-RSA-AES128-SHA (128/128 bits))
+	(Client did not present a certificate)
+	by ozlabs.org (Postfix) with ESMTPSA id ACF33B6F8E;
+	Thu,  8 Sep 2011 10:45:24 +1000 (EST)
+X-Mailbox-Line: From anton at samba.org Thu Sep  8 10:41:21 2011
+User-Agent: quilt/0.48-1
+Content-Disposition: inline; filename=ibmveth_1.patch
+Original-Sender: netdev-owner at vger.kernel.org
+Precedence: bulk
+List-ID: <netdev.vger.kernel.org>
+X-Mailing-List: netdev at vger.kernel.org
+Xref: news.gmane.org gmane.linux.network:205933
+Archived-At: <http://permalink.gmane.org/gmane.linux.network/205933>
+
+From: Brian King <brking at linux.vnet.ibm.com>
+
+Commit 6e8ab30ec677 (ibmveth: Add scatter-gather support) introduced a
+DMA mapping API inconsistency resulting in dma_unmap_page getting
+called on memory mapped via dma_map_single. This was seen when
+CONFIG_DMA_API_DEBUG was enabled. Fix up this API usage inconsistency.
+
+Signed-off-by: Brian King <brking at linux.vnet.ibm.com>
+Acked-by: Anton Blanchard <anton at samba.org>
+Cc: <stable at kernel.org> # v2.6.37+
+---
+
+Index: linux-build/drivers/net/ibmveth.c
+===================================================================
+--- linux-build.orig/drivers/net/ibmveth.c	2011-09-08 08:00:16.842856634 +1000
++++ linux-build/drivers/net/ibmveth.c	2011-09-08 09:45:43.163851274 +1000
+@@ -1026,7 +1026,12 @@ retry_bounce:
+ 		netdev->stats.tx_bytes += skb->len;
+ 	}
+ 
+-	for (i = 0; i < skb_shinfo(skb)->nr_frags + 1; i++)
++	dma_unmap_single(&adapter->vdev->dev,
++			 descs[0].fields.address,
++			 descs[0].fields.flags_len & IBMVETH_BUF_LEN_MASK,
++			 DMA_TO_DEVICE);
++
++	for (i = 1; i < skb_shinfo(skb)->nr_frags + 1; i++)
+ 		dma_unmap_page(&adapter->vdev->dev, descs[i].fields.address,
+ 			       descs[i].fields.flags_len & IBMVETH_BUF_LEN_MASK,
+ 			       DMA_TO_DEVICE);
+
+
diff --git a/ibmveth-Fix-issue-with-DMA-mapping-failure.patch b/ibmveth-Fix-issue-with-DMA-mapping-failure.patch
new file mode 100644
index 0000000..af2d834
--- /dev/null
+++ b/ibmveth-Fix-issue-with-DMA-mapping-failure.patch
@@ -0,0 +1,93 @@
+Path: news.gmane.org!not-for-mail
+From: Anton Blanchard <anton at samba.org>
+Newsgroups: gmane.linux.network
+Subject: [PATCH 2/4] ibmveth: Fix issue with DMA mapping failure
+Date: Thu, 08 Sep 2011 10:41:04 +1000
+Lines: 47
+Approved: news at gmane.org
+Message-ID: <20110908004121.669225190 at samba.org>
+References: <20110908004102.355674129 at samba.org>
+NNTP-Posting-Host: lo.gmane.org
+X-Trace: dough.gmane.org 1315442760 18037 80.91.229.12 (8 Sep 2011 00:46:00 GMT)
+X-Complaints-To: usenet at dough.gmane.org
+NNTP-Posting-Date: Thu, 8 Sep 2011 00:46:00 +0000 (UTC)
+Cc: netdev at vger.kernel.org
+To: Santiago Leon <santil at linux.vnet.ibm.com>,
+	brking at linux.vnet.ibm.com, rcj at linux.vnet.ibm.com
+Original-X-From: netdev-owner at vger.kernel.org Thu Sep 08 02:45:55 2011
+Return-path: <netdev-owner at vger.kernel.org>
+Envelope-to: linux-netdev-2 at lo.gmane.org
+Original-Received: from vger.kernel.org ([209.132.180.67])
+	by lo.gmane.org with esmtp (Exim 4.69)
+	(envelope-from <netdev-owner at vger.kernel.org>)
+	id 1R1Ska-0001cA-M3
+	for linux-netdev-2 at lo.gmane.org; Thu, 08 Sep 2011 02:45:53 +0200
+Original-Received: (majordomo at vger.kernel.org) by vger.kernel.org via listexpand
+	id S1757665Ab1IHApa (ORCPT <rfc822;linux-netdev-2 at m.gmane.org>);
+	Wed, 7 Sep 2011 20:45:30 -0400
+Original-Received: from ozlabs.org ([203.10.76.45]:60840 "EHLO ozlabs.org"
+	rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP
+	id S1757659Ab1IHAp1 (ORCPT <rfc822;netdev at vger.kernel.org>);
+	Wed, 7 Sep 2011 20:45:27 -0400
+Original-Received: from localhost (ppp121-44-79-234.lns20.syd6.internode.on.net [121.44.79.234])
+	(using TLSv1 with cipher DHE-RSA-AES128-SHA (128/128 bits))
+	(Client did not present a certificate)
+	by ozlabs.org (Postfix) with ESMTPSA id 56E01B6F97;
+	Thu,  8 Sep 2011 10:45:25 +1000 (EST)
+X-Mailbox-Line: From anton at samba.org Thu Sep  8 10:41:21 2011
+User-Agent: quilt/0.48-1
+Content-Disposition: inline; filename=ibmveth_dma_mapping_error.patch
+Original-Sender: netdev-owner at vger.kernel.org
+Precedence: bulk
+List-ID: <netdev.vger.kernel.org>
+X-Mailing-List: netdev at vger.kernel.org
+Xref: news.gmane.org gmane.linux.network:205931
+Archived-At: <http://permalink.gmane.org/gmane.linux.network/205931>
+
+descs[].fields.address is 32bit which truncates any dma mapping
+errors so dma_mapping_error() fails to catch it.
+
+Use a dma_addr_t to do the comparison. With this patch I was able
+to transfer many gigabytes of data with IOMMU fault injection set
+at 10% probability.
+
+Signed-off-by: Anton Blanchard <anton at samba.org>
+Cc: <stable at kernel.org> # v2.6.37+
+---
+
+Index: linux-build/drivers/net/ibmveth.c
+===================================================================
+--- linux-build.orig/drivers/net/ibmveth.c	2011-09-01 15:01:18.066844039 +1000
++++ linux-build/drivers/net/ibmveth.c	2011-09-01 15:03:34.299079796 +1000
+@@ -930,6 +930,7 @@ static netdev_tx_t ibmveth_start_xmit(st
+ 	union ibmveth_buf_desc descs[6];
+ 	int last, i;
+ 	int force_bounce = 0;
++	dma_addr_t dma_addr;
+ 
+ 	/*
+ 	 * veth handles a maximum of 6 segments including the header, so
+@@ -994,17 +995,16 @@ retry_bounce:
+ 	}
+ 
+ 	/* Map the header */
+-	descs[0].fields.address = dma_map_single(&adapter->vdev->dev, skb->data,
+-						 skb_headlen(skb),
+-						 DMA_TO_DEVICE);
+-	if (dma_mapping_error(&adapter->vdev->dev, descs[0].fields.address))
++	dma_addr = dma_map_single(&adapter->vdev->dev, skb->data,
++				  skb_headlen(skb), DMA_TO_DEVICE);
++	if (dma_mapping_error(&adapter->vdev->dev, dma_addr))
+ 		goto map_failed;
+ 
+ 	descs[0].fields.flags_len = desc_flags | skb_headlen(skb);
++	descs[0].fields.address = dma_addr;
+ 
+ 	/* Map the frags */
+ 	for (i = 0; i < skb_shinfo(skb)->nr_frags; i++) {
+-		unsigned long dma_addr;
+ 		skb_frag_t *frag = &skb_shinfo(skb)->frags[i];
+ 
+ 		dma_addr = dma_map_page(&adapter->vdev->dev, frag->page,
+
+
diff --git a/kernel.spec b/kernel.spec
index 0b9f3d7..7fd2c78 100644
--- a/kernel.spec
+++ b/kernel.spec
@@ -51,7 +51,7 @@ Summary: The Linux kernel
 # For non-released -rc kernels, this will be prepended with "0.", so
 # for example a 3 here will become 0.3
 #
-%global baserelease 1
+%global baserelease 2
 %global fedora_build %{baserelease}
 
 # base_sublevel is the kernel version we're starting with and patching
@@ -731,6 +731,10 @@ Patch13008: add-macbookair41-btusb.patch
 
 Patch13009: hvcs_pi_buf_alloc.patch
 
+Patch13010: ibmveth-Fix-DMA-unmap-error.patch
+Patch13011: ibmveth-Fix-issue-with-DMA-mapping-failure.patch
+Patch13012: ibmveth-Checksum-offload-is-always-disabled.patch
+
 Patch20000: utrace.patch
 
 # Flattened devicetree support
@@ -1351,6 +1355,10 @@ ApplyPatch add-macbookair41-btusb.patch
 
 ApplyPatch hvcs_pi_buf_alloc.patch
 
+ApplyPatch ibmveth-Fix-DMA-unmap-error.patch
+ApplyPatch ibmveth-Fix-issue-with-DMA-mapping-failure.patch
+ApplyPatch ibmveth-Checksum-offload-is-always-disabled.patch
+
 # utrace.
 ApplyPatch utrace.patch
 
@@ -2056,6 +2064,7 @@ fi
 * Wed Sep 14 2011 Josh Boyer <jwboyer at redhat.com>
 - Add support for Macbook Air 4,1 keyboard, trackpad, and bluetooth
 - Add patch to fix HVCS on ppc64 (rhbz 738096)
+- Add various ibmveth driver fixes (rhbz 733766)
 
 * Tue Sep 13 2011 Adam Jackson <ajax at redhat.com>
 - drm/i915: Shut the fbc messages up when drm.debug & 4


More information about the scm-commits mailing list