Lines Matching full:mp
49 struct xfs_mount *mp, in xfs_zone_bucket() argument
53 mp->m_groups[XG_TYPE_RTG].blocks; in xfs_zone_bucket()
82 struct xfs_mount *mp = rtg_mount(rtg); in xfs_zone_account_reclaimable() local
83 struct xfs_zone_info *zi = mp->m_zone_info; in xfs_zone_account_reclaimable()
86 uint32_t from_bucket = xfs_zone_bucket(mp, used + freed); in xfs_zone_account_reclaimable()
87 uint32_t to_bucket = xfs_zone_bucket(mp, used); in xfs_zone_account_reclaimable()
131 if (zi->zi_gc_thread && xfs_zoned_need_gc(mp)) in xfs_zone_account_reclaimable()
150 struct xfs_mount *mp = rtg_mount(rtg); in xfs_open_zone_mark_full() local
151 struct xfs_zone_info *zi = mp->m_zone_info; in xfs_open_zone_mark_full()
181 struct xfs_mount *mp = tp->t_mountp; in xfs_zone_record_blocks() local
185 trace_xfs_zone_record_blocks(oz, xfs_rtb_to_rgbno(mp, fsbno), len); in xfs_zone_record_blocks()
308 struct xfs_mount *mp = ip->i_mount; in xfs_zoned_end_io() local
309 xfs_fileoff_t end_fsb = XFS_B_TO_FSB(mp, offset + count); in xfs_zoned_end_io()
311 .br_startoff = XFS_B_TO_FSBT(mp, offset), in xfs_zoned_end_io()
312 .br_startblock = xfs_daddr_to_rtb(mp, daddr), in xfs_zoned_end_io()
316 XFS_EXTENTADD_SPACE_RES(mp, XFS_DATA_FORK); in xfs_zoned_end_io()
320 if (xfs_is_shutdown(mp)) in xfs_zoned_end_io()
326 error = xfs_trans_alloc(mp, &M_RES(mp)->tr_write, resblks, 0, in xfs_zoned_end_io()
363 struct xfs_mount *mp = tp->t_mountp; in xfs_zone_free_blocks() local
369 xfs_err(mp, in xfs_zone_free_blocks()
374 xfs_force_shutdown(mp, SHUTDOWN_CORRUPT_INCORE); in xfs_zone_free_blocks()
378 trace_xfs_zone_free_blocks(rtg, xfs_rtb_to_rgbno(mp, fsbno), len); in xfs_zone_free_blocks()
388 xfs_add_frextents(mp, len); in xfs_zone_free_blocks()
395 struct xfs_mount *mp, in xfs_find_free_zone() argument
399 struct xfs_zone_info *zi = mp->m_zone_info; in xfs_find_free_zone()
400 XA_STATE (xas, &mp->m_groups[XG_TYPE_RTG].xa, start); in xfs_find_free_zone()
452 struct xfs_mount *mp, in xfs_open_zone() argument
456 struct xfs_zone_info *zi = mp->m_zone_info; in xfs_open_zone()
459 xg = xfs_find_free_zone(mp, zi->zi_free_zone_cursor, ULONG_MAX); in xfs_open_zone()
461 xg = xfs_find_free_zone(mp, 0, zi->zi_free_zone_cursor); in xfs_open_zone()
471 struct xfs_mount *mp, in xfs_try_open_zone() argument
474 struct xfs_zone_info *zi = mp->m_zone_info; in xfs_try_open_zone()
477 if (zi->zi_nr_open_zones >= mp->m_max_open_zones - XFS_OPEN_GC_ZONES) in xfs_try_open_zone()
489 oz = xfs_open_zone(mp, write_hint, false); in xfs_try_open_zone()
505 if (xfs_zoned_need_gc(mp)) in xfs_try_open_zone()
641 struct xfs_mount *mp = ip->i_mount; in xfs_zoned_pack_tight() local
643 XFS_FSB_TO_B(mp, mp->m_groups[XG_TYPE_RTG].blocks); in xfs_zoned_pack_tight()
658 struct xfs_mount *mp, in xfs_select_zone_nowait() argument
662 struct xfs_zone_info *zi = mp->m_zone_info; in xfs_select_zone_nowait()
665 if (xfs_is_shutdown(mp)) in xfs_select_zone_nowait()
688 oz = xfs_try_open_zone(mp, write_hint); in xfs_select_zone_nowait()
710 struct xfs_mount *mp, in xfs_select_zone() argument
714 struct xfs_zone_info *zi = mp->m_zone_info; in xfs_select_zone()
718 oz = xfs_select_zone_nowait(mp, write_hint, pack_tight); in xfs_select_zone()
724 oz = xfs_select_zone_nowait(mp, write_hint, pack_tight); in xfs_select_zone()
725 if (oz || xfs_is_shutdown(mp)) in xfs_select_zone()
741 struct xfs_mount *mp = rtg_mount(rtg); in xfs_zone_alloc_blocks() local
758 *is_seq = bdev_zone_is_seq(mp->m_rtdev_targp->bt_bdev, *sector); in xfs_zone_alloc_blocks()
760 *sector += XFS_FSB_TO_BB(mp, allocated); in xfs_zone_alloc_blocks()
761 return XFS_FSB_TO_B(mp, count_fsb); in xfs_zone_alloc_blocks()
768 struct xfs_mount *mp = XFS_I(ioend->io_inode)->i_mount; in xfs_mark_rtg_boundary() local
771 if (xfs_rtb_to_rgbno(mp, xfs_daddr_to_rtb(mp, sector)) == 0) in xfs_mark_rtg_boundary()
852 struct xfs_mount *mp = ip->i_mount; in xfs_zone_alloc_and_submit() local
859 if (xfs_is_shutdown(mp)) in xfs_zone_alloc_and_submit()
871 *oz = xfs_select_zone(mp, write_hint, pack_tight); in xfs_zone_alloc_and_submit()
877 alloc_len = xfs_zone_alloc_blocks(*oz, XFS_B_TO_FSB(mp, ioend->io_size), in xfs_zone_alloc_and_submit()
910 struct xfs_mount *mp) in xfs_zoned_wake_all() argument
918 if ((mp->m_super->s_flags & SB_ACTIVE) && mp->m_zone_info) in xfs_zoned_wake_all()
919 wake_up_all(&mp->m_zone_info->zi_zone_wait); in xfs_zoned_wake_all()
961 struct xfs_mount *mp; member
972 struct xfs_mount *mp = rtg_mount(rtg); in xfs_init_zone() local
973 struct xfs_zone_info *zi = mp->m_zone_info; in xfs_init_zone()
1048 struct xfs_mount *mp = iz->mp; in xfs_get_zone_info_cb() local
1049 xfs_fsblock_t zsbno = xfs_daddr_to_rtb(mp, zone->start); in xfs_get_zone_info_cb()
1054 if (xfs_rtb_to_rgbno(mp, zsbno) != 0) { in xfs_get_zone_info_cb()
1055 xfs_warn(mp, "mismatched zone start 0x%llx.", zsbno); in xfs_get_zone_info_cb()
1059 rgno = xfs_rtb_to_rgno(mp, zsbno); in xfs_get_zone_info_cb()
1060 rtg = xfs_rtgroup_grab(mp, rgno); in xfs_get_zone_info_cb()
1062 xfs_warn(mp, "realtime group not found for zone %u.", rgno); in xfs_get_zone_info_cb()
1076 struct xfs_mount *mp) in xfs_max_open_zones() argument
1085 max_open_data_zones = (mp->m_sb.sb_rgcount - XFS_MIN_ZONES) / 2 + 1; in xfs_max_open_zones()
1093 max_open = min(max_open, mp->m_sb.sb_rgcount / 4); in xfs_max_open_zones()
1114 struct xfs_mount *mp) in xfs_calc_open_zones() argument
1116 struct block_device *bdev = mp->m_rtdev_targp->bt_bdev; in xfs_calc_open_zones()
1119 if (!mp->m_max_open_zones) { in xfs_calc_open_zones()
1121 mp->m_max_open_zones = bdev_open_zones; in xfs_calc_open_zones()
1123 mp->m_max_open_zones = XFS_DEFAULT_MAX_OPEN_ZONES; in xfs_calc_open_zones()
1126 if (mp->m_max_open_zones < XFS_MIN_OPEN_ZONES) { in xfs_calc_open_zones()
1127 xfs_notice(mp, "need at least %u open zones.", in xfs_calc_open_zones()
1132 if (bdev_open_zones && bdev_open_zones < mp->m_max_open_zones) { in xfs_calc_open_zones()
1133 mp->m_max_open_zones = bdev_open_zones; in xfs_calc_open_zones()
1134 xfs_info(mp, "limiting open zones to %u due to hardware limit.\n", in xfs_calc_open_zones()
1138 if (mp->m_max_open_zones > xfs_max_open_zones(mp)) { in xfs_calc_open_zones()
1139 mp->m_max_open_zones = xfs_max_open_zones(mp); in xfs_calc_open_zones()
1140 xfs_info(mp, in xfs_calc_open_zones()
1142 mp->m_max_open_zones, mp->m_sb.sb_rgcount); in xfs_calc_open_zones()
1150 struct xfs_mount *mp) in xfs_alloc_bucket_bitmap() argument
1152 return kvmalloc_array(BITS_TO_LONGS(mp->m_sb.sb_rgcount), in xfs_alloc_bucket_bitmap()
1158 struct xfs_mount *mp) in xfs_alloc_zone_info() argument
1174 zi->zi_used_bucket_bitmap[i] = xfs_alloc_bucket_bitmap(mp); in xfs_alloc_zone_info()
1201 struct xfs_mount *mp) in xfs_mount_zones() argument
1204 .mp = mp, in xfs_mount_zones()
1206 struct xfs_buftarg *bt = mp->m_rtdev_targp; in xfs_mount_zones()
1210 xfs_notice(mp, "RT device missing."); in xfs_mount_zones()
1214 if (!xfs_has_rtgroups(mp) || !xfs_has_rmapbt(mp)) { in xfs_mount_zones()
1215 xfs_notice(mp, "invalid flag combination."); in xfs_mount_zones()
1218 if (mp->m_sb.sb_rextsize != 1) { in xfs_mount_zones()
1219 xfs_notice(mp, "zoned file systems do not support rextsize."); in xfs_mount_zones()
1222 if (mp->m_sb.sb_rgcount < XFS_MIN_ZONES) { in xfs_mount_zones()
1223 xfs_notice(mp, in xfs_mount_zones()
1228 error = xfs_calc_open_zones(mp); in xfs_mount_zones()
1232 mp->m_zone_info = xfs_alloc_zone_info(mp); in xfs_mount_zones()
1233 if (!mp->m_zone_info) in xfs_mount_zones()
1236 xfs_info(mp, "%u zones of %u blocks (%u max open zones)", in xfs_mount_zones()
1237 mp->m_sb.sb_rgcount, mp->m_groups[XG_TYPE_RTG].blocks, in xfs_mount_zones()
1238 mp->m_max_open_zones); in xfs_mount_zones()
1239 trace_xfs_zones_mount(mp); in xfs_mount_zones()
1243 XFS_FSB_TO_BB(mp, mp->m_sb.sb_rtstart), in xfs_mount_zones()
1244 mp->m_sb.sb_rgcount, xfs_get_zone_info_cb, &iz); in xfs_mount_zones()
1250 while ((rtg = xfs_rtgroup_next(mp, rtg))) { in xfs_mount_zones()
1259 xfs_set_freecounter(mp, XC_FREE_RTAVAILABLE, iz.available); in xfs_mount_zones()
1260 xfs_set_freecounter(mp, XC_FREE_RTEXTENTS, in xfs_mount_zones()
1268 mp->m_zonegc_low_space = 0; in xfs_mount_zones()
1270 error = xfs_zone_gc_mount(mp); in xfs_mount_zones()
1276 xfs_free_zone_info(mp->m_zone_info); in xfs_mount_zones()
1282 struct xfs_mount *mp) in xfs_unmount_zones() argument
1284 xfs_zone_gc_unmount(mp); in xfs_unmount_zones()
1285 xfs_free_zone_info(mp->m_zone_info); in xfs_unmount_zones()