162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright (c) 2000,2005 Silicon Graphics, Inc.
462306a36Sopenharmony_ci * All Rights Reserved.
562306a36Sopenharmony_ci */
662306a36Sopenharmony_ci#ifndef __XFS_IALLOC_BTREE_H__
762306a36Sopenharmony_ci#define	__XFS_IALLOC_BTREE_H__
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci/*
1062306a36Sopenharmony_ci * Inode map on-disk structures
1162306a36Sopenharmony_ci */
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_cistruct xfs_buf;
1462306a36Sopenharmony_cistruct xfs_btree_cur;
1562306a36Sopenharmony_cistruct xfs_mount;
1662306a36Sopenharmony_cistruct xfs_perag;
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci/*
1962306a36Sopenharmony_ci * Btree block header size depends on a superblock flag.
2062306a36Sopenharmony_ci */
2162306a36Sopenharmony_ci#define XFS_INOBT_BLOCK_LEN(mp) \
2262306a36Sopenharmony_ci	(xfs_has_crc(((mp))) ? \
2362306a36Sopenharmony_ci		XFS_BTREE_SBLOCK_CRC_LEN : XFS_BTREE_SBLOCK_LEN)
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci/*
2662306a36Sopenharmony_ci * Record, key, and pointer address macros for btree blocks.
2762306a36Sopenharmony_ci *
2862306a36Sopenharmony_ci * (note that some of these may appear unused, but they are used in userspace)
2962306a36Sopenharmony_ci */
3062306a36Sopenharmony_ci#define XFS_INOBT_REC_ADDR(mp, block, index) \
3162306a36Sopenharmony_ci	((xfs_inobt_rec_t *) \
3262306a36Sopenharmony_ci		((char *)(block) + \
3362306a36Sopenharmony_ci		 XFS_INOBT_BLOCK_LEN(mp) + \
3462306a36Sopenharmony_ci		 (((index) - 1) * sizeof(xfs_inobt_rec_t))))
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci#define XFS_INOBT_KEY_ADDR(mp, block, index) \
3762306a36Sopenharmony_ci	((xfs_inobt_key_t *) \
3862306a36Sopenharmony_ci		((char *)(block) + \
3962306a36Sopenharmony_ci		 XFS_INOBT_BLOCK_LEN(mp) + \
4062306a36Sopenharmony_ci		 ((index) - 1) * sizeof(xfs_inobt_key_t)))
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci#define XFS_INOBT_PTR_ADDR(mp, block, index, maxrecs) \
4362306a36Sopenharmony_ci	((xfs_inobt_ptr_t *) \
4462306a36Sopenharmony_ci		((char *)(block) + \
4562306a36Sopenharmony_ci		 XFS_INOBT_BLOCK_LEN(mp) + \
4662306a36Sopenharmony_ci		 (maxrecs) * sizeof(xfs_inobt_key_t) + \
4762306a36Sopenharmony_ci		 ((index) - 1) * sizeof(xfs_inobt_ptr_t)))
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ciextern struct xfs_btree_cur *xfs_inobt_init_cursor(struct xfs_perag *pag,
5062306a36Sopenharmony_ci		struct xfs_trans *tp, struct xfs_buf *agbp, xfs_btnum_t btnum);
5162306a36Sopenharmony_cistruct xfs_btree_cur *xfs_inobt_stage_cursor(struct xfs_perag *pag,
5262306a36Sopenharmony_ci		struct xbtree_afakeroot *afake, xfs_btnum_t btnum);
5362306a36Sopenharmony_ciextern int xfs_inobt_maxrecs(struct xfs_mount *, int, int);
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ci/* ir_holemask to inode allocation bitmap conversion */
5662306a36Sopenharmony_ciuint64_t xfs_inobt_irec_to_allocmask(const struct xfs_inobt_rec_incore *irec);
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci#if defined(DEBUG) || defined(XFS_WARN)
5962306a36Sopenharmony_ciint xfs_inobt_rec_check_count(struct xfs_mount *,
6062306a36Sopenharmony_ci			      struct xfs_inobt_rec_incore *);
6162306a36Sopenharmony_ci#else
6262306a36Sopenharmony_ci#define xfs_inobt_rec_check_count(mp, rec)	0
6362306a36Sopenharmony_ci#endif	/* DEBUG */
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_ciint xfs_finobt_calc_reserves(struct xfs_perag *perag, struct xfs_trans *tp,
6662306a36Sopenharmony_ci		xfs_extlen_t *ask, xfs_extlen_t *used);
6762306a36Sopenharmony_ciextern xfs_extlen_t xfs_iallocbt_calc_size(struct xfs_mount *mp,
6862306a36Sopenharmony_ci		unsigned long long len);
6962306a36Sopenharmony_ciint xfs_inobt_cur(struct xfs_perag *pag, struct xfs_trans *tp,
7062306a36Sopenharmony_ci		xfs_btnum_t btnum, struct xfs_btree_cur **curpp,
7162306a36Sopenharmony_ci		struct xfs_buf **agi_bpp);
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_civoid xfs_inobt_commit_staged_btree(struct xfs_btree_cur *cur,
7462306a36Sopenharmony_ci		struct xfs_trans *tp, struct xfs_buf *agbp);
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ciunsigned int xfs_iallocbt_maxlevels_ondisk(void);
7762306a36Sopenharmony_ci
7862306a36Sopenharmony_ciint __init xfs_inobt_init_cur_cache(void);
7962306a36Sopenharmony_civoid xfs_inobt_destroy_cur_cache(void);
8062306a36Sopenharmony_ci
8162306a36Sopenharmony_ci#endif	/* __XFS_IALLOC_BTREE_H__ */
82