aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs
diff options
context:
space:
mode:
Diffstat (limited to 'fs/xfs')
-rw-r--r--fs/xfs/xfs_bmap.c56
-rw-r--r--fs/xfs/xfs_bmap.h2
2 files changed, 28 insertions, 30 deletions
diff --git a/fs/xfs/xfs_bmap.c b/fs/xfs/xfs_bmap.c
index 6a7832d3540e..a54326bf9aa0 100644
--- a/fs/xfs/xfs_bmap.c
+++ b/fs/xfs/xfs_bmap.c
@@ -4608,7 +4608,6 @@ STATIC int
4608xfs_bmapi_allocate( 4608xfs_bmapi_allocate(
4609 struct xfs_bmalloca *bma, 4609 struct xfs_bmalloca *bma,
4610 xfs_extnum_t *lastx, 4610 xfs_extnum_t *lastx,
4611 struct xfs_btree_cur **cur,
4612 int flags, 4611 int flags,
4613 int *nallocs, 4612 int *nallocs,
4614 int *logflags) 4613 int *logflags)
@@ -4668,14 +4667,14 @@ xfs_bmapi_allocate(
4668 4667
4669 if (bma->flist->xbf_low) 4668 if (bma->flist->xbf_low)
4670 bma->minleft = 0; 4669 bma->minleft = 0;
4671 if (*cur) 4670 if (bma->cur)
4672 (*cur)->bc_private.b.firstblock = *bma->firstblock; 4671 bma->cur->bc_private.b.firstblock = *bma->firstblock;
4673 if (bma->blkno == NULLFSBLOCK) 4672 if (bma->blkno == NULLFSBLOCK)
4674 return 0; 4673 return 0;
4675 if ((ifp->if_flags & XFS_IFBROOT) && !*cur) { 4674 if ((ifp->if_flags & XFS_IFBROOT) && !bma->cur) {
4676 (*cur) = xfs_bmbt_init_cursor(mp, bma->tp, bma->ip, whichfork); 4675 bma->cur = xfs_bmbt_init_cursor(mp, bma->tp, bma->ip, whichfork);
4677 (*cur)->bc_private.b.firstblock = *bma->firstblock; 4676 bma->cur->bc_private.b.firstblock = *bma->firstblock;
4678 (*cur)->bc_private.b.flist = bma->flist; 4677 bma->cur->bc_private.b.flist = bma->flist;
4679 } 4678 }
4680 /* 4679 /*
4681 * Bump the number of extents we've allocated 4680 * Bump the number of extents we've allocated
@@ -4683,8 +4682,8 @@ xfs_bmapi_allocate(
4683 */ 4682 */
4684 (*nallocs)++; 4683 (*nallocs)++;
4685 4684
4686 if (*cur) 4685 if (bma->cur)
4687 (*cur)->bc_private.b.flags = 4686 bma->cur->bc_private.b.flags =
4688 bma->wasdel ? XFS_BTCUR_BPRV_WASDEL : 0; 4687 bma->wasdel ? XFS_BTCUR_BPRV_WASDEL : 0;
4689 4688
4690 bma->got.br_startoff = bma->offset; 4689 bma->got.br_startoff = bma->offset;
@@ -4702,12 +4701,12 @@ xfs_bmapi_allocate(
4702 4701
4703 if (bma->wasdel) { 4702 if (bma->wasdel) {
4704 error = xfs_bmap_add_extent_delay_real(bma->tp, bma->ip, lastx, 4703 error = xfs_bmap_add_extent_delay_real(bma->tp, bma->ip, lastx,
4705 cur, &bma->got, bma->firstblock, bma->flist, 4704 &bma->cur, &bma->got, bma->firstblock,
4706 logflags); 4705 bma->flist, logflags);
4707 } else { 4706 } else {
4708 error = xfs_bmap_add_extent_hole_real(bma->tp, bma->ip, lastx, 4707 error = xfs_bmap_add_extent_hole_real(bma->tp, bma->ip, lastx,
4709 cur, &bma->got, bma->firstblock, bma->flist, 4708 &bma->cur, &bma->got, bma->firstblock,
4710 logflags, whichfork); 4709 bma->flist, logflags, whichfork);
4711 } 4710 }
4712 4711
4713 if (error) 4712 if (error)
@@ -4734,7 +4733,6 @@ xfs_bmapi_convert_unwritten(
4734 struct xfs_bmbt_irec *mval, 4733 struct xfs_bmbt_irec *mval,
4735 xfs_filblks_t len, 4734 xfs_filblks_t len,
4736 xfs_extnum_t *lastx, 4735 xfs_extnum_t *lastx,
4737 struct xfs_btree_cur **cur,
4738 int flags, 4736 int flags,
4739 int *logflags) 4737 int *logflags)
4740{ 4738{
@@ -4760,17 +4758,17 @@ xfs_bmapi_convert_unwritten(
4760 * Modify (by adding) the state flag, if writing. 4758 * Modify (by adding) the state flag, if writing.
4761 */ 4759 */
4762 ASSERT(mval->br_blockcount <= len); 4760 ASSERT(mval->br_blockcount <= len);
4763 if ((ifp->if_flags & XFS_IFBROOT) && !*cur) { 4761 if ((ifp->if_flags & XFS_IFBROOT) && !bma->cur) {
4764 *cur = xfs_bmbt_init_cursor(bma->ip->i_mount, bma->tp, 4762 bma->cur = xfs_bmbt_init_cursor(bma->ip->i_mount, bma->tp,
4765 bma->ip, whichfork); 4763 bma->ip, whichfork);
4766 (*cur)->bc_private.b.firstblock = *bma->firstblock; 4764 bma->cur->bc_private.b.firstblock = *bma->firstblock;
4767 (*cur)->bc_private.b.flist = bma->flist; 4765 bma->cur->bc_private.b.flist = bma->flist;
4768 } 4766 }
4769 mval->br_state = (mval->br_state == XFS_EXT_UNWRITTEN) 4767 mval->br_state = (mval->br_state == XFS_EXT_UNWRITTEN)
4770 ? XFS_EXT_NORM : XFS_EXT_UNWRITTEN; 4768 ? XFS_EXT_NORM : XFS_EXT_UNWRITTEN;
4771 4769
4772 error = xfs_bmap_add_extent_unwritten_real(bma->tp, bma->ip, lastx, 4770 error = xfs_bmap_add_extent_unwritten_real(bma->tp, bma->ip, lastx,
4773 cur, mval, bma->firstblock, bma->flist, logflags); 4771 &bma->cur, mval, bma->firstblock, bma->flist, logflags);
4774 if (error) 4772 if (error)
4775 return error; 4773 return error;
4776 4774
@@ -4819,7 +4817,6 @@ xfs_bmapi_write(
4819 struct xfs_mount *mp = ip->i_mount; 4817 struct xfs_mount *mp = ip->i_mount;
4820 struct xfs_ifork *ifp; 4818 struct xfs_ifork *ifp;
4821 struct xfs_bmalloca bma = { 0 }; /* args for xfs_bmap_alloc */ 4819 struct xfs_bmalloca bma = { 0 }; /* args for xfs_bmap_alloc */
4822 struct xfs_btree_cur *cur; /* bmap btree cursor */
4823 xfs_fileoff_t end; /* end of mapped file region */ 4820 xfs_fileoff_t end; /* end of mapped file region */
4824 int eof; /* after the end of extents */ 4821 int eof; /* after the end of extents */
4825 int error; /* error return */ 4822 int error; /* error return */
@@ -4875,7 +4872,6 @@ xfs_bmapi_write(
4875 4872
4876 logflags = 0; 4873 logflags = 0;
4877 nallocs = 0; 4874 nallocs = 0;
4878 cur = NULL;
4879 4875
4880 if (XFS_IFORK_FORMAT(ip, whichfork) == XFS_DINODE_FMT_LOCAL) { 4876 if (XFS_IFORK_FORMAT(ip, whichfork) == XFS_DINODE_FMT_LOCAL) {
4881 error = xfs_bmap_local_to_extents(tp, ip, firstblock, total, 4877 error = xfs_bmap_local_to_extents(tp, ip, firstblock, total,
@@ -4927,7 +4923,7 @@ xfs_bmapi_write(
4927 bma.length = len; 4923 bma.length = len;
4928 bma.offset = bno; 4924 bma.offset = bno;
4929 4925
4930 error = xfs_bmapi_allocate(&bma, &lastx, &cur, flags, 4926 error = xfs_bmapi_allocate(&bma, &lastx, flags,
4931 &nallocs, &tmp_logflags); 4927 &nallocs, &tmp_logflags);
4932 logflags |= tmp_logflags; 4928 logflags |= tmp_logflags;
4933 if (error) 4929 if (error)
@@ -4942,7 +4938,7 @@ xfs_bmapi_write(
4942 4938
4943 /* Execute unwritten extent conversion if necessary */ 4939 /* Execute unwritten extent conversion if necessary */
4944 error = xfs_bmapi_convert_unwritten(&bma, mval, len, &lastx, 4940 error = xfs_bmapi_convert_unwritten(&bma, mval, len, &lastx,
4945 &cur, flags, &tmp_logflags); 4941 flags, &tmp_logflags);
4946 logflags |= tmp_logflags; 4942 logflags |= tmp_logflags;
4947 if (error == EAGAIN) 4943 if (error == EAGAIN)
4948 continue; 4944 continue;
@@ -4974,8 +4970,8 @@ xfs_bmapi_write(
4974 */ 4970 */
4975 if (XFS_IFORK_FORMAT(ip, whichfork) == XFS_DINODE_FMT_BTREE && 4971 if (XFS_IFORK_FORMAT(ip, whichfork) == XFS_DINODE_FMT_BTREE &&
4976 XFS_IFORK_NEXTENTS(ip, whichfork) <= ifp->if_ext_max) { 4972 XFS_IFORK_NEXTENTS(ip, whichfork) <= ifp->if_ext_max) {
4977 ASSERT(cur); 4973 ASSERT(bma.cur);
4978 error = xfs_bmap_btree_to_extents(tp, ip, cur, 4974 error = xfs_bmap_btree_to_extents(tp, ip, bma.cur,
4979 &tmp_logflags, whichfork); 4975 &tmp_logflags, whichfork);
4980 logflags |= tmp_logflags; 4976 logflags |= tmp_logflags;
4981 if (error) 4977 if (error)
@@ -5005,19 +5001,19 @@ error0:
5005 if (logflags) 5001 if (logflags)
5006 xfs_trans_log_inode(tp, ip, logflags); 5002 xfs_trans_log_inode(tp, ip, logflags);
5007 5003
5008 if (cur) { 5004 if (bma.cur) {
5009 if (!error) { 5005 if (!error) {
5010 ASSERT(*firstblock == NULLFSBLOCK || 5006 ASSERT(*firstblock == NULLFSBLOCK ||
5011 XFS_FSB_TO_AGNO(mp, *firstblock) == 5007 XFS_FSB_TO_AGNO(mp, *firstblock) ==
5012 XFS_FSB_TO_AGNO(mp, 5008 XFS_FSB_TO_AGNO(mp,
5013 cur->bc_private.b.firstblock) || 5009 bma.cur->bc_private.b.firstblock) ||
5014 (flist->xbf_low && 5010 (flist->xbf_low &&
5015 XFS_FSB_TO_AGNO(mp, *firstblock) < 5011 XFS_FSB_TO_AGNO(mp, *firstblock) <
5016 XFS_FSB_TO_AGNO(mp, 5012 XFS_FSB_TO_AGNO(mp,
5017 cur->bc_private.b.firstblock))); 5013 bma.cur->bc_private.b.firstblock)));
5018 *firstblock = cur->bc_private.b.firstblock; 5014 *firstblock = bma.cur->bc_private.b.firstblock;
5019 } 5015 }
5020 xfs_btree_del_cursor(cur, 5016 xfs_btree_del_cursor(bma.cur,
5021 error ? XFS_BTREE_ERROR : XFS_BTREE_NOERROR); 5017 error ? XFS_BTREE_ERROR : XFS_BTREE_NOERROR);
5022 } 5018 }
5023 if (!error) 5019 if (!error)
diff --git a/fs/xfs/xfs_bmap.h b/fs/xfs/xfs_bmap.h
index 5f398b1ac70c..858d9d509989 100644
--- a/fs/xfs/xfs_bmap.h
+++ b/fs/xfs/xfs_bmap.h
@@ -120,6 +120,8 @@ typedef struct xfs_bmalloca {
120 xfs_extlen_t length; /* i/o length asked/allocated */ 120 xfs_extlen_t length; /* i/o length asked/allocated */
121 xfs_fsblock_t blkno; /* starting block of new extent */ 121 xfs_fsblock_t blkno; /* starting block of new extent */
122 122
123 struct xfs_btree_cur *cur; /* btree cursor */
124
123 xfs_extlen_t total; /* total blocks needed for xaction */ 125 xfs_extlen_t total; /* total blocks needed for xaction */
124 xfs_extlen_t minlen; /* minimum allocation size (blocks) */ 126 xfs_extlen_t minlen; /* minimum allocation size (blocks) */
125 xfs_extlen_t minleft; /* amount must be left after alloc */ 127 xfs_extlen_t minleft; /* amount must be left after alloc */