diff options
Diffstat (limited to 'fs/ext2/inode.c')
| -rw-r--r-- | fs/ext2/inode.c | 20 | 
1 files changed, 10 insertions, 10 deletions
| diff --git a/fs/ext2/inode.c b/fs/ext2/inode.c index 6bd58e6ff038..fcbe58641e40 100644 --- a/fs/ext2/inode.c +++ b/fs/ext2/inode.c @@ -26,6 +26,7 @@  #include <linux/highuid.h>  #include <linux/pagemap.h>  #include <linux/dax.h> +#include <linux/blkdev.h>  #include <linux/quotaops.h>  #include <linux/writeback.h>  #include <linux/buffer_head.h> @@ -737,19 +738,18 @@ static int ext2_get_blocks(struct inode *inode,  		 * so that it's not found by another thread before it's  		 * initialised  		 */ -		err = dax_clear_sectors(inode->i_sb->s_bdev, -				le32_to_cpu(chain[depth-1].key) << -				(inode->i_blkbits - 9), -				1 << inode->i_blkbits); +		err = sb_issue_zeroout(inode->i_sb, +				le32_to_cpu(chain[depth-1].key), count, +				GFP_NOFS);  		if (err) {  			mutex_unlock(&ei->truncate_mutex);  			goto cleanup;  		} -	} +	} else +		set_buffer_new(bh_result);  	ext2_splice_branch(inode, iblock, partial, indirect_blks, count);  	mutex_unlock(&ei->truncate_mutex); -	set_buffer_new(bh_result);  got_it:  	map_bh(bh_result, inode->i_sb, le32_to_cpu(chain[depth-1].key));  	if (count > blocks_to_boundary) @@ -854,20 +854,20 @@ static sector_t ext2_bmap(struct address_space *mapping, sector_t block)  }  static ssize_t -ext2_direct_IO(struct kiocb *iocb, struct iov_iter *iter, loff_t offset) +ext2_direct_IO(struct kiocb *iocb, struct iov_iter *iter)  {  	struct file *file = iocb->ki_filp;  	struct address_space *mapping = file->f_mapping;  	struct inode *inode = mapping->host;  	size_t count = iov_iter_count(iter); +	loff_t offset = iocb->ki_pos;  	ssize_t ret;  	if (IS_DAX(inode)) -		ret = dax_do_io(iocb, inode, iter, offset, ext2_get_block, NULL, +		ret = dax_do_io(iocb, inode, iter, ext2_get_block, NULL,  				DIO_LOCKING);  	else -		ret = blockdev_direct_IO(iocb, inode, iter, offset, -					 ext2_get_block); +		ret = blockdev_direct_IO(iocb, inode, iter, ext2_get_block);  	if (ret < 0 && iov_iter_rw(iter) == WRITE)  		ext2_write_failed(mapping, offset + count);  	return ret; | 
