2  * Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
 
   5  * This program is free software; you can redistribute it and/or
 
   6  * modify it under the terms of the GNU General Public License as
 
   7  * published by the Free Software Foundation.
 
   9  * This program is distributed in the hope that it would be useful,
 
  10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  12  * GNU General Public License for more details.
 
  14  * You should have received a copy of the GNU General Public License
 
  15  * along with this program; if not, write the Free Software Foundation,
 
  16  * Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
  18 #ifndef __XFS_DIR2_BLOCK_H__
 
  19 #define __XFS_DIR2_BLOCK_H__
 
  23  * Directory version 2, single block format structures
 
  29 struct xfs_dir2_data_hdr;
 
  30 struct xfs_dir2_leaf_entry;
 
  36  * The single block format is as follows:
 
  37  * xfs_dir2_data_hdr_t structure
 
  38  * xfs_dir2_data_entry_t and xfs_dir2_data_unused_t structures
 
  39  * xfs_dir2_leaf_entry_t structures
 
  40  * xfs_dir2_block_tail_t structure
 
  43 #define XFS_DIR2_BLOCK_MAGIC    0x58443242      /* XD2B: for one block dirs */
 
  45 typedef struct xfs_dir2_block_tail {
 
  46         __uint32_t      count;                  /* count of leaf entries */
 
  47         __uint32_t      stale;                  /* count of stale lf entries */
 
  48 } xfs_dir2_block_tail_t;
 
  51  * Generic single-block structure, for xfs_db.
 
  53 typedef struct xfs_dir2_block {
 
  54         xfs_dir2_data_hdr_t     hdr;            /* magic XFS_DIR2_BLOCK_MAGIC */
 
  55         xfs_dir2_data_union_t   u[1];
 
  56         xfs_dir2_leaf_entry_t   leaf[1];
 
  57         xfs_dir2_block_tail_t   tail;
 
  61  * Pointer to the leaf header embedded in a data block (1-block format)
 
  63 #define XFS_DIR2_BLOCK_TAIL_P(mp,block) xfs_dir2_block_tail_p(mp,block)
 
  64 static inline xfs_dir2_block_tail_t *
 
  65 xfs_dir2_block_tail_p(struct xfs_mount *mp, xfs_dir2_block_t *block)
 
  67         return (((xfs_dir2_block_tail_t *)
 
  68                 ((char *)(block) + (mp)->m_dirblksize)) - 1);
 
  72  * Pointer to the leaf entries embedded in a data block (1-block format)
 
  74 #define XFS_DIR2_BLOCK_LEAF_P(btp)      xfs_dir2_block_leaf_p(btp)
 
  75 static inline struct xfs_dir2_leaf_entry *
 
  76 xfs_dir2_block_leaf_p(xfs_dir2_block_tail_t *btp)
 
  78         return (((struct xfs_dir2_leaf_entry *)
 
  79                 (btp)) - INT_GET((btp)->count, ARCH_CONVERT));
 
  83  * Function declarations.
 
  85 extern int xfs_dir2_block_addname(struct xfs_da_args *args);
 
  86 extern int xfs_dir2_block_getdents(struct xfs_trans *tp, struct xfs_inode *dp,
 
  87                                    struct uio *uio, int *eofp,
 
  88                                    struct xfs_dirent *dbp, xfs_dir2_put_t put);
 
  89 extern int xfs_dir2_block_lookup(struct xfs_da_args *args);
 
  90 extern int xfs_dir2_block_removename(struct xfs_da_args *args);
 
  91 extern int xfs_dir2_block_replace(struct xfs_da_args *args);
 
  92 extern int xfs_dir2_leaf_to_block(struct xfs_da_args *args,
 
  93                                   struct xfs_dabuf *lbp, struct xfs_dabuf *dbp);
 
  94 extern int xfs_dir2_sf_to_block(struct xfs_da_args *args);
 
  96 #endif  /* __XFS_DIR2_BLOCK_H__ */