From patchwork Wed Nov 23 05:58:24 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Nitesh Shetty X-Patchwork-Id: 13053105 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id C528AC433FE for ; Wed, 23 Nov 2022 06:14:20 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236030AbiKWGOT (ORCPT ); Wed, 23 Nov 2022 01:14:19 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51066 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229477AbiKWGNu (ORCPT ); Wed, 23 Nov 2022 01:13:50 -0500 Received: from mailout4.samsung.com (mailout4.samsung.com [203.254.224.34]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BEF5DF3930 for ; Tue, 22 Nov 2022 22:13:40 -0800 (PST) Received: from epcas5p4.samsung.com (unknown [182.195.41.42]) by mailout4.samsung.com (KnoxPortal) with ESMTP id 20221123061339epoutp0405804b9759a43665bd856df8d48e9801~qIgWUQ5OU2309423094epoutp04u for ; Wed, 23 Nov 2022 06:13:39 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 mailout4.samsung.com 20221123061339epoutp0405804b9759a43665bd856df8d48e9801~qIgWUQ5OU2309423094epoutp04u DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=samsung.com; s=mail20170921; t=1669184019; bh=jXzSR3ie2tfHlOJCwFoO5jv52UvRDIp1dABQIpgm1Oc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=L/8dRuKpVC7QSUwYg5F+w3CYToULVTiehEIAxAf/8uYNRetlTHyI2vcaAibkB8a1b 3JOczz/fKVfh7jiZe9a43Q7hpd7UwiIhCa352oYO48HpqLvJC1f8WuayQ7OKvq1rdx eYnDwGgXszoW91XCN2DACRoyrDaVgxHtQrYIFESY= Received: from epsnrtp3.localdomain (unknown [182.195.42.164]) by epcas5p1.samsung.com (KnoxPortal) with ESMTP id 20221123061338epcas5p19a10d044dd5231ab4c410f9e745d3588~qIgVsGcz_0806308063epcas5p1o; Wed, 23 Nov 2022 06:13:38 +0000 (GMT) Received: from epsmges5p3new.samsung.com (unknown [182.195.38.177]) by epsnrtp3.localdomain (Postfix) with ESMTP id 4NH9mc6sMzz4x9Pp; Wed, 23 Nov 2022 06:13:36 +0000 (GMT) Received: from epcas5p3.samsung.com ( [182.195.41.41]) by epsmges5p3new.samsung.com (Symantec Messaging Gateway) with SMTP id 0D.27.56352.01ABD736; Wed, 23 Nov 2022 15:13:36 +0900 (KST) Received: from epsmtrp2.samsung.com (unknown [182.195.40.14]) by epcas5p3.samsung.com (KnoxPortal) with ESMTPA id 20221123061034epcas5p3fe90293ad08df4901f98bae2d7cfc1ba~qIdqbAfxR2070420704epcas5p3G; Wed, 23 Nov 2022 06:10:34 +0000 (GMT) Received: from epsmgms1p1new.samsung.com (unknown [182.195.42.41]) by epsmtrp2.samsung.com (KnoxPortal) with ESMTP id 20221123061034epsmtrp2602de2e166f8f56c95c08c75cbe028c4~qIdqaBxvZ0466304663epsmtrp2x; Wed, 23 Nov 2022 06:10:34 +0000 (GMT) X-AuditID: b6c32a4b-5f7fe7000001dc20-0e-637dba10585d Received: from epsmtip1.samsung.com ( [182.195.34.30]) by epsmgms1p1new.samsung.com (Symantec Messaging Gateway) with SMTP id 52.1B.14392.A59BD736; Wed, 23 Nov 2022 15:10:34 +0900 (KST) Received: from test-zns.sa.corp.samsungelectronics.net (unknown [107.110.206.5]) by epsmtip1.samsung.com (KnoxPortal) with ESMTPA id 20221123061031epsmtip1a9bf6055f42237a716527282c7e5298d~qIdnbPUwA1988319883epsmtip1d; Wed, 23 Nov 2022 06:10:31 +0000 (GMT) From: Nitesh Shetty To: axboe@kernel.dk, agk@redhat.com, snitzer@kernel.org, dm-devel@redhat.com, kbusch@kernel.org, hch@lst.de, sagi@grimberg.me, james.smart@broadcom.com, kch@nvidia.com, damien.lemoal@opensource.wdc.com, naohiro.aota@wdc.com, jth@kernel.org, viro@zeniv.linux.org.uk Cc: linux-block@vger.kernel.org, linux-kernel@vger.kernel.org, linux-nvme@lists.infradead.org, linux-fsdevel@vger.kernel.org, anuj20.g@samsung.com, joshi.k@samsung.com, p.raghav@samsung.com, nitheshshetty@gmail.com, gost.dev@samsung.com, Nitesh Shetty Subject: [PATCH v5 07/10] dm: Add support for copy offload. Date: Wed, 23 Nov 2022 11:28:24 +0530 Message-Id: <20221123055827.26996-8-nj.shetty@samsung.com> X-Mailer: git-send-email 2.35.1.500.gb896f729e2 In-Reply-To: <20221123055827.26996-1-nj.shetty@samsung.com> MIME-Version: 1.0 X-Brightmail-Tracker: H4sIAAAAAAAAA01TbUxTZxTOe2+5LSyVK199BURSMpZC+Ogo5UVgM5lxl0kmiZhl+gPu2ruC QNv0Y04iAwdMZMqHgNEy+dgUJyBsBRRayhgbVpAOpyKCQDdCl30ERFlGHDLWcnHz33POeZ5z nnPevDzc6xOuPy9LqWM0SjpHSHhwrn0nEkWQpnxZdP9SDOoYuYGjjyvXcNQ6U0GgVdsYjiyL dW5ocqAXQ1dahzBkbnqMoaH1BQL9/OcUB50ZvA+QY9yAIctUOOqzDHPQXdNnBGpodnBRlbXT DfXMHwfo2moDjpYvFXNR+x+POOjmVAAaW7O67RJQBruNoHoNM1xqbPZrDnXXpqeMLScJqvNi AWWeLCSo00WLTkKJ3Y161D9OUOVdLYBaNgZRJwY+xSjj/AKWuuVgdmImQ8sZTTCjlKnkWUpF knDv/vQ30mOl0eIIcTyKEwYr6VwmSbg7JTViT1aOc39h8Ad0jt6ZSqW1WmHUa4kalV7HBGeq tLokIaOW56gl6kgtnavVKxWRSka3Uxwd/Wqsk5iRnTn+zQqhnvH/cOLqALcQTPqWAR4PkhL4 eVdgGXDneZFmAK+25ZcBDyd+AqC5rgawwV8AjtS2u7lYLsHsHTvGFiwAnlqyEKy8BIOXFvWu rgQZDm+t81wcH7Icg6XmAdwV4GQdBhean3FdAm8yAVpLhze6csiX4frwdeDCfHInnD7nwFl7 UbDCvtWVdnfSR380YSxlKxw+P89xYZzcAYu663DWXIM7vDd9jMW74WJz9aZpb/i7tYvLYn+4 vMh6huQReKXmS8LlDZLFABomDIAtvA5LRio2POCkCHaYotj0dlg70o6xc7fA06vzGJvnw576 5zgEtnU0bvbfBu+vHN/EFGxous1hb1UO4PhQaCUINrywjuGFdQz/T24EeAvYxqi1uQpGG6uO UTJH/ntimSrXCDY+RNjeHjD301LkIMB4YBBAHi704RckH5N58eX00TxGo0rX6HMY7SCIdZ67 Cvf3lamcP0qpSxdL4qMlUqlUEh8jFQsF/C/Ohcm8SAWtY7IZRs1onuswnrt/IZYSRIQeWBMp vjKJ6s9Axo5Z056NBaw9jOoWvWl/C4Vk5Hsa4ox3VHy68qkUBNUcbrZtr6u3rThMnpVPFSuF fVP7eb8KHOIZh2Niat86jsy3A3/pP4iSHe8QAo7sQPdHKRZpX2rpD378Qzd+c2RkdJbk0e+n yb3eviUxJFx/5UFc6IU9AD8cf2juaOC78n1zgecLmcbw1pVSAVLcu5xQ79eXeHHX5cb0m7Nt aQmevu+N2qpPhJbXXgjIW4V/V2Rm9fhINC3Ncd58VLU7mfas8uAUpw2shRSc/FaQgfGJJ36a 3qIdTWN26z/Tp15a/b7a+EBVdZZ82KcIeOxuG20RcrSZtDgM12jpfwEIyS52mQQAAA== X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFtrPIsWRmVeSWpSXmKPExsWy7bCSnG7Uztpkg5eXFS3WnzrGbNE04S+z xeq7/WwWv8+eZ7bY+242q8XNAzuZLFauPspksXvhRyaLo//fslk8/HKLxWLSoWuMFk+vzmKy 2HtL22LP3pMsFpd3zWGzmL/sKbvFxOObWS12PGlktNj2ez6zxeelLewW616/Z7E4cUva4vzf 46wO4h6z7p9l89g56y67x/l7G1k8Lp8t9di0qpPNY/OSeo/dNxvYPHqb3wEVtN5n9Xi/7yqb R9+WVYwenzfJebQf6Gby2PTkLVMAXxSXTUpqTmZZapG+XQJXxtX939kK7kpVXF97gL2B8aZo FyMnh4SAicS9S/eZuhi5OIQEdjNKLNs8gREiISmx7O8RZghbWGLlv+fsEEXNTBJnW3cBFXFw sAloS5z+zwESFxFYwCRx+d4rZhCHWWApk8TsK3fZQLqFBawljnecZAWxWQRUJf6f3A62gVfA SuLOjKfMIIMkBPQl+u8LgoQ5gcrPXNzFBBIWAirZs0wHolpQ4uTMJywgNrOAvETz1tnMExgF ZiFJzUKSWsDItIpRMrWgODc9t9iwwDAvtVyvODG3uDQvXS85P3cTIziOtTR3MG5f9UHvECMT B+MhRgkOZiUR3nrPmmQh3pTEyqrUovz4otKc1OJDjNIcLErivBe6TsYLCaQnlqRmp6YWpBbB ZJk4OKUamDzePZG6uYuBaYZieZKjvIJKgOPil6H1epy1kxV/x0Vy1j/qVL0xgeXShGuLrVtq wva9+O0jG30od36n5OIpNQHq4l+Fp+3KmWd78qOi0vSFj/33B6hPX8X/+Etlq8vxi7LHg894 ygcd7bslsfKwsO2jPeU3ROImzpyncjDy6OTX2ozul9jmf1fscensWPNScdHi5xZyx31zO0p6 L3xP79z/9eXKjIN3PWruN0zeG8AXs93Me8XjLdb2UhUbfxeu9tq/In+ytLRZzImeuN9He99v KQ8tWySmK8LEPJFb5dBhh00ZXOlbQhUj53/tXRB81d/jdr21sqmrWvp1I69Go30bNpz0mpEa brRx8dkfukosxRmJhlrMRcWJAFoIfGtSAwAA X-CMS-MailID: 20221123061034epcas5p3fe90293ad08df4901f98bae2d7cfc1ba X-Msg-Generator: CA X-Sendblock-Type: REQ_APPROVE CMS-TYPE: 105P DLP-Filter: Pass X-CFilter-Loop: Reflected X-CMS-RootMailID: 20221123061034epcas5p3fe90293ad08df4901f98bae2d7cfc1ba References: <20221123055827.26996-1-nj.shetty@samsung.com> Precedence: bulk List-ID: X-Mailing-List: linux-fsdevel@vger.kernel.org Before enabling copy for dm target, check if underlying devices and dm target support copy. Avoid split happening inside dm target. Fail early if the request needs split, currently splitting copy request is not supported. Signed-off-by: Nitesh Shetty --- drivers/md/dm-table.c | 42 +++++++++++++++++++++++++++++++++++ drivers/md/dm.c | 7 ++++++ include/linux/device-mapper.h | 5 +++++ 3 files changed, 54 insertions(+) diff --git a/drivers/md/dm-table.c b/drivers/md/dm-table.c index 078da18bb86d..b2073e857a74 100644 --- a/drivers/md/dm-table.c +++ b/drivers/md/dm-table.c @@ -1875,6 +1875,39 @@ static bool dm_table_supports_nowait(struct dm_table *t) return true; } +static int device_not_copy_capable(struct dm_target *ti, struct dm_dev *dev, + sector_t start, sector_t len, void *data) +{ + struct request_queue *q = bdev_get_queue(dev->bdev); + + return !blk_queue_copy(q); +} + +static bool dm_table_supports_copy(struct dm_table *t) +{ + struct dm_target *ti; + unsigned int i; + + for (i = 0; i < t->num_targets; i++) { + ti = dm_table_get_target(t, i); + + if (!ti->copy_offload_supported) + return false; + + /* + * target provides copy support (as implied by setting + * 'copy_offload_supported') + * and it relies on _all_ data devices having copy support. + */ + if (!ti->type->iterate_devices || + ti->type->iterate_devices(ti, + device_not_copy_capable, NULL)) + return false; + } + + return true; +} + static int device_not_discard_capable(struct dm_target *ti, struct dm_dev *dev, sector_t start, sector_t len, void *data) { @@ -1957,6 +1990,15 @@ int dm_table_set_restrictions(struct dm_table *t, struct request_queue *q, q->limits.discard_misaligned = 0; } + if (!dm_table_supports_copy(t)) { + blk_queue_flag_clear(QUEUE_FLAG_COPY, q); + /* Must also clear copy limits... */ + q->limits.max_copy_sectors = 0; + q->limits.max_copy_sectors_hw = 0; + } else { + blk_queue_flag_set(QUEUE_FLAG_COPY, q); + } + if (!dm_table_supports_secure_erase(t)) q->limits.max_secure_erase_sectors = 0; diff --git a/drivers/md/dm.c b/drivers/md/dm.c index e1ea3a7bd9d9..713335995290 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c @@ -1690,6 +1690,13 @@ static blk_status_t __split_and_process_bio(struct clone_info *ci) if (unlikely(ci->is_abnormal_io)) return __process_abnormal_io(ci, ti); + if ((unlikely(op_is_copy(ci->bio->bi_opf)) && + max_io_len(ti, ci->sector) < ci->sector_count)) { + DMERR("Error, IO size(%u) > max target size(%llu)\n", + ci->sector_count, max_io_len(ti, ci->sector)); + return BLK_STS_IOERR; + } + /* * Only support bio polling for normal IO, and the target io is * exactly inside the dm_io instance (verified in dm_poll_dm_io) diff --git a/include/linux/device-mapper.h b/include/linux/device-mapper.h index 04c6acf7faaa..da4e77e81011 100644 --- a/include/linux/device-mapper.h +++ b/include/linux/device-mapper.h @@ -379,6 +379,11 @@ struct dm_target { * bio_set_dev(). NOTE: ideally a target should _not_ need this. */ bool needs_bio_set_dev:1; + + /* + * copy offload is supported + */ + bool copy_offload_supported:1; }; void *dm_per_bio_data(struct bio *bio, size_t data_size);