Add a shortcut for the common XFS_INO_TO_AGINO(mp, ip->i_ino) pattern.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Carlos Maiolino <cmaiolino@redhat.com>
Reviewed-by: "Darrick J. Wong" <djwong@kernel.org>
Signed-off-by: Carlos Maiolino <cem@kernel.org>
XFS_INO_TO_AGNO((ip)->i_mount, (ip)->i_ino)
#define XFS_INO_TO_AGINO(mp,i) \
((xfs_agino_t)(i) & XFS_INO_MASK(XFS_INO_AGINO_BITS(mp)))
+#define XFS_INODE_TO_AGINO(ip) \
+ XFS_INO_TO_AGINO((ip)->i_mount, (ip)->i_ino)
#define XFS_INO_TO_AGBNO(mp,i) \
(((xfs_agblock_t)(i) >> XFS_INO_OFFSET_BITS(mp)) & \
XFS_INO_MASK(XFS_INO_AGBNO_BITS(mp)))
struct xfs_buf *agibp,
struct xfs_inode *ip)
{
- struct xfs_mount *mp = tp->t_mountp;
struct xfs_agi *agi = agibp->b_addr;
xfs_agino_t next_agino;
- xfs_agino_t agino = XFS_INO_TO_AGINO(mp, ip->i_ino);
+ xfs_agino_t agino = XFS_INODE_TO_AGINO(ip);
short bucket_index = agino % XFS_AGI_UNLINKED_BUCKETS;
int error;
{
struct xfs_mount *mp = tp->t_mountp;
struct xfs_agi *agi = agibp->b_addr;
- xfs_agino_t agino = XFS_INO_TO_AGINO(mp, ip->i_ino);
+ xfs_agino_t agino = XFS_INODE_TO_AGINO(ip);
xfs_agino_t head_agino;
short bucket_index = agino % XFS_AGI_UNLINKED_BUCKETS;
int error;
struct xrep_agi *ragi,
unsigned int batch_idx)
{
- struct xfs_mount *mp = ragi->sc->mp;
struct xfs_inode *ip = ragi->lookup_batch[batch_idx];
- xfs_agino_t agino;
- unsigned int bucket;
+ xfs_agino_t agino = XFS_INODE_TO_AGINO(ip);
+ unsigned int bucket = agino % XFS_AGI_UNLINKED_BUCKETS;
int error;
ASSERT(XFS_INODE_TO_AGNO(ip) == pag_agno(ragi->sc->sa.pag));
ASSERT(xfs_inode_on_unlinked_list(ip));
- agino = XFS_INO_TO_AGINO(mp, ip->i_ino);
- bucket = agino % XFS_AGI_UNLINKED_BUCKETS;
-
trace_xrep_iunlink_visit(ragi->sc->sa.pag, bucket,
ragi->iunlink_heads[bucket], ip);
if (XFS_INODE_TO_AGNO(ip) != pag_agno(pag))
continue;
first_index = XFS_INO_TO_AGINO(mp, ip->i_ino + 1);
- if (first_index < XFS_INO_TO_AGINO(mp, ip->i_ino))
+ if (first_index < XFS_INODE_TO_AGINO(ip))
done = true;
}
TP_fast_assign(
__entry->dev = pag_mount(pag)->m_super->s_dev;
__entry->agno = pag_agno(pag);
- __entry->agino = XFS_INO_TO_AGINO(pag_mount(pag), ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(ip);
__entry->bucket = bucket;
__entry->bucket_agino = bucket_agino;
__entry->prev_agino = ip->i_prev_unlinked;
TP_fast_assign(
__entry->dev = ip->i_mount->m_super->s_dev;
__entry->agno = XFS_INODE_TO_AGNO(ip);
- __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(ip);
__entry->old_prev_agino = ip->i_prev_unlinked;
__entry->prev_agino = prev_agino;
__entry->next_agino = ip->i_next_unlinked;
TP_fast_assign(
__entry->dev = ip->i_mount->m_super->s_dev;
__entry->agno = XFS_INODE_TO_AGNO(ip);
- __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(ip);
__entry->nlink = VFS_I(ip)->i_nlink;
__entry->next_agino = ip->i_next_unlinked;
),
TP_fast_assign(
__entry->dev = ip->i_mount->m_super->s_dev;
__entry->agno = XFS_INODE_TO_AGNO(ip);
- __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(ip);
__entry->next_agino = ip->i_next_unlinked;
__entry->new_next_agino = next_agino;
),
TP_fast_assign(
__entry->dev = ip->i_mount->m_super->s_dev;
__entry->agno = XFS_INODE_TO_AGNO(ip);
- __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(ip);
__entry->prev_agino = ip->i_prev_unlinked;
__entry->new_prev_agino = prev_agino;
),
*/
ip->i_flags &= ~XFS_IRECLAIM_RESET_FLAGS;
ip->i_flags |= XFS_INEW;
- xfs_perag_clear_inode_tag(pag, XFS_INO_TO_AGINO(mp, ip->i_ino),
+ xfs_perag_clear_inode_tag(pag, XFS_INODE_TO_AGINO(ip),
XFS_ICI_RECLAIM_TAG);
inode_state_assign_raw(inode, I_NEW);
spin_unlock(&ip->i_flags_lock);
pag = xfs_perag_get(mp, XFS_INODE_TO_AGNO(ip));
spin_lock(&pag->pag_ici_lock);
- xfs_perag_set_inode_tag(pag, XFS_INO_TO_AGINO(mp, ip->i_ino),
+ xfs_perag_set_inode_tag(pag, XFS_INODE_TO_AGINO(ip),
XFS_ICI_BLOCKGC_TAG);
spin_unlock(&pag->pag_ici_lock);
pag = xfs_perag_get(mp, XFS_INODE_TO_AGNO(ip));
spin_lock(&pag->pag_ici_lock);
- xfs_perag_clear_inode_tag(pag, XFS_INO_TO_AGINO(mp, ip->i_ino),
+ xfs_perag_clear_inode_tag(pag, XFS_INODE_TO_AGINO(ip),
XFS_ICI_BLOCKGC_TAG);
spin_unlock(&pag->pag_ici_lock);
if (XFS_INODE_TO_AGNO(ip) != pag_agno(pag))
continue;
first_index = XFS_INO_TO_AGINO(mp, ip->i_ino + 1);
- if (first_index < XFS_INO_TO_AGINO(mp, ip->i_ino))
+ if (first_index < XFS_INODE_TO_AGINO(ip))
done = true;
}
trace_xfs_inode_set_reclaimable(ip);
ip->i_flags &= ~(XFS_NEED_INACTIVE | XFS_INACTIVATING);
ip->i_flags |= XFS_IRECLAIMABLE;
- xfs_perag_set_inode_tag(pag, XFS_INO_TO_AGINO(mp, ip->i_ino),
+ xfs_perag_set_inode_tag(pag, XFS_INODE_TO_AGINO(ip),
XFS_ICI_RECLAIM_TAG);
spin_unlock(&ip->i_flags_lock);
struct xfs_agi *agi;
struct xfs_perag *pag;
xfs_agnumber_t agno = XFS_INODE_TO_AGNO(ip);
- xfs_agino_t agino = XFS_INO_TO_AGINO(mp, ip->i_ino);
+ xfs_agino_t agino = XFS_INODE_TO_AGINO(ip);
xfs_agino_t prev_agino, next_agino;
unsigned int bucket;
bool foundit = false;
TP_fast_assign(
__entry->dev = pag_mount(iup->pag)->m_super->s_dev;
__entry->agno = pag_agno(iup->pag);
- __entry->agino =
- XFS_INO_TO_AGINO(iup->ip->i_mount, iup->ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(iup->ip);
__entry->old_ptr = old_ptr;
__entry->new_ptr = iup->next_agino;
),
TP_fast_assign(
__entry->dev = ip->i_mount->m_super->s_dev;
__entry->agno = XFS_INODE_TO_AGNO(ip);
- __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(ip);
__entry->prev_agino = ip->i_prev_unlinked;
__entry->next_agino = ip->i_next_unlinked;
),
TP_fast_assign(
__entry->dev = ip->i_mount->m_super->s_dev;
__entry->agno = XFS_INODE_TO_AGNO(ip);
- __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(ip);
),
TP_printk("dev %d:%d agno 0x%x agino 0x%x bucket %u",
MAJOR(__entry->dev), MINOR(__entry->dev),
TP_fast_assign(
__entry->dev = VFS_I(ip)->i_sb->s_dev;
__entry->agno = XFS_INODE_TO_AGNO(ip);
- __entry->agino = XFS_INO_TO_AGINO(ip->i_mount, ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(ip);
),
TP_printk("dev %d:%d agno 0x%x agino 0x%x",
MAJOR(__entry->dev), MINOR(__entry->dev),
__entry->dev = cur->bc_mp->m_super->s_dev;
__assign_str(name);
__entry->agno = XFS_INODE_TO_AGNO(cur->bc_ino.ip);
- __entry->agino = XFS_INO_TO_AGINO(cur->bc_mp,
- cur->bc_ino.ip->i_ino);
+ __entry->agino = XFS_INODE_TO_AGINO(cur->bc_ino.ip);
__entry->levels = cur->bc_ino.ifake->if_levels;
__entry->blocks = cur->bc_ino.ifake->if_blocks;
__entry->whichfork = cur->bc_ino.whichfork;