aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2011-07-08 08:34:47 -0400
committerChristoph Hellwig <hch@lst.de>2011-07-08 08:34:47 -0400
commitf3ca87389dbff0a3dc1a7cb2fa7c62e25421c66c (patch)
tree39a6aa16be0bbab79e65525d57404b23eaff0205
parent7a249cf83da1813cfa71cfe1e265b40045eceb47 (diff)
xfs: remove i_transp
Remove the transaction pointer in the inode. It's only used to avoid passing down an argument in the bmap code, and for a few asserts in the transaction code right now. Also use the local variable ip in a few more places in xfs_inode_item_unlock, so that it isn't only used for debug builds after the above change. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Alex Elder <aelder@sgi.com> Reviewed-by: Dave Chinner <dchinner@redhat.com>
-rw-r--r--fs/xfs/quota/xfs_trans_dquot.c2
-rw-r--r--fs/xfs/xfs_bmap.c35
-rw-r--r--fs/xfs/xfs_inode.c3
-rw-r--r--fs/xfs/xfs_inode.h1
-rw-r--r--fs/xfs/xfs_inode_item.c13
-rw-r--r--fs/xfs/xfs_trans_inode.c9
6 files changed, 24 insertions, 39 deletions
diff --git a/fs/xfs/quota/xfs_trans_dquot.c b/fs/xfs/quota/xfs_trans_dquot.c
index 2a3648731331..24084edb7803 100644
--- a/fs/xfs/quota/xfs_trans_dquot.c
+++ b/fs/xfs/quota/xfs_trans_dquot.c
@@ -59,7 +59,7 @@ xfs_trans_dqjoin(
59 xfs_trans_add_item(tp, &dqp->q_logitem.qli_item); 59 xfs_trans_add_item(tp, &dqp->q_logitem.qli_item);
60 60
61 /* 61 /*
62 * Initialize i_transp so we can later determine if this dquot is 62 * Initialize d_transp so we can later determine if this dquot is
63 * associated with this transaction. 63 * associated with this transaction.
64 */ 64 */
65 dqp->q_transp = tp; 65 dqp->q_transp = tp;
diff --git a/fs/xfs/xfs_bmap.c b/fs/xfs/xfs_bmap.c
index e546a33214c9..7b46b78ba3f0 100644
--- a/fs/xfs/xfs_bmap.c
+++ b/fs/xfs/xfs_bmap.c
@@ -94,6 +94,7 @@ xfs_bmap_add_attrfork_local(
94 */ 94 */
95STATIC int /* error */ 95STATIC int /* error */
96xfs_bmap_add_extent_delay_real( 96xfs_bmap_add_extent_delay_real(
97 struct xfs_trans *tp, /* transaction pointer */
97 xfs_inode_t *ip, /* incore inode pointer */ 98 xfs_inode_t *ip, /* incore inode pointer */
98 xfs_extnum_t *idx, /* extent number to update/insert */ 99 xfs_extnum_t *idx, /* extent number to update/insert */
99 xfs_btree_cur_t **curp, /* if *curp is null, not a btree */ 100 xfs_btree_cur_t **curp, /* if *curp is null, not a btree */
@@ -439,6 +440,7 @@ xfs_bmap_add_attrfork_local(
439 */ 440 */
440STATIC int /* error */ 441STATIC int /* error */
441xfs_bmap_add_extent( 442xfs_bmap_add_extent(
443 struct xfs_trans *tp, /* transaction pointer */
442 xfs_inode_t *ip, /* incore inode pointer */ 444 xfs_inode_t *ip, /* incore inode pointer */
443 xfs_extnum_t *idx, /* extent number to update/insert */ 445 xfs_extnum_t *idx, /* extent number to update/insert */
444 xfs_btree_cur_t **curp, /* if *curp is null, not a btree */ 446 xfs_btree_cur_t **curp, /* if *curp is null, not a btree */
@@ -524,7 +526,7 @@ xfs_bmap_add_extent(
524 if (cur) 526 if (cur)
525 ASSERT(cur->bc_private.b.flags & 527 ASSERT(cur->bc_private.b.flags &
526 XFS_BTCUR_BPRV_WASDEL); 528 XFS_BTCUR_BPRV_WASDEL);
527 error = xfs_bmap_add_extent_delay_real(ip, 529 error = xfs_bmap_add_extent_delay_real(tp, ip,
528 idx, &cur, new, &da_new, 530 idx, &cur, new, &da_new,
529 first, flist, &logflags); 531 first, flist, &logflags);
530 } else { 532 } else {
@@ -561,7 +563,7 @@ xfs_bmap_add_extent(
561 int tmp_logflags; /* partial log flag return val */ 563 int tmp_logflags; /* partial log flag return val */
562 564
563 ASSERT(cur == NULL); 565 ASSERT(cur == NULL);
564 error = xfs_bmap_extents_to_btree(ip->i_transp, ip, first, 566 error = xfs_bmap_extents_to_btree(tp, ip, first,
565 flist, &cur, da_old > 0, &tmp_logflags, whichfork); 567 flist, &cur, da_old > 0, &tmp_logflags, whichfork);
566 logflags |= tmp_logflags; 568 logflags |= tmp_logflags;
567 if (error) 569 if (error)
@@ -604,6 +606,7 @@ done:
604 */ 606 */
605STATIC int /* error */ 607STATIC int /* error */
606xfs_bmap_add_extent_delay_real( 608xfs_bmap_add_extent_delay_real(
609 struct xfs_trans *tp, /* transaction pointer */
607 xfs_inode_t *ip, /* incore inode pointer */ 610 xfs_inode_t *ip, /* incore inode pointer */
608 xfs_extnum_t *idx, /* extent number to update/insert */ 611 xfs_extnum_t *idx, /* extent number to update/insert */
609 xfs_btree_cur_t **curp, /* if *curp is null, not a btree */ 612 xfs_btree_cur_t **curp, /* if *curp is null, not a btree */
@@ -901,7 +904,7 @@ xfs_bmap_add_extent_delay_real(
901 } 904 }
902 if (ip->i_d.di_format == XFS_DINODE_FMT_EXTENTS && 905 if (ip->i_d.di_format == XFS_DINODE_FMT_EXTENTS &&
903 ip->i_d.di_nextents > ip->i_df.if_ext_max) { 906 ip->i_d.di_nextents > ip->i_df.if_ext_max) {
904 error = xfs_bmap_extents_to_btree(ip->i_transp, ip, 907 error = xfs_bmap_extents_to_btree(tp, ip,
905 first, flist, &cur, 1, &tmp_rval, 908 first, flist, &cur, 1, &tmp_rval,
906 XFS_DATA_FORK); 909 XFS_DATA_FORK);
907 rval |= tmp_rval; 910 rval |= tmp_rval;
@@ -984,7 +987,7 @@ xfs_bmap_add_extent_delay_real(
984 } 987 }
985 if (ip->i_d.di_format == XFS_DINODE_FMT_EXTENTS && 988 if (ip->i_d.di_format == XFS_DINODE_FMT_EXTENTS &&
986 ip->i_d.di_nextents > ip->i_df.if_ext_max) { 989 ip->i_d.di_nextents > ip->i_df.if_ext_max) {
987 error = xfs_bmap_extents_to_btree(ip->i_transp, ip, 990 error = xfs_bmap_extents_to_btree(tp, ip,
988 first, flist, &cur, 1, &tmp_rval, 991 first, flist, &cur, 1, &tmp_rval,
989 XFS_DATA_FORK); 992 XFS_DATA_FORK);
990 rval |= tmp_rval; 993 rval |= tmp_rval;
@@ -1052,7 +1055,7 @@ xfs_bmap_add_extent_delay_real(
1052 } 1055 }
1053 if (ip->i_d.di_format == XFS_DINODE_FMT_EXTENTS && 1056 if (ip->i_d.di_format == XFS_DINODE_FMT_EXTENTS &&
1054 ip->i_d.di_nextents > ip->i_df.if_ext_max) { 1057 ip->i_d.di_nextents > ip->i_df.if_ext_max) {
1055 error = xfs_bmap_extents_to_btree(ip->i_transp, ip, 1058 error = xfs_bmap_extents_to_btree(tp, ip,
1056 first, flist, &cur, 1, &tmp_rval, 1059 first, flist, &cur, 1, &tmp_rval,
1057 XFS_DATA_FORK); 1060 XFS_DATA_FORK);
1058 rval |= tmp_rval; 1061 rval |= tmp_rval;
@@ -2871,8 +2874,8 @@ xfs_bmap_del_extent(
2871 len = del->br_blockcount; 2874 len = del->br_blockcount;
2872 do_div(bno, mp->m_sb.sb_rextsize); 2875 do_div(bno, mp->m_sb.sb_rextsize);
2873 do_div(len, mp->m_sb.sb_rextsize); 2876 do_div(len, mp->m_sb.sb_rextsize);
2874 if ((error = xfs_rtfree_extent(ip->i_transp, bno, 2877 error = xfs_rtfree_extent(tp, bno, (xfs_extlen_t)len);
2875 (xfs_extlen_t)len))) 2878 if (error)
2876 goto done; 2879 goto done;
2877 do_fx = 0; 2880 do_fx = 0;
2878 nblks = len * mp->m_sb.sb_rextsize; 2881 nblks = len * mp->m_sb.sb_rextsize;
@@ -4662,7 +4665,7 @@ xfs_bmapi(
4662 if (!wasdelay && (flags & XFS_BMAPI_PREALLOC)) 4665 if (!wasdelay && (flags & XFS_BMAPI_PREALLOC))
4663 got.br_state = XFS_EXT_UNWRITTEN; 4666 got.br_state = XFS_EXT_UNWRITTEN;
4664 } 4667 }
4665 error = xfs_bmap_add_extent(ip, &lastx, &cur, &got, 4668 error = xfs_bmap_add_extent(tp, ip, &lastx, &cur, &got,
4666 firstblock, flist, &tmp_logflags, 4669 firstblock, flist, &tmp_logflags,
4667 whichfork); 4670 whichfork);
4668 logflags |= tmp_logflags; 4671 logflags |= tmp_logflags;
@@ -4763,7 +4766,7 @@ xfs_bmapi(
4763 mval->br_state = (mval->br_state == XFS_EXT_UNWRITTEN) 4766 mval->br_state = (mval->br_state == XFS_EXT_UNWRITTEN)
4764 ? XFS_EXT_NORM 4767 ? XFS_EXT_NORM
4765 : XFS_EXT_UNWRITTEN; 4768 : XFS_EXT_UNWRITTEN;
4766 error = xfs_bmap_add_extent(ip, &lastx, &cur, mval, 4769 error = xfs_bmap_add_extent(tp, ip, &lastx, &cur, mval,
4767 firstblock, flist, &tmp_logflags, 4770 firstblock, flist, &tmp_logflags,
4768 whichfork); 4771 whichfork);
4769 logflags |= tmp_logflags; 4772 logflags |= tmp_logflags;
@@ -5117,7 +5120,7 @@ xfs_bunmapi(
5117 del.br_blockcount = mod; 5120 del.br_blockcount = mod;
5118 } 5121 }
5119 del.br_state = XFS_EXT_UNWRITTEN; 5122 del.br_state = XFS_EXT_UNWRITTEN;
5120 error = xfs_bmap_add_extent(ip, &lastx, &cur, &del, 5123 error = xfs_bmap_add_extent(tp, ip, &lastx, &cur, &del,
5121 firstblock, flist, &logflags, 5124 firstblock, flist, &logflags,
5122 XFS_DATA_FORK); 5125 XFS_DATA_FORK);
5123 if (error) 5126 if (error)
@@ -5175,18 +5178,18 @@ xfs_bunmapi(
5175 } 5178 }
5176 prev.br_state = XFS_EXT_UNWRITTEN; 5179 prev.br_state = XFS_EXT_UNWRITTEN;
5177 lastx--; 5180 lastx--;
5178 error = xfs_bmap_add_extent(ip, &lastx, &cur, 5181 error = xfs_bmap_add_extent(tp, ip, &lastx,
5179 &prev, firstblock, flist, &logflags, 5182 &cur, &prev, firstblock, flist,
5180 XFS_DATA_FORK); 5183 &logflags, XFS_DATA_FORK);
5181 if (error) 5184 if (error)
5182 goto error0; 5185 goto error0;
5183 goto nodelete; 5186 goto nodelete;
5184 } else { 5187 } else {
5185 ASSERT(del.br_state == XFS_EXT_NORM); 5188 ASSERT(del.br_state == XFS_EXT_NORM);
5186 del.br_state = XFS_EXT_UNWRITTEN; 5189 del.br_state = XFS_EXT_UNWRITTEN;
5187 error = xfs_bmap_add_extent(ip, &lastx, &cur, 5190 error = xfs_bmap_add_extent(tp, ip, &lastx,
5188 &del, firstblock, flist, &logflags, 5191 &cur, &del, firstblock, flist,
5189 XFS_DATA_FORK); 5192 &logflags, XFS_DATA_FORK);
5190 if (error) 5193 if (error)
5191 goto error0; 5194 goto error0;
5192 goto nodelete; 5195 goto nodelete;
diff --git a/fs/xfs/xfs_inode.c b/fs/xfs/xfs_inode.c
index aa143b870afb..db310f8fb76a 100644
--- a/fs/xfs/xfs_inode.c
+++ b/fs/xfs/xfs_inode.c
@@ -1261,7 +1261,6 @@ xfs_itruncate_extents(
1261 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL|XFS_IOLOCK_EXCL)); 1261 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL|XFS_IOLOCK_EXCL));
1262 ASSERT(new_size <= ip->i_size); 1262 ASSERT(new_size <= ip->i_size);
1263 ASSERT(tp->t_flags & XFS_TRANS_PERM_LOG_RES); 1263 ASSERT(tp->t_flags & XFS_TRANS_PERM_LOG_RES);
1264 ASSERT(ip->i_transp == tp);
1265 ASSERT(ip->i_itemp != NULL); 1264 ASSERT(ip->i_itemp != NULL);
1266 ASSERT(ip->i_itemp->ili_lock_flags == 0); 1265 ASSERT(ip->i_itemp->ili_lock_flags == 0);
1267 ASSERT(!XFS_NOT_DQATTACHED(mp, ip)); 1266 ASSERT(!XFS_NOT_DQATTACHED(mp, ip));
@@ -1436,7 +1435,6 @@ xfs_iunlink(
1436 1435
1437 ASSERT(ip->i_d.di_nlink == 0); 1436 ASSERT(ip->i_d.di_nlink == 0);
1438 ASSERT(ip->i_d.di_mode != 0); 1437 ASSERT(ip->i_d.di_mode != 0);
1439 ASSERT(ip->i_transp == tp);
1440 1438
1441 mp = tp->t_mountp; 1439 mp = tp->t_mountp;
1442 1440
@@ -1828,7 +1826,6 @@ xfs_ifree(
1828 xfs_buf_t *ibp; 1826 xfs_buf_t *ibp;
1829 1827
1830 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL)); 1828 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL));
1831 ASSERT(ip->i_transp == tp);
1832 ASSERT(ip->i_d.di_nlink == 0); 1829 ASSERT(ip->i_d.di_nlink == 0);
1833 ASSERT(ip->i_d.di_nextents == 0); 1830 ASSERT(ip->i_d.di_nextents == 0);
1834 ASSERT(ip->i_d.di_anextents == 0); 1831 ASSERT(ip->i_d.di_anextents == 0);
diff --git a/fs/xfs/xfs_inode.h b/fs/xfs/xfs_inode.h
index 6495578efe05..a97644ab945a 100644
--- a/fs/xfs/xfs_inode.h
+++ b/fs/xfs/xfs_inode.h
@@ -241,7 +241,6 @@ typedef struct xfs_inode {
241 xfs_ifork_t i_df; /* data fork */ 241 xfs_ifork_t i_df; /* data fork */
242 242
243 /* Transaction and locking information. */ 243 /* Transaction and locking information. */
244 struct xfs_trans *i_transp; /* ptr to owning transaction*/
245 struct xfs_inode_log_item *i_itemp; /* logging information */ 244 struct xfs_inode_log_item *i_itemp; /* logging information */
246 mrlock_t i_lock; /* inode lock */ 245 mrlock_t i_lock; /* inode lock */
247 mrlock_t i_iolock; /* inode IO lock */ 246 mrlock_t i_iolock; /* inode IO lock */
diff --git a/fs/xfs/xfs_inode_item.c b/fs/xfs/xfs_inode_item.c
index b1e88d56069c..a49811a3e5a4 100644
--- a/fs/xfs/xfs_inode_item.c
+++ b/fs/xfs/xfs_inode_item.c
@@ -632,13 +632,8 @@ xfs_inode_item_unlock(
632 struct xfs_inode *ip = iip->ili_inode; 632 struct xfs_inode *ip = iip->ili_inode;
633 unsigned short lock_flags; 633 unsigned short lock_flags;
634 634
635 ASSERT(iip->ili_inode->i_itemp != NULL); 635 ASSERT(ip->i_itemp != NULL);
636 ASSERT(xfs_isilocked(iip->ili_inode, XFS_ILOCK_EXCL)); 636 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL));
637
638 /*
639 * Clear the transaction pointer in the inode.
640 */
641 ip->i_transp = NULL;
642 637
643 /* 638 /*
644 * If the inode needed a separate buffer with which to log 639 * If the inode needed a separate buffer with which to log
@@ -664,8 +659,8 @@ xfs_inode_item_unlock(
664 lock_flags = iip->ili_lock_flags; 659 lock_flags = iip->ili_lock_flags;
665 iip->ili_lock_flags = 0; 660 iip->ili_lock_flags = 0;
666 if (lock_flags) { 661 if (lock_flags) {
667 xfs_iunlock(iip->ili_inode, lock_flags); 662 xfs_iunlock(ip, lock_flags);
668 IRELE(iip->ili_inode); 663 IRELE(ip);
669 } 664 }
670} 665}
671 666
diff --git a/fs/xfs/xfs_trans_inode.c b/fs/xfs/xfs_trans_inode.c
index 048b0c689d3e..c8dea2fd7e68 100644
--- a/fs/xfs/xfs_trans_inode.c
+++ b/fs/xfs/xfs_trans_inode.c
@@ -55,7 +55,6 @@ xfs_trans_ijoin(
55{ 55{
56 xfs_inode_log_item_t *iip; 56 xfs_inode_log_item_t *iip;
57 57
58 ASSERT(ip->i_transp == NULL);
59 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL)); 58 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL));
60 if (ip->i_itemp == NULL) 59 if (ip->i_itemp == NULL)
61 xfs_inode_item_init(ip, ip->i_mount); 60 xfs_inode_item_init(ip, ip->i_mount);
@@ -68,12 +67,6 @@ xfs_trans_ijoin(
68 xfs_trans_add_item(tp, &iip->ili_item); 67 xfs_trans_add_item(tp, &iip->ili_item);
69 68
70 xfs_trans_inode_broot_debug(ip); 69 xfs_trans_inode_broot_debug(ip);
71
72 /*
73 * Initialize i_transp so we can find it with xfs_inode_incore()
74 * in xfs_trans_iget() above.
75 */
76 ip->i_transp = tp;
77} 70}
78 71
79/* 72/*
@@ -111,7 +104,6 @@ xfs_trans_ichgtime(
111 104
112 ASSERT(tp); 105 ASSERT(tp);
113 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL)); 106 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL));
114 ASSERT(ip->i_transp == tp);
115 107
116 tv = current_fs_time(inode->i_sb); 108 tv = current_fs_time(inode->i_sb);
117 109
@@ -140,7 +132,6 @@ xfs_trans_log_inode(
140 xfs_inode_t *ip, 132 xfs_inode_t *ip,
141 uint flags) 133 uint flags)
142{ 134{
143 ASSERT(ip->i_transp == tp);
144 ASSERT(ip->i_itemp != NULL); 135 ASSERT(ip->i_itemp != NULL);
145 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL)); 136 ASSERT(xfs_isilocked(ip, XFS_ILOCK_EXCL));
146 137