diff options
| -rw-r--r-- | fs/ocfs2/aops.c | 5 | ||||
| -rw-r--r-- | fs/ocfs2/aops.h | 3 | ||||
| -rw-r--r-- | fs/ocfs2/mmap.c | 7 |
3 files changed, 9 insertions, 6 deletions
diff --git a/fs/ocfs2/aops.c b/fs/ocfs2/aops.c index 0de69c9a08be..e3efdd93773f 100644 --- a/fs/ocfs2/aops.c +++ b/fs/ocfs2/aops.c | |||
| @@ -1642,7 +1642,8 @@ static int ocfs2_zero_tail(struct inode *inode, struct buffer_head *di_bh, | |||
| 1642 | return ret; | 1642 | return ret; |
| 1643 | } | 1643 | } |
| 1644 | 1644 | ||
| 1645 | int ocfs2_write_begin_nolock(struct address_space *mapping, | 1645 | int ocfs2_write_begin_nolock(struct file *filp, |
| 1646 | struct address_space *mapping, | ||
| 1646 | loff_t pos, unsigned len, unsigned flags, | 1647 | loff_t pos, unsigned len, unsigned flags, |
| 1647 | struct page **pagep, void **fsdata, | 1648 | struct page **pagep, void **fsdata, |
| 1648 | struct buffer_head *di_bh, struct page *mmap_page) | 1649 | struct buffer_head *di_bh, struct page *mmap_page) |
| @@ -1854,7 +1855,7 @@ static int ocfs2_write_begin(struct file *file, struct address_space *mapping, | |||
| 1854 | */ | 1855 | */ |
| 1855 | down_write(&OCFS2_I(inode)->ip_alloc_sem); | 1856 | down_write(&OCFS2_I(inode)->ip_alloc_sem); |
| 1856 | 1857 | ||
| 1857 | ret = ocfs2_write_begin_nolock(mapping, pos, len, flags, pagep, | 1858 | ret = ocfs2_write_begin_nolock(file, mapping, pos, len, flags, pagep, |
| 1858 | fsdata, di_bh, NULL); | 1859 | fsdata, di_bh, NULL); |
| 1859 | if (ret) { | 1860 | if (ret) { |
| 1860 | mlog_errno(ret); | 1861 | mlog_errno(ret); |
diff --git a/fs/ocfs2/aops.h b/fs/ocfs2/aops.h index c48e93ffc513..7606f663da6d 100644 --- a/fs/ocfs2/aops.h +++ b/fs/ocfs2/aops.h | |||
| @@ -48,7 +48,8 @@ int ocfs2_write_end_nolock(struct address_space *mapping, | |||
| 48 | loff_t pos, unsigned len, unsigned copied, | 48 | loff_t pos, unsigned len, unsigned copied, |
| 49 | struct page *page, void *fsdata); | 49 | struct page *page, void *fsdata); |
| 50 | 50 | ||
| 51 | int ocfs2_write_begin_nolock(struct address_space *mapping, | 51 | int ocfs2_write_begin_nolock(struct file *filp, |
| 52 | struct address_space *mapping, | ||
| 52 | loff_t pos, unsigned len, unsigned flags, | 53 | loff_t pos, unsigned len, unsigned flags, |
| 53 | struct page **pagep, void **fsdata, | 54 | struct page **pagep, void **fsdata, |
| 54 | struct buffer_head *di_bh, struct page *mmap_page); | 55 | struct buffer_head *di_bh, struct page *mmap_page); |
diff --git a/fs/ocfs2/mmap.c b/fs/ocfs2/mmap.c index af2b8fe1f139..b04d6961c0d4 100644 --- a/fs/ocfs2/mmap.c +++ b/fs/ocfs2/mmap.c | |||
| @@ -59,10 +59,11 @@ static int ocfs2_fault(struct vm_area_struct *area, struct vm_fault *vmf) | |||
| 59 | return ret; | 59 | return ret; |
| 60 | } | 60 | } |
| 61 | 61 | ||
| 62 | static int __ocfs2_page_mkwrite(struct inode *inode, struct buffer_head *di_bh, | 62 | static int __ocfs2_page_mkwrite(struct file *file, struct buffer_head *di_bh, |
| 63 | struct page *page) | 63 | struct page *page) |
| 64 | { | 64 | { |
| 65 | int ret; | 65 | int ret; |
| 66 | struct inode *inode = file->f_path.dentry->d_inode; | ||
| 66 | struct address_space *mapping = inode->i_mapping; | 67 | struct address_space *mapping = inode->i_mapping; |
| 67 | loff_t pos = page_offset(page); | 68 | loff_t pos = page_offset(page); |
| 68 | unsigned int len = PAGE_CACHE_SIZE; | 69 | unsigned int len = PAGE_CACHE_SIZE; |
| @@ -109,7 +110,7 @@ static int __ocfs2_page_mkwrite(struct inode *inode, struct buffer_head *di_bh, | |||
| 109 | if (page->index == last_index) | 110 | if (page->index == last_index) |
| 110 | len = size & ~PAGE_CACHE_MASK; | 111 | len = size & ~PAGE_CACHE_MASK; |
| 111 | 112 | ||
| 112 | ret = ocfs2_write_begin_nolock(mapping, pos, len, 0, &locked_page, | 113 | ret = ocfs2_write_begin_nolock(file, mapping, pos, len, 0, &locked_page, |
| 113 | &fsdata, di_bh, page); | 114 | &fsdata, di_bh, page); |
| 114 | if (ret) { | 115 | if (ret) { |
| 115 | if (ret != -ENOSPC) | 116 | if (ret != -ENOSPC) |
| @@ -157,7 +158,7 @@ static int ocfs2_page_mkwrite(struct vm_area_struct *vma, struct vm_fault *vmf) | |||
| 157 | */ | 158 | */ |
| 158 | down_write(&OCFS2_I(inode)->ip_alloc_sem); | 159 | down_write(&OCFS2_I(inode)->ip_alloc_sem); |
| 159 | 160 | ||
| 160 | ret = __ocfs2_page_mkwrite(inode, di_bh, page); | 161 | ret = __ocfs2_page_mkwrite(vma->vm_file, di_bh, page); |
| 161 | 162 | ||
| 162 | up_write(&OCFS2_I(inode)->ip_alloc_sem); | 163 | up_write(&OCFS2_I(inode)->ip_alloc_sem); |
| 163 | 164 | ||
