root/fs/xfs/libxfs/xfs_zones.h
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _LIBXFS_ZONES_H
#define _LIBXFS_ZONES_H

struct xfs_rtgroup;
struct blk_zone;

/*
 * In order to guarantee forward progress for GC we need to reserve at least
 * two zones:  one that will be used for moving data into and one spare zone
 * making sure that we have enough space to relocate a nearly-full zone.
 * To allow for slightly sloppy accounting for when we need to reserve the
 * second zone, we actually reserve three as that is easier than doing fully
 * accurate bookkeeping.
 */
#define XFS_GC_ZONES            3U

/*
 * In addition we need two zones for user writes, one open zone for writing
 * and one to still have available blocks without resetting the open zone
 * when data in the open zone has been freed.
 */
#define XFS_RESERVED_ZONES      (XFS_GC_ZONES + 1)
#define XFS_MIN_ZONES           (XFS_RESERVED_ZONES + 1)

/*
 * Always keep one zone out of the general open zone pool to allow for GC to
 * happen while other writers are waiting for free space.
 */
#define XFS_OPEN_GC_ZONES       1U
#define XFS_MIN_OPEN_ZONES      (XFS_OPEN_GC_ZONES + 1U)

/*
 * For zoned devices that do not have a limit on the number of open zones, and
 * for regular devices using the zoned allocator, use the most common SMR disks
 * limit (128) as the default limit on the number of open zones.
 */
#define XFS_DEFAULT_MAX_OPEN_ZONES      128

bool xfs_validate_blk_zone(struct xfs_mount *mp, struct blk_zone *zone,
        unsigned int zone_no, uint32_t expected_size,
        uint32_t expected_capacity, xfs_rgblock_t *write_pointer);

#endif /* _LIBXFS_ZONES_H */