fiemap.txt 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. ============
  2. Fiemap Ioctl
  3. ============
  4. The fiemap ioctl is an efficient method for userspace to get file
  5. extent mappings. Instead of block-by-block mapping (such as bmap), fiemap
  6. returns a list of extents.
  7. Request Basics
  8. --------------
  9. A fiemap request is encoded within struct fiemap:
  10. struct fiemap {
  11. __u64 fm_start; /* logical offset (inclusive) at
  12. * which to start mapping (in) */
  13. __u64 fm_length; /* logical length of mapping which
  14. * userspace cares about (in) */
  15. __u32 fm_flags; /* FIEMAP_FLAG_* flags for request (in/out) */
  16. __u32 fm_mapped_extents; /* number of extents that were
  17. * mapped (out) */
  18. __u32 fm_extent_count; /* size of fm_extents array (in) */
  19. __u32 fm_reserved;
  20. struct fiemap_extent fm_extents[0]; /* array of mapped extents (out) */
  21. };
  22. fm_start, and fm_length specify the logical range within the file
  23. which the process would like mappings for. Extents returned mirror
  24. those on disk - that is, the logical offset of the 1st returned extent
  25. may start before fm_start, and the range covered by the last returned
  26. extent may end after fm_length. All offsets and lengths are in bytes.
  27. Certain flags to modify the way in which mappings are looked up can be
  28. set in fm_flags. If the kernel doesn't understand some particular
  29. flags, it will return EBADR and the contents of fm_flags will contain
  30. the set of flags which caused the error. If the kernel is compatible
  31. with all flags passed, the contents of fm_flags will be unmodified.
  32. It is up to userspace to determine whether rejection of a particular
  33. flag is fatal to its operation. This scheme is intended to allow the
  34. fiemap interface to grow in the future but without losing
  35. compatibility with old software.
  36. fm_extent_count specifies the number of elements in the fm_extents[] array
  37. that can be used to return extents. If fm_extent_count is zero, then the
  38. fm_extents[] array is ignored (no extents will be returned), and the
  39. fm_mapped_extents count will hold the number of extents needed in
  40. fm_extents[] to hold the file's current mapping. Note that there is
  41. nothing to prevent the file from changing between calls to FIEMAP.
  42. The following flags can be set in fm_flags:
  43. * FIEMAP_FLAG_SYNC
  44. If this flag is set, the kernel will sync the file before mapping extents.
  45. * FIEMAP_FLAG_XATTR
  46. If this flag is set, the extents returned will describe the inodes
  47. extended attribute lookup tree, instead of its data tree.
  48. Extent Mapping
  49. --------------
  50. Extent information is returned within the embedded fm_extents array
  51. which userspace must allocate along with the fiemap structure. The
  52. number of elements in the fiemap_extents[] array should be passed via
  53. fm_extent_count. The number of extents mapped by kernel will be
  54. returned via fm_mapped_extents. If the number of fiemap_extents
  55. allocated is less than would be required to map the requested range,
  56. the maximum number of extents that can be mapped in the fm_extent[]
  57. array will be returned and fm_mapped_extents will be equal to
  58. fm_extent_count. In that case, the last extent in the array will not
  59. complete the requested range and will not have the FIEMAP_EXTENT_LAST
  60. flag set (see the next section on extent flags).
  61. Each extent is described by a single fiemap_extent structure as
  62. returned in fm_extents.
  63. struct fiemap_extent {
  64. __u64 fe_logical; /* logical offset in bytes for the start of
  65. * the extent */
  66. __u64 fe_physical; /* physical offset in bytes for the start
  67. * of the extent */
  68. __u64 fe_length; /* length in bytes for the extent */
  69. __u64 fe_reserved64[2];
  70. __u32 fe_flags; /* FIEMAP_EXTENT_* flags for this extent */
  71. __u32 fe_reserved[3];
  72. };
  73. All offsets and lengths are in bytes and mirror those on disk. It is valid
  74. for an extents logical offset to start before the request or its logical
  75. length to extend past the request. Unless FIEMAP_EXTENT_NOT_ALIGNED is
  76. returned, fe_logical, fe_physical, and fe_length will be aligned to the
  77. block size of the file system. With the exception of extents flagged as
  78. FIEMAP_EXTENT_MERGED, adjacent extents will not be merged.
  79. The fe_flags field contains flags which describe the extent returned.
  80. A special flag, FIEMAP_EXTENT_LAST is always set on the last extent in
  81. the file so that the process making fiemap calls can determine when no
  82. more extents are available, without having to call the ioctl again.
  83. Some flags are intentionally vague and will always be set in the
  84. presence of other more specific flags. This way a program looking for
  85. a general property does not have to know all existing and future flags
  86. which imply that property.
  87. For example, if FIEMAP_EXTENT_DATA_INLINE or FIEMAP_EXTENT_DATA_TAIL
  88. are set, FIEMAP_EXTENT_NOT_ALIGNED will also be set. A program looking
  89. for inline or tail-packed data can key on the specific flag. Software
  90. which simply cares not to try operating on non-aligned extents
  91. however, can just key on FIEMAP_EXTENT_NOT_ALIGNED, and not have to
  92. worry about all present and future flags which might imply unaligned
  93. data. Note that the opposite is not true - it would be valid for
  94. FIEMAP_EXTENT_NOT_ALIGNED to appear alone.
  95. * FIEMAP_EXTENT_LAST
  96. This is the last extent in the file. A mapping attempt past this
  97. extent will return nothing.
  98. * FIEMAP_EXTENT_UNKNOWN
  99. The location of this extent is currently unknown. This may indicate
  100. the data is stored on an inaccessible volume or that no storage has
  101. been allocated for the file yet.
  102. * FIEMAP_EXTENT_DELALLOC
  103. - This will also set FIEMAP_EXTENT_UNKNOWN.
  104. Delayed allocation - while there is data for this extent, its
  105. physical location has not been allocated yet.
  106. * FIEMAP_EXTENT_ENCODED
  107. This extent does not consist of plain filesystem blocks but is
  108. encoded (e.g. encrypted or compressed). Reading the data in this
  109. extent via I/O to the block device will have undefined results.
  110. Note that it is *always* undefined to try to update the data
  111. in-place by writing to the indicated location without the
  112. assistance of the filesystem, or to access the data using the
  113. information returned by the FIEMAP interface while the filesystem
  114. is mounted. In other words, user applications may only read the
  115. extent data via I/O to the block device while the filesystem is
  116. unmounted, and then only if the FIEMAP_EXTENT_ENCODED flag is
  117. clear; user applications must not try reading or writing to the
  118. filesystem via the block device under any other circumstances.
  119. * FIEMAP_EXTENT_DATA_ENCRYPTED
  120. - This will also set FIEMAP_EXTENT_ENCODED
  121. The data in this extent has been encrypted by the file system.
  122. * FIEMAP_EXTENT_NOT_ALIGNED
  123. Extent offsets and length are not guaranteed to be block aligned.
  124. * FIEMAP_EXTENT_DATA_INLINE
  125. This will also set FIEMAP_EXTENT_NOT_ALIGNED
  126. Data is located within a meta data block.
  127. * FIEMAP_EXTENT_DATA_TAIL
  128. This will also set FIEMAP_EXTENT_NOT_ALIGNED
  129. Data is packed into a block with data from other files.
  130. * FIEMAP_EXTENT_UNWRITTEN
  131. Unwritten extent - the extent is allocated but its data has not been
  132. initialized. This indicates the extent's data will be all zero if read
  133. through the filesystem but the contents are undefined if read directly from
  134. the device.
  135. * FIEMAP_EXTENT_MERGED
  136. This will be set when a file does not support extents, i.e., it uses a block
  137. based addressing scheme. Since returning an extent for each block back to
  138. userspace would be highly inefficient, the kernel will try to merge most
  139. adjacent blocks into 'extents'.
  140. VFS -> File System Implementation
  141. ---------------------------------
  142. File systems wishing to support fiemap must implement a ->fiemap callback on
  143. their inode_operations structure. The fs ->fiemap call is responsible for
  144. defining its set of supported fiemap flags, and calling a helper function on
  145. each discovered extent:
  146. struct inode_operations {
  147. ...
  148. int (*fiemap)(struct inode *, struct fiemap_extent_info *, u64 start,
  149. u64 len);
  150. ->fiemap is passed struct fiemap_extent_info which describes the
  151. fiemap request:
  152. struct fiemap_extent_info {
  153. unsigned int fi_flags; /* Flags as passed from user */
  154. unsigned int fi_extents_mapped; /* Number of mapped extents */
  155. unsigned int fi_extents_max; /* Size of fiemap_extent array */
  156. struct fiemap_extent *fi_extents_start; /* Start of fiemap_extent array */
  157. };
  158. It is intended that the file system should not need to access any of this
  159. structure directly. Filesystem handlers should be tolerant to signals and return
  160. EINTR once fatal signal received.
  161. Flag checking should be done at the beginning of the ->fiemap callback via the
  162. fiemap_check_flags() helper:
  163. int fiemap_check_flags(struct fiemap_extent_info *fieinfo, u32 fs_flags);
  164. The struct fieinfo should be passed in as received from ioctl_fiemap(). The
  165. set of fiemap flags which the fs understands should be passed via fs_flags. If
  166. fiemap_check_flags finds invalid user flags, it will place the bad values in
  167. fieinfo->fi_flags and return -EBADR. If the file system gets -EBADR, from
  168. fiemap_check_flags(), it should immediately exit, returning that error back to
  169. ioctl_fiemap().
  170. For each extent in the request range, the file system should call
  171. the helper function, fiemap_fill_next_extent():
  172. int fiemap_fill_next_extent(struct fiemap_extent_info *info, u64 logical,
  173. u64 phys, u64 len, u32 flags, u32 dev);
  174. fiemap_fill_next_extent() will use the passed values to populate the
  175. next free extent in the fm_extents array. 'General' extent flags will
  176. automatically be set from specific flags on behalf of the calling file
  177. system so that the userspace API is not broken.
  178. fiemap_fill_next_extent() returns 0 on success, and 1 when the
  179. user-supplied fm_extents array is full. If an error is encountered
  180. while copying the extent to user memory, -EFAULT will be returned.