aboutsummaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
Diffstat (limited to 'mm')
-rw-r--r--mm/filemap.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/mm/filemap.c b/mm/filemap.c
index 380776c2a9ac..f9a29c87a2cf 100644
--- a/mm/filemap.c
+++ b/mm/filemap.c
@@ -1243,12 +1243,15 @@ generic_file_aio_read(struct kiocb *iocb, const struct iovec *iov,
1243 unsigned long seg = 0; 1243 unsigned long seg = 0;
1244 size_t count; 1244 size_t count;
1245 loff_t *ppos = &iocb->ki_pos; 1245 loff_t *ppos = &iocb->ki_pos;
1246 struct blk_plug plug;
1246 1247
1247 count = 0; 1248 count = 0;
1248 retval = generic_segment_checks(iov, &nr_segs, &count, VERIFY_WRITE); 1249 retval = generic_segment_checks(iov, &nr_segs, &count, VERIFY_WRITE);
1249 if (retval) 1250 if (retval)
1250 return retval; 1251 return retval;
1251 1252
1253 blk_start_plug(&plug);
1254
1252 /* coalesce the iovecs and go direct-to-BIO for O_DIRECT */ 1255 /* coalesce the iovecs and go direct-to-BIO for O_DIRECT */
1253 if (filp->f_flags & O_DIRECT) { 1256 if (filp->f_flags & O_DIRECT) {
1254 loff_t size; 1257 loff_t size;
@@ -1321,6 +1324,7 @@ generic_file_aio_read(struct kiocb *iocb, const struct iovec *iov,
1321 break; 1324 break;
1322 } 1325 }
1323out: 1326out:
1327 blk_finish_plug(&plug);
1324 return retval; 1328 return retval;
1325} 1329}
1326EXPORT_SYMBOL(generic_file_aio_read); 1330EXPORT_SYMBOL(generic_file_aio_read);
@@ -2432,11 +2436,13 @@ ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
2432{ 2436{
2433 struct file *file = iocb->ki_filp; 2437 struct file *file = iocb->ki_filp;
2434 struct inode *inode = file->f_mapping->host; 2438 struct inode *inode = file->f_mapping->host;
2439 struct blk_plug plug;
2435 ssize_t ret; 2440 ssize_t ret;
2436 2441
2437 BUG_ON(iocb->ki_pos != pos); 2442 BUG_ON(iocb->ki_pos != pos);
2438 2443
2439 mutex_lock(&inode->i_mutex); 2444 mutex_lock(&inode->i_mutex);
2445 blk_start_plug(&plug);
2440 ret = __generic_file_aio_write(iocb, iov, nr_segs, &iocb->ki_pos); 2446 ret = __generic_file_aio_write(iocb, iov, nr_segs, &iocb->ki_pos);
2441 mutex_unlock(&inode->i_mutex); 2447 mutex_unlock(&inode->i_mutex);
2442 2448
@@ -2447,6 +2453,7 @@ ssize_t generic_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
2447 if (err < 0 && ret > 0) 2453 if (err < 0 && ret > 0)
2448 ret = err; 2454 ret = err;
2449 } 2455 }
2456 blk_finish_plug(&plug);
2450 return ret; 2457 return ret;
2451} 2458}
2452EXPORT_SYMBOL(generic_file_aio_write); 2459EXPORT_SYMBOL(generic_file_aio_write);