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