Loading fs/hfsplus/inode.c +16 −11 Original line number Original line Diff line number Diff line Loading @@ -28,6 +28,16 @@ static int hfsplus_writepage(struct page *page, struct writeback_control *wbc) return block_write_full_page(page, hfsplus_get_block, wbc); return block_write_full_page(page, hfsplus_get_block, wbc); } } static void hfsplus_write_failed(struct address_space *mapping, loff_t to) { struct inode *inode = mapping->host; if (to > inode->i_size) { truncate_pagecache(inode, to, inode->i_size); hfsplus_file_truncate(inode); } } static int hfsplus_write_begin(struct file *file, struct address_space *mapping, static int hfsplus_write_begin(struct file *file, struct address_space *mapping, loff_t pos, unsigned len, unsigned flags, loff_t pos, unsigned len, unsigned flags, struct page **pagep, void **fsdata) struct page **pagep, void **fsdata) Loading @@ -38,11 +48,8 @@ static int hfsplus_write_begin(struct file *file, struct address_space *mapping, ret = cont_write_begin(file, mapping, pos, len, flags, pagep, fsdata, ret = cont_write_begin(file, mapping, pos, len, flags, pagep, fsdata, hfsplus_get_block, hfsplus_get_block, &HFSPLUS_I(mapping->host)->phys_size); &HFSPLUS_I(mapping->host)->phys_size); if (unlikely(ret)) { if (unlikely(ret)) loff_t isize = mapping->host->i_size; hfsplus_write_failed(mapping, pos + len); if (pos + len > isize) vmtruncate(mapping->host, isize); } return ret; return ret; } } Loading Loading @@ -116,6 +123,7 @@ static ssize_t hfsplus_direct_IO(int rw, struct kiocb *iocb, const struct iovec *iov, loff_t offset, unsigned long nr_segs) const struct iovec *iov, loff_t offset, unsigned long nr_segs) { { struct file *file = iocb->ki_filp; struct file *file = iocb->ki_filp; struct address_space *mapping = file->f_mapping; struct inode *inode = file->f_path.dentry->d_inode->i_mapping->host; struct inode *inode = file->f_path.dentry->d_inode->i_mapping->host; ssize_t ret; ssize_t ret; Loading @@ -131,7 +139,7 @@ static ssize_t hfsplus_direct_IO(int rw, struct kiocb *iocb, loff_t end = offset + iov_length(iov, nr_segs); loff_t end = offset + iov_length(iov, nr_segs); if (end > isize) if (end > isize) vmtruncate(inode, isize); hfsplus_write_failed(mapping, end); } } return ret; return ret; Loading Loading @@ -300,10 +308,8 @@ static int hfsplus_setattr(struct dentry *dentry, struct iattr *attr) if ((attr->ia_valid & ATTR_SIZE) && if ((attr->ia_valid & ATTR_SIZE) && attr->ia_size != i_size_read(inode)) { attr->ia_size != i_size_read(inode)) { inode_dio_wait(inode); inode_dio_wait(inode); truncate_setsize(inode, attr->ia_size); error = vmtruncate(inode, attr->ia_size); hfsplus_file_truncate(inode); if (error) return error; } } setattr_copy(inode, attr); setattr_copy(inode, attr); Loading Loading @@ -358,7 +364,6 @@ int hfsplus_file_fsync(struct file *file, loff_t start, loff_t end, static const struct inode_operations hfsplus_file_inode_operations = { static const struct inode_operations hfsplus_file_inode_operations = { .lookup = hfsplus_file_lookup, .lookup = hfsplus_file_lookup, .truncate = hfsplus_file_truncate, .setattr = hfsplus_setattr, .setattr = hfsplus_setattr, .setxattr = hfsplus_setxattr, .setxattr = hfsplus_setxattr, .getxattr = hfsplus_getxattr, .getxattr = hfsplus_getxattr, Loading Loading
fs/hfsplus/inode.c +16 −11 Original line number Original line Diff line number Diff line Loading @@ -28,6 +28,16 @@ static int hfsplus_writepage(struct page *page, struct writeback_control *wbc) return block_write_full_page(page, hfsplus_get_block, wbc); return block_write_full_page(page, hfsplus_get_block, wbc); } } static void hfsplus_write_failed(struct address_space *mapping, loff_t to) { struct inode *inode = mapping->host; if (to > inode->i_size) { truncate_pagecache(inode, to, inode->i_size); hfsplus_file_truncate(inode); } } static int hfsplus_write_begin(struct file *file, struct address_space *mapping, static int hfsplus_write_begin(struct file *file, struct address_space *mapping, loff_t pos, unsigned len, unsigned flags, loff_t pos, unsigned len, unsigned flags, struct page **pagep, void **fsdata) struct page **pagep, void **fsdata) Loading @@ -38,11 +48,8 @@ static int hfsplus_write_begin(struct file *file, struct address_space *mapping, ret = cont_write_begin(file, mapping, pos, len, flags, pagep, fsdata, ret = cont_write_begin(file, mapping, pos, len, flags, pagep, fsdata, hfsplus_get_block, hfsplus_get_block, &HFSPLUS_I(mapping->host)->phys_size); &HFSPLUS_I(mapping->host)->phys_size); if (unlikely(ret)) { if (unlikely(ret)) loff_t isize = mapping->host->i_size; hfsplus_write_failed(mapping, pos + len); if (pos + len > isize) vmtruncate(mapping->host, isize); } return ret; return ret; } } Loading Loading @@ -116,6 +123,7 @@ static ssize_t hfsplus_direct_IO(int rw, struct kiocb *iocb, const struct iovec *iov, loff_t offset, unsigned long nr_segs) const struct iovec *iov, loff_t offset, unsigned long nr_segs) { { struct file *file = iocb->ki_filp; struct file *file = iocb->ki_filp; struct address_space *mapping = file->f_mapping; struct inode *inode = file->f_path.dentry->d_inode->i_mapping->host; struct inode *inode = file->f_path.dentry->d_inode->i_mapping->host; ssize_t ret; ssize_t ret; Loading @@ -131,7 +139,7 @@ static ssize_t hfsplus_direct_IO(int rw, struct kiocb *iocb, loff_t end = offset + iov_length(iov, nr_segs); loff_t end = offset + iov_length(iov, nr_segs); if (end > isize) if (end > isize) vmtruncate(inode, isize); hfsplus_write_failed(mapping, end); } } return ret; return ret; Loading Loading @@ -300,10 +308,8 @@ static int hfsplus_setattr(struct dentry *dentry, struct iattr *attr) if ((attr->ia_valid & ATTR_SIZE) && if ((attr->ia_valid & ATTR_SIZE) && attr->ia_size != i_size_read(inode)) { attr->ia_size != i_size_read(inode)) { inode_dio_wait(inode); inode_dio_wait(inode); truncate_setsize(inode, attr->ia_size); error = vmtruncate(inode, attr->ia_size); hfsplus_file_truncate(inode); if (error) return error; } } setattr_copy(inode, attr); setattr_copy(inode, attr); Loading Loading @@ -358,7 +364,6 @@ int hfsplus_file_fsync(struct file *file, loff_t start, loff_t end, static const struct inode_operations hfsplus_file_inode_operations = { static const struct inode_operations hfsplus_file_inode_operations = { .lookup = hfsplus_file_lookup, .lookup = hfsplus_file_lookup, .truncate = hfsplus_file_truncate, .setattr = hfsplus_setattr, .setattr = hfsplus_setattr, .setxattr = hfsplus_setxattr, .setxattr = hfsplus_setxattr, .getxattr = hfsplus_getxattr, .getxattr = hfsplus_getxattr, Loading