2020-05-12 16:54:17 -07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2011-07-13 04:43:48 -07:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
|
|
|
|
* All Rights Reserved.
|
|
|
|
*/
|
|
|
|
#ifndef __XFS_DIR2_PRIV_H__
|
|
|
|
#define __XFS_DIR2_PRIV_H__
|
|
|
|
|
2013-08-12 03:50:09 -07:00
|
|
|
struct dir_context;
|
|
|
|
|
2019-11-08 15:52:06 -07:00
|
|
|
/*
|
|
|
|
* In-core version of the leaf and free block headers to abstract the
|
|
|
|
* differences in the v2 and v3 disk format of the headers.
|
|
|
|
*/
|
|
|
|
struct xfs_dir3_icleaf_hdr {
|
|
|
|
uint32_t forw;
|
|
|
|
uint32_t back;
|
|
|
|
uint16_t magic;
|
|
|
|
uint16_t count;
|
|
|
|
uint16_t stale;
|
2019-11-08 15:57:50 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Pointer to the on-disk format entries, which are behind the
|
|
|
|
* variable size (v4 vs v5) header in the on-disk block.
|
|
|
|
*/
|
|
|
|
struct xfs_dir2_leaf_entry *ents;
|
2019-11-08 15:52:06 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct xfs_dir3_icfree_hdr {
|
|
|
|
uint32_t magic;
|
|
|
|
uint32_t firstdb;
|
|
|
|
uint32_t nvalid;
|
|
|
|
uint32_t nused;
|
2019-11-08 15:58:05 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Pointer to the on-disk format entries, which are behind the
|
|
|
|
* variable size (v4 vs v5) header in the on-disk block.
|
|
|
|
*/
|
|
|
|
__be16 *bests;
|
2019-11-08 15:52:06 -07:00
|
|
|
};
|
|
|
|
|
2011-07-13 04:43:48 -07:00
|
|
|
/* xfs_dir2.c */
|
2022-03-09 11:16:09 -07:00
|
|
|
xfs_dahash_t xfs_ascii_ci_hashname(const struct xfs_name *name);
|
2019-11-11 13:59:26 -07:00
|
|
|
enum xfs_dacmp xfs_ascii_ci_compname(struct xfs_da_args *args,
|
|
|
|
const unsigned char *name, int len);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_grow_inode(struct xfs_da_args *args, int space,
|
|
|
|
xfs_dir2_db_t *dbp);
|
|
|
|
extern int xfs_dir_cilookup_result(struct xfs_da_args *args,
|
|
|
|
const unsigned char *name, int len);
|
|
|
|
|
2013-08-12 03:50:09 -07:00
|
|
|
|
2011-07-13 04:43:48 -07:00
|
|
|
/* xfs_dir2_block.c */
|
2024-04-15 14:54:41 -07:00
|
|
|
int xfs_dir3_block_read(struct xfs_trans *tp, struct xfs_inode *dp,
|
|
|
|
xfs_ino_t owner, struct xfs_buf **bpp);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_block_addname(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_block_lookup(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_block_removename(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_block_replace(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_leaf_to_block(struct xfs_da_args *args,
|
2012-06-22 01:50:14 -07:00
|
|
|
struct xfs_buf *lbp, struct xfs_buf *dbp);
|
2011-07-13 04:43:48 -07:00
|
|
|
|
|
|
|
/* xfs_dir2_data.c */
|
2019-11-08 16:05:39 -07:00
|
|
|
struct xfs_dir2_data_free *xfs_dir2_data_bestfree_p(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir2_data_hdr *hdr);
|
2019-11-08 16:05:37 -07:00
|
|
|
__be16 *xfs_dir2_data_entry_tag_p(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir2_data_entry *dep);
|
2019-11-08 16:05:48 -07:00
|
|
|
uint8_t xfs_dir2_data_get_ftype(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir2_data_entry *dep);
|
|
|
|
void xfs_dir2_data_put_ftype(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir2_data_entry *dep, uint8_t ftype);
|
2019-11-08 16:05:37 -07:00
|
|
|
|
2011-07-13 04:43:48 -07:00
|
|
|
#ifdef DEBUG
|
2018-01-08 11:51:03 -07:00
|
|
|
extern void xfs_dir3_data_check(struct xfs_inode *dp, struct xfs_buf *bp);
|
2011-07-13 04:43:48 -07:00
|
|
|
#else
|
2013-04-02 22:11:22 -07:00
|
|
|
#define xfs_dir3_data_check(dp,bp)
|
2011-07-13 04:43:48 -07:00
|
|
|
#endif
|
2012-11-13 23:54:40 -07:00
|
|
|
|
2018-01-08 11:51:03 -07:00
|
|
|
extern xfs_failaddr_t __xfs_dir3_data_check(struct xfs_inode *dp,
|
|
|
|
struct xfs_buf *bp);
|
2019-11-20 10:46:04 -07:00
|
|
|
int xfs_dir3_data_read(struct xfs_trans *tp, struct xfs_inode *dp,
|
2024-04-15 14:54:40 -07:00
|
|
|
xfs_ino_t owner, xfs_dablk_t bno, unsigned int flags,
|
|
|
|
struct xfs_buf **bpp);
|
2019-11-20 10:46:02 -07:00
|
|
|
int xfs_dir3_data_readahead(struct xfs_inode *dp, xfs_dablk_t bno,
|
|
|
|
unsigned int flags);
|
2012-11-12 04:54:12 -07:00
|
|
|
|
2011-07-13 04:43:48 -07:00
|
|
|
extern struct xfs_dir2_data_free *
|
|
|
|
xfs_dir2_data_freeinsert(struct xfs_dir2_data_hdr *hdr,
|
2013-10-29 04:11:49 -07:00
|
|
|
struct xfs_dir2_data_free *bf, struct xfs_dir2_data_unused *dup,
|
|
|
|
int *loghead);
|
2013-04-02 22:11:20 -07:00
|
|
|
extern int xfs_dir3_data_init(struct xfs_da_args *args, xfs_dir2_db_t blkno,
|
2012-06-22 01:50:14 -07:00
|
|
|
struct xfs_buf **bpp);
|
2011-07-13 04:43:48 -07:00
|
|
|
|
|
|
|
/* xfs_dir2_leaf.c */
|
2019-11-08 15:57:49 -07:00
|
|
|
void xfs_dir2_leaf_hdr_from_disk(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir3_icleaf_hdr *to, struct xfs_dir2_leaf *from);
|
2019-11-08 15:57:50 -07:00
|
|
|
void xfs_dir2_leaf_hdr_to_disk(struct xfs_mount *mp, struct xfs_dir2_leaf *to,
|
|
|
|
struct xfs_dir3_icleaf_hdr *from);
|
2019-11-20 10:46:03 -07:00
|
|
|
int xfs_dir3_leaf_read(struct xfs_trans *tp, struct xfs_inode *dp,
|
2024-04-15 14:54:39 -07:00
|
|
|
xfs_ino_t owner, xfs_dablk_t fbno, struct xfs_buf **bpp);
|
2019-11-20 10:46:03 -07:00
|
|
|
int xfs_dir3_leafn_read(struct xfs_trans *tp, struct xfs_inode *dp,
|
2024-04-15 14:54:39 -07:00
|
|
|
xfs_ino_t owner, xfs_dablk_t fbno, struct xfs_buf **bpp);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_block_to_leaf(struct xfs_da_args *args,
|
2012-06-22 01:50:14 -07:00
|
|
|
struct xfs_buf *dbp);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_leaf_addname(struct xfs_da_args *args);
|
2013-04-11 14:30:21 -07:00
|
|
|
extern void xfs_dir3_leaf_compact(struct xfs_da_args *args,
|
|
|
|
struct xfs_dir3_icleaf_hdr *leafhdr, struct xfs_buf *bp);
|
|
|
|
extern void xfs_dir3_leaf_compact_x1(struct xfs_dir3_icleaf_hdr *leafhdr,
|
|
|
|
struct xfs_dir2_leaf_entry *ents, int *indexp,
|
2011-07-13 04:43:48 -07:00
|
|
|
int *lowstalep, int *highstalep, int *lowlogp, int *highlogp);
|
2013-04-11 14:30:21 -07:00
|
|
|
extern int xfs_dir3_leaf_get_buf(struct xfs_da_args *args, xfs_dir2_db_t bno,
|
2017-06-16 11:00:05 -07:00
|
|
|
struct xfs_buf **bpp, uint16_t magic);
|
2014-06-05 22:20:54 -07:00
|
|
|
extern void xfs_dir3_leaf_log_ents(struct xfs_da_args *args,
|
2019-11-08 15:57:50 -07:00
|
|
|
struct xfs_dir3_icleaf_hdr *hdr, struct xfs_buf *bp, int first,
|
|
|
|
int last);
|
2014-06-05 22:20:54 -07:00
|
|
|
extern void xfs_dir3_leaf_log_header(struct xfs_da_args *args,
|
2012-06-22 01:50:14 -07:00
|
|
|
struct xfs_buf *bp);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_leaf_lookup(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_leaf_removename(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_leaf_replace(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_leaf_search_hash(struct xfs_da_args *args,
|
2012-06-22 01:50:14 -07:00
|
|
|
struct xfs_buf *lbp);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_leaf_trim_data(struct xfs_da_args *args,
|
2012-06-22 01:50:14 -07:00
|
|
|
struct xfs_buf *lbp, xfs_dir2_db_t db);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern struct xfs_dir2_leaf_entry *
|
2013-04-11 14:30:21 -07:00
|
|
|
xfs_dir3_leaf_find_entry(struct xfs_dir3_icleaf_hdr *leafhdr,
|
|
|
|
struct xfs_dir2_leaf_entry *ents, int index, int compact,
|
|
|
|
int lowstale, int highstale, int *lfloglow, int *lfloghigh);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_node_to_leaf(struct xfs_da_state *state);
|
|
|
|
|
2018-01-08 11:51:03 -07:00
|
|
|
extern xfs_failaddr_t xfs_dir3_leaf_check_int(struct xfs_mount *mp,
|
2021-03-22 09:52:05 -07:00
|
|
|
struct xfs_dir3_icleaf_hdr *hdr, struct xfs_dir2_leaf *leaf,
|
|
|
|
bool expensive_checks);
|
2013-04-11 14:30:21 -07:00
|
|
|
|
2011-07-13 04:43:48 -07:00
|
|
|
/* xfs_dir2_node.c */
|
2019-11-08 15:57:52 -07:00
|
|
|
void xfs_dir2_free_hdr_from_disk(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir3_icfree_hdr *to, struct xfs_dir2_free *from);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_leaf_to_node(struct xfs_da_args *args,
|
2012-06-22 01:50:14 -07:00
|
|
|
struct xfs_buf *lbp);
|
2017-06-16 11:00:13 -07:00
|
|
|
extern xfs_dahash_t xfs_dir2_leaf_lasthash(struct xfs_inode *dp,
|
2013-10-29 04:11:50 -07:00
|
|
|
struct xfs_buf *bp, int *count);
|
2012-06-22 01:50:14 -07:00
|
|
|
extern int xfs_dir2_leafn_lookup_int(struct xfs_buf *bp,
|
2011-07-13 04:43:48 -07:00
|
|
|
struct xfs_da_args *args, int *indexp,
|
|
|
|
struct xfs_da_state *state);
|
2013-10-29 04:11:50 -07:00
|
|
|
extern int xfs_dir2_leafn_order(struct xfs_inode *dp, struct xfs_buf *leaf1_bp,
|
2012-06-22 01:50:14 -07:00
|
|
|
struct xfs_buf *leaf2_bp);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_leafn_split(struct xfs_da_state *state,
|
|
|
|
struct xfs_da_state_blk *oldblk, struct xfs_da_state_blk *newblk);
|
|
|
|
extern int xfs_dir2_leafn_toosmall(struct xfs_da_state *state, int *action);
|
|
|
|
extern void xfs_dir2_leafn_unbalance(struct xfs_da_state *state,
|
|
|
|
struct xfs_da_state_blk *drop_blk,
|
|
|
|
struct xfs_da_state_blk *save_blk);
|
|
|
|
extern int xfs_dir2_node_addname(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_node_lookup(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_node_removename(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_node_replace(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_node_trim_free(struct xfs_da_args *args, xfs_fileoff_t fo,
|
|
|
|
int *rvalp);
|
2024-04-15 14:54:41 -07:00
|
|
|
int xfs_dir2_free_read(struct xfs_trans *tp, struct xfs_inode *dp,
|
|
|
|
xfs_ino_t owner, xfs_dablk_t fbno, struct xfs_buf **bpp);
|
2011-07-13 04:43:48 -07:00
|
|
|
|
|
|
|
/* xfs_dir2_sf.c */
|
2019-11-08 16:02:59 -07:00
|
|
|
xfs_ino_t xfs_dir2_sf_get_ino(struct xfs_mount *mp, struct xfs_dir2_sf_hdr *hdr,
|
|
|
|
struct xfs_dir2_sf_entry *sfep);
|
2019-11-08 16:02:31 -07:00
|
|
|
xfs_ino_t xfs_dir2_sf_get_parent_ino(struct xfs_dir2_sf_hdr *hdr);
|
|
|
|
void xfs_dir2_sf_put_parent_ino(struct xfs_dir2_sf_hdr *hdr, xfs_ino_t ino);
|
2019-11-08 16:03:30 -07:00
|
|
|
uint8_t xfs_dir2_sf_get_ftype(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir2_sf_entry *sfep);
|
2019-11-08 16:02:38 -07:00
|
|
|
struct xfs_dir2_sf_entry *xfs_dir2_sf_nextentry(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir2_sf_hdr *hdr, struct xfs_dir2_sf_entry *sfep);
|
2011-07-13 04:43:48 -07:00
|
|
|
extern int xfs_dir2_block_sfsize(struct xfs_inode *dp,
|
|
|
|
struct xfs_dir2_data_hdr *block, struct xfs_dir2_sf_hdr *sfhp);
|
2012-06-22 01:50:14 -07:00
|
|
|
extern int xfs_dir2_block_to_sf(struct xfs_da_args *args, struct xfs_buf *bp,
|
2011-07-13 04:43:48 -07:00
|
|
|
int size, xfs_dir2_sf_hdr_t *sfhp);
|
|
|
|
extern int xfs_dir2_sf_addname(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_sf_create(struct xfs_da_args *args, xfs_ino_t pino);
|
|
|
|
extern int xfs_dir2_sf_lookup(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_sf_removename(struct xfs_da_args *args);
|
|
|
|
extern int xfs_dir2_sf_replace(struct xfs_da_args *args);
|
2023-12-15 11:03:37 -07:00
|
|
|
xfs_failaddr_t xfs_dir2_sf_verify(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir2_sf_hdr *sfp, int64_t size);
|
2019-12-16 12:14:09 -07:00
|
|
|
int xfs_dir2_sf_entsize(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir2_sf_hdr *hdr, int len);
|
|
|
|
void xfs_dir2_sf_put_ino(struct xfs_mount *mp, struct xfs_dir2_sf_hdr *hdr,
|
|
|
|
struct xfs_dir2_sf_entry *sfep, xfs_ino_t ino);
|
|
|
|
void xfs_dir2_sf_put_ftype(struct xfs_mount *mp,
|
|
|
|
struct xfs_dir2_sf_entry *sfep, uint8_t ftype);
|
2011-07-13 04:43:48 -07:00
|
|
|
|
2013-08-12 03:49:45 -07:00
|
|
|
/* xfs_dir2_readdir.c */
|
2017-06-16 11:00:14 -07:00
|
|
|
extern int xfs_readdir(struct xfs_trans *tp, struct xfs_inode *dp,
|
|
|
|
struct dir_context *ctx, size_t bufsize);
|
2013-08-12 03:49:45 -07:00
|
|
|
|
2024-06-13 19:22:53 -07:00
|
|
|
static inline unsigned int
|
|
|
|
xfs_dir2_data_unusedsize(
|
|
|
|
unsigned int len)
|
|
|
|
{
|
|
|
|
return round_up(len, XFS_DIR2_DATA_ALIGN);
|
|
|
|
}
|
|
|
|
|
2019-11-08 16:05:38 -07:00
|
|
|
static inline unsigned int
|
|
|
|
xfs_dir2_data_entsize(
|
|
|
|
struct xfs_mount *mp,
|
|
|
|
unsigned int namelen)
|
|
|
|
{
|
|
|
|
unsigned int len;
|
|
|
|
|
|
|
|
len = offsetof(struct xfs_dir2_data_entry, name[0]) + namelen +
|
|
|
|
sizeof(xfs_dir2_data_off_t) /* tag */;
|
2021-08-18 18:46:55 -07:00
|
|
|
if (xfs_has_ftype(mp))
|
2019-11-08 16:05:38 -07:00
|
|
|
len += sizeof(uint8_t);
|
|
|
|
return round_up(len, XFS_DIR2_DATA_ALIGN);
|
|
|
|
}
|
|
|
|
|
2022-03-09 11:16:09 -07:00
|
|
|
xfs_dahash_t xfs_dir2_hashname(struct xfs_mount *mp,
|
|
|
|
const struct xfs_name *name);
|
2019-12-16 12:14:09 -07:00
|
|
|
enum xfs_dacmp xfs_dir2_compname(struct xfs_da_args *args,
|
|
|
|
const unsigned char *name, int len);
|
2019-11-11 13:59:26 -07:00
|
|
|
|
2011-07-13 04:43:48 -07:00
|
|
|
#endif /* __XFS_DIR2_PRIV_H__ */
|