diff options
| author | Pan Bian <bianpan2016@163.com> | 2018-12-12 08:46:20 -0800 | 
|---|---|---|
| committer | Darrick J. Wong <darrick.wong@oracle.com> | 2018-12-12 08:46:20 -0800 | 
| commit | fe5ed6c22e94b131ed5608d66ebce1efc39a7edb (patch) | |
| tree | ec8459076d766822547c8e2eb00e8249461b89f3 | |
| parent | d6f215f359637db116f0a671cc445317ea82d01e (diff) | |
xfs: libxfs: move xfs_perag_put late
The function xfs_alloc_get_freelist calls xfs_perag_put to drop the
reference. However, pag->pagf_btreeblks is read and written after the
put operation. This patch moves the put operation later.
Signed-off-by: Pan Bian <bianpan2016@163.com>
Reviewed-by: Carlos Maiolino <cmaiolino@redhat.com>
[darrick: minor changelog edits]
Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
| -rw-r--r-- | fs/xfs/libxfs/xfs_alloc.c | 2 | 
1 files changed, 1 insertions, 1 deletions
| diff --git a/fs/xfs/libxfs/xfs_alloc.c b/fs/xfs/libxfs/xfs_alloc.c index e1c0c0d2f1b0..4be387de8294 100644 --- a/fs/xfs/libxfs/xfs_alloc.c +++ b/fs/xfs/libxfs/xfs_alloc.c @@ -2435,7 +2435,6 @@ xfs_alloc_get_freelist(  	be32_add_cpu(&agf->agf_flcount, -1);  	xfs_trans_agflist_delta(tp, -1);  	pag->pagf_flcount--; -	xfs_perag_put(pag);  	logflags = XFS_AGF_FLFIRST | XFS_AGF_FLCOUNT;  	if (btreeblk) { @@ -2443,6 +2442,7 @@ xfs_alloc_get_freelist(  		pag->pagf_btreeblks++;  		logflags |= XFS_AGF_BTREEBLKS;  	} +	xfs_perag_put(pag);  	xfs_alloc_log_agf(tp, agbp, logflags);  	*bnop = bno; | 
