Skip to content

Commit 1e9d180

Browse files
Ross Zwislertytso
authored andcommitted
ext2, ext4: fix issue with missing journal entry in ext4_dax_mkwrite()
As it is currently written ext4_dax_mkwrite() assumes that the call into __dax_mkwrite() will not have to do a block allocation so it doesn't create a journal entry. For a read that creates a zero page to cover a hole followed by a write that actually allocates storage this is incorrect. The ext4_dax_mkwrite() -> __dax_mkwrite() -> __dax_fault() path calls get_blocks() to allocate storage. Fix this by having the ->page_mkwrite fault handler call ext4_dax_fault() as this function already has all the logic needed to allocate a journal entry and call __dax_fault(). Also update the ext2 fault handlers in this same way to remove duplicate code and keep the logic between ext2 and ext4 the same. Reviewed-by: Jan Kara <[email protected]> Signed-off-by: Ross Zwisler <[email protected]> Signed-off-by: Theodore Ts'o <[email protected]>
1 parent 74dae42 commit 1e9d180

File tree

2 files changed

+3
-35
lines changed

2 files changed

+3
-35
lines changed

fs/ext2/file.c

Lines changed: 1 addition & 18 deletions
Original file line numberDiff line numberDiff line change
@@ -80,23 +80,6 @@ static int ext2_dax_pmd_fault(struct vm_area_struct *vma, unsigned long addr,
8080
return ret;
8181
}
8282

83-
static int ext2_dax_mkwrite(struct vm_area_struct *vma, struct vm_fault *vmf)
84-
{
85-
struct inode *inode = file_inode(vma->vm_file);
86-
struct ext2_inode_info *ei = EXT2_I(inode);
87-
int ret;
88-
89-
sb_start_pagefault(inode->i_sb);
90-
file_update_time(vma->vm_file);
91-
down_read(&ei->dax_sem);
92-
93-
ret = __dax_mkwrite(vma, vmf, ext2_get_block, NULL);
94-
95-
up_read(&ei->dax_sem);
96-
sb_end_pagefault(inode->i_sb);
97-
return ret;
98-
}
99-
10083
static int ext2_dax_pfn_mkwrite(struct vm_area_struct *vma,
10184
struct vm_fault *vmf)
10285
{
@@ -124,7 +107,7 @@ static int ext2_dax_pfn_mkwrite(struct vm_area_struct *vma,
124107
static const struct vm_operations_struct ext2_dax_vm_ops = {
125108
.fault = ext2_dax_fault,
126109
.pmd_fault = ext2_dax_pmd_fault,
127-
.page_mkwrite = ext2_dax_mkwrite,
110+
.page_mkwrite = ext2_dax_fault,
128111
.pfn_mkwrite = ext2_dax_pfn_mkwrite,
129112
};
130113

fs/ext4/file.c

Lines changed: 2 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -262,23 +262,8 @@ static int ext4_dax_pmd_fault(struct vm_area_struct *vma, unsigned long addr,
262262
return result;
263263
}
264264

265-
static int ext4_dax_mkwrite(struct vm_area_struct *vma, struct vm_fault *vmf)
266-
{
267-
int err;
268-
struct inode *inode = file_inode(vma->vm_file);
269-
270-
sb_start_pagefault(inode->i_sb);
271-
file_update_time(vma->vm_file);
272-
down_read(&EXT4_I(inode)->i_mmap_sem);
273-
err = __dax_mkwrite(vma, vmf, ext4_dax_mmap_get_block, NULL);
274-
up_read(&EXT4_I(inode)->i_mmap_sem);
275-
sb_end_pagefault(inode->i_sb);
276-
277-
return err;
278-
}
279-
280265
/*
281-
* Handle write fault for VM_MIXEDMAP mappings. Similarly to ext4_dax_mkwrite()
266+
* Handle write fault for VM_MIXEDMAP mappings. Similarly to ext4_dax_fault()
282267
* handler we check for races agaist truncate. Note that since we cycle through
283268
* i_mmap_sem, we are sure that also any hole punching that began before we
284269
* were called is finished by now and so if it included part of the file we
@@ -311,7 +296,7 @@ static int ext4_dax_pfn_mkwrite(struct vm_area_struct *vma,
311296
static const struct vm_operations_struct ext4_dax_vm_ops = {
312297
.fault = ext4_dax_fault,
313298
.pmd_fault = ext4_dax_pmd_fault,
314-
.page_mkwrite = ext4_dax_mkwrite,
299+
.page_mkwrite = ext4_dax_fault,
315300
.pfn_mkwrite = ext4_dax_pfn_mkwrite,
316301
};
317302
#else

0 commit comments

Comments
 (0)