Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1507848ybh; Thu, 16 Jul 2020 14:18:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzKijWS3YZdbnbFvq6vRV0gQppoBXmemmU4nWJyT3NX80hFNpJtaoHWMzH8Rno7/YVJHkzQ X-Received: by 2002:a17:906:f20d:: with SMTP id gt13mr5673338ejb.117.1594934332035; Thu, 16 Jul 2020 14:18:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594934332; cv=none; d=google.com; s=arc-20160816; b=fsR2GymYMhGjuGEIcLxzT8IkfGx5BRebuE5WNEeY9QbxW3uTIJBrCf9hfHzHN/8/0Z sPp5/nwKI4aeYFYRn7BfhByPIusbZ/sbCZECNnycjtNGb1i80Ksz/qPDsuYTFXmwV1sE 8SzmboJibV1Mbj9H5oP6/58MM2246SrYzc9DRz+5cGJOHHtHjh7Ja6drHMf4hLMxlR8W 98/cfCe8Y29JTg8ntZ4QS6mg1GXbDOKGJpC0h8nVXd5rGZTj5Fs6FXNvnDFDWsmvkND0 s79CNPP2Z4NfIGWXf8w88UJRwkBOd49rjjjEGKa0LRr23cHqd55R31br7RWJM3BQb82w 807w== 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=d+Tpl560W8nSezZX7G2fZavVOKSfRlDlqVBC70jvjGE=; b=moDPVKjxSnQ75vh4EK3GYIaVFLooCtoO2E7igbXVTTQ+CH8AKwQwwzPzxivKNDtBrK pSg1jymbw04HuEG5ZPE+PwOVpLufRMyjJE0/vDIyd8NzyghvW9+u5mb1sHPkGo+kegcT ps4bgGqjKp4u4KnD0fE3nd9/HvL4SpqNUW6yi4zmrkmejGm8/Qa6FBYE4yb5cJ6SOfIh encDdCUxaEhQggxyxVQJ0vyWwJuf1/nPnya1l1370lLVVELYFoBqYkAakXIfbqzJ9ztu Qb3Ciongkun+t7HGfcH8YNP5lEMpvPszmLm91KxEeP31npnLm520ETY/7lwlUln8CkuK LAcw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@deltatee.com header.s=20200525 header.b=FGyFkTwQ; 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 u6si2462598ejb.450.2020.07.16.14.18.28; Thu, 16 Jul 2020 14:18:52 -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=FGyFkTwQ; 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 S1727861AbgGPVSE (ORCPT + 99 others); Thu, 16 Jul 2020 17:18:04 -0400 Received: from ale.deltatee.com ([204.191.154.188]:47702 "EHLO ale.deltatee.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727834AbgGPVR7 (ORCPT ); Thu, 16 Jul 2020 17:17:59 -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=d+Tpl560W8nSezZX7G2fZavVOKSfRlDlqVBC70jvjGE=; b=FGyFkTwQ6IJuNDhmdG3NC9007c +udxNkeejJ3To1Jb8cI2pyefatAaUTWIelc2yDNWqPYFffwUF/BJX0QQ7/Lv0/8LVeQCQyYM6F4Bp F1YVpJGpRToOY+yzcz0+exADJOMPYbzThv4Jzq4eGRUiO34mAFnEJdGD+yYFnUYcqyZ6JOizrJr3w oQd1R7HDl53cpaECSDDtyejXhmUja9Ct7FWutzu9A4ogALVQjKB1rkiRXMPoOGgMSwS8o/W64Cpqt 68x4dk8rSBfaHBs3rCVrmLVSbCuVFUMMvq6Di40+LarrgrKAkC4A4IK2kPHj+VIz5KGGdbpYL5iLX Cv+tuPnQ==; 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 1jwAZH-0005uH-GW; Thu, 16 Jul 2020 14:33:26 -0600 Received: from gunthorp by cgy1-donard.priv.deltatee.com with local (Exim 4.92) (envelope-from ) id 1jwAZE-0004BI-Cw; Thu, 16 Jul 2020 14:33:20 -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: Thu, 16 Jul 2020 14:33:10 -0600 Message-Id: <20200716203319.16022-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=-6.7 required=5.0 tests=ALL_TRUSTED,BAYES_00, MYRULES_NO_TEXT autolearn=no autolearn_force=no version=3.4.2 Subject: [PATCH v15 0/9] nvmet: add target passthru commands support 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 This is v15 of the passthru patchset which fixes a random kconfig bug caught by the kernel test robot. A git branch is available here and is based on nvme-5.9 on Jul 16th: https://github.com/sbates130272/linux-p2pmem nvmet_passthru_v15 -- v15 Changes: 1. Rebased onto nvme-5.9, required minor merge. 2. Ensure NVME_CORE is not a module if NVME_TARGET is builtin when selecting NVME_TARGET_PASSTHRU (per kernel test robot) v14 Changes: 1. Rebased onto nvme-5.9 (per Chaitanya's suggestion), required minor merge. 2. Dropped the #ifdef around the prototypes in nvme.h because kbuild started complaining about non-staic functions that don't have prototypes. 3. Removed an unecessary if/else in nvmet_passthru_execute_cmd() as spotted by Chaitanya. 4. Removed unecessary casts in a pr_warn(), per Chaitanya v13 Changes: 1. Rebased onto v5.7-rc5 2. Collected Sagi's Reviewed-by tags v12 Changes: 1. Rebased onto v5.7-rc1 2. Collected Sagi's Reviewed-by tags 3. Per Sagi's feedback implement an whitelist for set/get features and audit the features for whether they are suitable to be passed-through v11 Changes: 1. Rebased onto v5.6-rc2 2. Collected Max's Reviewed-By tag v10 Changes: 1. Rebased onto v5.5-rc1 2. Disable all exports in core nvme if CONFIG_NVME_TARGET_PASSTHRU is not set and put them near the end of the file with a big fat comment (per Christoph) 3. Don't fake up the vs field: pass it through as is and bump it to 1.2.1 if it is below that (per Christoph) 4. Rework how passthru requests are submitted into the core with proper nvme_passthru_start/end handling (per Christoph) 5. Rework how commands are parsed with passthru hooks in parse_admin_cmd() and nvmet_parse_io_cmd() (per Christoph) 6. Rework commands are handled so they are only done in a work item if absolutely necessary (per Christoph) 7. The data_len hack was dropped as a patchset was introduced to remove data_len altogether (per Christoph) 8. The passthru accounting changes are now in v5.5-rc1 9. A large number of other minor cleanups that were pointed out by Christoph v9 Changes: 1. Rebased onto v5.4-rc2 (required adjusting nvme_identify_ns() usage) 2. Collected Sagi's Reviewed-By Tags 3. Squashed seperate Kconfig patch into passthru patch (Per Sagi) 4. Set REQ_FUA for flush requests and remove special casing on RQF_IO_STAT (Per Sagi) v8 Changes: 1. Rebased onto v5.3-rc6 2. Collected Max's Reviewed-By tags 3. Converted admin command black-list to a white-list, but allow all vendor specific commands. With this, we feel it's safe to allow multiple connections from hosts. (As per Sagi's feedback) v7 Changes: 1. Rebased onto v5.3-rc2 2. Rework nvme_ctrl_get_by_path() to use filp_open() instead of the cdev changes that were in v6. (Per Al) 3. Override the cmic bit to allow multipath and allow multiple connections from the same hostnqn. (At the same time I cleaned up the method of rejecting multiple connections.) See Patch 8) 4. Found a bug when used with the tcp transport (See Patch 10) v6 Changes: 1. Rebased onto v5.3-rc1 2. Rework configfs interface to simply be a passthru directory within the existing subsystem. The directory is similar to and consistent with a namespace directory. 3. Have the configfs take a path instead of a bare controller name 4. Renamed the main passthru file to io-cmd-passthru.c for consistency with the file and block-dev methods. 5. Cleaned up all the CONFIG_NVME_TARGET_PASSTHRU usage to remove all the inline #ifdefs 6. Restructured nvmet_passthru_make_request() a bit for clearer code 7. Moved nvme_find_get_ns() call into nvmet_passthru_execute_cmd() seeing calling it in nvmet_req_init() causes a lockdep warning due to nvme_find_get_ns() being able to sleep. 8. Added a check in nvmet_passthru_execute_cmd() to ensure we don't violate queue_max_segments or queue_max_hw_sectors and overrode mdts to ensure hosts don't intentionally submit commands that will exceed these limits. 9. Reworked the code which ensures there's only one subsystem per passthru controller to use an xarray instead of a list as this is simpler and more easily fixed some bugs triggered by disabling subsystems that weren't enabled. 10. Removed the overide of the target cntlid with the passthru cntlid; this seemed like a really bad idea especially in the presence of mixed systems as you could end up with two ctrlrs with the same cntlid. For now, commands that depend on cntlid are black listed. 11. Implement block accounting for passthru so the target can track usage using /proc/diskstats 12. A number of other minor bug fixes and cleanups v5 Changes (not sent to list, from Chaitanya): 1. Added workqueue for admin commands. 2. Added kconfig option for the pass-thru feature. 3. Restructure the parsing code according to your suggestion, call nvmet_xxx_parse_cmd() from nvmet_passthru_parse_cmd(). 4. Use pass-thru instead of pt. 5. Several cleanups and add comments at the appropriate locations. 6. Minimize the code for checking pass-thru ns across all the subsystems. 7. Removed the delays in the ns related admin commands since I was not able to reproduce the previous bug. v4 Changes: 1. Add request polling interface to the block layer. 2. Use request polling interface in the NVMEoF target passthru code path. 3. Add checks suggested by Sagi for creating one target ctrl per passthru ctrl. 4. Don't enable the namespace if it belongs to the configured passthru ctrl. 5. Adjust the code latest kernel. v3 Changes: 1. Split the addition of passthru command handlers and integration into two different patches since we add guards to create one target controller per passthru controller. This way it will be easier to review the code. 2. Adjust the code for 4.18. v2 Changes: 1. Update the new nvme core controller find API naming and changed the string comparison of the ctrl. 2. Get rid of the newly added #defines for target ctrl values. 3. Use the newly added structure members in the same patch where they are used. Aggregate the passthru command handling support and integration with nvmet-core into one patch. 4. Introduce global NVMe Target subsystem list for connected and not connected subsystems on the target side. 5. Add check when configuring the target ns and target passthru ctrl to allow only one target controller to be created for one passthru subsystem. 6. Use the passthru ctrl cntlid when creating the target controller. Chaitanya Kulkarni (1): nvmet-passthru: Introduce NVMet passthru Kconfig option Logan Gunthorpe (8): nvme-core: Clear any SGL flags in passthru commands nvme: Create helper function to obtain command effects nvme: Move nvme_passthru_[start|end]() calls to common helper nvme-core: Introduce nvme_ctrl_get_by_path() nvme: Export existing nvme core functions nvmet-passthru: Add passthru code to process commands nvmet-passthru: Add enable/disable helpers nvmet-configfs: Introduce passthru configfs interface drivers/nvme/host/core.c | 251 +++++++++------ drivers/nvme/host/nvme.h | 11 + drivers/nvme/target/Kconfig | 12 + drivers/nvme/target/Makefile | 1 + drivers/nvme/target/admin-cmd.c | 7 +- drivers/nvme/target/configfs.c | 103 ++++++ drivers/nvme/target/core.c | 13 +- drivers/nvme/target/nvmet.h | 52 +++ drivers/nvme/target/passthru.c | 543 ++++++++++++++++++++++++++++++++ include/linux/nvme.h | 4 + 10 files changed, 893 insertions(+), 104 deletions(-) create mode 100644 drivers/nvme/target/passthru.c base-commit: 84c2c94f1adc59eaed24554666f755bcdd0140e8 -- 2.20.1