From patchwork Fri Feb 5 23:19:17 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alexandre Bounine X-Patchwork-Id: 61358 Delivered-To: patch@linaro.org Received: by 10.112.43.199 with SMTP id y7csp251935lbl; Fri, 5 Feb 2016 15:28:57 -0800 (PST) X-Received: by 10.66.234.104 with SMTP id ud8mr23805628pac.143.1454714937156; Fri, 05 Feb 2016 15:28:57 -0800 (PST) Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id ey12si26740862pac.203.2016.02.05.15.28.56; Fri, 05 Feb 2016 15:28:57 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751576AbcBEX2j (ORCPT + 30 others); Fri, 5 Feb 2016 18:28:39 -0500 Received: from mxout1.idt.com ([157.165.5.25]:40099 "EHLO mxout1.idt.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751463AbcBEX2f (ORCPT ); Fri, 5 Feb 2016 18:28:35 -0500 X-Greylist: delayed 506 seconds by postgrey-1.27 at vger.kernel.org; Fri, 05 Feb 2016 18:28:35 EST Received: from mail.idt.com (localhost [127.0.0.1]) by mxout1.idt.com (8.13.1/8.13.1) with ESMTP id u15NK103018372; Fri, 5 Feb 2016 15:20:01 -0800 Received: from corpml3.corp.idt.com (corpml3.corp.idt.com [157.165.140.25]) by mail.idt.com (8.13.8/8.13.8) with ESMTP id u15NK1Uk025864; Fri, 5 Feb 2016 15:20:01 -0800 (PST) Received: from kaneng03.ott.idt.com (corpimss.corp.idt.com [157.165.140.30]) by corpml3.corp.idt.com (8.11.7p1+Sun/8.11.7) with ESMTP id u15NJxv23833; Fri, 5 Feb 2016 15:19:59 -0800 (PST) Received: (from abounine@localhost) by kaneng03.ott.idt.com (8.14.4/8.13.8/Submit) id u15NJxVP015325; Fri, 5 Feb 2016 18:19:59 -0500 From: Alexandre Bounine To: Andrew Morton Cc: Aurelien Jacquiot , Alexandre Bounine , Matt Porter , Andre van Herk , linux-kernel@vger.kernel.org, netdev@vger.kernel.org Subject: [PATCH 01/30] rapidio/rionet: fix deadlock on SMP Date: Fri, 5 Feb 2016 18:19:17 -0500 Message-Id: <1454714386-15259-2-git-send-email-alexandre.bounine@idt.com> X-Mailer: git-send-email 1.7.8.4 In-Reply-To: <1454714386-15259-1-git-send-email-alexandre.bounine@idt.com> References: <1454714386-15259-1-git-send-email-alexandre.bounine@idt.com> X-TM-AS-MML: disable X-Scanned-By: MIMEDefang 2.43 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Aurelien Jacquiot Fix deadlocking during concurrent receive and transmit operations on SMP platforms caused by the use of incorrect lock: on transmit 'tx_lock' spinlock should be used instead of 'lock' which is used for receive operation. This fix is applicable to kernel versions starting from v2.15. Signed-off-by: Aurelien Jacquiot Signed-off-by: Alexandre Bounine Cc: Matt Porter Cc: Andre van Herk Cc: linux-kernel@vger.kernel.org Cc: netdev@vger.kernel.org --- drivers/net/rionet.c | 4 ++-- 1 files changed, 2 insertions(+), 2 deletions(-) -- 1.7.8.4 diff --git a/drivers/net/rionet.c b/drivers/net/rionet.c index 01f08a7..e7034c5 100644 --- a/drivers/net/rionet.c +++ b/drivers/net/rionet.c @@ -280,7 +280,7 @@ static void rionet_outb_msg_event(struct rio_mport *mport, void *dev_id, int mbo struct net_device *ndev = dev_id; struct rionet_private *rnet = netdev_priv(ndev); - spin_lock(&rnet->lock); + spin_lock(&rnet->tx_lock); if (netif_msg_intr(rnet)) printk(KERN_INFO @@ -299,7 +299,7 @@ static void rionet_outb_msg_event(struct rio_mport *mport, void *dev_id, int mbo if (rnet->tx_cnt < RIONET_TX_RING_SIZE) netif_wake_queue(ndev); - spin_unlock(&rnet->lock); + spin_unlock(&rnet->tx_lock); } static int rionet_open(struct net_device *ndev)