mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 23:00:21 +00:00
filemap: consistently use ->f_mapping over ->i_mapping
Use file->f_mapping in all remaining places that have a struct file available to properly handle the case where inode->i_mapping != file_inode(file)->i_mapping. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Jan Kara <jack@suse.cz> Reviewed-by: Hannes Reinecke <hare@suse.de> Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com> Reviewed-by: Matthew Wilcox (Oracle) <willy@infradead.org> Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
5a20d073ec
commit
5df1a67269
13
mm/filemap.c
13
mm/filemap.c
@ -2886,14 +2886,14 @@ EXPORT_SYMBOL(filemap_map_pages);
|
||||
|
||||
vm_fault_t filemap_page_mkwrite(struct vm_fault *vmf)
|
||||
{
|
||||
struct address_space *mapping = vmf->vma->vm_file->f_mapping;
|
||||
struct page *page = vmf->page;
|
||||
struct inode *inode = file_inode(vmf->vma->vm_file);
|
||||
vm_fault_t ret = VM_FAULT_LOCKED;
|
||||
|
||||
sb_start_pagefault(inode->i_sb);
|
||||
sb_start_pagefault(mapping->host->i_sb);
|
||||
file_update_time(vmf->vma->vm_file);
|
||||
lock_page(page);
|
||||
if (page->mapping != inode->i_mapping) {
|
||||
if (page->mapping != mapping) {
|
||||
unlock_page(page);
|
||||
ret = VM_FAULT_NOPAGE;
|
||||
goto out;
|
||||
@ -2906,7 +2906,7 @@ vm_fault_t filemap_page_mkwrite(struct vm_fault *vmf)
|
||||
set_page_dirty(page);
|
||||
wait_for_stable_page(page);
|
||||
out:
|
||||
sb_end_pagefault(inode->i_sb);
|
||||
sb_end_pagefault(mapping->host->i_sb);
|
||||
return ret;
|
||||
}
|
||||
|
||||
@ -3149,10 +3149,9 @@ void dio_warn_stale_pagecache(struct file *filp)
|
||||
{
|
||||
static DEFINE_RATELIMIT_STATE(_rs, 86400 * HZ, DEFAULT_RATELIMIT_BURST);
|
||||
char pathname[128];
|
||||
struct inode *inode = file_inode(filp);
|
||||
char *path;
|
||||
|
||||
errseq_set(&inode->i_mapping->wb_err, -EIO);
|
||||
errseq_set(&filp->f_mapping->wb_err, -EIO);
|
||||
if (__ratelimit(&_rs)) {
|
||||
path = file_path(filp, pathname, sizeof(pathname));
|
||||
if (IS_ERR(path))
|
||||
@ -3179,7 +3178,7 @@ generic_file_direct_write(struct kiocb *iocb, struct iov_iter *from)
|
||||
|
||||
if (iocb->ki_flags & IOCB_NOWAIT) {
|
||||
/* If there are pages to writeback, return */
|
||||
if (filemap_range_has_page(inode->i_mapping, pos,
|
||||
if (filemap_range_has_page(file->f_mapping, pos,
|
||||
pos + write_len - 1))
|
||||
return -EAGAIN;
|
||||
} else {
|
||||
|
Loading…
x
Reference in New Issue
Block a user