Fixes for loopback files in btrfs
Signed-off-by: Chris Mason <chris.mason@oracle.com>
This commit is contained in:
parent
6e3b96668e
commit
e9906a9849
@ -861,6 +861,7 @@ struct file_operations btrfs_file_operations = {
|
|||||||
.llseek = generic_file_llseek,
|
.llseek = generic_file_llseek,
|
||||||
.read = do_sync_read,
|
.read = do_sync_read,
|
||||||
.aio_read = generic_file_aio_read,
|
.aio_read = generic_file_aio_read,
|
||||||
|
.splice_read = generic_file_splice_read,
|
||||||
.write = btrfs_file_write,
|
.write = btrfs_file_write,
|
||||||
.mmap = btrfs_file_mmap,
|
.mmap = btrfs_file_mmap,
|
||||||
.open = generic_file_open,
|
.open = generic_file_open,
|
||||||
|
@ -1893,8 +1893,19 @@ static void btrfs_truncate(struct inode *inode)
|
|||||||
int btrfs_commit_write(struct file *file, struct page *page,
|
int btrfs_commit_write(struct file *file, struct page *page,
|
||||||
unsigned from, unsigned to)
|
unsigned from, unsigned to)
|
||||||
{
|
{
|
||||||
return extent_commit_write(&BTRFS_I(page->mapping->host)->extent_tree,
|
loff_t pos = ((loff_t)page->index << PAGE_CACHE_SHIFT) + to;
|
||||||
page->mapping->host, page, from, to);
|
struct inode *inode = page->mapping->host;
|
||||||
|
|
||||||
|
btrfs_cow_one_page(inode, page, PAGE_CACHE_SIZE);
|
||||||
|
|
||||||
|
set_page_extent_mapped(page);
|
||||||
|
set_page_dirty(page);
|
||||||
|
|
||||||
|
if (pos > inode->i_size) {
|
||||||
|
i_size_write(inode, pos);
|
||||||
|
mark_inode_dirty(inode);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int create_subvol(struct btrfs_root *root, char *name, int namelen)
|
static int create_subvol(struct btrfs_root *root, char *name, int namelen)
|
||||||
|
Loading…
Reference in New Issue
Block a user