+.. SPDX-License-Identifier: GPL-2.0+
+
+Ext4 File System
+================
+
+Overview
+--------
+
U-Boot supports access of both ext2 and ext4 filesystems, either in read-only
mode or in read-write mode.
+Configuration
+-------------
+
First, to enable support for both ext4 (and, automatically, ext2 as well),
but without selecting the corresponding commands, enable one of the following:
+::
+
CONFIG_FS_EXT4 (for read-only)
CONFIG_EXT4_WRITE (for read-write)
use one or both of:
- CONFIG_CMD_EXT2
- CONFIG_CMD_EXT4
+::
+
+ CONFIG_CMD_EXT2
+ CONFIG_CMD_EXT4
Selecting either of the above automatically selects CONFIG_FS_EXT4 if it
wasn't enabled already.
-In addition, to get the write access command "ext4write", enable:
+In addition, to get the write access command ``ext4write``, enable:
- CONFIG_CMD_EXT4_WRITE
+::
+
+ CONFIG_CMD_EXT4_WRITE
which automatically selects CONFIG_EXT4_WRITE if it wasn't defined
already.
Also relevant are the generic filesystem commands, selected by:
- CONFIG_CMD_FS_GENERIC
+::
+
+ CONFIG_CMD_FS_GENERIC
This does not automatically enable EXT4 support for you, you still need
to do that yourself.
of memory to run successfully. The following enable support for
large Ext4 partitions:
+::
+
CONFIG_EXT4_MAX_JOURNAL_ENTRIES
CONFIG_SYS_MALLOC_LEN
to the partition capacity. For example, an ext4 4TB HDD partition could
require approximately 500 entries and more than 128 MB heap space.
+Examples
+--------
+
Some sample commands to test ext4 support:
-1. Check that the commands can be seen in the output of U-Boot help:
+1. Check that the ext4 commands can be seen in the output of U-Boot help:
+
+::
- UBOOT #help
+ => help
...
ext4load- load binary file from a Ext4 file system
ext4ls - list files in a directory (default /)
ext4write- create a file in ext4 formatted partition
...
-2. To list the files in an ext4-formatted partition, run:
+2. The ``ext4ls`` command can be used to list the files in an ext4-formatted partition:
+
+::
ext4ls <interface> <dev[:part]> [directory]
- For example:
- UBOOT #ext4ls mmc 0:5 /usr/lib
+For example, to list files in ext4-formatted partition directory /usr/lib:
+
+::
+
+ => ext4ls mmc 0:5 /usr/lib
+
+3. The ``ext4load`` command can be used to read and load a file from an
+ext4-formatted partition to RAM:
+
+::
+
+ ext4load <interface> [<dev[:part]> [addr [filename [bytes [pos]]]]]
+
+For example, to load file /uImage from an ext4-formatted partition:
+
+::
+
+ => ext4load mmc 2:2 0x30007fc0 uImage
+
+4. The ``ext4write`` command can be used to write to an ext4 partition:
+
+::
-3. To read and load a file from an ext4-formatted partition to RAM, run:
+ ext4write <interface> <dev[:part]> <addr> <absolute filename path> [sizebytes] [file offset]
- ext4load <interface> <dev[:part]> [addr] [filename] [bytes]
+For example, to write a file loaded at 0x8200000 of size 256 bytes to an
+ext4-formatted partition with the filename ``/boot/sample_file.hex``:
- For example:
- UBOOT #ext4load mmc 2:2 0x30007fc0 uImage
+::
-4. To write a file to an ext4-formatted partition.
+ => ext4write mmc 2:2 0x82000000 /boot/sample_file.hex 0x100
+ 256 bytes written in 138 ms (1000 Bytes/s)
- a) First load a file to RAM at a particular address for example 0x30007fc0.
- Now execute ext4write command:
- ext4write <interface> <dev[:part]> [filename] [Address] [sizebytes]
- For example:
- UBOOT #ext4write mmc 2:2 /boot/uImage 0x30007fc0 6183120
- (here 6183120 is the size of the file to be written)
- Note: Absolute path is required for the file to be written
+References
+----------
-References :
- -- ext4 implementation in Linux Kernel
- -- Uboot existing ext2 load and ls implementation
- -- Journaling block device JBD2 implementation in linux Kernel
+ * ext4 implementation in Linux Kernel
+ * Uboot existing ext2 load and ls implementation
+ * Journaling block device JBD2 implementation in linux Kernel