1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
//! Configuration constants used across the ext4 implementation.
use crate*;
// ============================================================================
// Journal configuration
// ============================================================================
/// Maximum number of in-memory JBD2 update buffers.
pub const JBD2_BUFFER_MAX: usize = 10;
// ============================================================================
// Block geometry
// ============================================================================
/// Filesystem block size in bytes.
pub const BLOCK_SIZE: usize = 4096;
pub const BLOCK_SIZE_U32: u32 = BLOCK_SIZE as u32;
/// Log2 delta stored in `s_log_block_size`.
///
/// ext4 encodes the real block size as `1024 << s_log_block_size`, so `2`
/// means a 4 KiB block size.
pub const LOG_BLOCK_SIZE: u32 = 2;
// ============================================================================
// Block-group layout
// ============================================================================
/// Size of a 64-bit ext4 group descriptor in bytes.
pub const GROUP_DESC_SIZE: u16 = 64;
/// Size of a legacy 32-bit ext4 group descriptor in bytes.
pub const GROUP_DESC_SIZE_OLD: u16 = 32;
// ============================================================================
// Inode geometry
// ============================================================================
/// Default inode size in bytes.
///
/// NOTE: real inode size is stored in superblock.s_inode_size.
/// This constant should only be used as a fallback when s_inode_size is 0.
pub const DEFAULT_INODE_SIZE: u16 = 256;
// ============================================================================
// Cache sizing
// ============================================================================
/// Enables the multi-level cache stack for inode tables, data blocks, bitmaps,
/// and group descriptors.
pub const USE_MULTILEVEL_CACHE: bool = cfg!;
/// Maximum number of inode-table cache entries.
pub const INODE_CACHE_MAX: usize = 128;
/// Maximum number of data-block cache entries.
pub const DATABLOCK_CACHE_MAX: usize = 128;
/// Maximum number of bitmap cache entries.
pub const BITMAP_CACHE_MAX: usize = 128;
// ============================================================================
// Directory entry layout
// ============================================================================
/// Maximum ext4 directory entry name length.
pub const DIRNAME_LEN: usize = 255;
/// Number of reserved inode numbers at the start of the filesystem.
pub const RESERVED_INODES: u32 = 10;
// ============================================================================
// Filesystem layout
// ============================================================================
/// On-disk byte offset of the primary superblock.
///
/// ext4 keeps the primary superblock at byte offset 1024 so the leading boot
/// area remains untouched.
pub const SUPERBLOCK_OFFSET: u64 = 1024;
/// Serialized superblock size in bytes.
pub const SUPERBLOCK_SIZE: usize = 1024;
/// Number of reserved GDT blocks kept for future online resize growth.
pub const RESERVED_GDT_BLOCKS: u32 = 0;
// ============================================================================
// Feature flags
// ============================================================================
/// Default COMPAT feature bitset written by mkfs.
pub const DEFAULT_FEATURE_COMPAT: u32 =
EXT4_FEATURE_COMPAT_HAS_JOURNAL | EXT4_FEATURE_COMPAT_DIR_INDEX;
/// Default INCOMPAT feature bitset written by mkfs.
pub const DEFAULT_FEATURE_INCOMPAT: u32 = EXT4_FEATURE_INCOMPAT_FILETYPE
| EXT4_FEATURE_INCOMPAT_64BIT
| EXT4_FEATURE_INCOMPAT_EXTENTS;
/// Default RO_COMPAT feature bitset written by mkfs.
pub const DEFAULT_FEATURE_RO_COMPAT: u32 = EXT4_FEATURE_RO_COMPAT_EXTRA_ISIZE
| EXT4_FEATURE_RO_COMPAT_SPARSE_SUPER
| EXT4_FEATURE_RO_COMPAT_METADATA_CSUM;
// ============================================================================
// Magic values and versioning
// ============================================================================
/// ext4 superblock magic stored in `s_magic`.
pub const EXT4_SUPER_MAGIC: u16 = 0xEF53;
/// Filesystem major revision advertised by mkfs.
pub const EXT4_MAJOR_VERSION: u32 = 1;
/// Filesystem minor revision advertised by mkfs.
pub const EXT4_MINOR_VERSION: u16 = 0;