aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/linux-2.6/xfs_buf.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/xfs/linux-2.6/xfs_buf.c')
-rw-r--r--fs/xfs/linux-2.6/xfs_buf.c24
1 files changed, 7 insertions, 17 deletions
diff --git a/fs/xfs/linux-2.6/xfs_buf.c b/fs/xfs/linux-2.6/xfs_buf.c
index 43128395d63b..489b7f63fd1f 100644
--- a/fs/xfs/linux-2.6/xfs_buf.c
+++ b/fs/xfs/linux-2.6/xfs_buf.c
@@ -458,14 +458,7 @@ _pagebuf_lookup_pages(
458 unlock_page(bp->pb_pages[i]); 458 unlock_page(bp->pb_pages[i]);
459 } 459 }
460 460
461 if (page_count) { 461 bp->pb_flags &= ~PBF_NONE;
462 /* if we have any uptodate pages, mark that in the buffer */
463 bp->pb_flags &= ~PBF_NONE;
464
465 /* if some pages aren't uptodate, mark that in the buffer */
466 if (page_count != bp->pb_page_count)
467 bp->pb_flags |= PBF_PARTIAL;
468 }
469 462
470 PB_TRACE(bp, "lookup_pages", (long)page_count); 463 PB_TRACE(bp, "lookup_pages", (long)page_count);
471 return error; 464 return error;
@@ -676,7 +669,7 @@ xfs_buf_read_flags(
676 669
677 pb = xfs_buf_get_flags(target, ioff, isize, flags); 670 pb = xfs_buf_get_flags(target, ioff, isize, flags);
678 if (pb) { 671 if (pb) {
679 if (PBF_NOT_DONE(pb)) { 672 if (!XFS_BUF_ISDONE(pb)) {
680 PB_TRACE(pb, "read", (unsigned long)flags); 673 PB_TRACE(pb, "read", (unsigned long)flags);
681 XFS_STATS_INC(pb_get_read); 674 XFS_STATS_INC(pb_get_read);
682 pagebuf_iostart(pb, flags); 675 pagebuf_iostart(pb, flags);
@@ -813,7 +806,7 @@ pagebuf_get_no_daddr(
813 bp = pagebuf_allocate(0); 806 bp = pagebuf_allocate(0);
814 if (unlikely(bp == NULL)) 807 if (unlikely(bp == NULL))
815 goto fail; 808 goto fail;
816 _pagebuf_initialize(bp, target, 0, len, PBF_FORCEIO); 809 _pagebuf_initialize(bp, target, 0, len, 0);
817 810
818 try_again: 811 try_again:
819 data = kmem_alloc(malloc_len, KM_SLEEP | KM_MAYFAIL); 812 data = kmem_alloc(malloc_len, KM_SLEEP | KM_MAYFAIL);
@@ -1121,21 +1114,18 @@ pagebuf_iodone_work(
1121void 1114void
1122pagebuf_iodone( 1115pagebuf_iodone(
1123 xfs_buf_t *pb, 1116 xfs_buf_t *pb,
1124 int dataio,
1125 int schedule) 1117 int schedule)
1126{ 1118{
1127 pb->pb_flags &= ~(PBF_READ | PBF_WRITE); 1119 pb->pb_flags &= ~(PBF_READ | PBF_WRITE);
1128 if (pb->pb_error == 0) { 1120 if (pb->pb_error == 0)
1129 pb->pb_flags &= ~(PBF_PARTIAL | PBF_NONE); 1121 pb->pb_flags &= ~PBF_NONE;
1130 }
1131 1122
1132 PB_TRACE(pb, "iodone", pb->pb_iodone); 1123 PB_TRACE(pb, "iodone", pb->pb_iodone);
1133 1124
1134 if ((pb->pb_iodone) || (pb->pb_flags & PBF_ASYNC)) { 1125 if ((pb->pb_iodone) || (pb->pb_flags & PBF_ASYNC)) {
1135 if (schedule) { 1126 if (schedule) {
1136 INIT_WORK(&pb->pb_iodone_work, pagebuf_iodone_work, pb); 1127 INIT_WORK(&pb->pb_iodone_work, pagebuf_iodone_work, pb);
1137 queue_work(dataio ? xfsdatad_workqueue : 1128 queue_work(xfslogd_workqueue, &pb->pb_iodone_work);
1138 xfslogd_workqueue, &pb->pb_iodone_work);
1139 } else { 1129 } else {
1140 pagebuf_iodone_work(pb); 1130 pagebuf_iodone_work(pb);
1141 } 1131 }
@@ -1235,7 +1225,7 @@ _pagebuf_iodone(
1235{ 1225{
1236 if (atomic_dec_and_test(&pb->pb_io_remaining) == 1) { 1226 if (atomic_dec_and_test(&pb->pb_io_remaining) == 1) {
1237 pb->pb_locked = 0; 1227 pb->pb_locked = 0;
1238 pagebuf_iodone(pb, (pb->pb_flags & PBF_FS_DATAIOD), schedule); 1228 pagebuf_iodone(pb, schedule);
1239 } 1229 }
1240} 1230}
1241 1231