Skip to content

Commit 60696eb

Browse files
Christoph Hellwigdjbw
authored andcommitted
fsdax: simplify the pgoff calculation
Replace the two steps of dax_iomap_sector and bdev_dax_pgoff with a single dax_iomap_pgoff helper that avoids lots of cumbersome sector conversions. Signed-off-by: Christoph Hellwig <[email protected]> Reviewed-by: Dan Williams <[email protected]> Reviewed-by: Darrick J. Wong <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Dan Williams <[email protected]>
1 parent 429f8de commit 60696eb

File tree

3 files changed

+10
-40
lines changed

3 files changed

+10
-40
lines changed

drivers/dax/super.c

Lines changed: 0 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -66,20 +66,6 @@ void dax_remove_host(struct gendisk *disk)
6666
}
6767
EXPORT_SYMBOL_GPL(dax_remove_host);
6868

69-
int bdev_dax_pgoff(struct block_device *bdev, sector_t sector, size_t size,
70-
pgoff_t *pgoff)
71-
{
72-
sector_t start_sect = bdev ? get_start_sect(bdev) : 0;
73-
phys_addr_t phys_off = (start_sect + sector) * 512;
74-
75-
if (pgoff)
76-
*pgoff = PHYS_PFN(phys_off);
77-
if (phys_off % PAGE_SIZE || size % PAGE_SIZE)
78-
return -EINVAL;
79-
return 0;
80-
}
81-
EXPORT_SYMBOL(bdev_dax_pgoff);
82-
8369
/**
8470
* fs_dax_get_by_bdev() - temporary lookup mechanism for filesystem-dax
8571
* @bdev: block device to find a dax_device for

fs/dax.c

Lines changed: 10 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -709,23 +709,22 @@ int dax_invalidate_mapping_entry_sync(struct address_space *mapping,
709709
return __dax_invalidate_entry(mapping, index, false);
710710
}
711711

712-
static sector_t dax_iomap_sector(const struct iomap *iomap, loff_t pos)
712+
static pgoff_t dax_iomap_pgoff(const struct iomap *iomap, loff_t pos)
713713
{
714-
return (iomap->addr + (pos & PAGE_MASK) - iomap->offset) >> 9;
714+
phys_addr_t paddr = iomap->addr + (pos & PAGE_MASK) - iomap->offset;
715+
716+
if (iomap->bdev)
717+
paddr += (get_start_sect(iomap->bdev) << SECTOR_SHIFT);
718+
return PHYS_PFN(paddr);
715719
}
716720

717721
static int copy_cow_page_dax(struct vm_fault *vmf, const struct iomap_iter *iter)
718722
{
719-
sector_t sector = dax_iomap_sector(&iter->iomap, iter->pos);
723+
pgoff_t pgoff = dax_iomap_pgoff(&iter->iomap, iter->pos);
720724
void *vto, *kaddr;
721-
pgoff_t pgoff;
722725
long rc;
723726
int id;
724727

725-
rc = bdev_dax_pgoff(iter->iomap.bdev, sector, PAGE_SIZE, &pgoff);
726-
if (rc)
727-
return rc;
728-
729728
id = dax_read_lock();
730729
rc = dax_direct_access(iter->iomap.dax_dev, pgoff, 1, &kaddr, NULL);
731730
if (rc < 0) {
@@ -1013,14 +1012,10 @@ EXPORT_SYMBOL_GPL(dax_writeback_mapping_range);
10131012
static int dax_iomap_pfn(const struct iomap *iomap, loff_t pos, size_t size,
10141013
pfn_t *pfnp)
10151014
{
1016-
const sector_t sector = dax_iomap_sector(iomap, pos);
1017-
pgoff_t pgoff;
1015+
pgoff_t pgoff = dax_iomap_pgoff(iomap, pos);
10181016
int id, rc;
10191017
long length;
10201018

1021-
rc = bdev_dax_pgoff(iomap->bdev, sector, size, &pgoff);
1022-
if (rc)
1023-
return rc;
10241019
id = dax_read_lock();
10251020
length = dax_direct_access(iomap->dax_dev, pgoff, PHYS_PFN(size),
10261021
NULL, pfnp);
@@ -1129,7 +1124,7 @@ static vm_fault_t dax_pmd_load_hole(struct xa_state *xas, struct vm_fault *vmf,
11291124
s64 dax_iomap_zero(loff_t pos, u64 length, struct iomap *iomap)
11301125
{
11311126
sector_t sector = iomap_sector(iomap, pos & PAGE_MASK);
1132-
pgoff_t pgoff;
1127+
pgoff_t pgoff = dax_iomap_pgoff(iomap, pos);
11331128
long rc, id;
11341129
void *kaddr;
11351130
bool page_aligned = false;
@@ -1140,10 +1135,6 @@ s64 dax_iomap_zero(loff_t pos, u64 length, struct iomap *iomap)
11401135
(size == PAGE_SIZE))
11411136
page_aligned = true;
11421137

1143-
rc = bdev_dax_pgoff(iomap->bdev, sector, PAGE_SIZE, &pgoff);
1144-
if (rc)
1145-
return rc;
1146-
11471138
id = dax_read_lock();
11481139

11491140
if (page_aligned)
@@ -1169,7 +1160,6 @@ static loff_t dax_iomap_iter(const struct iomap_iter *iomi,
11691160
const struct iomap *iomap = &iomi->iomap;
11701161
loff_t length = iomap_length(iomi);
11711162
loff_t pos = iomi->pos;
1172-
struct block_device *bdev = iomap->bdev;
11731163
struct dax_device *dax_dev = iomap->dax_dev;
11741164
loff_t end = pos + length, done = 0;
11751165
ssize_t ret = 0;
@@ -1203,20 +1193,15 @@ static loff_t dax_iomap_iter(const struct iomap_iter *iomi,
12031193
while (pos < end) {
12041194
unsigned offset = pos & (PAGE_SIZE - 1);
12051195
const size_t size = ALIGN(length + offset, PAGE_SIZE);
1206-
const sector_t sector = dax_iomap_sector(iomap, pos);
1196+
pgoff_t pgoff = dax_iomap_pgoff(iomap, pos);
12071197
ssize_t map_len;
1208-
pgoff_t pgoff;
12091198
void *kaddr;
12101199

12111200
if (fatal_signal_pending(current)) {
12121201
ret = -EINTR;
12131202
break;
12141203
}
12151204

1216-
ret = bdev_dax_pgoff(bdev, sector, size, &pgoff);
1217-
if (ret)
1218-
break;
1219-
12201205
map_len = dax_direct_access(dax_dev, pgoff, PHYS_PFN(size),
12211206
&kaddr, NULL);
12221207
if (map_len < 0) {

include/linux/dax.h

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -107,7 +107,6 @@ static inline bool daxdev_mapping_supported(struct vm_area_struct *vma,
107107
#endif
108108

109109
struct writeback_control;
110-
int bdev_dax_pgoff(struct block_device *, sector_t, size_t, pgoff_t *pgoff);
111110
#if IS_ENABLED(CONFIG_FS_DAX)
112111
int dax_add_host(struct dax_device *dax_dev, struct gendisk *disk);
113112
void dax_remove_host(struct gendisk *disk);

0 commit comments

Comments
 (0)