Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp666020pxb; Tue, 5 Apr 2022 17:57:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyseg5uBQjcIOzoQ5wRvOYaCF3fK3CkKw7Acmf2XstW7sZU1ol2LPYg28MeGHVIqp5kHhS6 X-Received: by 2002:a17:906:1153:b0:6df:d816:264a with SMTP id i19-20020a170906115300b006dfd816264amr5859239eja.546.1649206659062; Tue, 05 Apr 2022 17:57:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649206659; cv=none; d=google.com; s=arc-20160816; b=Sx90+4b2j29yBwUva/jBA+WeO2lHeiOmGgVRk0AjURcH40ukVKp8BKXLm5VvqZo6Au X2iRO4TmrC1PmlKiLPDBCvdyiTcBXD2Po8dYvKTqjYcuzDKk63aTuFgZ+pkcyIMJ8w7g ug4ui3p5m/Y6XmkxWjVSJiJnBmT8bNswWrWpsF2ZsHoxuAdt1yFCdR45HFedkSYMOgIf iHZ2WtjorYEh8y94O/nlgA2mpBATKPCYJCrzjY/rMO/dgEDSm8AAbnt8sE+KL/xH5/LE SVdDhYIlYZtnp/ROMok2wk/mEiIUjjbKdTD8O84RkRTUx/AMKFsyhoivE/0TA/VsnC7f /7fQ== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=AX7H9C1af/PHrcuBHwcirsRycjPc9AYT1swTM17gXEo=; b=uzEAK1EhJIfCO+t4ryZWNuRdhOmXWFnR/7gMTa/nQsChC/dDGUCoxtgOXkDSATSqxT SywucpU231yDrQbmi2W06fi/w0h7wtuVTr+gZiIlV8pW9hK6HU/K/9TQO6m9HCrVpZKv A2pA9Z7ZUpFTG4Eo06zdD7jpfzB+uzhU7E4nNSLelol55KKCaY3dpbcQ46jf50P6SyCY fKNUIDAtuArCoJOW7cnLgxivNNjnZ9EZuogdTDBquFJ7K9410WBPdN8/CUWESPFuMdOD f2yiCA2QD041BMDUnxOSqO71v4l1493TLu0jYFlRw5O/v8XT1a7PMHz7HqK8QIqlyvj5 LFQg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=loOaz+Lq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g4-20020a056402424400b00418ff09ac1csi11743046edb.292.2022.04.05.17.57.11; Tue, 05 Apr 2022 17:57:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=loOaz+Lq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1378512AbiDELeQ (ORCPT + 99 others); Tue, 5 Apr 2022 07:34:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46836 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244601AbiDEIw1 (ORCPT ); Tue, 5 Apr 2022 04:52:27 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B36C61088; Tue, 5 Apr 2022 01:41:26 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 91DBC614E4; Tue, 5 Apr 2022 08:41:26 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 9C8F2C385A0; Tue, 5 Apr 2022 08:41:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1649148086; bh=9Y8hspwR757HQR50VmYUTmXqz6gF2M9OELzXprpEHMU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=loOaz+LqNDQZ77uhdaDrI6QHZJhk9o6YIvx0P1w1UseZD1+Ap0jaRv8W1h9gIpCMP DaCd8xKOxYMIn++aYrwT18OADt52jeVfi+aWKkAEk3kJ4CCXaodmHI6sOBoBYADUKo YH/U9NUCovzEuxyYnpPCtC+wBdh/IJ84eyk4plbk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Christoph Hellwig , Keith Busch , Chaitanya Kulkarni , Sasha Levin Subject: [PATCH 5.16 0230/1017] nvme: fix the check for duplicate unique identifiers Date: Tue, 5 Apr 2022 09:19:03 +0200 Message-Id: <20220405070401.081684539@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220405070354.155796697@linuxfoundation.org> References: <20220405070354.155796697@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Christoph Hellwig [ Upstream commit e2724cb9f0c406b8fb66efd3aa9e8b3edfd8d5c8 ] nvme_subsys_check_duplicate_ids should needs to return an error if any of the identifiers matches, not just if all of them match. But it does not need to and should not look at the CSI value for this sanity check. Rewrite the logic to be separate from nvme_ns_ids_equal and optimize it by reducing duplicate checks for non-present identifiers. Fixes: ed754e5deeb1 ("nvme: track shared namespaces") Signed-off-by: Christoph Hellwig Reviewed-by: Keith Busch Reviewed-by: Chaitanya Kulkarni Signed-off-by: Sasha Levin --- drivers/nvme/host/core.c | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/drivers/nvme/host/core.c b/drivers/nvme/host/core.c index 078ad43b94a1..1b39b50cb958 100644 --- a/drivers/nvme/host/core.c +++ b/drivers/nvme/host/core.c @@ -1685,13 +1685,6 @@ static void nvme_config_discard(struct gendisk *disk, struct nvme_ns *ns) blk_queue_max_write_zeroes_sectors(queue, UINT_MAX); } -static bool nvme_ns_ids_valid(struct nvme_ns_ids *ids) -{ - return !uuid_is_null(&ids->uuid) || - memchr_inv(ids->nguid, 0, sizeof(ids->nguid)) || - memchr_inv(ids->eui64, 0, sizeof(ids->eui64)); -} - static bool nvme_ns_ids_equal(struct nvme_ns_ids *a, struct nvme_ns_ids *b) { return uuid_equal(&a->uuid, &b->uuid) && @@ -3608,12 +3601,21 @@ static struct nvme_ns_head *nvme_find_ns_head(struct nvme_subsystem *subsys, static int nvme_subsys_check_duplicate_ids(struct nvme_subsystem *subsys, struct nvme_ns_ids *ids) { + bool has_uuid = !uuid_is_null(&ids->uuid); + bool has_nguid = memchr_inv(ids->nguid, 0, sizeof(ids->nguid)); + bool has_eui64 = memchr_inv(ids->eui64, 0, sizeof(ids->eui64)); struct nvme_ns_head *h; lockdep_assert_held(&subsys->lock); list_for_each_entry(h, &subsys->nsheads, entry) { - if (nvme_ns_ids_valid(ids) && nvme_ns_ids_equal(ids, &h->ids)) + if (has_uuid && uuid_equal(&ids->uuid, &h->ids.uuid)) + return -EINVAL; + if (has_nguid && + memcmp(&ids->nguid, &h->ids.nguid, sizeof(ids->nguid)) == 0) + return -EINVAL; + if (has_eui64 && + memcmp(&ids->eui64, &h->ids.eui64, sizeof(ids->eui64)) == 0) return -EINVAL; } -- 2.34.1