Received: by 2002:a25:ca44:0:0:0:0:0 with SMTP id a65csp1366196ybg; Wed, 29 Jul 2020 12:13:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJymkc0Fe2QfVMeoqYTrhp7h8QUC9UkieB9oPU+SqL4kIrDKp+gH4Zz2komlAiswoLRonX/r X-Received: by 2002:aa7:d84d:: with SMTP id f13mr5447663eds.155.1596050002884; Wed, 29 Jul 2020 12:13:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596050002; cv=none; d=google.com; s=arc-20160816; b=yMf9INznfZTaqGjUwVrmxLfggMRWt5t6OpkfIQgGAJI6KqS3HtL1NT5yErm49TCNge 7D1BTeGaTgTz76VI0hSKF10UP5WYngY8DPhsjvbko/T0/Tdkb0/0pGDZ1IQCt4qDkuNg S9m5GTiLmabZQi5RWNryFe2M1hk2RzgmemaMKtCnA0sQFszPbqwholA9X7IBaYzOxzmh 2u4GenBsh2hP8qxt7bjDaROzJpABtlZANzO8yR46ipv3oxP0RhivOiVUJ7f4IYFhBcnm vZ/IGIVlqQF8NF4U60kOKKiM+Pf3TT3YHOiHieJucCdBo+BS9kCgWXxYK9XnYH4fBzIq JvyA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:subject:content-transfer-encoding :mime-version:message-id:date:cc:to:from:dkim-signature; bh=ytNmU6XECJ6mse7dyEPBYBvTEidvGF6L8NfDouGCEKo=; b=j+VhzECfOEImclco2co61NUp4dCo8Hfqe2XicjQn+ISL055DJmxmSRtFvXG3eIzvtw +47nsxCgb+ir1CpRLDXdNFeIK/f23D6kArLkLNTCocFEq9Q8O++g2NImc90ugQ9RHqGF ot9hnL9ztLLBlFr7ADs/TVo5o+74ADifLjgjJo48WgVHeGlpeCGTJ4LQOgePJqbZBsEV WIzdQgBtZZcnuPPo2lmSlx35HdQrqU7I9Ea8YysA+zQAD/bFAr1mfWSyv1OCCJ1Y2+6W Nw2QENhFho/Ps6PCy1H977b1qOHB7tSwGhVkvLd+wagfhMDYank5PDAQrnaA0nD0wrnH tnNg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@deltatee.com header.s=20200525 header.b=coWKfw7k; 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 rl3si1573075ejb.643.2020.07.29.12.12.59; Wed, 29 Jul 2020 12:13:22 -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=fail header.i=@deltatee.com header.s=20200525 header.b=coWKfw7k; 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 S1726628AbgG2TKT (ORCPT + 99 others); Wed, 29 Jul 2020 15:10:19 -0400 Received: from ale.deltatee.com ([204.191.154.188]:53204 "EHLO ale.deltatee.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726365AbgG2TKT (ORCPT ); Wed, 29 Jul 2020 15:10:19 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=deltatee.com; s=20200525; h=Subject:Content-Transfer-Encoding:MIME-Version: Message-Id:Date:Cc:To:From:Sender:Reply-To:Content-Type:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:In-Reply-To:References:List-Id:List-Help:List-Unsubscribe: List-Subscribe:List-Post:List-Owner:List-Archive; bh=ytNmU6XECJ6mse7dyEPBYBvTEidvGF6L8NfDouGCEKo=; b=coWKfw7kgDX6kPpKypL29C8i6c 2UjCxfqsiR6FV8nDg6idbi7pN84McLwfQFl6SPR6ihkO7AGoiosPTcetEGznhcvc7eB+yP/VZU9TW gDRGwiioVibCBct9ai45bsHWxT77Bsx4fBZ5ZYKZmwzJva1pOffp1X2wY0WrX2tNzaQDHqDVLY8be fILaR3F8/UFrkDNddHzsIf3dtDF863P+5iIpKBABTygGcYhu1+5ZcRceDSEET3LIeqWs1u+nl9t6j cR4J8t1hSdW3dxBV1Y0d3TzaI5m5x7TH4LsV8ghmc8BxNYdzR31VwpAvHqo9mXHmV3SXXIZdYA0/W 4NQloHhw==; Received: from cgy1-donard.priv.deltatee.com ([172.16.1.31]) by ale.deltatee.com with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1k0rSz-0007XN-DQ; Wed, 29 Jul 2020 13:10:18 -0600 Received: from gunthorp by cgy1-donard.priv.deltatee.com with local (Exim 4.92) (envelope-from ) id 1k0rSt-0001B4-12; Wed, 29 Jul 2020 13:10:11 -0600 From: Logan Gunthorpe To: linux-kernel@vger.kernel.org, linux-nvme@lists.infradead.org Cc: Christoph Hellwig , Sagi Grimberg , Keith Busch , Jens Axboe , Chaitanya Kulkarni , Max Gurtovoy , Stephen Bates , Logan Gunthorpe Date: Wed, 29 Jul 2020 13:10:09 -0600 Message-Id: <20200729191009.4485-1-logang@deltatee.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 172.16.1.31 X-SA-Exim-Rcpt-To: linux-kernel@vger.kernel.org, linux-nvme@lists.infradead.org, hch@lst.de, sagi@grimberg.me, kbusch@kernel.org, axboe@fb.com, Chaitanya.Kulkarni@wdc.com, maxg@mellanox.com, sbates@raithlin.com, logang@deltatee.com X-SA-Exim-Mail-From: gunthorp@deltatee.com X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on ale.deltatee.com X-Spam-Level: X-Spam-Status: No, score=-8.7 required=5.0 tests=ALL_TRUSTED,BAYES_00, GREYLIST_ISWHITE,MYRULES_NO_TEXT autolearn=ham autolearn_force=no version=3.4.2 Subject: [PATCH] nvmet-passthru: Reject commands with non-sgl flags set X-SA-Exim-Version: 4.2.1 (built Wed, 08 May 2019 21:11:16 +0000) X-SA-Exim-Scanned: Yes (on ale.deltatee.com) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Any command with a non-SGL flag set (like fuse flags) should be rejected. Fixes: c1fef73f793b ("nvmet: add passthru code to process commands") Signed-off-by: Logan Gunthorpe --- Note: this patch may be squashed with the patch noted in the fixes tag, currently in nvme-5.9. drivers/nvme/target/passthru.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/drivers/nvme/target/passthru.c b/drivers/nvme/target/passthru.c index 89d91dc999a6..f69c3ac82e58 100644 --- a/drivers/nvme/target/passthru.c +++ b/drivers/nvme/target/passthru.c @@ -326,6 +326,10 @@ static u16 nvmet_setup_passthru_command(struct nvmet_req *req) u16 nvmet_parse_passthru_io_cmd(struct nvmet_req *req) { + /* Reject any commands with non-sgl flags set (ie. fused commands) */ + if (req->cmd->common.flags & ~NVME_CMD_SGL_ALL) + return NVME_SC_INVALID_FIELD; + switch (req->cmd->common.opcode) { case nvme_cmd_resv_register: case nvme_cmd_resv_report: @@ -396,6 +400,10 @@ static u16 nvmet_passthru_get_set_features(struct nvmet_req *req) u16 nvmet_parse_passthru_admin_cmd(struct nvmet_req *req) { + /* Reject any commands with non-sgl flags set (ie. fused commands) */ + if (req->cmd->common.flags & ~NVME_CMD_SGL_ALL) + return NVME_SC_INVALID_FIELD; + /* * Passthru all vendor specific commands */ base-commit: b6cec06d19d90db5dbcc50034fb33983f6259b8b -- 2.20.1