blob: 43fb8e7664118804e366dc4626acac55fbd0d644 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Uma Shankara74a99a2012-05-25 21:22:49 +05302/*
3 * (C) Copyright 2011 - 2012 Samsung Electronics
4 * EXT4 filesystem implementation in Uboot by
5 * Uma Shankar <uma.shankar@samsung.com>
6 * Manjunatha C Achar <a.manjunatha@samsung.com>
7 *
8 * Journal data structures and headers for Journaling feature of ext4
9 * have been referred from JBD2 (Journaling Block device 2)
10 * implementation in Linux Kernel.
11 *
12 * Written by Stephen C. Tweedie <sct@redhat.com>
13 *
14 * Copyright 1998-2000 Red Hat, Inc --- All Rights Reserved
Uma Shankara74a99a2012-05-25 21:22:49 +053015 */
16
17#ifndef __EXT4_JRNL__
18#define __EXT4_JRNL__
19
Marek Szyprowskia9588152019-06-21 15:35:35 +020020#define EXT4_FEATURE_COMPAT_HAS_JOURNAL 0x0004
21
Uma Shankara74a99a2012-05-25 21:22:49 +053022#define EXT2_JOURNAL_INO 8 /* Journal inode */
23#define EXT2_JOURNAL_SUPERBLOCK 0 /* Journal Superblock number */
24
25#define JBD2_FEATURE_COMPAT_CHECKSUM 0x00000001
26#define EXT3_JOURNAL_MAGIC_NUMBER 0xc03b3998U
27#define TRANSACTION_RUNNING 1
28#define TRANSACTION_COMPLETE 0
29#define EXT3_FEATURE_INCOMPAT_RECOVER 0x0004 /* Needs recovery */
30#define EXT3_JOURNAL_DESCRIPTOR_BLOCK 1
31#define EXT3_JOURNAL_COMMIT_BLOCK 2
32#define EXT3_JOURNAL_SUPERBLOCK_V1 3
33#define EXT3_JOURNAL_SUPERBLOCK_V2 4
34#define EXT3_JOURNAL_REVOKE_BLOCK 5
35#define EXT3_JOURNAL_FLAG_ESCAPE 1
36#define EXT3_JOURNAL_FLAG_SAME_UUID 2
37#define EXT3_JOURNAL_FLAG_DELETED 4
38#define EXT3_JOURNAL_FLAG_LAST_TAG 8
39
40/* Maximum entries in 1 journal transaction */
41#define MAX_JOURNAL_ENTRIES 100
42struct journal_log {
43 char *buf;
44 int blknr;
45};
46
47struct dirty_blocks {
48 char *buf;
49 int blknr;
50};
51
52/* Standard header for all descriptor blocks: */
53struct journal_header_t {
Michael Walle2a819612016-08-29 10:46:43 +020054 __be32 h_magic;
55 __be32 h_blocktype;
56 __be32 h_sequence;
Uma Shankara74a99a2012-05-25 21:22:49 +053057};
58
59/* The journal superblock. All fields are in big-endian byte order. */
60struct journal_superblock_t {
61 /* 0x0000 */
62 struct journal_header_t s_header;
63
64 /* Static information describing the journal */
Michael Walle2a819612016-08-29 10:46:43 +020065 __be32 s_blocksize; /* journal device blocksize */
66 __be32 s_maxlen; /* total blocks in journal file */
67 __be32 s_first; /* first block of log information */
Uma Shankara74a99a2012-05-25 21:22:49 +053068
69 /* Dynamic information describing the current state of the log */
Michael Walle2a819612016-08-29 10:46:43 +020070 __be32 s_sequence; /* first commit ID expected in log */
71 __be32 s_start; /* blocknr of start of log */
Uma Shankara74a99a2012-05-25 21:22:49 +053072
73 /* Error value, as set by journal_abort(). */
Michael Walle2a819612016-08-29 10:46:43 +020074 __be32 s_errno;
Uma Shankara74a99a2012-05-25 21:22:49 +053075
76 /* Remaining fields are only valid in a version-2 superblock */
Michael Walle2a819612016-08-29 10:46:43 +020077 __be32 s_feature_compat; /* compatible feature set */
78 __be32 s_feature_incompat; /* incompatible feature set */
79 __be32 s_feature_ro_compat; /* readonly-compatible feature set */
Uma Shankara74a99a2012-05-25 21:22:49 +053080 /* 0x0030 */
81 __u8 s_uuid[16]; /* 128-bit uuid for journal */
82
83 /* 0x0040 */
Michael Walle2a819612016-08-29 10:46:43 +020084 __be32 s_nr_users; /* Nr of filesystems sharing log */
Uma Shankara74a99a2012-05-25 21:22:49 +053085
Michael Walle2a819612016-08-29 10:46:43 +020086 __be32 s_dynsuper; /* Blocknr of dynamic superblock copy */
Uma Shankara74a99a2012-05-25 21:22:49 +053087
88 /* 0x0048 */
Michael Walle2a819612016-08-29 10:46:43 +020089 __be32 s_max_transaction; /* Limit of journal blocks per trans. */
90 __be32 s_max_trans_data; /* Limit of data blocks per trans. */
Uma Shankara74a99a2012-05-25 21:22:49 +053091
92 /* 0x0050 */
Michael Walle2a819612016-08-29 10:46:43 +020093 __be32 s_padding[44];
Uma Shankara74a99a2012-05-25 21:22:49 +053094
95 /* 0x0100 */
96 __u8 s_users[16 * 48]; /* ids of all fs'es sharing the log */
97 /* 0x0400 */
98} ;
99
100struct ext3_journal_block_tag {
Michael Walle2a819612016-08-29 10:46:43 +0200101 __be32 block;
102 __be32 flags;
Uma Shankara74a99a2012-05-25 21:22:49 +0530103};
104
105struct journal_revoke_header_t {
106 struct journal_header_t r_header;
Michael Walle2a819612016-08-29 10:46:43 +0200107 __be32 r_count; /* Count of bytes used in the block */
Uma Shankara74a99a2012-05-25 21:22:49 +0530108};
109
110struct revoke_blk_list {
111 char *content; /* revoke block itself */
112 struct revoke_blk_list *next;
113};
114
115extern struct ext2_data *ext4fs_root;
116
117int ext4fs_init_journal(void);
118int ext4fs_log_gdt(char *gd_table);
119int ext4fs_check_journal_state(int recovery_flag);
Michael Walle13179c22016-09-01 11:21:40 +0200120int ext4fs_log_journal(char *journal_buffer, uint32_t blknr);
121int ext4fs_put_metadata(char *metadata_buffer, uint32_t blknr);
Uma Shankara74a99a2012-05-25 21:22:49 +0530122void ext4fs_update_journal(void);
123void ext4fs_dump_metadata(void);
124void ext4fs_push_revoke_blk(char *buffer);
125void ext4fs_free_journal(void);
126void ext4fs_free_revoke_blks(void);
127#endif