diff options
Diffstat (limited to 'fs/xfs/linux-2.6/xfs_lrw.c')
-rw-r--r-- | fs/xfs/linux-2.6/xfs_lrw.c | 31 |
1 files changed, 13 insertions, 18 deletions
diff --git a/fs/xfs/linux-2.6/xfs_lrw.c b/fs/xfs/linux-2.6/xfs_lrw.c index 166353388490..3c20007ab48f 100644 --- a/fs/xfs/linux-2.6/xfs_lrw.c +++ b/fs/xfs/linux-2.6/xfs_lrw.c | |||
@@ -228,11 +228,11 @@ xfs_read( | |||
228 | xfs_ilock(ip, XFS_IOLOCK_SHARED); | 228 | xfs_ilock(ip, XFS_IOLOCK_SHARED); |
229 | 229 | ||
230 | if (DM_EVENT_ENABLED(ip, DM_EVENT_READ) && !(ioflags & IO_INVIS)) { | 230 | if (DM_EVENT_ENABLED(ip, DM_EVENT_READ) && !(ioflags & IO_INVIS)) { |
231 | bhv_vrwlock_t locktype = VRWLOCK_READ; | ||
232 | int dmflags = FILP_DELAY_FLAG(file) | DM_SEM_FLAG_RD(ioflags); | 231 | int dmflags = FILP_DELAY_FLAG(file) | DM_SEM_FLAG_RD(ioflags); |
232 | int iolock = XFS_IOLOCK_SHARED; | ||
233 | 233 | ||
234 | ret = -XFS_SEND_DATA(mp, DM_EVENT_READ, vp, *offset, size, | 234 | ret = -XFS_SEND_DATA(mp, DM_EVENT_READ, vp, *offset, size, |
235 | dmflags, &locktype); | 235 | dmflags, &iolock); |
236 | if (ret) { | 236 | if (ret) { |
237 | xfs_iunlock(ip, XFS_IOLOCK_SHARED); | 237 | xfs_iunlock(ip, XFS_IOLOCK_SHARED); |
238 | if (unlikely(ioflags & IO_ISDIRECT)) | 238 | if (unlikely(ioflags & IO_ISDIRECT)) |
@@ -287,11 +287,11 @@ xfs_splice_read( | |||
287 | xfs_ilock(ip, XFS_IOLOCK_SHARED); | 287 | xfs_ilock(ip, XFS_IOLOCK_SHARED); |
288 | 288 | ||
289 | if (DM_EVENT_ENABLED(ip, DM_EVENT_READ) && !(ioflags & IO_INVIS)) { | 289 | if (DM_EVENT_ENABLED(ip, DM_EVENT_READ) && !(ioflags & IO_INVIS)) { |
290 | bhv_vrwlock_t locktype = VRWLOCK_READ; | 290 | int iolock = XFS_IOLOCK_SHARED; |
291 | int error; | 291 | int error; |
292 | 292 | ||
293 | error = XFS_SEND_DATA(mp, DM_EVENT_READ, vp, *ppos, count, | 293 | error = XFS_SEND_DATA(mp, DM_EVENT_READ, vp, *ppos, count, |
294 | FILP_DELAY_FLAG(infilp), &locktype); | 294 | FILP_DELAY_FLAG(infilp), &iolock); |
295 | if (error) { | 295 | if (error) { |
296 | xfs_iunlock(ip, XFS_IOLOCK_SHARED); | 296 | xfs_iunlock(ip, XFS_IOLOCK_SHARED); |
297 | return -error; | 297 | return -error; |
@@ -330,11 +330,11 @@ xfs_splice_write( | |||
330 | xfs_ilock(ip, XFS_IOLOCK_EXCL); | 330 | xfs_ilock(ip, XFS_IOLOCK_EXCL); |
331 | 331 | ||
332 | if (DM_EVENT_ENABLED(ip, DM_EVENT_WRITE) && !(ioflags & IO_INVIS)) { | 332 | if (DM_EVENT_ENABLED(ip, DM_EVENT_WRITE) && !(ioflags & IO_INVIS)) { |
333 | bhv_vrwlock_t locktype = VRWLOCK_WRITE; | 333 | int iolock = XFS_IOLOCK_EXCL; |
334 | int error; | 334 | int error; |
335 | 335 | ||
336 | error = XFS_SEND_DATA(mp, DM_EVENT_WRITE, vp, *ppos, count, | 336 | error = XFS_SEND_DATA(mp, DM_EVENT_WRITE, vp, *ppos, count, |
337 | FILP_DELAY_FLAG(outfilp), &locktype); | 337 | FILP_DELAY_FLAG(outfilp), &iolock); |
338 | if (error) { | 338 | if (error) { |
339 | xfs_iunlock(ip, XFS_IOLOCK_EXCL); | 339 | xfs_iunlock(ip, XFS_IOLOCK_EXCL); |
340 | return -error; | 340 | return -error; |
@@ -580,7 +580,6 @@ xfs_write( | |||
580 | xfs_fsize_t isize, new_size; | 580 | xfs_fsize_t isize, new_size; |
581 | int iolock; | 581 | int iolock; |
582 | int eventsent = 0; | 582 | int eventsent = 0; |
583 | bhv_vrwlock_t locktype; | ||
584 | size_t ocount = 0, count; | 583 | size_t ocount = 0, count; |
585 | loff_t pos; | 584 | loff_t pos; |
586 | int need_i_mutex; | 585 | int need_i_mutex; |
@@ -607,11 +606,9 @@ xfs_write( | |||
607 | relock: | 606 | relock: |
608 | if (ioflags & IO_ISDIRECT) { | 607 | if (ioflags & IO_ISDIRECT) { |
609 | iolock = XFS_IOLOCK_SHARED; | 608 | iolock = XFS_IOLOCK_SHARED; |
610 | locktype = VRWLOCK_WRITE_DIRECT; | ||
611 | need_i_mutex = 0; | 609 | need_i_mutex = 0; |
612 | } else { | 610 | } else { |
613 | iolock = XFS_IOLOCK_EXCL; | 611 | iolock = XFS_IOLOCK_EXCL; |
614 | locktype = VRWLOCK_WRITE; | ||
615 | need_i_mutex = 1; | 612 | need_i_mutex = 1; |
616 | mutex_lock(&inode->i_mutex); | 613 | mutex_lock(&inode->i_mutex); |
617 | } | 614 | } |
@@ -635,8 +632,7 @@ start: | |||
635 | 632 | ||
636 | xfs_iunlock(xip, XFS_ILOCK_EXCL); | 633 | xfs_iunlock(xip, XFS_ILOCK_EXCL); |
637 | error = XFS_SEND_DATA(xip->i_mount, DM_EVENT_WRITE, vp, | 634 | error = XFS_SEND_DATA(xip->i_mount, DM_EVENT_WRITE, vp, |
638 | pos, count, | 635 | pos, count, dmflags, &iolock); |
639 | dmflags, &locktype); | ||
640 | if (error) { | 636 | if (error) { |
641 | goto out_unlock_internal; | 637 | goto out_unlock_internal; |
642 | } | 638 | } |
@@ -667,7 +663,6 @@ start: | |||
667 | if (!need_i_mutex && (VN_CACHED(vp) || pos > xip->i_size)) { | 663 | if (!need_i_mutex && (VN_CACHED(vp) || pos > xip->i_size)) { |
668 | xfs_iunlock(xip, XFS_ILOCK_EXCL|iolock); | 664 | xfs_iunlock(xip, XFS_ILOCK_EXCL|iolock); |
669 | iolock = XFS_IOLOCK_EXCL; | 665 | iolock = XFS_IOLOCK_EXCL; |
670 | locktype = VRWLOCK_WRITE; | ||
671 | need_i_mutex = 1; | 666 | need_i_mutex = 1; |
672 | mutex_lock(&inode->i_mutex); | 667 | mutex_lock(&inode->i_mutex); |
673 | xfs_ilock(xip, XFS_ILOCK_EXCL|iolock); | 668 | xfs_ilock(xip, XFS_ILOCK_EXCL|iolock); |
@@ -744,7 +739,6 @@ retry: | |||
744 | mutex_unlock(&inode->i_mutex); | 739 | mutex_unlock(&inode->i_mutex); |
745 | 740 | ||
746 | iolock = XFS_IOLOCK_SHARED; | 741 | iolock = XFS_IOLOCK_SHARED; |
747 | locktype = VRWLOCK_WRITE_DIRECT; | ||
748 | need_i_mutex = 0; | 742 | need_i_mutex = 0; |
749 | } | 743 | } |
750 | 744 | ||
@@ -781,7 +775,7 @@ retry: | |||
781 | 775 | ||
782 | if (ret == -ENOSPC && | 776 | if (ret == -ENOSPC && |
783 | DM_EVENT_ENABLED(xip, DM_EVENT_NOSPACE) && !(ioflags & IO_INVIS)) { | 777 | DM_EVENT_ENABLED(xip, DM_EVENT_NOSPACE) && !(ioflags & IO_INVIS)) { |
784 | xfs_rwunlock(xip, locktype); | 778 | xfs_iunlock(xip, iolock); |
785 | if (need_i_mutex) | 779 | if (need_i_mutex) |
786 | mutex_unlock(&inode->i_mutex); | 780 | mutex_unlock(&inode->i_mutex); |
787 | error = XFS_SEND_NAMESP(xip->i_mount, DM_EVENT_NOSPACE, vp, | 781 | error = XFS_SEND_NAMESP(xip->i_mount, DM_EVENT_NOSPACE, vp, |
@@ -789,7 +783,7 @@ retry: | |||
789 | 0, 0, 0); /* Delay flag intentionally unused */ | 783 | 0, 0, 0); /* Delay flag intentionally unused */ |
790 | if (need_i_mutex) | 784 | if (need_i_mutex) |
791 | mutex_lock(&inode->i_mutex); | 785 | mutex_lock(&inode->i_mutex); |
792 | xfs_rwlock(xip, locktype); | 786 | xfs_ilock(xip, iolock); |
793 | if (error) | 787 | if (error) |
794 | goto out_unlock_internal; | 788 | goto out_unlock_internal; |
795 | pos = xip->i_size; | 789 | pos = xip->i_size; |
@@ -817,7 +811,8 @@ retry: | |||
817 | /* Handle various SYNC-type writes */ | 811 | /* Handle various SYNC-type writes */ |
818 | if ((file->f_flags & O_SYNC) || IS_SYNC(inode)) { | 812 | if ((file->f_flags & O_SYNC) || IS_SYNC(inode)) { |
819 | int error2; | 813 | int error2; |
820 | xfs_rwunlock(xip, locktype); | 814 | |
815 | xfs_iunlock(xip, iolock); | ||
821 | if (need_i_mutex) | 816 | if (need_i_mutex) |
822 | mutex_unlock(&inode->i_mutex); | 817 | mutex_unlock(&inode->i_mutex); |
823 | error2 = sync_page_range(inode, mapping, pos, ret); | 818 | error2 = sync_page_range(inode, mapping, pos, ret); |
@@ -825,7 +820,7 @@ retry: | |||
825 | error = error2; | 820 | error = error2; |
826 | if (need_i_mutex) | 821 | if (need_i_mutex) |
827 | mutex_lock(&inode->i_mutex); | 822 | mutex_lock(&inode->i_mutex); |
828 | xfs_rwlock(xip, locktype); | 823 | xfs_ilock(xip, iolock); |
829 | error2 = xfs_write_sync_logforce(mp, xip); | 824 | error2 = xfs_write_sync_logforce(mp, xip); |
830 | if (!error) | 825 | if (!error) |
831 | error = error2; | 826 | error = error2; |
@@ -846,7 +841,7 @@ retry: | |||
846 | xip->i_d.di_size = xip->i_size; | 841 | xip->i_d.di_size = xip->i_size; |
847 | xfs_iunlock(xip, XFS_ILOCK_EXCL); | 842 | xfs_iunlock(xip, XFS_ILOCK_EXCL); |
848 | } | 843 | } |
849 | xfs_rwunlock(xip, locktype); | 844 | xfs_iunlock(xip, iolock); |
850 | out_unlock_mutex: | 845 | out_unlock_mutex: |
851 | if (need_i_mutex) | 846 | if (need_i_mutex) |
852 | mutex_unlock(&inode->i_mutex); | 847 | mutex_unlock(&inode->i_mutex); |