Received: by 10.223.185.116 with SMTP id b49csp945055wrg; Wed, 21 Feb 2018 09:25:38 -0800 (PST) X-Google-Smtp-Source: AH8x226Fgcc2xb8LQg3tvwcjZucgL/ZdGclI360+Z3OWJgnnNUVwm5RuN/HQjIQjROGYb2qjqbl2 X-Received: by 2002:a17:902:6e01:: with SMTP id u1-v6mr3778916plk.12.1519233938805; Wed, 21 Feb 2018 09:25:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519233938; cv=none; d=google.com; s=arc-20160816; b=UfcLIHJ1OWevsoDj76S8hibfwY9jG+bR39PFWNdvY+Q7putc7vaid7ZV26Nd/LJYx/ 3mj5xpyGPic2bnonzbHJgeRzp1fQVWwcuxUX7Uw16krJ0UTbcWD6mEG9TLaIEFV+Wbu7 Oc+GmfBDy8SzXoAtwUvXKjMR9IwtkWaKDyZDIWiZDUlB6qsAleGSmA2GfPS5+flOyEbx Kcjepx8S+zylnukQcV2cDqLmoH1CG8FihN8YycEFypzjdo2fOd2sxHLfoZFjr1PxfJ1T PdBmlXIotdgxOJfaJBmfiKMeThOSY6H1VP+3wI5Mx+QqMpIyVmjugGaxkxkEmEL9PgE9 nZ6A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=pR6sla89HwPxSpGKYPlk1irQC40aHqJyO0vLDxGoJmI=; b=rARhfqPeh622H7BAMW+HwdEsB7xy2wGFBBkvF+J9gfa53N+zB8SdW+HSYZa9iG8XXf 7amkqI2rz1vaqgEL+1f0rmc8hxWKRSGRuPSDnCKjgGca+VfrLMHdFltQ1us3UmGRknVx UhZiKoll2S/yWkXGAwHXlFmvtgZ5FPR7/wqFVWTeU3Jw04zC1dcnS+EXxaZK7UmeBG+x +4dHUliqG5m9K5aj4WSYgjMDswCGCPfghFlxPKN73cM8kLOrBmYbhfqwewo2E55s4hwm bk/+/33wFtTr2ZHqP1/cjz+N1xsm05NEvFGLsRba0SEZW9NKAmGlU5Ob6nciAb/PCrdW /uVA== ARC-Authentication-Results: i=1; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y96-v6si104376plh.796.2018.02.21.09.25.24; Wed, 21 Feb 2018 09:25:38 -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 S935041AbeBUM7H (ORCPT + 99 others); Wed, 21 Feb 2018 07:59:07 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:36378 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935025AbeBUM7D (ORCPT ); Wed, 21 Feb 2018 07:59:03 -0500 Received: from localhost (LFbn-1-12258-90.w90-92.abo.wanadoo.fr [90.92.71.90]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 2BD27FBA; Wed, 21 Feb 2018 12:59:03 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jack Morgenstein , Leon Romanovsky , Jason Gunthorpe Subject: [PATCH 4.14 005/167] IB/mlx4: Fix incorrectly releasing steerable UD QPs when have only ETH ports Date: Wed, 21 Feb 2018 13:46:56 +0100 Message-Id: <20180221124524.932553978@linuxfoundation.org> X-Mailer: git-send-email 2.16.2 In-Reply-To: <20180221124524.639039577@linuxfoundation.org> References: <20180221124524.639039577@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Jack Morgenstein commit 852f6927594d0d3e8632c889b2ab38cbc46476ad upstream. Allocating steerable UD QPs depends on having at least one IB port, while releasing those QPs does not. As a result, when there are only ETH ports, the IB (RoCE) driver requests releasing a qp range whose base qp is zero, with qp count zero. When SR-IOV is enabled, and the VF driver is running on a VM over a hypervisor which treats such qp release calls as errors (rather than NOPs), we see lines in the VM message log like: mlx4_core 0002:00:02.0: Failed to release qp range base:0 cnt:0 Fix this by adding a check for a zero count in mlx4_release_qp_range() (which thus treats releasing 0 qps as a nop), and eliminating the check for device managed flow steering when releasing steerable UD QPs. (Freeing ib_uc_qpns_bitmap unconditionally is also OK, since it remains NULL when steerable UD QPs are not allocated). Fixes: 4196670be786 ("IB/mlx4: Don't allocate range of steerable UD QPs for Ethernet-only device") Signed-off-by: Jack Morgenstein Signed-off-by: Leon Romanovsky Signed-off-by: Jason Gunthorpe Signed-off-by: Greg Kroah-Hartman --- drivers/infiniband/hw/mlx4/main.c | 13 +++++-------- drivers/net/ethernet/mellanox/mlx4/qp.c | 3 +++ 2 files changed, 8 insertions(+), 8 deletions(-) --- a/drivers/infiniband/hw/mlx4/main.c +++ b/drivers/infiniband/hw/mlx4/main.c @@ -2972,9 +2972,8 @@ err_steer_free_bitmap: kfree(ibdev->ib_uc_qpns_bitmap); err_steer_qp_release: - if (ibdev->steering_support == MLX4_STEERING_MODE_DEVICE_MANAGED) - mlx4_qp_release_range(dev, ibdev->steer_qpn_base, - ibdev->steer_qpn_count); + mlx4_qp_release_range(dev, ibdev->steer_qpn_base, + ibdev->steer_qpn_count); err_counter: for (i = 0; i < ibdev->num_ports; ++i) mlx4_ib_delete_counters_table(ibdev, &ibdev->counters_table[i]); @@ -3079,11 +3078,9 @@ static void mlx4_ib_remove(struct mlx4_d ibdev->iboe.nb.notifier_call = NULL; } - if (ibdev->steering_support == MLX4_STEERING_MODE_DEVICE_MANAGED) { - mlx4_qp_release_range(dev, ibdev->steer_qpn_base, - ibdev->steer_qpn_count); - kfree(ibdev->ib_uc_qpns_bitmap); - } + mlx4_qp_release_range(dev, ibdev->steer_qpn_base, + ibdev->steer_qpn_count); + kfree(ibdev->ib_uc_qpns_bitmap); iounmap(ibdev->uar_map); for (p = 0; p < ibdev->num_ports; ++p) --- a/drivers/net/ethernet/mellanox/mlx4/qp.c +++ b/drivers/net/ethernet/mellanox/mlx4/qp.c @@ -287,6 +287,9 @@ void mlx4_qp_release_range(struct mlx4_d u64 in_param = 0; int err; + if (!cnt) + return; + if (mlx4_is_mfunc(dev)) { set_param_l(&in_param, base_qpn); set_param_h(&in_param, cnt);