dir.h 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /* -*- mode: c; c-basic-offset: 8; -*-
  2. * vim: noexpandtab sw=8 ts=8 sts=0:
  3. *
  4. * dir.h
  5. *
  6. * Function prototypes
  7. *
  8. * Copyright (C) 2002, 2004 Oracle. All rights reserved.
  9. *
  10. * This program is free software; you can redistribute it and/or
  11. * modify it under the terms of the GNU General Public
  12. * License as published by the Free Software Foundation; either
  13. * version 2 of the License, or (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  18. * General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU General Public
  21. * License along with this program; if not, write to the
  22. * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
  23. * Boston, MA 021110-1307, USA.
  24. */
  25. #ifndef OCFS2_DIR_H
  26. #define OCFS2_DIR_H
  27. struct ocfs2_dir_lookup_result {
  28. struct buffer_head *dl_leaf_bh;
  29. struct ocfs2_dir_entry *dl_entry;
  30. };
  31. void ocfs2_free_dir_lookup_result(struct ocfs2_dir_lookup_result *res);
  32. int ocfs2_find_entry(const char *name, int namelen,
  33. struct inode *dir,
  34. struct ocfs2_dir_lookup_result *lookup);
  35. int ocfs2_delete_entry(handle_t *handle,
  36. struct inode *dir,
  37. struct ocfs2_dir_lookup_result *res);
  38. int __ocfs2_add_entry(handle_t *handle,
  39. struct inode *dir,
  40. const char *name, int namelen,
  41. struct inode *inode, u64 blkno,
  42. struct buffer_head *parent_fe_bh,
  43. struct ocfs2_dir_lookup_result *lookup);
  44. static inline int ocfs2_add_entry(handle_t *handle,
  45. struct dentry *dentry,
  46. struct inode *inode, u64 blkno,
  47. struct buffer_head *parent_fe_bh,
  48. struct ocfs2_dir_lookup_result *lookup)
  49. {
  50. return __ocfs2_add_entry(handle, dentry->d_parent->d_inode,
  51. dentry->d_name.name, dentry->d_name.len,
  52. inode, blkno, parent_fe_bh, lookup);
  53. }
  54. int ocfs2_update_entry(struct inode *dir, handle_t *handle,
  55. struct ocfs2_dir_lookup_result *res,
  56. struct inode *new_entry_inode);
  57. int ocfs2_check_dir_for_entry(struct inode *dir,
  58. const char *name,
  59. int namelen);
  60. int ocfs2_empty_dir(struct inode *inode);
  61. int ocfs2_find_files_on_disk(const char *name,
  62. int namelen,
  63. u64 *blkno,
  64. struct inode *inode,
  65. struct ocfs2_dir_lookup_result *res);
  66. int ocfs2_lookup_ino_from_name(struct inode *dir, const char *name,
  67. int namelen, u64 *blkno);
  68. int ocfs2_readdir(struct file *filp, void *dirent, filldir_t filldir);
  69. int ocfs2_dir_foreach(struct inode *inode, loff_t *f_pos, void *priv,
  70. filldir_t filldir);
  71. int ocfs2_prepare_dir_for_insert(struct ocfs2_super *osb,
  72. struct inode *dir,
  73. struct buffer_head *parent_fe_bh,
  74. const char *name,
  75. int namelen,
  76. struct ocfs2_dir_lookup_result *lookup);
  77. struct ocfs2_alloc_context;
  78. int ocfs2_fill_new_dir(struct ocfs2_super *osb,
  79. handle_t *handle,
  80. struct inode *parent,
  81. struct inode *inode,
  82. struct buffer_head *fe_bh,
  83. struct ocfs2_alloc_context *data_ac);
  84. struct ocfs2_dir_block_trailer *ocfs2_dir_trailer_from_size(int blocksize,
  85. void *data);
  86. #endif /* OCFS2_DIR_H */