static inline void xfs_perag_intent_hold(struct xfs_perag *pag) {}
static inline void xfs_perag_intent_rele(struct xfs_perag *pag) {}
+struct xfs_rtgroup;
+
+#define xfs_rtgroup_intent_get(mp, rgno) \
+ xfs_rtgroup_get((mp), xfs_rtb_to_rgno((mp), (rgno)))
+#define xfs_rtgroup_intent_put(rtg) xfs_rtgroup_put(rtg)
+
+static inline void xfs_rtgroup_intent_hold(struct xfs_rtgroup *rtg) { }
+static inline void xfs_rtgroup_intent_rele(struct xfs_rtgroup *rtg) { }
+
+#define xfs_drain_free(dr) ((void)0)
+#define xfs_drain_init(dr) ((void)0)
+
static inline void libxfs_buftarg_drain(struct xfs_buftarg *btp)
{
cache_purge(btp->bcache);
struct xfs_mount *mp = tp->t_mountp;
if (xfs_efi_is_realtime(xefi)) {
- xfs_rgnumber_t rgno;
-
- rgno = xfs_rtb_to_rgno(mp, xefi->xefi_startblock);
- xefi->xefi_rtg = xfs_rtgroup_get(mp, rgno);
-
+ xefi->xefi_rtg = xfs_rtgroup_intent_get(mp,
+ xefi->xefi_startblock);
*dfpp = xfs_defer_add(tp, &xefi->xefi_list,
&xfs_rtextent_free_defer_type);
return;
{
struct xfs_extent_free_item *xefi = xefi_entry(item);
- xfs_rtgroup_put(xefi->xefi_rtg);
+ xfs_rtgroup_intent_put(xefi->xefi_rtg);
kmem_cache_free(xfs_extfree_item_cache, xefi);
}
* section updates.
*/
if (ri->ri_realtime) {
- xfs_rgnumber_t rgno;
-
- rgno = xfs_rtb_to_rgno(mp, ri->ri_bmap.br_startblock);
- ri->ri_rtg = xfs_rtgroup_get(mp, rgno);
+ ri->ri_rtg = xfs_rtgroup_intent_get(mp,
+ ri->ri_bmap.br_startblock);
xfs_defer_add(tp, &ri->ri_list, &xfs_rtrmap_update_defer_type);
} else {
- ri->ri_pag = xfs_perag_intent_get(mp, ri->ri_bmap.br_startblock);
+ ri->ri_pag = xfs_perag_intent_get(mp,
+ ri->ri_bmap.br_startblock);
xfs_defer_add(tp, &ri->ri_list, &xfs_rmap_update_defer_type);
}
}
{
struct xfs_rmap_intent *ri = ri_entry(item);
- xfs_rtgroup_put(ri->ri_rtg);
+ xfs_rtgroup_intent_put(ri->ri_rtg);
kmem_cache_free(xfs_rmap_intent_cache, ri);
}
{
if (xfs_ifork_is_realtime(bi->bi_owner, bi->bi_whichfork)) {
if (xfs_has_rtgroups(mp)) {
- xfs_rgnumber_t rgno;
-
- rgno = xfs_rtb_to_rgno(mp, bi->bi_bmap.br_startblock);
- bi->bi_rtg = xfs_rtgroup_get(mp, rgno);
+ bi->bi_rtg = xfs_rtgroup_intent_get(mp,
+ bi->bi_bmap.br_startblock);
} else {
bi->bi_rtg = NULL;
}
struct xfs_bmap_intent *bi)
{
if (xfs_ifork_is_realtime(bi->bi_owner, bi->bi_whichfork)) {
- if (xfs_has_rtgroups(bi->bi_owner->i_mount))
- xfs_rtgroup_put(bi->bi_rtg);
+ if (xfs_has_rtgroups(bi->bi_owner->i_mount)) {
+ xfs_rtgroup_intent_put(bi->bi_rtg);
+ }
return;
}
init_waitqueue_head(&rtg->rtg_active_wq);
memset(&rtg->lock_class, 0, sizeof(rtg->lock_class));
lockdep_register_key(&rtg->lock_class);
+ xfs_defer_drain_init(&rtg->rtg_intents_drain);
#endif /* __KERNEL__ */
/* Active ref owned by mount indicates rtgroup is online. */
break;
#ifdef __KERNEL__
lockdep_unregister_key(&rtg->lock_class);
+ xfs_defer_drain_free(&rtg->rtg_intents_drain);
#endif
kfree(rtg);
}
XFS_IS_CORRUPT(mp, atomic_read(&rtg->rtg_ref) != 0);
#ifdef __KERNEL__
lockdep_unregister_key(&rtg->lock_class);
+ xfs_defer_drain_free(&rtg->rtg_intents_drain);
#endif
/* drop the mount's active reference */