xref: /rk3399_rockchip-uboot/fs/ext4/ext4_journal.h (revision ed34f34dbaf206dfe223f4bc2147d600fe1b0f58)
1*ed34f34dSUma Shankar /*
2*ed34f34dSUma Shankar  * (C) Copyright 2011 - 2012 Samsung Electronics
3*ed34f34dSUma Shankar  * EXT4 filesystem implementation in Uboot by
4*ed34f34dSUma Shankar  * Uma Shankar <uma.shankar@samsung.com>
5*ed34f34dSUma Shankar  * Manjunatha C Achar <a.manjunatha@samsung.com>
6*ed34f34dSUma Shankar  *
7*ed34f34dSUma Shankar  * Journal data structures and headers for Journaling feature of ext4
8*ed34f34dSUma Shankar  * have been referred from JBD2 (Journaling Block device 2)
9*ed34f34dSUma Shankar  * implementation in Linux Kernel.
10*ed34f34dSUma Shankar  *
11*ed34f34dSUma Shankar  * Written by Stephen C. Tweedie <sct@redhat.com>
12*ed34f34dSUma Shankar  *
13*ed34f34dSUma Shankar  * Copyright 1998-2000 Red Hat, Inc --- All Rights Reserved
14*ed34f34dSUma Shankar  * This file is part of the Linux kernel and is made available under
15*ed34f34dSUma Shankar  * the terms of the GNU General Public License, version 2, or at your
16*ed34f34dSUma Shankar  * option, any later version, incorporated herein by reference.
17*ed34f34dSUma Shankar  *
18*ed34f34dSUma Shankar  * This program is free software; you can redistribute it and/or modify
19*ed34f34dSUma Shankar  * it under the terms of the GNU General Public License as published by
20*ed34f34dSUma Shankar  * the Free Software Foundation; either version 2 of the License, or
21*ed34f34dSUma Shankar  * (at your option) any later version.
22*ed34f34dSUma Shankar  *
23*ed34f34dSUma Shankar  * This program is distributed in the hope that it will be useful,
24*ed34f34dSUma Shankar  * but WITHOUT ANY WARRANTY; without even the implied warranty of
25*ed34f34dSUma Shankar  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
26*ed34f34dSUma Shankar  * GNU General Public License for more details.
27*ed34f34dSUma Shankar  *
28*ed34f34dSUma Shankar  * You should have received a copy of the GNU General Public License
29*ed34f34dSUma Shankar  * along with this program; if not, write to the Free Software
30*ed34f34dSUma Shankar  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
31*ed34f34dSUma Shankar  */
32*ed34f34dSUma Shankar 
33*ed34f34dSUma Shankar #ifndef __EXT4_JRNL__
34*ed34f34dSUma Shankar #define __EXT4_JRNL__
35*ed34f34dSUma Shankar 
36*ed34f34dSUma Shankar #define EXT2_JOURNAL_INO		8	/* Journal inode */
37*ed34f34dSUma Shankar #define EXT2_JOURNAL_SUPERBLOCK	0	/* Journal  Superblock number */
38*ed34f34dSUma Shankar 
39*ed34f34dSUma Shankar #define JBD2_FEATURE_COMPAT_CHECKSUM	0x00000001
40*ed34f34dSUma Shankar #define EXT3_JOURNAL_MAGIC_NUMBER	0xc03b3998U
41*ed34f34dSUma Shankar #define TRANSACTION_RUNNING		1
42*ed34f34dSUma Shankar #define TRANSACTION_COMPLETE		0
43*ed34f34dSUma Shankar #define EXT3_FEATURE_INCOMPAT_RECOVER	0x0004	/* Needs recovery */
44*ed34f34dSUma Shankar #define EXT3_JOURNAL_DESCRIPTOR_BLOCK	1
45*ed34f34dSUma Shankar #define EXT3_JOURNAL_COMMIT_BLOCK	2
46*ed34f34dSUma Shankar #define EXT3_JOURNAL_SUPERBLOCK_V1	3
47*ed34f34dSUma Shankar #define EXT3_JOURNAL_SUPERBLOCK_V2	4
48*ed34f34dSUma Shankar #define EXT3_JOURNAL_REVOKE_BLOCK	5
49*ed34f34dSUma Shankar #define EXT3_JOURNAL_FLAG_ESCAPE	1
50*ed34f34dSUma Shankar #define EXT3_JOURNAL_FLAG_SAME_UUID	2
51*ed34f34dSUma Shankar #define EXT3_JOURNAL_FLAG_DELETED	4
52*ed34f34dSUma Shankar #define EXT3_JOURNAL_FLAG_LAST_TAG	8
53*ed34f34dSUma Shankar 
54*ed34f34dSUma Shankar /* Maximum entries in 1 journal transaction */
55*ed34f34dSUma Shankar #define MAX_JOURNAL_ENTRIES 100
56*ed34f34dSUma Shankar struct journal_log {
57*ed34f34dSUma Shankar 	char *buf;
58*ed34f34dSUma Shankar 	int blknr;
59*ed34f34dSUma Shankar };
60*ed34f34dSUma Shankar 
61*ed34f34dSUma Shankar struct dirty_blocks {
62*ed34f34dSUma Shankar 	char *buf;
63*ed34f34dSUma Shankar 	int blknr;
64*ed34f34dSUma Shankar };
65*ed34f34dSUma Shankar 
66*ed34f34dSUma Shankar /* Standard header for all descriptor blocks: */
67*ed34f34dSUma Shankar struct journal_header_t {
68*ed34f34dSUma Shankar 	__u32 h_magic;
69*ed34f34dSUma Shankar 	__u32 h_blocktype;
70*ed34f34dSUma Shankar 	__u32 h_sequence;
71*ed34f34dSUma Shankar };
72*ed34f34dSUma Shankar 
73*ed34f34dSUma Shankar /* The journal superblock.  All fields are in big-endian byte order. */
74*ed34f34dSUma Shankar struct journal_superblock_t {
75*ed34f34dSUma Shankar 	/* 0x0000 */
76*ed34f34dSUma Shankar 	struct journal_header_t s_header;
77*ed34f34dSUma Shankar 
78*ed34f34dSUma Shankar 	/* Static information describing the journal */
79*ed34f34dSUma Shankar 	__u32 s_blocksize;	/* journal device blocksize */
80*ed34f34dSUma Shankar 	__u32 s_maxlen;		/* total blocks in journal file */
81*ed34f34dSUma Shankar 	__u32 s_first;		/* first block of log information */
82*ed34f34dSUma Shankar 
83*ed34f34dSUma Shankar 	/* Dynamic information describing the current state of the log */
84*ed34f34dSUma Shankar 	__u32 s_sequence;	/* first commit ID expected in log */
85*ed34f34dSUma Shankar 	__u32 s_start;		/* blocknr of start of log */
86*ed34f34dSUma Shankar 
87*ed34f34dSUma Shankar 	/* Error value, as set by journal_abort(). */
88*ed34f34dSUma Shankar 	__s32 s_errno;
89*ed34f34dSUma Shankar 
90*ed34f34dSUma Shankar 	/* Remaining fields are only valid in a version-2 superblock */
91*ed34f34dSUma Shankar 	__u32 s_feature_compat;	/* compatible feature set */
92*ed34f34dSUma Shankar 	__u32 s_feature_incompat;	/* incompatible feature set */
93*ed34f34dSUma Shankar 	__u32 s_feature_ro_compat;	/* readonly-compatible feature set */
94*ed34f34dSUma Shankar 	/* 0x0030 */
95*ed34f34dSUma Shankar 	__u8 s_uuid[16];	/* 128-bit uuid for journal */
96*ed34f34dSUma Shankar 
97*ed34f34dSUma Shankar 	/* 0x0040 */
98*ed34f34dSUma Shankar 	__u32 s_nr_users;	/* Nr of filesystems sharing log */
99*ed34f34dSUma Shankar 
100*ed34f34dSUma Shankar 	__u32 s_dynsuper;	/* Blocknr of dynamic superblock copy */
101*ed34f34dSUma Shankar 
102*ed34f34dSUma Shankar 	/* 0x0048 */
103*ed34f34dSUma Shankar 	__u32 s_max_transaction;	/* Limit of journal blocks per trans. */
104*ed34f34dSUma Shankar 	__u32 s_max_trans_data;	/* Limit of data blocks per trans. */
105*ed34f34dSUma Shankar 
106*ed34f34dSUma Shankar 	/* 0x0050 */
107*ed34f34dSUma Shankar 	__u32 s_padding[44];
108*ed34f34dSUma Shankar 
109*ed34f34dSUma Shankar 	/* 0x0100 */
110*ed34f34dSUma Shankar 	__u8 s_users[16 * 48];	/* ids of all fs'es sharing the log */
111*ed34f34dSUma Shankar 	/* 0x0400 */
112*ed34f34dSUma Shankar } ;
113*ed34f34dSUma Shankar 
114*ed34f34dSUma Shankar struct ext3_journal_block_tag {
115*ed34f34dSUma Shankar 	uint32_t block;
116*ed34f34dSUma Shankar 	uint32_t flags;
117*ed34f34dSUma Shankar };
118*ed34f34dSUma Shankar 
119*ed34f34dSUma Shankar struct journal_revoke_header_t {
120*ed34f34dSUma Shankar 	struct journal_header_t r_header;
121*ed34f34dSUma Shankar 	int r_count;		/* Count of bytes used in the block */
122*ed34f34dSUma Shankar };
123*ed34f34dSUma Shankar 
124*ed34f34dSUma Shankar struct revoke_blk_list {
125*ed34f34dSUma Shankar 	char *content;		/* revoke block itself */
126*ed34f34dSUma Shankar 	struct revoke_blk_list *next;
127*ed34f34dSUma Shankar };
128*ed34f34dSUma Shankar 
129*ed34f34dSUma Shankar extern struct ext2_data *ext4fs_root;
130*ed34f34dSUma Shankar 
131*ed34f34dSUma Shankar int ext4fs_init_journal(void);
132*ed34f34dSUma Shankar int ext4fs_log_gdt(char *gd_table);
133*ed34f34dSUma Shankar int ext4fs_check_journal_state(int recovery_flag);
134*ed34f34dSUma Shankar int ext4fs_log_journal(char *journal_buffer, long int blknr);
135*ed34f34dSUma Shankar int ext4fs_put_metadata(char *metadata_buffer, long int blknr);
136*ed34f34dSUma Shankar void ext4fs_update_journal(void);
137*ed34f34dSUma Shankar void ext4fs_dump_metadata(void);
138*ed34f34dSUma Shankar void ext4fs_push_revoke_blk(char *buffer);
139*ed34f34dSUma Shankar void ext4fs_free_journal(void);
140*ed34f34dSUma Shankar void ext4fs_free_revoke_blks(void);
141*ed34f34dSUma Shankar #endif
142