ext4_dir_idx.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /*
  2. * Copyright (c) 2013 Grzegorz Kostka (kostka.grzegorz@gmail.com)
  3. *
  4. *
  5. * HelenOS:
  6. * Copyright (c) 2012 Martin Sucha
  7. * Copyright (c) 2012 Frantisek Princ
  8. * All rights reserved.
  9. *
  10. * Redistribution and use in source and binary forms, with or without
  11. * modification, are permitted provided that the following conditions
  12. * are met:
  13. *
  14. * - Redistributions of source code must retain the above copyright
  15. * notice, this list of conditions and the following disclaimer.
  16. * - Redistributions in binary form must reproduce the above copyright
  17. * notice, this list of conditions and the following disclaimer in the
  18. * documentation and/or other materials provided with the distribution.
  19. * - The name of the author may not be used to endorse or promote products
  20. * derived from this software without specific prior written permission.
  21. *
  22. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  23. * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  24. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  25. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  26. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  27. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  28. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  29. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  30. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  31. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  32. */
  33. /** @addtogroup lwext4
  34. * @{
  35. */
  36. /**
  37. * @file ext4_dir_idx.h
  38. * @brief Directory indexing procedures.
  39. */
  40. #ifndef EXT4_DIR_IDX_H_
  41. #define EXT4_DIR_IDX_H_
  42. #ifdef __cplusplus
  43. extern "C" {
  44. #endif
  45. #include <ext4_config.h>
  46. #include <ext4_types.h>
  47. #include <ext4_fs.h>
  48. #include <ext4_dir.h>
  49. #include <stdint.h>
  50. #include <stdbool.h>
  51. struct ext4_dir_idx_block {
  52. struct ext4_block b;
  53. struct ext4_dir_idx_entry *entries;
  54. struct ext4_dir_idx_entry *position;
  55. };
  56. #define EXT4_DIR_DX_INIT_BCNT 2
  57. /**@brief Initialize index structure of new directory.
  58. * @param dir Pointer to directory i-node
  59. * @param dir Pointer to parent directory i-node
  60. * @return Error code
  61. */
  62. int ext4_dir_dx_init(struct ext4_inode_ref *dir,
  63. struct ext4_inode_ref *parent);
  64. /**@brief Try to find directory entry using directory index.
  65. * @param result Output value - if entry will be found,
  66. * than will be passed through this parameter
  67. * @param inode_ref Directory i-node
  68. * @param name_len Length of name to be found
  69. * @param name Name to be found
  70. * @return Error code
  71. */
  72. int ext4_dir_dx_find_entry(struct ext4_dir_search_result *result,
  73. struct ext4_inode_ref *inode_ref, size_t name_len,
  74. const char *name);
  75. /**@brief Add new entry to indexed directory
  76. * @param parent Directory i-node
  77. * @param child I-node to be referenced from directory entry
  78. * @param name Name of new directory entry
  79. * @return Error code
  80. */
  81. int ext4_dir_dx_add_entry(struct ext4_inode_ref *parent,
  82. struct ext4_inode_ref *child, const char *name, uint32_t name_len);
  83. /**@brief Add new entry to indexed directory
  84. * @param dir Directory i-node
  85. * @param parent_inode parent inode index
  86. * @return Error code
  87. */
  88. int ext4_dir_dx_reset_parent_inode(struct ext4_inode_ref *dir,
  89. uint32_t parent_inode);
  90. #ifdef __cplusplus
  91. }
  92. #endif
  93. #endif /* EXT4_DIR_IDX_H_ */
  94. /**
  95. * @}
  96. */