 84fb7ca4b3
			
		
	
	84fb7ca4b3
	
	
	
		
			
			Document the format of verity files on ext4, and the corresponding inode and superblock flags. Reviewed-by: Theodore Ts'o <tytso@mit.edu> Signed-off-by: Eric Biggers <ebiggers@google.com>
		
			
				
	
	
		
			28 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0
 | |
| 
 | |
| High Level Design
 | |
| =================
 | |
| 
 | |
| An ext4 file system is split into a series of block groups. To reduce
 | |
| performance difficulties due to fragmentation, the block allocator tries
 | |
| very hard to keep each file's blocks within the same group, thereby
 | |
| reducing seek times. The size of a block group is specified in
 | |
| ``sb.s_blocks_per_group`` blocks, though it can also calculated as 8 \*
 | |
| ``block_size_in_bytes``. With the default block size of 4KiB, each group
 | |
| will contain 32,768 blocks, for a length of 128MiB. The number of block
 | |
| groups is the size of the device divided by the size of a block group.
 | |
| 
 | |
| All fields in ext4 are written to disk in little-endian order. HOWEVER,
 | |
| all fields in jbd2 (the journal) are written to disk in big-endian
 | |
| order.
 | |
| 
 | |
| .. include:: blocks.rst
 | |
| .. include:: blockgroup.rst
 | |
| .. include:: special_inodes.rst
 | |
| .. include:: allocators.rst
 | |
| .. include:: checksums.rst
 | |
| .. include:: bigalloc.rst
 | |
| .. include:: inlinedata.rst
 | |
| .. include:: eainode.rst
 | |
| .. include:: verity.rst
 |