xfs: refactor xfs_difree() inobt bits into xfs_difree_inobt() helper
Refactor xfs_difree() in preparation for the finobt. xfs_difree() performs the validity checks against the ag and reads the agi header. The work of physically updating the inode allocation btree is pushed down into the new xfs_difree_inobt() helper. Signed-off-by: Brian Foster <bfoster@redhat.com> Reviewed-by: Dave Chinner <dchinner@redhat.com> Signed-off-by: Dave Chinner <david@fromorbit.com>
This commit is contained in:
parent
6dd8638e4e
commit
2b64ee5cdc
|
@ -1430,74 +1430,30 @@ out_error:
|
||||||
return XFS_ERROR(error);
|
return XFS_ERROR(error);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
STATIC int
|
||||||
* Free disk inode. Carefully avoids touching the incore inode, all
|
xfs_difree_inobt(
|
||||||
* manipulations incore are the caller's responsibility.
|
struct xfs_mount *mp,
|
||||||
* The on-disk inode is not changed by this operation, only the
|
struct xfs_trans *tp,
|
||||||
* btree (free inode mask) is changed.
|
struct xfs_buf *agbp,
|
||||||
*/
|
xfs_agino_t agino,
|
||||||
int
|
struct xfs_bmap_free *flist,
|
||||||
xfs_difree(
|
int *delete,
|
||||||
xfs_trans_t *tp, /* transaction pointer */
|
xfs_ino_t *first_ino,
|
||||||
xfs_ino_t inode, /* inode to be freed */
|
struct xfs_inobt_rec_incore *orec)
|
||||||
xfs_bmap_free_t *flist, /* extents to free */
|
|
||||||
int *delete, /* set if inode cluster was deleted */
|
|
||||||
xfs_ino_t *first_ino) /* first inode in deleted cluster */
|
|
||||||
{
|
{
|
||||||
/* REFERENCED */
|
struct xfs_agi *agi = XFS_BUF_TO_AGI(agbp);
|
||||||
xfs_agblock_t agbno; /* block number containing inode */
|
xfs_agnumber_t agno = be32_to_cpu(agi->agi_seqno);
|
||||||
xfs_buf_t *agbp; /* buffer containing allocation group header */
|
struct xfs_perag *pag;
|
||||||
xfs_agino_t agino; /* inode number relative to allocation group */
|
struct xfs_btree_cur *cur;
|
||||||
xfs_agnumber_t agno; /* allocation group number */
|
struct xfs_inobt_rec_incore rec;
|
||||||
xfs_agi_t *agi; /* allocation group header */
|
int ilen;
|
||||||
xfs_btree_cur_t *cur; /* inode btree cursor */
|
int error;
|
||||||
int error; /* error return value */
|
int i;
|
||||||
int i; /* result code */
|
int off;
|
||||||
int ilen; /* inodes in an inode cluster */
|
|
||||||
xfs_mount_t *mp; /* mount structure for filesystem */
|
|
||||||
int off; /* offset of inode in inode chunk */
|
|
||||||
xfs_inobt_rec_incore_t rec; /* btree record */
|
|
||||||
struct xfs_perag *pag;
|
|
||||||
|
|
||||||
mp = tp->t_mountp;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Break up inode number into its components.
|
|
||||||
*/
|
|
||||||
agno = XFS_INO_TO_AGNO(mp, inode);
|
|
||||||
if (agno >= mp->m_sb.sb_agcount) {
|
|
||||||
xfs_warn(mp, "%s: agno >= mp->m_sb.sb_agcount (%d >= %d).",
|
|
||||||
__func__, agno, mp->m_sb.sb_agcount);
|
|
||||||
ASSERT(0);
|
|
||||||
return XFS_ERROR(EINVAL);
|
|
||||||
}
|
|
||||||
agino = XFS_INO_TO_AGINO(mp, inode);
|
|
||||||
if (inode != XFS_AGINO_TO_INO(mp, agno, agino)) {
|
|
||||||
xfs_warn(mp, "%s: inode != XFS_AGINO_TO_INO() (%llu != %llu).",
|
|
||||||
__func__, (unsigned long long)inode,
|
|
||||||
(unsigned long long)XFS_AGINO_TO_INO(mp, agno, agino));
|
|
||||||
ASSERT(0);
|
|
||||||
return XFS_ERROR(EINVAL);
|
|
||||||
}
|
|
||||||
agbno = XFS_AGINO_TO_AGBNO(mp, agino);
|
|
||||||
if (agbno >= mp->m_sb.sb_agblocks) {
|
|
||||||
xfs_warn(mp, "%s: agbno >= mp->m_sb.sb_agblocks (%d >= %d).",
|
|
||||||
__func__, agbno, mp->m_sb.sb_agblocks);
|
|
||||||
ASSERT(0);
|
|
||||||
return XFS_ERROR(EINVAL);
|
|
||||||
}
|
|
||||||
/*
|
|
||||||
* Get the allocation group header.
|
|
||||||
*/
|
|
||||||
error = xfs_ialloc_read_agi(mp, tp, agno, &agbp);
|
|
||||||
if (error) {
|
|
||||||
xfs_warn(mp, "%s: xfs_ialloc_read_agi() returned error %d.",
|
|
||||||
__func__, error);
|
|
||||||
return error;
|
|
||||||
}
|
|
||||||
agi = XFS_BUF_TO_AGI(agbp);
|
|
||||||
ASSERT(agi->agi_magicnum == cpu_to_be32(XFS_AGI_MAGIC));
|
ASSERT(agi->agi_magicnum == cpu_to_be32(XFS_AGI_MAGIC));
|
||||||
ASSERT(agbno < be32_to_cpu(agi->agi_length));
|
ASSERT(XFS_AGINO_TO_AGBNO(mp, agino) < be32_to_cpu(agi->agi_length));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Initialize the cursor.
|
* Initialize the cursor.
|
||||||
*/
|
*/
|
||||||
|
@ -1593,6 +1549,7 @@ xfs_difree(
|
||||||
if (error)
|
if (error)
|
||||||
goto error0;
|
goto error0;
|
||||||
|
|
||||||
|
*orec = rec;
|
||||||
xfs_btree_del_cursor(cur, XFS_BTREE_NOERROR);
|
xfs_btree_del_cursor(cur, XFS_BTREE_NOERROR);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
@ -1601,6 +1558,80 @@ error0:
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Free disk inode. Carefully avoids touching the incore inode, all
|
||||||
|
* manipulations incore are the caller's responsibility.
|
||||||
|
* The on-disk inode is not changed by this operation, only the
|
||||||
|
* btree (free inode mask) is changed.
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
xfs_difree(
|
||||||
|
struct xfs_trans *tp, /* transaction pointer */
|
||||||
|
xfs_ino_t inode, /* inode to be freed */
|
||||||
|
struct xfs_bmap_free *flist, /* extents to free */
|
||||||
|
int *delete,/* set if inode cluster was deleted */
|
||||||
|
xfs_ino_t *first_ino)/* first inode in deleted cluster */
|
||||||
|
{
|
||||||
|
/* REFERENCED */
|
||||||
|
xfs_agblock_t agbno; /* block number containing inode */
|
||||||
|
struct xfs_buf *agbp; /* buffer for allocation group header */
|
||||||
|
xfs_agino_t agino; /* allocation group inode number */
|
||||||
|
xfs_agnumber_t agno; /* allocation group number */
|
||||||
|
int error; /* error return value */
|
||||||
|
struct xfs_mount *mp; /* mount structure for filesystem */
|
||||||
|
struct xfs_inobt_rec_incore rec;/* btree record */
|
||||||
|
|
||||||
|
mp = tp->t_mountp;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Break up inode number into its components.
|
||||||
|
*/
|
||||||
|
agno = XFS_INO_TO_AGNO(mp, inode);
|
||||||
|
if (agno >= mp->m_sb.sb_agcount) {
|
||||||
|
xfs_warn(mp, "%s: agno >= mp->m_sb.sb_agcount (%d >= %d).",
|
||||||
|
__func__, agno, mp->m_sb.sb_agcount);
|
||||||
|
ASSERT(0);
|
||||||
|
return XFS_ERROR(EINVAL);
|
||||||
|
}
|
||||||
|
agino = XFS_INO_TO_AGINO(mp, inode);
|
||||||
|
if (inode != XFS_AGINO_TO_INO(mp, agno, agino)) {
|
||||||
|
xfs_warn(mp, "%s: inode != XFS_AGINO_TO_INO() (%llu != %llu).",
|
||||||
|
__func__, (unsigned long long)inode,
|
||||||
|
(unsigned long long)XFS_AGINO_TO_INO(mp, agno, agino));
|
||||||
|
ASSERT(0);
|
||||||
|
return XFS_ERROR(EINVAL);
|
||||||
|
}
|
||||||
|
agbno = XFS_AGINO_TO_AGBNO(mp, agino);
|
||||||
|
if (agbno >= mp->m_sb.sb_agblocks) {
|
||||||
|
xfs_warn(mp, "%s: agbno >= mp->m_sb.sb_agblocks (%d >= %d).",
|
||||||
|
__func__, agbno, mp->m_sb.sb_agblocks);
|
||||||
|
ASSERT(0);
|
||||||
|
return XFS_ERROR(EINVAL);
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* Get the allocation group header.
|
||||||
|
*/
|
||||||
|
error = xfs_ialloc_read_agi(mp, tp, agno, &agbp);
|
||||||
|
if (error) {
|
||||||
|
xfs_warn(mp, "%s: xfs_ialloc_read_agi() returned error %d.",
|
||||||
|
__func__, error);
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Fix up the inode allocation btree.
|
||||||
|
*/
|
||||||
|
error = xfs_difree_inobt(mp, tp, agbp, agino, flist, delete, first_ino,
|
||||||
|
&rec);
|
||||||
|
if (error)
|
||||||
|
goto error0;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
error0:
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
STATIC int
|
STATIC int
|
||||||
xfs_imap_lookup(
|
xfs_imap_lookup(
|
||||||
struct xfs_mount *mp,
|
struct xfs_mount *mp,
|
||||||
|
|
Loading…
Reference in New Issue