Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp2464672imd; Fri, 2 Nov 2018 11:52:38 -0700 (PDT) X-Google-Smtp-Source: AJdET5cQ4wL/CIttrzVwWndCVEQU3XigpaKC4cNIxwfqRq85F+br7pgUgFzZCk+nXHeyG/5S71uR X-Received: by 2002:a17:902:bf0c:: with SMTP id bi12-v6mr13078516plb.330.1541184758036; Fri, 02 Nov 2018 11:52:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1541184758; cv=none; d=google.com; s=arc-20160816; b=ee5svZ/W+1AUCQwxTTTp1Y3VviFKH71p8w22T+3/3+MQO0FTskP9g/wrmp1RfsRQaZ 7k/XZIAUFxsgQIKQl1mkYdMPqh7yauWfsUbRNQZqFS0+bnA5uzL6fRbSk17uDRu+3NMb 5z8MZms/50W422Yep1JPG7TZp+elbsNd593lLOYnHA4/tQ3NzyISrBmfQlMXnbod9hm9 vYPlz3QLSpNTWAeEhvE+Q0Cb6Bam+eOfc71s53+z7hjdi1XlenTbkkU+cLHP/6AFt3NA qyS5FCNUQU2shrf82Ptqz61hgKga11gJqa58wEjN8WoXT1WBe4FP5Nyym23VWCzwMOBm xo/w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=B8JIW42Sls6QI35XH0FJYHI3p9AxAvLtspP/AgU47wg=; b=Jc+dPOj7IReT4MCXngqEBL1DRWUI17iFnu4KcoluVrora+cdoS0LuHct33nCs0LSkh +GjQaix4rmrOtyrzDkcvzFIrHjj1O+PxWUj6fxMCN7NecfqZO3D9MFnWJxQ1cdrNGAoG gcstXb30T/I65bz+TWdt/6epWvt51Jf+Am4gb+D86wKvNMh+3KyreiofK2IHIr/VqJUk MVcs3C8f+vQ3rgBpdfuRo/tRpLkzhk96pj5PFSelgdN53eNDB9hKO+aoR9SVi5JT1qme L7JyB94oMbN2tMrW4nYBXrnh9yXn68EPkcFAWDlSPrVts3VQgESseHLoi3qkqK79876N LMFg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Y4j+EoaR; 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 134-v6si35017272pfu.273.2018.11.02.11.52.23; Fri, 02 Nov 2018 11:52:38 -0700 (PDT) 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; dkim=pass header.i=@kernel.org header.s=default header.b=Y4j+EoaR; 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 S1730653AbeKCD7H (ORCPT + 99 others); Fri, 2 Nov 2018 23:59:07 -0400 Received: from mail.kernel.org ([198.145.29.99]:54868 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729339AbeKCD7G (ORCPT ); Fri, 2 Nov 2018 23:59:06 -0400 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 902D62082D; Fri, 2 Nov 2018 18:50:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1541184651; bh=FYwT6zCgrc+yBDfp9Ob7X9kLpCrD9Gkgm/bnQL4lzEM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Y4j+EoaRztj+wzXOJEZUSPyRR8moRIRvNueaV/neo9ZOYeO9xTwF+IujJAfpYZIFU o6KL9F/uM8uces+nGqmDD2rml7ouGUkCWmqawL9cYEyB5LMgfyd3ICbxiEythfL2Wp gFFIwP5ta4MZTZET5yIACpJvOoylsD/HVFgmlVWs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Israel Rukshin , Max Gurtovoy , Sagi Grimberg , Sasha Levin Subject: [PATCH 4.14 060/143] net/mlx5: Fix mlx5_get_vector_affinity function Date: Fri, 2 Nov 2018 19:34:05 +0100 Message-Id: <20181102182901.906765329@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181102182857.064326086@linuxfoundation.org> References: <20181102182857.064326086@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 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. ------------------ [ Upstream commit 6082d9c9c94a408d7409b5f2e4e42ac9e8b16d0d ] Adding the vector offset when calling to mlx5_vector2eqn() is wrong. This is because mlx5_vector2eqn() checks if EQ index is equal to vector number and the fact that the internal completion vectors that mlx5 allocates don't get an EQ index. The second problem here is that using effective_affinity_mask gives the same CPU for different vectors. This leads to unmapped queues when calling it from blk_mq_rdma_map_queues(). This doesn't happen when using affinity_hint mask. Fixes: 2572cf57d75a ("mlx5: fix mlx5_get_vector_affinity to start from completion vector 0") Fixes: 05e0cc84e00c ("net/mlx5: Fix get vector affinity helper function") Signed-off-by: Israel Rukshin Reviewed-by: Max Gurtovoy Reviewed-by: Sagi Grimberg Signed-off-by: Sasha Levin --- drivers/infiniband/hw/mlx5/main.c | 2 +- include/linux/mlx5/driver.h | 12 +++--------- 2 files changed, 4 insertions(+), 10 deletions(-) diff --git a/drivers/infiniband/hw/mlx5/main.c b/drivers/infiniband/hw/mlx5/main.c index ab70194a73db..c3a4f5d92391 100644 --- a/drivers/infiniband/hw/mlx5/main.c +++ b/drivers/infiniband/hw/mlx5/main.c @@ -3911,7 +3911,7 @@ mlx5_ib_get_vector_affinity(struct ib_device *ibdev, int comp_vector) { struct mlx5_ib_dev *dev = to_mdev(ibdev); - return mlx5_get_vector_affinity(dev->mdev, comp_vector); + return mlx5_get_vector_affinity_hint(dev->mdev, comp_vector); } static void *mlx5_ib_add(struct mlx5_core_dev *mdev) diff --git a/include/linux/mlx5/driver.h b/include/linux/mlx5/driver.h index c4d19e77fea8..5eff332092bc 100644 --- a/include/linux/mlx5/driver.h +++ b/include/linux/mlx5/driver.h @@ -1193,25 +1193,19 @@ enum { }; static inline const struct cpumask * -mlx5_get_vector_affinity(struct mlx5_core_dev *dev, int vector) +mlx5_get_vector_affinity_hint(struct mlx5_core_dev *dev, int vector) { - const struct cpumask *mask; struct irq_desc *desc; unsigned int irq; int eqn; int err; - err = mlx5_vector2eqn(dev, MLX5_EQ_VEC_COMP_BASE + vector, &eqn, &irq); + err = mlx5_vector2eqn(dev, vector, &eqn, &irq); if (err) return NULL; desc = irq_to_desc(irq); -#ifdef CONFIG_GENERIC_IRQ_EFFECTIVE_AFF_MASK - mask = irq_data_get_effective_affinity_mask(&desc->irq_data); -#else - mask = desc->irq_common_data.affinity; -#endif - return mask; + return desc->affinity_hint; } #endif /* MLX5_DRIVER_H */ -- 2.17.1