xfs_dir2.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /*
  2. * Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
  3. * All Rights Reserved.
  4. *
  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.
  8. *
  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.
  13. *
  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
  17. */
  18. #ifndef __XFS_DIR2_H__
  19. #define __XFS_DIR2_H__
  20. struct uio;
  21. struct xfs_dabuf;
  22. struct xfs_da_args;
  23. struct xfs_dir2_put_args;
  24. struct xfs_inode;
  25. struct xfs_trans;
  26. /*
  27. * Directory version 2.
  28. * There are 4 possible formats:
  29. * shortform
  30. * single block - data with embedded leaf at the end
  31. * multiple data blocks, single leaf+freeindex block
  32. * data blocks, node&leaf blocks (btree), freeindex blocks
  33. *
  34. * The shortform format is in xfs_dir2_sf.h.
  35. * The single block format is in xfs_dir2_block.h.
  36. * The data block format is in xfs_dir2_data.h.
  37. * The leaf and freeindex block formats are in xfs_dir2_leaf.h.
  38. * Node blocks are the same as the other version, in xfs_da_btree.h.
  39. */
  40. /*
  41. * Byte offset in data block and shortform entry.
  42. */
  43. typedef __uint16_t xfs_dir2_data_off_t;
  44. #define NULLDATAOFF 0xffffU
  45. typedef uint xfs_dir2_data_aoff_t; /* argument form */
  46. /*
  47. * Directory block number (logical dirblk in file)
  48. */
  49. typedef __uint32_t xfs_dir2_db_t;
  50. /*
  51. * Byte offset in a directory.
  52. */
  53. typedef xfs_off_t xfs_dir2_off_t;
  54. /*
  55. * For getdents, argument struct for put routines.
  56. */
  57. typedef int (*xfs_dir2_put_t)(struct xfs_dir2_put_args *pa);
  58. typedef struct xfs_dir2_put_args {
  59. xfs_off_t cook; /* cookie of (next) entry */
  60. xfs_intino_t ino; /* inode number */
  61. xfs_dirent_t *dbp; /* buffer pointer */
  62. char *name; /* directory entry name */
  63. int namelen; /* length of name */
  64. int done; /* output: set if value was stored */
  65. xfs_dir2_put_t put; /* put function ptr (i/o) */
  66. struct uio *uio; /* uio control structure */
  67. } xfs_dir2_put_args_t;
  68. /*
  69. * Other interfaces used by the rest of the dir v2 code.
  70. */
  71. extern int xfs_dir2_grow_inode(struct xfs_da_args *args, int space,
  72. xfs_dir2_db_t *dbp);
  73. extern int xfs_dir2_isblock(struct xfs_trans *tp, struct xfs_inode *dp,
  74. int *vp);
  75. extern int xfs_dir2_isleaf(struct xfs_trans *tp, struct xfs_inode *dp,
  76. int *vp);
  77. extern int xfs_dir2_shrink_inode(struct xfs_da_args *args, xfs_dir2_db_t db,
  78. struct xfs_dabuf *bp);
  79. #endif /* __XFS_DIR2_H__ */