xfs: Use iomap_dio_rw to wait for unaligned direct IO
authorJan Kara <jack@suse.cz>
Tue, 15 Oct 2019 15:43:43 +0000 (08:43 -0700)
committerDarrick J. Wong <darrick.wong@oracle.com>
Tue, 15 Oct 2019 15:43:43 +0000 (08:43 -0700)
Use iomap_dio_rw() to wait for unaligned direct IO instead of opencoding
the wait.

Signed-off-by: Jan Kara <jack@suse.cz>
Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
fs/xfs/xfs_file.c

index 0739ba7..c062013 100644 (file)
@@ -547,16 +547,12 @@ xfs_file_dio_aio_write(
        }
 
        trace_xfs_file_direct_write(ip, count, iocb->ki_pos);
-       ret = iomap_dio_rw(iocb, from, &xfs_iomap_ops, &xfs_dio_write_ops,
-                          is_sync_kiocb(iocb));
-
        /*
-        * If unaligned, this is the only IO in-flight. If it has not yet
-        * completed, wait on it before we release the iolock to prevent
-        * subsequent overlapping IO.
+        * If unaligned, this is the only IO in-flight. Wait on it before we
+        * release the iolock to prevent subsequent overlapping IO.
         */
-       if (ret == -EIOCBQUEUED && unaligned_io)
-               inode_dio_wait(inode);
+       ret = iomap_dio_rw(iocb, from, &xfs_iomap_ops, &xfs_dio_write_ops,
+                          is_sync_kiocb(iocb) || unaligned_io);
 out:
        xfs_iunlock(ip, iolock);