ext_common.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. /*
  2. * (C) Copyright 2011 - 2012 Samsung Electronics
  3. * EXT4 filesystem implementation in Uboot by
  4. * Uma Shankar <uma.shankar@samsung.com>
  5. * Manjunatha C Achar <a.manjunatha@samsung.com>
  6. *
  7. * Data structures and headers for ext4 support have been taken from
  8. * ext2 ls load support in Uboot
  9. *
  10. * (C) Copyright 2004
  11. * esd gmbh <www.esd-electronics.com>
  12. * Reinhard Arlt <reinhard.arlt@esd-electronics.com>
  13. *
  14. * based on code from grub2 fs/ext2.c and fs/fshelp.c by
  15. * GRUB -- GRand Unified Bootloader
  16. * Copyright (C) 2003, 2004 Free Software Foundation, Inc.
  17. *
  18. * SPDX-License-Identifier: GPL-2.0+
  19. */
  20. #ifndef __EXT_COMMON__
  21. #define __EXT_COMMON__
  22. #include <command.h>
  23. #define SECTOR_SIZE 0x200
  24. /* Magic value used to identify an ext2 filesystem. */
  25. #define EXT2_MAGIC 0xEF53
  26. /* Amount of indirect blocks in an inode. */
  27. #define INDIRECT_BLOCKS 12
  28. /* Maximum lenght of a pathname. */
  29. #define EXT2_PATH_MAX 4096
  30. /* Maximum nesting of symlinks, used to prevent a loop. */
  31. #define EXT2_MAX_SYMLINKCNT 8
  32. /* Filetype used in directory entry. */
  33. #define FILETYPE_UNKNOWN 0
  34. #define FILETYPE_REG 1
  35. #define FILETYPE_DIRECTORY 2
  36. #define FILETYPE_SYMLINK 7
  37. /* Filetype information as used in inodes. */
  38. #define FILETYPE_INO_MASK 0170000
  39. #define FILETYPE_INO_REG 0100000
  40. #define FILETYPE_INO_DIRECTORY 0040000
  41. #define FILETYPE_INO_SYMLINK 0120000
  42. #define EXT2_ROOT_INO 2 /* Root inode */
  43. /* The size of an ext2 block in bytes. */
  44. #define EXT2_BLOCK_SIZE(data) (1 << LOG2_BLOCK_SIZE(data))
  45. /* Log2 size of ext2 block in bytes. */
  46. #define LOG2_BLOCK_SIZE(data) (le32_to_cpu \
  47. (data->sblock.log2_block_size) \
  48. + EXT2_MIN_BLOCK_LOG_SIZE)
  49. #define INODE_SIZE_FILESYSTEM(data) (le16_to_cpu \
  50. (data->sblock.inode_size))
  51. #define EXT2_FT_DIR 2
  52. #define SUCCESS 1
  53. /* Macro-instructions used to manage several block sizes */
  54. #define EXT2_MIN_BLOCK_LOG_SIZE 10 /* 1024 */
  55. #define EXT2_MAX_BLOCK_LOG_SIZE 16 /* 65536 */
  56. #define EXT2_MIN_BLOCK_SIZE (1 << EXT2_MIN_BLOCK_LOG_SIZE)
  57. #define EXT2_MAX_BLOCK_SIZE (1 << EXT2_MAX_BLOCK_LOG_SIZE)
  58. /* The ext2 superblock. */
  59. struct ext2_sblock {
  60. __le32 total_inodes;
  61. __le32 total_blocks;
  62. __le32 reserved_blocks;
  63. __le32 free_blocks;
  64. __le32 free_inodes;
  65. __le32 first_data_block;
  66. __le32 log2_block_size;
  67. __le32 log2_fragment_size;
  68. __le32 blocks_per_group;
  69. __le32 fragments_per_group;
  70. __le32 inodes_per_group;
  71. __le32 mtime;
  72. __le32 utime;
  73. __le16 mnt_count;
  74. __le16 max_mnt_count;
  75. __le16 magic;
  76. __le16 fs_state;
  77. __le16 error_handling;
  78. __le16 minor_revision_level;
  79. __le32 lastcheck;
  80. __le32 checkinterval;
  81. __le32 creator_os;
  82. __le32 revision_level;
  83. __le16 uid_reserved;
  84. __le16 gid_reserved;
  85. __le32 first_inode;
  86. __le16 inode_size;
  87. __le16 block_group_number;
  88. __le32 feature_compatibility;
  89. __le32 feature_incompat;
  90. __le32 feature_ro_compat;
  91. __le32 unique_id[4];
  92. char volume_name[16];
  93. char last_mounted_on[64];
  94. __le32 compression_info;
  95. };
  96. struct ext2_block_group {
  97. __le32 block_id; /* Blocks bitmap block */
  98. __le32 inode_id; /* Inodes bitmap block */
  99. __le32 inode_table_id; /* Inodes table block */
  100. __le16 free_blocks; /* Free blocks count */
  101. __le16 free_inodes; /* Free inodes count */
  102. __le16 used_dir_cnt; /* Directories count */
  103. __le16 bg_flags;
  104. __le32 bg_reserved[2];
  105. __le16 bg_itable_unused; /* Unused inodes count */
  106. __le16 bg_checksum; /* crc16(s_uuid+grouo_num+group_desc)*/
  107. };
  108. /* The ext2 inode. */
  109. struct ext2_inode {
  110. __le16 mode;
  111. __le16 uid;
  112. __le32 size;
  113. __le32 atime;
  114. __le32 ctime;
  115. __le32 mtime;
  116. __le32 dtime;
  117. __le16 gid;
  118. __le16 nlinks;
  119. __le32 blockcnt; /* Blocks of 512 bytes!! */
  120. __le32 flags;
  121. __le32 osd1;
  122. union {
  123. struct datablocks {
  124. __le32 dir_blocks[INDIRECT_BLOCKS];
  125. __le32 indir_block;
  126. __le32 double_indir_block;
  127. __le32 triple_indir_block;
  128. } blocks;
  129. char symlink[60];
  130. } b;
  131. __le32 version;
  132. __le32 acl;
  133. __le32 dir_acl;
  134. __le32 fragment_addr;
  135. __le32 osd2[3];
  136. };
  137. /* The header of an ext2 directory entry. */
  138. struct ext2_dirent {
  139. __le32 inode;
  140. __le16 direntlen;
  141. __u8 namelen;
  142. __u8 filetype;
  143. };
  144. struct ext2fs_node {
  145. struct ext2_data *data;
  146. struct ext2_inode inode;
  147. int ino;
  148. int inode_read;
  149. };
  150. /* Information about a "mounted" ext2 filesystem. */
  151. struct ext2_data {
  152. struct ext2_sblock sblock;
  153. struct ext2_inode *inode;
  154. struct ext2fs_node diropen;
  155. };
  156. extern lbaint_t part_offset;
  157. int do_ext2ls(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]);
  158. int do_ext2load(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]);
  159. int do_ext4_load(cmd_tbl_t *cmdtp, int flag, int argc,
  160. char *const argv[]);
  161. int do_ext4_ls(cmd_tbl_t *cmdtp, int flag, int argc, char *const argv[]);
  162. int do_ext4_write(cmd_tbl_t *cmdtp, int flag, int argc,
  163. char *const argv[]);
  164. #endif