Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp2652308pxb; Sun, 17 Oct 2021 21:41:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwR50YTL3tK7xbM5SE4NtXCqywhPSIOFkEmNGrFCxPhGaTVHK2OshhW6VmKbXDeDflfemBc X-Received: by 2002:a05:6a00:2405:b0:3e1:9f65:9703 with SMTP id z5-20020a056a00240500b003e19f659703mr27124575pfh.6.1634532114272; Sun, 17 Oct 2021 21:41:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634532114; cv=none; d=google.com; s=arc-20160816; b=zFYazV9Xk9fo4H7Qbwstk8IfOUWuUlDQPdcRLk0IRHZ488O293/Ng5OfFPTG5EZ0uo nIWMW1j0LfW9XnbM8lBufHl9CT4L87YOZhvDozUVmDFhg9KC7PkIaC46iHePQRTgdA4C tishCX/+OcZD5iXxMtOVCRZ5Vp26UZhwjGe0HIOwsRd/Hih4RJI2syfG0Oc59MzMZKpJ EK3t5EYirEI7CqvxwTjwOw8hAexl8F5dz7EmtfESC/mPbmafvx1q8bXKr4HwtB+XltSe 8cvO/PfjZzpv3HqGc94L7kbm6MUyyekw/YFmDaI2XJwW4+SfNHYt85jFEXCGzHj/D0x3 40sA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:to:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:from :dkim-signature; bh=BLjmYRCcrzVSVv/Dx+s/G4G/vdiYtJgTg17dNCcoT9I=; b=gZ3dqI2+XDeHV0yptKIgQmIUzFGBNpQgoQNyq2a6rdlNsTr86prhaGz1gvXBLgjGI2 knftsN1RlUmP6v8vRUMm7Ua9BokYB5hV/Nvc42hMekCE7icnWltMaMZ4Qy4oKg9TgG2a x7uTouXLZeI32GZN/ZnXbAQl3RB5MbYz9/RH7WYaTYQ2TjsmHqON8RSzupSK3vljZk9w Vj7E1bsBiuRu+1Ki/r2eBuihZ9fG56FdlnspoiSQb2tirJOQix0+fiNvv5LNqHIpC6jZ kXrijZsVT2DTezv71AlFigX8DFZYVOO5Hdf2ZT9C/dsWP0V4hJDCRCSahAAQ1sOYB+CZ n73Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20210309 header.b=MldUs6q+; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-ext4-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 f12si18865258pln.297.2021.10.17.21.41.41; Sun, 17 Oct 2021 21:41:54 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-ext4-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=@infradead.org header.s=bombadil.20210309 header.b=MldUs6q+; spf=pass (google.com: domain of linux-ext4-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229890AbhJREnp (ORCPT + 99 others); Mon, 18 Oct 2021 00:43:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55072 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230013AbhJREno (ORCPT ); Mon, 18 Oct 2021 00:43:44 -0400 Received: from bombadil.infradead.org (unknown [IPv6:2607:7c80:54:e::133]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 26080C06161C; Sun, 17 Oct 2021 21:41:34 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20210309; h=Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Sender :Reply-To:Content-Type:Content-ID:Content-Description; bh=BLjmYRCcrzVSVv/Dx+s/G4G/vdiYtJgTg17dNCcoT9I=; b=MldUs6q+d7/Vxgl46oHfGE5Cin PPE/M7rQRHbaB57ALi4TLUUSo69TKCgiSPnCUcXufWxL8IfnTXyaJ1G0mL9a6hVdDTzrhpRyLeGNc WL6RfRgC2KIuXhUj5ovuylg49B6CNmYE1jKt/NMuXOfI5LtqwaTnR1cnYeTxgQqLhQm1MX1v+Noos 2qcyA0xcR/wpRQN6wWgbPjIEHAvOeCKFLs/ysOupsKfaT7His5QAge/w7z1Goik9g+w4O5314gyW8 rqEeu9Fc4/xoFizHnVKGR0oNYrfxKxqJCHwdK4mVkXlE9EjFjLKmQ+HLhOnKxXbsIOqd49CGTWZXH jZJ/Im/A==; Received: from 089144211028.atnat0020.highway.a1.net ([89.144.211.28] helo=localhost) by bombadil.infradead.org with esmtpsa (Exim 4.94.2 #2 (Red Hat Linux)) id 1mcKSk-00E3QG-MP; Mon, 18 Oct 2021 04:41:27 +0000 From: Christoph Hellwig Cc: Dan Williams , Mike Snitzer , Ira Weiny , dm-devel@redhat.com, linux-xfs@vger.kernel.org, nvdimm@lists.linux.dev, linux-s390@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-erofs@lists.ozlabs.org, linux-ext4@vger.kernel.org, virtualization@lists.linux-foundation.org Subject: [PATCH 09/11] dm-log-writes: add a log_writes_dax_pgoff helper Date: Mon, 18 Oct 2021 06:40:52 +0200 Message-Id: <20211018044054.1779424-10-hch@lst.de> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20211018044054.1779424-1-hch@lst.de> References: <20211018044054.1779424-1-hch@lst.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org. See http://www.infradead.org/rpr.html To: unlisted-recipients:; (no To-header on input) Precedence: bulk List-ID: X-Mailing-List: linux-ext4@vger.kernel.org Add a helper to perform the entire remapping for DAX accesses. This helper open codes bdev_dax_pgoff given that the alignment checks have already been done by the submitting file system and don't need to be repeated. Signed-off-by: Christoph Hellwig --- drivers/md/dm-log-writes.c | 42 +++++++++++++++----------------------- 1 file changed, 17 insertions(+), 25 deletions(-) diff --git a/drivers/md/dm-log-writes.c b/drivers/md/dm-log-writes.c index 6d694526881d0..5aac60c1b774c 100644 --- a/drivers/md/dm-log-writes.c +++ b/drivers/md/dm-log-writes.c @@ -949,17 +949,21 @@ static int log_dax(struct log_writes_c *lc, sector_t sector, size_t bytes, return 0; } +static struct dax_device *log_writes_dax_pgoff(struct dm_target *ti, + pgoff_t *pgoff) +{ + struct log_writes_c *lc = ti->private; + + *pgoff += (get_start_sect(lc->dev->bdev) >> PAGE_SECTORS_SHIFT); + return lc->dev->dax_dev; +} + static long log_writes_dax_direct_access(struct dm_target *ti, pgoff_t pgoff, long nr_pages, void **kaddr, pfn_t *pfn) { - struct log_writes_c *lc = ti->private; - sector_t sector = pgoff * PAGE_SECTORS; - int ret; + struct dax_device *dax_dev = log_writes_dax_pgoff(ti, &pgoff); - ret = bdev_dax_pgoff(lc->dev->bdev, sector, nr_pages * PAGE_SIZE, &pgoff); - if (ret) - return ret; - return dax_direct_access(lc->dev->dax_dev, pgoff, nr_pages, kaddr, pfn); + return dax_direct_access(dax_dev, pgoff, nr_pages, kaddr, pfn); } static size_t log_writes_dax_copy_from_iter(struct dm_target *ti, @@ -968,11 +972,9 @@ static size_t log_writes_dax_copy_from_iter(struct dm_target *ti, { struct log_writes_c *lc = ti->private; sector_t sector = pgoff * PAGE_SECTORS; + struct dax_device *dax_dev = log_writes_dax_pgoff(ti, &pgoff); int err; - if (bdev_dax_pgoff(lc->dev->bdev, sector, ALIGN(bytes, PAGE_SIZE), &pgoff)) - return 0; - /* Don't bother doing anything if logging has been disabled */ if (!lc->logging_enabled) goto dax_copy; @@ -983,34 +985,24 @@ static size_t log_writes_dax_copy_from_iter(struct dm_target *ti, return 0; } dax_copy: - return dax_copy_from_iter(lc->dev->dax_dev, pgoff, addr, bytes, i); + return dax_copy_from_iter(dax_dev, pgoff, addr, bytes, i); } static size_t log_writes_dax_copy_to_iter(struct dm_target *ti, pgoff_t pgoff, void *addr, size_t bytes, struct iov_iter *i) { - struct log_writes_c *lc = ti->private; - sector_t sector = pgoff * PAGE_SECTORS; + struct dax_device *dax_dev = log_writes_dax_pgoff(ti, &pgoff); - if (bdev_dax_pgoff(lc->dev->bdev, sector, ALIGN(bytes, PAGE_SIZE), &pgoff)) - return 0; - return dax_copy_to_iter(lc->dev->dax_dev, pgoff, addr, bytes, i); + return dax_copy_to_iter(dax_dev, pgoff, addr, bytes, i); } static int log_writes_dax_zero_page_range(struct dm_target *ti, pgoff_t pgoff, size_t nr_pages) { - int ret; - struct log_writes_c *lc = ti->private; - sector_t sector = pgoff * PAGE_SECTORS; + struct dax_device *dax_dev = log_writes_dax_pgoff(ti, &pgoff); - ret = bdev_dax_pgoff(lc->dev->bdev, sector, nr_pages << PAGE_SHIFT, - &pgoff); - if (ret) - return ret; - return dax_zero_page_range(lc->dev->dax_dev, pgoff, - nr_pages << PAGE_SHIFT); + return dax_zero_page_range(dax_dev, pgoff, nr_pages << PAGE_SHIFT); } #else -- 2.30.2