~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/filesystems/ext4/ifork.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /Documentation/filesystems/ext4/ifork.rst (Architecture sparc64) and /Documentation/filesystems/ext4/ifork.rst (Architecture sparc)


  1 .. SPDX-License-Identifier: GPL-2.0                 1 .. SPDX-License-Identifier: GPL-2.0
  2                                                     2 
  3 The Contents of inode.i_block                       3 The Contents of inode.i_block
  4 ------------------------------                      4 ------------------------------
  5                                                     5 
  6 Depending on the type of file an inode describ      6 Depending on the type of file an inode describes, the 60 bytes of
  7 storage in ``inode.i_block`` can be used in di      7 storage in ``inode.i_block`` can be used in different ways. In general,
  8 regular files and directories will use it for       8 regular files and directories will use it for file block indexing
  9 information, and special files will use it for      9 information, and special files will use it for special purposes.
 10                                                    10 
 11 Symbolic Links                                     11 Symbolic Links
 12 ~~~~~~~~~~~~~~                                     12 ~~~~~~~~~~~~~~
 13                                                    13 
 14 The target of a symbolic link will be stored i     14 The target of a symbolic link will be stored in this field if the target
 15 string is less than 60 bytes long. Otherwise,      15 string is less than 60 bytes long. Otherwise, either extents or block
 16 maps will be used to allocate data blocks to s     16 maps will be used to allocate data blocks to store the link target.
 17                                                    17 
 18 Direct/Indirect Block Addressing                   18 Direct/Indirect Block Addressing
 19 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~                   19 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 20                                                    20 
 21 In ext2/3, file block numbers were mapped to l     21 In ext2/3, file block numbers were mapped to logical block numbers by
 22 means of an (up to) three level 1-1 block map.     22 means of an (up to) three level 1-1 block map. To find the logical block
 23 that stores a particular file block, the code      23 that stores a particular file block, the code would navigate through
 24 this increasingly complicated structure. Notic     24 this increasingly complicated structure. Notice that there is neither a
 25 magic number nor a checksum to provide any lev     25 magic number nor a checksum to provide any level of confidence that the
 26 block isn't full of garbage.                       26 block isn't full of garbage.
 27                                                    27 
 28 .. ifconfig:: builder != 'latex'                   28 .. ifconfig:: builder != 'latex'
 29                                                    29 
 30    .. include:: blockmap.rst                       30    .. include:: blockmap.rst
 31                                                    31 
 32 .. ifconfig:: builder == 'latex'                   32 .. ifconfig:: builder == 'latex'
 33                                                    33 
 34    [Table omitted because LaTeX doesn't suppor     34    [Table omitted because LaTeX doesn't support nested tables.]
 35                                                    35 
 36 Note that with this block mapping scheme, it i     36 Note that with this block mapping scheme, it is necessary to fill out a
 37 lot of mapping data even for a large contiguou     37 lot of mapping data even for a large contiguous file! This inefficiency
 38 led to the creation of the extent mapping sche     38 led to the creation of the extent mapping scheme, discussed below.
 39                                                    39 
 40 Notice also that a file using this mapping sch     40 Notice also that a file using this mapping scheme cannot be placed
 41 higher than 2^32 blocks.                           41 higher than 2^32 blocks.
 42                                                    42 
 43 Extent Tree                                        43 Extent Tree
 44 ~~~~~~~~~~~                                        44 ~~~~~~~~~~~
 45                                                    45 
 46 In ext4, the file to logical block map has bee     46 In ext4, the file to logical block map has been replaced with an extent
 47 tree. Under the old scheme, allocating a conti     47 tree. Under the old scheme, allocating a contiguous run of 1,000 blocks
 48 requires an indirect block to map all 1,000 en     48 requires an indirect block to map all 1,000 entries; with extents, the
 49 mapping is reduced to a single ``struct ext4_e     49 mapping is reduced to a single ``struct ext4_extent`` with
 50 ``ee_len = 1000``. If flex_bg is enabled, it i     50 ``ee_len = 1000``. If flex_bg is enabled, it is possible to allocate
 51 very large files with a single extent, at a co     51 very large files with a single extent, at a considerable reduction in
 52 metadata block use, and some improvement in di     52 metadata block use, and some improvement in disk efficiency. The inode
 53 must have the extents flag (0x80000) flag set      53 must have the extents flag (0x80000) flag set for this feature to be in
 54 use.                                               54 use.
 55                                                    55 
 56 Extents are arranged as a tree. Each node of t     56 Extents are arranged as a tree. Each node of the tree begins with a
 57 ``struct ext4_extent_header``. If the node is      57 ``struct ext4_extent_header``. If the node is an interior node
 58 (``eh.eh_depth`` > 0), the header is followed      58 (``eh.eh_depth`` > 0), the header is followed by ``eh.eh_entries``
 59 instances of ``struct ext4_extent_idx``; each      59 instances of ``struct ext4_extent_idx``; each of these index entries
 60 points to a block containing more nodes in the     60 points to a block containing more nodes in the extent tree. If the node
 61 is a leaf node (``eh.eh_depth == 0``), then th     61 is a leaf node (``eh.eh_depth == 0``), then the header is followed by
 62 ``eh.eh_entries`` instances of ``struct ext4_e     62 ``eh.eh_entries`` instances of ``struct ext4_extent``; these instances
 63 point to the file's data blocks. The root node     63 point to the file's data blocks. The root node of the extent tree is
 64 stored in ``inode.i_block``, which allows for      64 stored in ``inode.i_block``, which allows for the first four extents to
 65 be recorded without the use of extra metadata      65 be recorded without the use of extra metadata blocks.
 66                                                    66 
 67 The extent tree header is recorded in ``struct     67 The extent tree header is recorded in ``struct ext4_extent_header``,
 68 which is 12 bytes long:                            68 which is 12 bytes long:
 69                                                    69 
 70 .. list-table::                                    70 .. list-table::
 71    :widths: 8 8 24 40                              71    :widths: 8 8 24 40
 72    :header-rows: 1                                 72    :header-rows: 1
 73                                                    73 
 74    * - Offset                                      74    * - Offset
 75      - Size                                        75      - Size
 76      - Name                                        76      - Name
 77      - Description                                 77      - Description
 78    * - 0x0                                         78    * - 0x0
 79      - __le16                                      79      - __le16
 80      - eh_magic                                    80      - eh_magic
 81      - Magic number, 0xF30A.                       81      - Magic number, 0xF30A.
 82    * - 0x2                                         82    * - 0x2
 83      - __le16                                      83      - __le16
 84      - eh_entries                                  84      - eh_entries
 85      - Number of valid entries following the h     85      - Number of valid entries following the header.
 86    * - 0x4                                         86    * - 0x4
 87      - __le16                                      87      - __le16
 88      - eh_max                                      88      - eh_max
 89      - Maximum number of entries that could fo     89      - Maximum number of entries that could follow the header.
 90    * - 0x6                                         90    * - 0x6
 91      - __le16                                      91      - __le16
 92      - eh_depth                                    92      - eh_depth
 93      - Depth of this extent node in the extent     93      - Depth of this extent node in the extent tree. 0 = this extent node
 94        points to data blocks; otherwise, this      94        points to data blocks; otherwise, this extent node points to other
 95        extent nodes. The extent tree can be at     95        extent nodes. The extent tree can be at most 5 levels deep: a logical
 96        block number can be at most ``2^32``, a     96        block number can be at most ``2^32``, and the smallest ``n`` that
 97        satisfies ``4*(((blocksize - 12)/12)^n)     97        satisfies ``4*(((blocksize - 12)/12)^n) >= 2^32`` is 5.
 98    * - 0x8                                         98    * - 0x8
 99      - __le32                                      99      - __le32
100      - eh_generation                              100      - eh_generation
101      - Generation of the tree. (Used by Lustre    101      - Generation of the tree. (Used by Lustre, but not standard ext4).
102                                                   102 
103 Internal nodes of the extent tree, also known     103 Internal nodes of the extent tree, also known as index nodes, are
104 recorded as ``struct ext4_extent_idx``, and ar    104 recorded as ``struct ext4_extent_idx``, and are 12 bytes long:
105                                                   105 
106 .. list-table::                                   106 .. list-table::
107    :widths: 8 8 24 40                             107    :widths: 8 8 24 40
108    :header-rows: 1                                108    :header-rows: 1
109                                                   109 
110    * - Offset                                     110    * - Offset
111      - Size                                       111      - Size
112      - Name                                       112      - Name
113      - Description                                113      - Description
114    * - 0x0                                        114    * - 0x0
115      - __le32                                     115      - __le32
116      - ei_block                                   116      - ei_block
117      - This index node covers file blocks from    117      - This index node covers file blocks from 'block' onward.
118    * - 0x4                                        118    * - 0x4
119      - __le32                                     119      - __le32
120      - ei_leaf_lo                                 120      - ei_leaf_lo
121      - Lower 32-bits of the block number of th    121      - Lower 32-bits of the block number of the extent node that is the next
122        level lower in the tree. The tree node     122        level lower in the tree. The tree node pointed to can be either another
123        internal node or a leaf node, described    123        internal node or a leaf node, described below.
124    * - 0x8                                        124    * - 0x8
125      - __le16                                     125      - __le16
126      - ei_leaf_hi                                 126      - ei_leaf_hi
127      - Upper 16-bits of the previous field.       127      - Upper 16-bits of the previous field.
128    * - 0xA                                        128    * - 0xA
129      - __u16                                      129      - __u16
130      - ei_unused                                  130      - ei_unused
131      -                                            131      -
132                                                   132 
133 Leaf nodes of the extent tree are recorded as     133 Leaf nodes of the extent tree are recorded as ``struct ext4_extent``,
134 and are also 12 bytes long:                       134 and are also 12 bytes long:
135                                                   135 
136 .. list-table::                                   136 .. list-table::
137    :widths: 8 8 24 40                             137    :widths: 8 8 24 40
138    :header-rows: 1                                138    :header-rows: 1
139                                                   139 
140    * - Offset                                     140    * - Offset
141      - Size                                       141      - Size
142      - Name                                       142      - Name
143      - Description                                143      - Description
144    * - 0x0                                        144    * - 0x0
145      - __le32                                     145      - __le32
146      - ee_block                                   146      - ee_block
147      - First file block number that this exten    147      - First file block number that this extent covers.
148    * - 0x4                                        148    * - 0x4
149      - __le16                                     149      - __le16
150      - ee_len                                     150      - ee_len
151      - Number of blocks covered by extent. If     151      - Number of blocks covered by extent. If the value of this field is <=
152        32768, the extent is initialized. If th    152        32768, the extent is initialized. If the value of the field is > 32768,
153        the extent is uninitialized and the act    153        the extent is uninitialized and the actual extent length is ``ee_len`` -
154        32768. Therefore, the maximum length of    154        32768. Therefore, the maximum length of a initialized extent is 32768
155        blocks, and the maximum length of an un    155        blocks, and the maximum length of an uninitialized extent is 32767.
156    * - 0x6                                        156    * - 0x6
157      - __le16                                     157      - __le16
158      - ee_start_hi                                158      - ee_start_hi
159      - Upper 16-bits of the block number to wh    159      - Upper 16-bits of the block number to which this extent points.
160    * - 0x8                                        160    * - 0x8
161      - __le32                                     161      - __le32
162      - ee_start_lo                                162      - ee_start_lo
163      - Lower 32-bits of the block number to wh    163      - Lower 32-bits of the block number to which this extent points.
164                                                   164 
165 Prior to the introduction of metadata checksum    165 Prior to the introduction of metadata checksums, the extent header +
166 extent entries always left at least 4 bytes of    166 extent entries always left at least 4 bytes of unallocated space at the
167 end of each extent tree data block (because (2    167 end of each extent tree data block (because (2^x % 12) >= 4). Therefore,
168 the 32-bit checksum is inserted into this spac    168 the 32-bit checksum is inserted into this space. The 4 extents in the
169 inode do not need checksumming, since the inod    169 inode do not need checksumming, since the inode is already checksummed.
170 The checksum is calculated against the FS UUID    170 The checksum is calculated against the FS UUID, the inode number, the
171 inode generation, and the entire extent block     171 inode generation, and the entire extent block leading up to (but not
172 including) the checksum itself.                   172 including) the checksum itself.
173                                                   173 
174 ``struct ext4_extent_tail`` is 4 bytes long:      174 ``struct ext4_extent_tail`` is 4 bytes long:
175                                                   175 
176 .. list-table::                                   176 .. list-table::
177    :widths: 8 8 24 40                             177    :widths: 8 8 24 40
178    :header-rows: 1                                178    :header-rows: 1
179                                                   179 
180    * - Offset                                     180    * - Offset
181      - Size                                       181      - Size
182      - Name                                       182      - Name
183      - Description                                183      - Description
184    * - 0x0                                        184    * - 0x0
185      - __le32                                     185      - __le32
186      - eb_checksum                                186      - eb_checksum
187      - Checksum of the extent block, crc32c(uu    187      - Checksum of the extent block, crc32c(uuid+inum+igeneration+extentblock)
188                                                   188 
189 Inline Data                                       189 Inline Data
190 ~~~~~~~~~~~                                       190 ~~~~~~~~~~~
191                                                   191 
192 If the inline data feature is enabled for the     192 If the inline data feature is enabled for the filesystem and the flag is
193 set for the inode, it is possible that the fir    193 set for the inode, it is possible that the first 60 bytes of the file
194 data are stored here.                             194 data are stored here.
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php