Received: by 2002:a05:6a10:c7c6:0:0:0:0 with SMTP id h6csp1467629pxy; Mon, 2 Aug 2021 02:16:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyU1+7lOZ9mHyECQyclsK78mv5CB1bidBBHG1hNgYiAdx4vgRLgLujrSWmzecFYf34CNnvn X-Received: by 2002:a5d:8596:: with SMTP id f22mr2313011ioj.147.1627895777976; Mon, 02 Aug 2021 02:16:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627895777; cv=none; d=google.com; s=arc-20160816; b=S6ftSzgvWjYaS2o51ZpgpaA5+q5KAvB58FPzxvbwtLYnfKHZ1Xoln+4hBZ4e2m9h4Q 9skqs4+XaAa61YfGS/W7/+wR/XGYF2TigMCsVjIr5kg/JVKSxEFEgRWQpr5cn8wiLFQP T+WBMiePTfDBgvki8b+80i26dFwOW9jenmdhYFqfqqSX15gIzRMalZEuBWWfKaym5GkK bbR/oJULo5EyJyfGWauGSnMS108UmJy4a5d4womhJMuj/8qSNGBAXAZW5IY9/iwsKvtD d5KwjlgzLYbZ8WZQpAiB36YIWD1LldTULrWHt+T23KhLKQqszBCvrU0iuZDqsPMn1jC8 tMjw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:dkim-signature; bh=dZOuzvx1phja24aAWw8Llh5el782SjhEfTlnpRDPjWI=; b=UguTK2bV2rM7ZccFnuWc8Uqgd9DYCFZ/mwVbhJJqTNJXJIaZ2633gpHFGMk/4K9tJC nOMSjhBFUL6uKWJjvezfPFwHDKMnq6qAU4f9bYseP/ENAmZJI2eZAY213MlUG2edZX/M KLWQ3ELC2uf2sU9FRCk/KhFeoNG73H4RuzFZiDZhjCgXTZ/rblGrCKYlxj1yhgQgPhm/ v/KlgTSSBGeFseZN+VjnyCp8j2kHUbvLKELIX8OnDmF3NWvhVARMe8Tx8pBz2OnQbZy7 ecz7DpK/8eR4dmARL4lXhd9V5TUpYbrxzx0c4eG+OCRciRRkv9efYyY2Ircd58QwxW4Y eY6w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b=P6hL87aJ; dkim=neutral (no key) header.i=@suse.de header.b="B/K3wKlJ"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b16si12262400ile.135.2021.08.02.02.16.07; Mon, 02 Aug 2021 02:16:17 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b=P6hL87aJ; dkim=neutral (no key) header.i=@suse.de header.b="B/K3wKlJ"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233116AbhHBJO6 (ORCPT + 99 others); Mon, 2 Aug 2021 05:14:58 -0400 Received: from smtp-out2.suse.de ([195.135.220.29]:58760 "EHLO smtp-out2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232855AbhHBJOc (ORCPT ); Mon, 2 Aug 2021 05:14:32 -0400 Received: from relay2.suse.de (relay2.suse.de [149.44.160.134]) by smtp-out2.suse.de (Postfix) with ESMTP id D20BA1FF56; Mon, 2 Aug 2021 09:14:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_rsa; t=1627895661; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=dZOuzvx1phja24aAWw8Llh5el782SjhEfTlnpRDPjWI=; b=P6hL87aJlTwaD428scHOsV2Oeb7gctZHNGULPgcBDwvx93QJ9/O3scEalKz3eBr7xS5k6w qeX50QLCophPPDcqv9q+xgOJawBgP49PN0lTMShQLqPHaciq9uYv4EifbHE9KKQ9c+4SM2 fvQ9M+GFsg322mPH5J//AvOF8sraGDw= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_ed25519; t=1627895661; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=dZOuzvx1phja24aAWw8Llh5el782SjhEfTlnpRDPjWI=; b=B/K3wKlJ0QTvVtaAQcd2acy5s8Y96c1dFCEVTx/IwcUGnn6GCRmDh0XiBbNQEcgNQ+Z03v XtwfuUcaTpsDO5AQ== Received: from adalid.arch.suse.de (adalid.arch.suse.de [10.161.8.13]) by relay2.suse.de (Postfix) with ESMTP id 0BBABA3B85; Mon, 2 Aug 2021 09:14:21 +0000 (UTC) Received: by adalid.arch.suse.de (Postfix, from userid 17828) id F0157518C089; Mon, 2 Aug 2021 11:14:20 +0200 (CEST) From: Daniel Wagner To: linux-kernel@vger.kernel.org Cc: James Smart , Keith Busch , Ming Lei , Sagi Grimberg , Hannes Reinecke , Wen Xiong , Daniel Wagner , James Smart Subject: [PATCH v4 1/8] nvme-fc: Update hardware queues before using them Date: Mon, 2 Aug 2021 11:14:12 +0200 Message-Id: <20210802091419.56425-2-dwagner@suse.de> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20210802091419.56425-1-dwagner@suse.de> References: <20210802091419.56425-1-dwagner@suse.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In case the number of hardware queues changes, do the update the tagset and ctx to hctx first before using the mapping to recreate and connnect the IO queues. Reviewed-by: James Smart Reviewed-by: Ming Lei Reviewed-by: Hannes Reinecke Signed-off-by: Daniel Wagner --- drivers/nvme/host/fc.c | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/drivers/nvme/host/fc.c b/drivers/nvme/host/fc.c index 7f462af1b02a..8a903769364f 100644 --- a/drivers/nvme/host/fc.c +++ b/drivers/nvme/host/fc.c @@ -2951,14 +2951,6 @@ nvme_fc_recreate_io_queues(struct nvme_fc_ctrl *ctrl) if (ctrl->ctrl.queue_count == 1) return 0; - ret = nvme_fc_create_hw_io_queues(ctrl, ctrl->ctrl.sqsize + 1); - if (ret) - goto out_free_io_queues; - - ret = nvme_fc_connect_io_queues(ctrl, ctrl->ctrl.sqsize + 1); - if (ret) - goto out_delete_hw_queues; - if (prior_ioq_cnt != nr_io_queues) { dev_info(ctrl->ctrl.device, "reconnect: revising io queue count from %d to %d\n", @@ -2968,6 +2960,14 @@ nvme_fc_recreate_io_queues(struct nvme_fc_ctrl *ctrl) nvme_unfreeze(&ctrl->ctrl); } + ret = nvme_fc_create_hw_io_queues(ctrl, ctrl->ctrl.sqsize + 1); + if (ret) + goto out_free_io_queues; + + ret = nvme_fc_connect_io_queues(ctrl, ctrl->ctrl.sqsize + 1); + if (ret) + goto out_delete_hw_queues; + return 0; out_delete_hw_queues: -- 2.29.2