ext4_xattr.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /*
  2. * Copyright (c) 2015 Grzegorz Kostka (kostka.grzegorz@gmail.com)
  3. * Copyright (c) 2015 Kaho Ng (ngkaho1234@gmail.com)
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. *
  9. * - Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. * - Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in the
  13. * documentation and/or other materials provided with the distribution.
  14. * - The name of the author may not be used to endorse or promote products
  15. * derived from this software without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  18. * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  19. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  20. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  21. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  22. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  23. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  24. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  25. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  26. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27. */
  28. /** @addtogroup lwext4
  29. * @{
  30. */
  31. /**
  32. * @file ext4_xattr.h
  33. * @brief Extended Attribute manipulation.
  34. */
  35. #ifndef EXT4_XATTR_H_
  36. #define EXT4_XATTR_H_
  37. #ifdef __cplusplus
  38. extern "C" {
  39. #endif
  40. #include <ext4_config.h>
  41. #include <ext4_types.h>
  42. #include <ext4_inode.h>
  43. struct ext4_xattr_info {
  44. uint8_t name_index;
  45. const char *name;
  46. size_t name_len;
  47. const void *value;
  48. size_t value_len;
  49. };
  50. struct ext4_xattr_list_entry {
  51. uint8_t name_index;
  52. char *name;
  53. size_t name_len;
  54. struct ext4_xattr_list_entry *next;
  55. };
  56. struct ext4_xattr_search {
  57. /* The first entry in the buffer */
  58. struct ext4_xattr_entry *first;
  59. /* The address of the buffer */
  60. void *base;
  61. /* The first inaccessible address */
  62. void *end;
  63. /* The current entry pointer */
  64. struct ext4_xattr_entry *here;
  65. /* Entry not found */
  66. bool not_found;
  67. };
  68. const char *ext4_extract_xattr_name(const char *full_name, size_t full_name_len,
  69. uint8_t *name_index, size_t *name_len,
  70. bool *found);
  71. const char *ext4_get_xattr_name_prefix(uint8_t name_index,
  72. size_t *ret_prefix_len);
  73. int ext4_xattr_list(struct ext4_inode_ref *inode_ref,
  74. struct ext4_xattr_list_entry *list, size_t *list_len);
  75. int ext4_xattr_get(struct ext4_inode_ref *inode_ref, uint8_t name_index,
  76. const char *name, size_t name_len, void *buf, size_t buf_len,
  77. size_t *data_len);
  78. int ext4_xattr_remove(struct ext4_inode_ref *inode_ref, uint8_t name_index,
  79. const char *name, size_t name_len);
  80. int ext4_xattr_set(struct ext4_inode_ref *inode_ref, uint8_t name_index,
  81. const char *name, size_t name_len, const void *value,
  82. size_t value_len);
  83. #ifdef __cplusplus
  84. }
  85. #endif
  86. #endif
  87. /**
  88. * @}
  89. */