aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/xfs_buf.c
diff options
context:
space:
mode:
authorDave Chinner <dchinner@redhat.com>2012-06-22 04:50:08 -0400
committerBen Myers <bpm@sgi.com>2012-07-01 15:50:04 -0400
commitcbb7baab285a540f173ef1ec3d5bcf9d0ad29d16 (patch)
tree33b570bfdf1a9e50482968823b05dd7c99b1e665 /fs/xfs/xfs_buf.c
parent77c1a08fc9ece4cb130b9fd279738e799f0c2864 (diff)
xfs: separate buffer indexing from block map
To support discontiguous buffers in the buffer cache, we need to separate the cache index variables from the I/O map. While this is currently a 1:1 mapping, discontiguous buffer support will break this relationship. However, for caching purposes, we can still treat them the same as a contiguous buffer - the block number of the first block and the length of the buffer - as that is still a unique representation. Also, the only way we will ever access the discontiguous regions of buffers is via bulding the complete buffer in the first place, so using the initial block number and entire buffer length is a sane way to index the buffers. Add a block mapping vector construct to the xfs_buf and use it in the places where we are doing IO instead of the current b_bn/b_length variables. Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Ben Myers <bpm@sgi.com>
Diffstat (limited to 'fs/xfs/xfs_buf.c')
-rw-r--r--fs/xfs/xfs_buf.c21
1 files changed, 12 insertions, 9 deletions
diff --git a/fs/xfs/xfs_buf.c b/fs/xfs/xfs_buf.c
index a4beb421018a..a843873b0954 100644
--- a/fs/xfs/xfs_buf.c
+++ b/fs/xfs/xfs_buf.c
@@ -202,6 +202,8 @@ xfs_buf_alloc(
202 bp->b_io_length = numblks; 202 bp->b_io_length = numblks;
203 bp->b_flags = flags; 203 bp->b_flags = flags;
204 bp->b_bn = blkno; 204 bp->b_bn = blkno;
205 bp->b_map.bm_bn = blkno;
206 bp->b_map.bm_len = numblks;
205 atomic_set(&bp->b_pin_count, 0); 207 atomic_set(&bp->b_pin_count, 0);
206 init_waitqueue_head(&bp->b_waiters); 208 init_waitqueue_head(&bp->b_waiters);
207 209
@@ -327,8 +329,9 @@ xfs_buf_allocate_memory(
327 } 329 }
328 330
329use_alloc_page: 331use_alloc_page:
330 start = BBTOB(bp->b_bn) >> PAGE_SHIFT; 332 start = BBTOB(bp->b_map.bm_bn) >> PAGE_SHIFT;
331 end = (BBTOB(bp->b_bn + bp->b_length) + PAGE_SIZE - 1) >> PAGE_SHIFT; 333 end = (BBTOB(bp->b_map.bm_bn + bp->b_length) + PAGE_SIZE - 1)
334 >> PAGE_SHIFT;
332 page_count = end - start; 335 page_count = end - start;
333 error = _xfs_buf_get_pages(bp, page_count, flags); 336 error = _xfs_buf_get_pages(bp, page_count, flags);
334 if (unlikely(error)) 337 if (unlikely(error))
@@ -560,8 +563,6 @@ xfs_buf_get(
560 if (bp != new_bp) 563 if (bp != new_bp)
561 xfs_buf_free(new_bp); 564 xfs_buf_free(new_bp);
562 565
563 bp->b_io_length = bp->b_length;
564
565found: 566found:
566 if (!bp->b_addr) { 567 if (!bp->b_addr) {
567 error = _xfs_buf_map_pages(bp, flags); 568 error = _xfs_buf_map_pages(bp, flags);
@@ -584,7 +585,7 @@ _xfs_buf_read(
584 xfs_buf_flags_t flags) 585 xfs_buf_flags_t flags)
585{ 586{
586 ASSERT(!(flags & XBF_WRITE)); 587 ASSERT(!(flags & XBF_WRITE));
587 ASSERT(bp->b_bn != XFS_BUF_DADDR_NULL); 588 ASSERT(bp->b_map.bm_bn != XFS_BUF_DADDR_NULL);
588 589
589 bp->b_flags &= ~(XBF_WRITE | XBF_ASYNC | XBF_READ_AHEAD); 590 bp->b_flags &= ~(XBF_WRITE | XBF_ASYNC | XBF_READ_AHEAD);
590 bp->b_flags |= flags & (XBF_READ | XBF_ASYNC | XBF_READ_AHEAD); 591 bp->b_flags |= flags & (XBF_READ | XBF_ASYNC | XBF_READ_AHEAD);
@@ -665,8 +666,8 @@ xfs_buf_read_uncached(
665 return NULL; 666 return NULL;
666 667
667 /* set up the buffer for a read IO */ 668 /* set up the buffer for a read IO */
668 XFS_BUF_SET_ADDR(bp, daddr); 669 bp->b_map.bm_bn = daddr;
669 XFS_BUF_READ(bp); 670 bp->b_flags |= XBF_READ;
670 671
671 xfsbdstrat(target->bt_mount, bp); 672 xfsbdstrat(target->bt_mount, bp);
672 error = xfs_buf_iowait(bp); 673 error = xfs_buf_iowait(bp);
@@ -695,6 +696,8 @@ xfs_buf_set_empty(
695 bp->b_length = numblks; 696 bp->b_length = numblks;
696 bp->b_io_length = numblks; 697 bp->b_io_length = numblks;
697 bp->b_bn = XFS_BUF_DADDR_NULL; 698 bp->b_bn = XFS_BUF_DADDR_NULL;
699 bp->b_map.bm_bn = XFS_BUF_DADDR_NULL;
700 bp->b_map.bm_len = bp->b_length;
698} 701}
699 702
700static inline struct page * 703static inline struct page *
@@ -1159,7 +1162,7 @@ _xfs_buf_ioapply(
1159 struct bio *bio; 1162 struct bio *bio;
1160 int offset = bp->b_offset; 1163 int offset = bp->b_offset;
1161 int size = BBTOB(bp->b_io_length); 1164 int size = BBTOB(bp->b_io_length);
1162 sector_t sector = bp->b_bn; 1165 sector_t sector = bp->b_map.bm_bn;
1163 1166
1164 total_nr_pages = bp->b_page_count; 1167 total_nr_pages = bp->b_page_count;
1165 map_i = 0; 1168 map_i = 0;
@@ -1564,7 +1567,7 @@ xfs_buf_cmp(
1564 struct xfs_buf *bp = container_of(b, struct xfs_buf, b_list); 1567 struct xfs_buf *bp = container_of(b, struct xfs_buf, b_list);
1565 xfs_daddr_t diff; 1568 xfs_daddr_t diff;
1566 1569
1567 diff = ap->b_bn - bp->b_bn; 1570 diff = ap->b_map.bm_bn - bp->b_map.bm_bn;
1568 if (diff < 0) 1571 if (diff < 0)
1569 return -1; 1572 return -1;
1570 if (diff > 0) 1573 if (diff > 0)