|  | .. SPDX-License-Identifier: GPL-2.0 | 
|  |  | 
|  | About this Book | 
|  | =============== | 
|  |  | 
|  | This document attempts to describe the on-disk format for ext4 | 
|  | filesystems. The same general ideas should apply to ext2/3 filesystems | 
|  | as well, though they do not support all the features that ext4 supports, | 
|  | and the fields will be shorter. | 
|  |  | 
|  | **NOTE**: This is a work in progress, based on notes that the author | 
|  | (djwong) made while picking apart a filesystem by hand. The data | 
|  | structure definitions should be current as of Linux 4.18 and | 
|  | e2fsprogs-1.44. All comments and corrections are welcome, since there is | 
|  | undoubtedly plenty of lore that might not be reflected in freshly | 
|  | created demonstration filesystems. | 
|  |  | 
|  | License | 
|  | ------- | 
|  | This book is licensed under the terms of the GNU Public License, v2. | 
|  |  | 
|  | Terminology | 
|  | ----------- | 
|  |  | 
|  | ext4 divides a storage device into an array of logical blocks both to | 
|  | reduce bookkeeping overhead and to increase throughput by forcing larger | 
|  | transfer sizes. Generally, the block size will be 4KiB (the same size as | 
|  | pages on x86 and the block layer's default block size), though the | 
|  | actual size is calculated as 2 ^ (10 + ``sb.s_log_block_size``) bytes. | 
|  | Throughout this document, disk locations are given in terms of these | 
|  | logical blocks, not raw LBAs, and not 1024-byte blocks. For the sake of | 
|  | convenience, the logical block size will be referred to as | 
|  | ``$block_size`` throughout the rest of the document. | 
|  |  | 
|  | When referenced in ``preformatted text`` blocks, ``sb`` refers to fields | 
|  | in the super block, and ``inode`` refers to fields in an inode table | 
|  | entry. | 
|  |  | 
|  | Other References | 
|  | ---------------- | 
|  |  | 
|  | Also see http://www.nongnu.org/ext2-doc/ for quite a collection of | 
|  | information about ext2/3. Here's another old reference: | 
|  | http://wiki.osdev.org/Ext2 |