xfs: let xfs_bwrite callers handle the xfs_buf_relse
authorChristoph Hellwig <hch@infradead.org>
Tue, 23 Aug 2011 08:28:07 +0000 (08:28 +0000)
committerAlex Elder <aelder@sgi.com>
Wed, 12 Oct 2011 02:15:00 +0000 (21:15 -0500)
Remove the xfs_buf_relse from xfs_bwrite and let the caller handle it to
mirror the delwri and read paths.

Also remove the mount pointer passed to xfs_bwrite, which is superflous now
that we have a mount pointer in the buftarg.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Alex Elder <aelder@sgi.com>
fs/xfs/xfs_attr.c
fs/xfs/xfs_buf.c
fs/xfs/xfs_buf.h
fs/xfs/xfs_dquot.c
fs/xfs/xfs_fsops.c
fs/xfs/xfs_inode.c
fs/xfs/xfs_log_recover.c
fs/xfs/xfs_sync.c

index b097fd5a2b3f3dacaf231a51c39e7462958040ba..8f0f65833500b55c5b2b3dfddbdaeee3d6be8534 100644 (file)
@@ -2128,9 +2128,10 @@ xfs_attr_rmtval_set(xfs_da_args_t *args)
                xfs_buf_iomove(bp, 0, tmp, src, XBRW_WRITE);
                if (tmp < XFS_BUF_SIZE(bp))
                        xfs_buf_zero(bp, tmp, XFS_BUF_SIZE(bp) - tmp);
-               if ((error = xfs_bwrite(mp, bp))) {/* GROT: NOTE: synchronous write */
-                       return (error);
-               }
+               error = xfs_bwrite(bp); /* GROT: NOTE: synchronous write */
+               xfs_buf_relse(bp);
+               if (error)
+                       return error;
                src += tmp;
                valuelen -= tmp;
 
index 309eca75fad48a7b1c7cf8f3ca96b8dda3ae9e22..63dbeb9efc49dcf5a413a96359d6f74e42044eaa 100644 (file)
@@ -1014,7 +1014,6 @@ xfs_buf_ioerror(
 
 int
 xfs_bwrite(
-       struct xfs_mount        *mp,
        struct xfs_buf          *bp)
 {
        int                     error;
@@ -1026,9 +1025,10 @@ xfs_bwrite(
        xfs_bdstrat_cb(bp);
 
        error = xfs_buf_iowait(bp);
-       if (error)
-               xfs_force_shutdown(mp, SHUTDOWN_META_IO_ERROR);
-       xfs_buf_relse(bp);
+       if (error) {
+               xfs_force_shutdown(bp->b_target->bt_mount,
+                                  SHUTDOWN_META_IO_ERROR);
+       }
        return error;
 }
 
index f1a8933becb6543ab823f5b8e29852eb6a057d13..3f543ed3009be3605bbf7c4ec0dcdd9e30e230c0 100644 (file)
@@ -197,7 +197,7 @@ extern void xfs_buf_unlock(xfs_buf_t *);
        ((bp)->b_sema.count <= 0)
 
 /* Buffer Read and Write Routines */
-extern int xfs_bwrite(struct xfs_mount *mp, struct xfs_buf *bp);
+extern int xfs_bwrite(struct xfs_buf *bp);
 
 extern void xfsbdstrat(struct xfs_mount *, struct xfs_buf *);
 extern int xfs_bdstrat_cb(struct xfs_buf *);
index 0f78dd46415c061aaab03ec96f0fabd6fa1049c5..3e2ccaedc51e15d9fac8716d264b3e5c7873b254 100644 (file)
@@ -1242,11 +1242,11 @@ xfs_qm_dqflush(
        }
 
        if (flags & SYNC_WAIT)
-               error = xfs_bwrite(mp, bp);
-       else {
+               error = xfs_bwrite(bp);
+       else
                xfs_buf_delwri_queue(bp);
-               xfs_buf_relse(bp);
-       }
+
+       xfs_buf_relse(bp);
 
        trace_xfs_dqflush_done(dqp);
 
index 9153d2c77caf2856ea636bb76d317f2ef1a8676e..e023f940a3dd345a0a8e9c24cdf9c21b6615ab33 100644 (file)
@@ -216,10 +216,11 @@ xfs_growfs_data_private(
                tmpsize = agsize - XFS_PREALLOC_BLOCKS(mp);
                agf->agf_freeblks = cpu_to_be32(tmpsize);
                agf->agf_longest = cpu_to_be32(tmpsize);
-               error = xfs_bwrite(mp, bp);
-               if (error) {
+               error = xfs_bwrite(bp);
+               xfs_buf_relse(bp);
+               if (error)
                        goto error0;
-               }
+
                /*
                 * AG inode header block
                 */
@@ -240,10 +241,11 @@ xfs_growfs_data_private(
                agi->agi_dirino = cpu_to_be32(NULLAGINO);
                for (bucket = 0; bucket < XFS_AGI_UNLINKED_BUCKETS; bucket++)
                        agi->agi_unlinked[bucket] = cpu_to_be32(NULLAGINO);
-               error = xfs_bwrite(mp, bp);
-               if (error) {
+               error = xfs_bwrite(bp);
+               xfs_buf_relse(bp);
+               if (error)
                        goto error0;
-               }
+
                /*
                 * BNO btree root block
                 */
@@ -262,10 +264,11 @@ xfs_growfs_data_private(
                arec->ar_startblock = cpu_to_be32(XFS_PREALLOC_BLOCKS(mp));
                arec->ar_blockcount = cpu_to_be32(
                        agsize - be32_to_cpu(arec->ar_startblock));
-               error = xfs_bwrite(mp, bp);
-               if (error) {
+               error = xfs_bwrite(bp);
+               xfs_buf_relse(bp);
+               if (error)
                        goto error0;
-               }
+
                /*
                 * CNT btree root block
                 */
@@ -285,10 +288,11 @@ xfs_growfs_data_private(
                arec->ar_blockcount = cpu_to_be32(
                        agsize - be32_to_cpu(arec->ar_startblock));
                nfree += be32_to_cpu(arec->ar_blockcount);
-               error = xfs_bwrite(mp, bp);
-               if (error) {
+               error = xfs_bwrite(bp);
+               xfs_buf_relse(bp);
+               if (error)
                        goto error0;
-               }
+
                /*
                 * INO btree root block
                 */
@@ -303,10 +307,10 @@ xfs_growfs_data_private(
                block->bb_numrecs = 0;
                block->bb_u.s.bb_leftsib = cpu_to_be32(NULLAGBLOCK);
                block->bb_u.s.bb_rightsib = cpu_to_be32(NULLAGBLOCK);
-               error = xfs_bwrite(mp, bp);
-               if (error) {
+               error = xfs_bwrite(bp);
+               xfs_buf_relse(bp);
+               if (error)
                        goto error0;
-               }
        }
        xfs_trans_agblocks_delta(tp, nfree);
        /*
@@ -396,9 +400,9 @@ xfs_growfs_data_private(
                 * just issue a warning and continue.  The real work is
                 * already done and committed.
                 */
-               if (!(error = xfs_bwrite(mp, bp))) {
-                       continue;
-               } else {
+               error = xfs_bwrite(bp);
+               xfs_buf_relse(bp);
+               if (error) {
                        xfs_warn(mp,
                "write error %d updating secondary superblock for ag %d",
                                error, agno);
index f8fe1c66d42044f975c47a04ddad38adeda8bfe7..7f237ba3c29284195849475739d3562131e4faeb 100644 (file)
@@ -2597,11 +2597,11 @@ xfs_iflush(
                goto cluster_corrupt_out;
 
        if (flags & SYNC_WAIT)
-               error = xfs_bwrite(mp, bp);
-       else {
+               error = xfs_bwrite(bp);
+       else
                xfs_buf_delwri_queue(bp);
-               xfs_buf_relse(bp);
-       }
+
+       xfs_buf_relse(bp);
        return error;
 
 corrupt_out:
index 22946949bf5e74cad6b88a65df5dc323c250fc02..be173852b2ca91f7c676b3ef63ddd1fb5bce8eec 100644 (file)
@@ -268,9 +268,12 @@ xlog_bwrite(
        xfs_buf_lock(bp);
        XFS_BUF_SET_COUNT(bp, BBTOB(nbblks));
 
-       if ((error = xfs_bwrite(log->l_mp, bp)))
+       error = xfs_bwrite(bp);
+       if (error) {
                xfs_ioerror_alert("xlog_bwrite", log->l_mp,
                                  bp, XFS_BUF_ADDR(bp));
+       }
+       xfs_buf_relse(bp);
        return error;
 }
 
@@ -2172,15 +2175,15 @@ xlog_recover_buffer_pass2(
            (XFS_BUF_COUNT(bp) != MAX(log->l_mp->m_sb.sb_blocksize,
                        (__uint32_t)XFS_INODE_CLUSTER_SIZE(log->l_mp)))) {
                XFS_BUF_STALE(bp);
-               error = xfs_bwrite(mp, bp);
+               error = xfs_bwrite(bp);
        } else {
                ASSERT(bp->b_target->bt_mount == mp);
                bp->b_iodone = xlog_recover_iodone;
                xfs_buf_delwri_queue(bp);
-               xfs_buf_relse(bp);
        }
 
-       return (error);
+       xfs_buf_relse(bp);
+       return error;
 }
 
 STATIC int
index 4604f90f86a3dff55fee6ddef043ac5f5250a4b2..90cc197e0433d4fe313c962485f87c0c02a2569a 100644 (file)
@@ -322,6 +322,7 @@ xfs_sync_fsdata(
        struct xfs_mount        *mp)
 {
        struct xfs_buf          *bp;
+       int                     error;
 
        /*
         * If the buffer is pinned then push on the log so we won't get stuck
@@ -334,8 +335,9 @@ xfs_sync_fsdata(
        bp = xfs_getsb(mp, 0);
        if (xfs_buf_ispinned(bp))
                xfs_log_force(mp, 0);
-
-       return xfs_bwrite(mp, bp);
+       error = xfs_bwrite(bp);
+       xfs_buf_relse(bp);
+       return error;
 }
 
 /*