2 * Copyright (C) 2010 The Android Open Source Project
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 #ifndef _EXT4_UTILS_H_
18 #define _EXT4_UTILS_H_
21 #define _FILE_OFFSET_BITS 64
22 #define _LARGEFILE64_SOURCE
23 #include <sys/types.h>
26 #include <sys/types.h>
34 #if defined(__APPLE__) && defined(__MACH__)
36 #define ftruncate64 ftruncate
42 extern void* __mmap2(void *, size_t, int, int, int, off_t);
43 static inline void *mmap64(void *addr, size_t length, int prot, int flags,
44 int fd, off64_t offset)
46 return __mmap2(addr, length, prot, flags, fd, offset >> 12);
52 #define warn(fmt, args...) do { fprintf(stderr, "warning: %s: " fmt "\n", __func__, ## args); } while (0)
53 #define error(fmt, args...) do { fprintf(stderr, "error: %s: " fmt "\n", __func__, ## args); if (!force) longjmp(setjmp_env, EXIT_FAILURE); } while (0)
54 #define error_errno(s, args...) error(s ": %s", ##args, strerror(errno))
55 #define critical_error(fmt, args...) do { fprintf(stderr, "critical error: %s: " fmt "\n", __func__, ## args); longjmp(setjmp_env, EXIT_FAILURE); } while (0)
56 #define critical_error_errno(s, args...) critical_error(s ": %s", ##args, strerror(errno))
58 #define EXT4_SUPER_MAGIC 0xEF53
59 #define EXT4_JNL_BACKUP_BLOCKS 1
61 #define min(a, b) ((a) < (b) ? (a) : (b))
63 #define DIV_ROUND_UP(x, y) (((x) + (y) - 1)/(y))
64 #define ALIGN(x, y) ((y) * DIV_ROUND_UP((x), (y)))
79 typedef unsigned long long u64;
80 typedef signed long long s64;
81 typedef unsigned int u32;
82 typedef unsigned short int u16;
83 typedef unsigned char u8;
85 struct block_group_info;
87 struct ext2_group_desc {
88 __le32 bg_block_bitmap;
89 __le32 bg_inode_bitmap;
90 __le32 bg_inode_table;
91 __le16 bg_free_blocks_count;
92 __le16 bg_free_inodes_count;
93 __le16 bg_used_dirs_count;
95 __le32 bg_reserved[3];
99 s64 len; /* If set to 0, ask the block device for the size,
100 * if less than 0, reserve that much space at the
101 * end of the partition, else use the size given. */
103 u32 blocks_per_group;
104 u32 inodes_per_group;
111 u32 bg_desc_reserve_blocks;
117 struct ext4_super_block *sb;
118 struct ext2_group_desc *bg_desc;
119 struct block_group_info *bgs;
120 u32 first_data_block;
122 u32 inode_table_blocks;
131 extern struct fs_info info;
132 extern struct fs_aux_info aux_info;
134 extern jmp_buf setjmp_env;
136 static inline int log_2(int j)
140 for (i = 0; j > 0; i++)
146 int ext4_bg_has_super_block(int bg);
147 void write_ext4_image(const char *filename, int gz, int sparse, int crc,
149 void ext4_create_fs_aux_info(void);
150 void ext4_free_fs_aux_info(void);
151 void ext4_fill_in_sb(void);
152 void ext4_create_resize_inode(void);
153 void ext4_create_journal_inode(void);
154 void ext4_update_free(void);
155 void ext4_queue_sb(void);
156 u64 get_file_size(const char *filename);
157 u64 parse_num(const char *arg);
158 void ext4_parse_sb(struct ext4_super_block *sb);