1 /*
2 * pass1.c -- pass #1 of e2fsck: sequential scan of the inode table
3 *
4 * Copyright (C) 1993, 1994, 1995, 1996, 1997 Theodore Ts'o.
5 *
6 * %Begin-Header%
7 * This file may be redistributed under the terms of the GNU Public
8 * License.
9 * %End-Header%
10 *
11 * Pass 1 of e2fsck iterates over all the inodes in the filesystems,
12 * and applies the following tests to each inode:
13 *
14 * - The mode field of the inode must be legal.
15 * - The size and block count fields of the inode are correct.
16 * - A data block must not be used by another inode
17 *
18 * Pass 1 also gathers the collects the following information:
19 *
20 * - A bitmap of which inodes are in use. (inode_used_map)
21 * - A bitmap of which inodes are directories. (inode_dir_map)
22 * - A bitmap of which inodes are regular files. (inode_reg_map)
23 * - A bitmap of which inodes have bad fields. (inode_bad_map)
24 * - A bitmap of which inodes are in bad blocks. (inode_bb_map)
25 * - A bitmap of which inodes are imagic inodes. (inode_imagic_map)
26 * - A bitmap of which blocks are in use. (block_found_map)
27 * - A bitmap of which blocks are in use by two inodes (block_dup_map)
28 * - The data blocks of the directory inodes. (dir_map)
29 *
30 * Pass 1 is designed to stash away enough information so that the
31 * other passes should not need to read in the inode information
32 * during the normal course of a filesystem check. (Althogh if an
33 * inconsistency is detected, other passes may need to read in an
34 * inode to fix it.)
35 *
36 * Note that pass 1B will be invoked if there are any duplicate blocks
37 * found.
38 */
39
40 #define _GNU_SOURCE 1 /* get strnlen() */
41 #include <string.h>
42 #include <time.h>
43 #ifdef HAVE_ERRNO_H
44 #include <errno.h>
45 #endif
46
47 #include "e2fsck.h"
48 #include <ext2fs/ext2_ext_attr.h>
49
50 #include "problem.h"
51
52 #ifdef NO_INLINE_FUNCS
53 #define _INLINE_
54 #else
55 #define _INLINE_ inline
56 #endif
57
58 static int process_block(ext2_filsys fs, blk64_t *blocknr,
59 e2_blkcnt_t blockcnt, blk64_t ref_blk,
60 int ref_offset, void *priv_data);
61 static int process_bad_block(ext2_filsys fs, blk64_t *block_nr,
62 e2_blkcnt_t blockcnt, blk64_t ref_blk,
63 int ref_offset, void *priv_data);
64 static void check_blocks(e2fsck_t ctx, struct problem_context *pctx,
65 char *block_buf);
66 static void mark_table_blocks(e2fsck_t ctx);
67 static void alloc_bb_map(e2fsck_t ctx);
68 static void alloc_imagic_map(e2fsck_t ctx);
69 static void mark_inode_bad(e2fsck_t ctx, ino_t ino);
70 static void handle_fs_bad_blocks(e2fsck_t ctx);
71 static void process_inodes(e2fsck_t ctx, char *block_buf);
72 static EXT2_QSORT_TYPE process_inode_cmp(const void *a, const void *b);
73 static errcode_t scan_callback(ext2_filsys fs, ext2_inode_scan scan,
74 dgrp_t group, void * priv_data);
75 static void adjust_extattr_refcount(e2fsck_t ctx, ext2_refcount_t refcount,
76 char *block_buf, int adjust_sign);
77 /* static char *describe_illegal_block(ext2_filsys fs, blk64_t block); */
78
79 struct process_block_struct {
80 ext2_ino_t ino;
81 unsigned is_dir:1, is_reg:1, clear:1, suppress:1,
82 fragmented:1, compressed:1, bbcheck:1;
83 blk64_t num_blocks;
84 blk64_t max_blocks;
85 e2_blkcnt_t last_block;
86 e2_blkcnt_t last_init_lblock;
87 e2_blkcnt_t last_db_block;
88 int num_illegal_blocks;
89 blk64_t previous_block;
90 struct ext2_inode *inode;
91 struct problem_context *pctx;
92 ext2fs_block_bitmap fs_meta_blocks;
93 e2fsck_t ctx;
94 };
95
96 struct process_inode_block {
97 ext2_ino_t ino;
98 struct ext2_inode inode;
99 };
100
101 struct scan_callback_struct {
102 e2fsck_t ctx;
103 char *block_buf;
104 };
105
106 /*
107 * For the inodes to process list.
108 */
109 static struct process_inode_block *inodes_to_process;
110 static int process_inode_count;
111
112 static __u64 ext2_max_sizes[EXT2_MAX_BLOCK_LOG_SIZE -
113 EXT2_MIN_BLOCK_LOG_SIZE + 1];
114
115 /*
116 * Free all memory allocated by pass1 in preparation for restarting
117 * things.
118 */
unwind_pass1(ext2_filsys fs EXT2FS_ATTR ((unused)))119 static void unwind_pass1(ext2_filsys fs EXT2FS_ATTR((unused)))
120 {
121 ext2fs_free_mem(&inodes_to_process);
122 inodes_to_process = 0;
123 }
124
125 /*
126 * Check to make sure a device inode is real. Returns 1 if the device
127 * checks out, 0 if not.
128 *
129 * Note: this routine is now also used to check FIFO's and Sockets,
130 * since they have the same requirement; the i_block fields should be
131 * zero.
132 */
e2fsck_pass1_check_device_inode(ext2_filsys fs EXT2FS_ATTR ((unused)),struct ext2_inode * inode)133 int e2fsck_pass1_check_device_inode(ext2_filsys fs EXT2FS_ATTR((unused)),
134 struct ext2_inode *inode)
135 {
136 int i;
137
138 /*
139 * If the index flag is set, then this is a bogus
140 * device/fifo/socket
141 */
142 if (inode->i_flags & EXT2_INDEX_FL)
143 return 0;
144
145 /*
146 * We should be able to do the test below all the time, but
147 * because the kernel doesn't forcibly clear the device
148 * inode's additional i_block fields, there are some rare
149 * occasions when a legitimate device inode will have non-zero
150 * additional i_block fields. So for now, we only complain
151 * when the immutable flag is set, which should never happen
152 * for devices. (And that's when the problem is caused, since
153 * you can't set or clear immutable flags for devices.) Once
154 * the kernel has been fixed we can change this...
155 */
156 if (inode->i_flags & (EXT2_IMMUTABLE_FL | EXT2_APPEND_FL)) {
157 for (i=4; i < EXT2_N_BLOCKS; i++)
158 if (inode->i_block[i])
159 return 0;
160 }
161 return 1;
162 }
163
164 /*
165 * Check to make sure a symlink inode is real. Returns 1 if the symlink
166 * checks out, 0 if not.
167 */
e2fsck_pass1_check_symlink(ext2_filsys fs,ext2_ino_t ino,struct ext2_inode * inode,char * buf)168 int e2fsck_pass1_check_symlink(ext2_filsys fs, ext2_ino_t ino,
169 struct ext2_inode *inode, char *buf)
170 {
171 unsigned int len;
172 int i;
173 blk64_t blocks;
174 ext2_extent_handle_t handle;
175 struct ext2_extent_info info;
176 struct ext2fs_extent extent;
177
178 if ((inode->i_size_high || inode->i_size == 0) ||
179 (inode->i_flags & EXT2_INDEX_FL))
180 return 0;
181
182 if (inode->i_flags & EXT4_EXTENTS_FL) {
183 if (inode->i_size > fs->blocksize)
184 return 0;
185 if (ext2fs_extent_open2(fs, ino, inode, &handle))
186 return 0;
187 i = 0;
188 if (ext2fs_extent_get_info(handle, &info) ||
189 (info.num_entries != 1) ||
190 (info.max_depth != 0))
191 goto exit_extent;
192 if (ext2fs_extent_get(handle, EXT2_EXTENT_ROOT, &extent) ||
193 (extent.e_lblk != 0) ||
194 (extent.e_len != 1) ||
195 (extent.e_pblk < fs->super->s_first_data_block) ||
196 (extent.e_pblk >= ext2fs_blocks_count(fs->super)))
197 goto exit_extent;
198 i = 1;
199 exit_extent:
200 ext2fs_extent_free(handle);
201 return i;
202 }
203
204 blocks = ext2fs_inode_data_blocks2(fs, inode);
205 if (blocks) {
206 if ((inode->i_size >= fs->blocksize) ||
207 (blocks != fs->blocksize >> 9) ||
208 (inode->i_block[0] < fs->super->s_first_data_block) ||
209 (inode->i_block[0] >= ext2fs_blocks_count(fs->super)))
210 return 0;
211
212 for (i = 1; i < EXT2_N_BLOCKS; i++)
213 if (inode->i_block[i])
214 return 0;
215
216 if (io_channel_read_blk64(fs->io, inode->i_block[0], 1, buf))
217 return 0;
218
219 len = strnlen(buf, fs->blocksize);
220 if (len == fs->blocksize)
221 return 0;
222 } else {
223 if (inode->i_size >= sizeof(inode->i_block))
224 return 0;
225
226 len = strnlen((char *)inode->i_block, sizeof(inode->i_block));
227 if (len == sizeof(inode->i_block))
228 return 0;
229 }
230 if (len != inode->i_size)
231 return 0;
232 return 1;
233 }
234
235 /*
236 * If the immutable (or append-only) flag is set on the inode, offer
237 * to clear it.
238 */
239 #define BAD_SPECIAL_FLAGS (EXT2_IMMUTABLE_FL | EXT2_APPEND_FL)
check_immutable(e2fsck_t ctx,struct problem_context * pctx)240 static void check_immutable(e2fsck_t ctx, struct problem_context *pctx)
241 {
242 if (!(pctx->inode->i_flags & BAD_SPECIAL_FLAGS))
243 return;
244
245 if (!fix_problem(ctx, PR_1_SET_IMMUTABLE, pctx))
246 return;
247
248 pctx->inode->i_flags &= ~BAD_SPECIAL_FLAGS;
249 e2fsck_write_inode(ctx, pctx->ino, pctx->inode, "pass1");
250 }
251
252 /*
253 * If device, fifo or socket, check size is zero -- if not offer to
254 * clear it
255 */
check_size(e2fsck_t ctx,struct problem_context * pctx)256 static void check_size(e2fsck_t ctx, struct problem_context *pctx)
257 {
258 struct ext2_inode *inode = pctx->inode;
259
260 if (EXT2_I_SIZE(inode) == 0)
261 return;
262
263 if (!fix_problem(ctx, PR_1_SET_NONZSIZE, pctx))
264 return;
265
266 inode->i_size = 0;
267 inode->i_size_high = 0;
268 e2fsck_write_inode(ctx, pctx->ino, pctx->inode, "pass1");
269 }
270
check_ea_in_inode(e2fsck_t ctx,struct problem_context * pctx)271 static void check_ea_in_inode(e2fsck_t ctx, struct problem_context *pctx)
272 {
273 struct ext2_super_block *sb = ctx->fs->super;
274 struct ext2_inode_large *inode;
275 struct ext2_ext_attr_entry *entry;
276 char *start;
277 unsigned int storage_size, remain;
278 problem_t problem = 0;
279
280 inode = (struct ext2_inode_large *) pctx->inode;
281 storage_size = EXT2_INODE_SIZE(ctx->fs->super) - EXT2_GOOD_OLD_INODE_SIZE -
282 inode->i_extra_isize;
283 start = ((char *) inode) + EXT2_GOOD_OLD_INODE_SIZE +
284 inode->i_extra_isize + sizeof(__u32);
285 entry = (struct ext2_ext_attr_entry *) start;
286
287 /* scan all entry's headers first */
288
289 /* take finish entry 0UL into account */
290 remain = storage_size - sizeof(__u32);
291
292 while (!EXT2_EXT_IS_LAST_ENTRY(entry)) {
293 __u32 hash;
294
295 /* header eats this space */
296 remain -= sizeof(struct ext2_ext_attr_entry);
297
298 /* is attribute name valid? */
299 if (EXT2_EXT_ATTR_SIZE(entry->e_name_len) > remain) {
300 pctx->num = entry->e_name_len;
301 problem = PR_1_ATTR_NAME_LEN;
302 goto fix;
303 }
304
305 /* attribute len eats this space */
306 remain -= EXT2_EXT_ATTR_SIZE(entry->e_name_len);
307
308 /* check value size */
309 if (entry->e_value_size > remain) {
310 pctx->num = entry->e_value_size;
311 problem = PR_1_ATTR_VALUE_SIZE;
312 goto fix;
313 }
314
315 /* e_value_block must be 0 in inode's ea */
316 if (entry->e_value_block != 0) {
317 pctx->num = entry->e_value_block;
318 problem = PR_1_ATTR_VALUE_BLOCK;
319 goto fix;
320 }
321
322 hash = ext2fs_ext_attr_hash_entry(entry,
323 start + entry->e_value_offs);
324
325 /* e_hash may be 0 in older inode's ea */
326 if (entry->e_hash != 0 && entry->e_hash != hash) {
327 pctx->num = entry->e_hash;
328 problem = PR_1_ATTR_HASH;
329 goto fix;
330 }
331
332 remain -= entry->e_value_size;
333
334 entry = EXT2_EXT_ATTR_NEXT(entry);
335 }
336 fix:
337 /*
338 * it seems like a corruption. it's very unlikely we could repair
339 * EA(s) in automatic fashion -bzzz
340 */
341 if (problem == 0 || !fix_problem(ctx, problem, pctx))
342 return;
343
344 /* simply remove all possible EA(s) */
345 *((__u32 *)start) = 0UL;
346 e2fsck_write_inode_full(ctx, pctx->ino, pctx->inode,
347 EXT2_INODE_SIZE(sb), "pass1");
348 }
349
check_inode_extra_space(e2fsck_t ctx,struct problem_context * pctx)350 static void check_inode_extra_space(e2fsck_t ctx, struct problem_context *pctx)
351 {
352 struct ext2_super_block *sb = ctx->fs->super;
353 struct ext2_inode_large *inode;
354 __u32 *eamagic;
355 int min, max;
356
357 inode = (struct ext2_inode_large *) pctx->inode;
358 if (EXT2_INODE_SIZE(sb) == EXT2_GOOD_OLD_INODE_SIZE) {
359 /* this isn't large inode. so, nothing to check */
360 return;
361 }
362
363 #if 0
364 printf("inode #%u, i_extra_size %d\n", pctx->ino,
365 inode->i_extra_isize);
366 #endif
367 /* i_extra_isize must cover i_extra_isize + i_checksum_hi at least */
368 min = sizeof(inode->i_extra_isize) + sizeof(inode->i_checksum_hi);
369 max = EXT2_INODE_SIZE(sb) - EXT2_GOOD_OLD_INODE_SIZE;
370 /*
371 * For now we will allow i_extra_isize to be 0, but really
372 * implementations should never allow i_extra_isize to be 0
373 */
374 if (inode->i_extra_isize &&
375 (inode->i_extra_isize < min || inode->i_extra_isize > max)) {
376 if (!fix_problem(ctx, PR_1_EXTRA_ISIZE, pctx))
377 return;
378 inode->i_extra_isize = min;
379 e2fsck_write_inode_full(ctx, pctx->ino, pctx->inode,
380 EXT2_INODE_SIZE(sb), "pass1");
381 return;
382 }
383
384 eamagic = (__u32 *) (((char *) inode) + EXT2_GOOD_OLD_INODE_SIZE +
385 inode->i_extra_isize);
386 if (*eamagic == EXT2_EXT_ATTR_MAGIC) {
387 /* it seems inode has an extended attribute(s) in body */
388 check_ea_in_inode(ctx, pctx);
389 }
390 }
391
392 /*
393 * Check to see if the inode might really be a directory, despite i_mode
394 *
395 * This is a lot of complexity for something for which I'm not really
396 * convinced happens frequently in the wild. If for any reason this
397 * causes any problems, take this code out.
398 * [tytso:20070331.0827EDT]
399 */
check_is_really_dir(e2fsck_t ctx,struct problem_context * pctx,char * buf)400 static void check_is_really_dir(e2fsck_t ctx, struct problem_context *pctx,
401 char *buf)
402 {
403 struct ext2_inode *inode = pctx->inode;
404 struct ext2_dir_entry *dirent;
405 errcode_t retval;
406 blk64_t blk;
407 unsigned int i, rec_len, not_device = 0;
408 int extent_fs;
409
410 /*
411 * If the mode looks OK, we believe it. If the first block in
412 * the i_block array is 0, this cannot be a directory. If the
413 * inode is extent-mapped, it is still the case that the latter
414 * cannot be 0 - the magic number in the extent header would make
415 * it nonzero.
416 */
417 if (LINUX_S_ISDIR(inode->i_mode) || LINUX_S_ISREG(inode->i_mode) ||
418 LINUX_S_ISLNK(inode->i_mode) || inode->i_block[0] == 0)
419 return;
420
421 /*
422 * Check the block numbers in the i_block array for validity:
423 * zero blocks are skipped (but the first one cannot be zero -
424 * see above), other blocks are checked against the first and
425 * max data blocks (from the the superblock) and against the
426 * block bitmap. Any invalid block found means this cannot be
427 * a directory.
428 *
429 * If there are non-zero blocks past the fourth entry, then
430 * this cannot be a device file: we remember that for the next
431 * check.
432 *
433 * For extent mapped files, we don't do any sanity checking:
434 * just try to get the phys block of logical block 0 and run
435 * with it.
436 */
437
438 extent_fs = (ctx->fs->super->s_feature_incompat &
439 EXT3_FEATURE_INCOMPAT_EXTENTS);
440 if (extent_fs && (inode->i_flags & EXT4_EXTENTS_FL)) {
441 /* extent mapped */
442 if (ext2fs_bmap2(ctx->fs, pctx->ino, inode, 0, 0, 0, 0,
443 &blk))
444 return;
445 /* device files are never extent mapped */
446 not_device++;
447 } else {
448 for (i=0; i < EXT2_N_BLOCKS; i++) {
449 blk = inode->i_block[i];
450 if (!blk)
451 continue;
452 if (i >= 4)
453 not_device++;
454
455 if (blk < ctx->fs->super->s_first_data_block ||
456 blk >= ext2fs_blocks_count(ctx->fs->super) ||
457 ext2fs_fast_test_block_bitmap2(ctx->block_found_map,
458 blk))
459 return; /* Invalid block, can't be dir */
460 }
461 blk = inode->i_block[0];
462 }
463
464 /*
465 * If the mode says this is a device file and the i_links_count field
466 * is sane and we have not ruled it out as a device file previously,
467 * we declare it a device file, not a directory.
468 */
469 if ((LINUX_S_ISCHR(inode->i_mode) || LINUX_S_ISBLK(inode->i_mode)) &&
470 (inode->i_links_count == 1) && !not_device)
471 return;
472
473 /* read the first block */
474 ehandler_operation(_("reading directory block"));
475 retval = ext2fs_read_dir_block3(ctx->fs, blk, buf, 0);
476 ehandler_operation(0);
477 if (retval)
478 return;
479
480 dirent = (struct ext2_dir_entry *) buf;
481 retval = ext2fs_get_rec_len(ctx->fs, dirent, &rec_len);
482 if (retval)
483 return;
484 if (((dirent->name_len & 0xFF) != 1) ||
485 (dirent->name[0] != '.') ||
486 (dirent->inode != pctx->ino) ||
487 (rec_len < 12) ||
488 (rec_len % 4) ||
489 (rec_len >= ctx->fs->blocksize - 12))
490 return;
491
492 dirent = (struct ext2_dir_entry *) (buf + rec_len);
493 retval = ext2fs_get_rec_len(ctx->fs, dirent, &rec_len);
494 if (retval)
495 return;
496 if (((dirent->name_len & 0xFF) != 2) ||
497 (dirent->name[0] != '.') ||
498 (dirent->name[1] != '.') ||
499 (rec_len < 12) ||
500 (rec_len % 4))
501 return;
502
503 if (fix_problem(ctx, PR_1_TREAT_AS_DIRECTORY, pctx)) {
504 inode->i_mode = (inode->i_mode & 07777) | LINUX_S_IFDIR;
505 e2fsck_write_inode_full(ctx, pctx->ino, inode,
506 EXT2_INODE_SIZE(ctx->fs->super),
507 "check_is_really_dir");
508 }
509 }
510
e2fsck_setup_tdb_icount(e2fsck_t ctx,int flags,ext2_icount_t * ret)511 void e2fsck_setup_tdb_icount(e2fsck_t ctx, int flags,
512 ext2_icount_t *ret)
513 {
514 unsigned int threshold;
515 ext2_ino_t num_dirs;
516 errcode_t retval;
517 char *tdb_dir;
518 int enable;
519
520 *ret = 0;
521
522 profile_get_string(ctx->profile, "scratch_files", "directory", 0, 0,
523 &tdb_dir);
524 profile_get_uint(ctx->profile, "scratch_files",
525 "numdirs_threshold", 0, 0, &threshold);
526 profile_get_boolean(ctx->profile, "scratch_files",
527 "icount", 0, 1, &enable);
528
529 retval = ext2fs_get_num_dirs(ctx->fs, &num_dirs);
530 if (retval)
531 num_dirs = 1024; /* Guess */
532
533 if (!enable || !tdb_dir || access(tdb_dir, W_OK) ||
534 (threshold && num_dirs <= threshold))
535 return;
536
537 retval = ext2fs_create_icount_tdb(ctx->fs, tdb_dir, flags, ret);
538 if (retval)
539 *ret = 0;
540 }
541
e2fsck_pass1(e2fsck_t ctx)542 void e2fsck_pass1(e2fsck_t ctx)
543 {
544 int i;
545 __u64 max_sizes;
546 ext2_filsys fs = ctx->fs;
547 ext2_ino_t ino = 0;
548 struct ext2_inode *inode;
549 ext2_inode_scan scan;
550 char *block_buf;
551 #ifdef RESOURCE_TRACK
552 struct resource_track rtrack;
553 #endif
554 unsigned char frag, fsize;
555 struct problem_context pctx;
556 struct scan_callback_struct scan_struct;
557 struct ext2_super_block *sb = ctx->fs->super;
558 const char *old_op;
559 unsigned int save_type;
560 int imagic_fs, extent_fs;
561 int busted_fs_time = 0;
562 int inode_size;
563
564 init_resource_track(&rtrack, ctx->fs->io);
565 clear_problem_context(&pctx);
566
567 if (!(ctx->options & E2F_OPT_PREEN))
568 fix_problem(ctx, PR_1_PASS_HEADER, &pctx);
569
570 if ((fs->super->s_feature_compat & EXT2_FEATURE_COMPAT_DIR_INDEX) &&
571 !(ctx->options & E2F_OPT_NO)) {
572 if (ext2fs_u32_list_create(&ctx->dirs_to_hash, 50))
573 ctx->dirs_to_hash = 0;
574 }
575
576 #ifdef MTRACE
577 mtrace_print("Pass 1");
578 #endif
579
580 #define EXT2_BPP(bits) (1ULL << ((bits) - 2))
581
582 for (i = EXT2_MIN_BLOCK_LOG_SIZE; i <= EXT2_MAX_BLOCK_LOG_SIZE; i++) {
583 max_sizes = EXT2_NDIR_BLOCKS + EXT2_BPP(i);
584 max_sizes = max_sizes + EXT2_BPP(i) * EXT2_BPP(i);
585 max_sizes = max_sizes + EXT2_BPP(i) * EXT2_BPP(i) * EXT2_BPP(i);
586 max_sizes = (max_sizes * (1UL << i));
587 ext2_max_sizes[i - EXT2_MIN_BLOCK_LOG_SIZE] = max_sizes;
588 }
589 #undef EXT2_BPP
590
591 imagic_fs = (sb->s_feature_compat & EXT2_FEATURE_COMPAT_IMAGIC_INODES);
592 extent_fs = (sb->s_feature_incompat & EXT3_FEATURE_INCOMPAT_EXTENTS);
593
594 /*
595 * Allocate bitmaps structures
596 */
597 pctx.errcode = e2fsck_allocate_inode_bitmap(fs, _("in-use inode map"),
598 EXT2FS_BMAP64_RBTREE,
599 "inode_used_map",
600 &ctx->inode_used_map);
601 if (pctx.errcode) {
602 pctx.num = 1;
603 fix_problem(ctx, PR_1_ALLOCATE_IBITMAP_ERROR, &pctx);
604 ctx->flags |= E2F_FLAG_ABORT;
605 return;
606 }
607 pctx.errcode = e2fsck_allocate_inode_bitmap(fs,
608 _("directory inode map"),
609 EXT2FS_BMAP64_AUTODIR,
610 "inode_dir_map", &ctx->inode_dir_map);
611 if (pctx.errcode) {
612 pctx.num = 2;
613 fix_problem(ctx, PR_1_ALLOCATE_IBITMAP_ERROR, &pctx);
614 ctx->flags |= E2F_FLAG_ABORT;
615 return;
616 }
617 pctx.errcode = e2fsck_allocate_inode_bitmap(fs,
618 _("regular file inode map"), EXT2FS_BMAP64_RBTREE,
619 "inode_reg_map", &ctx->inode_reg_map);
620 if (pctx.errcode) {
621 pctx.num = 6;
622 fix_problem(ctx, PR_1_ALLOCATE_IBITMAP_ERROR, &pctx);
623 ctx->flags |= E2F_FLAG_ABORT;
624 return;
625 }
626 pctx.errcode = e2fsck_allocate_subcluster_bitmap(fs,
627 _("in-use block map"), EXT2FS_BMAP64_RBTREE,
628 "block_found_map", &ctx->block_found_map);
629 if (pctx.errcode) {
630 pctx.num = 1;
631 fix_problem(ctx, PR_1_ALLOCATE_BBITMAP_ERROR, &pctx);
632 ctx->flags |= E2F_FLAG_ABORT;
633 return;
634 }
635 e2fsck_setup_tdb_icount(ctx, 0, &ctx->inode_link_info);
636 if (!ctx->inode_link_info) {
637 e2fsck_set_bitmap_type(fs, EXT2FS_BMAP64_RBTREE,
638 "inode_link_info", &save_type);
639 pctx.errcode = ext2fs_create_icount2(fs, 0, 0, 0,
640 &ctx->inode_link_info);
641 fs->default_bitmap_type = save_type;
642 }
643
644 if (pctx.errcode) {
645 fix_problem(ctx, PR_1_ALLOCATE_ICOUNT, &pctx);
646 ctx->flags |= E2F_FLAG_ABORT;
647 return;
648 }
649 inode_size = EXT2_INODE_SIZE(fs->super);
650 inode = (struct ext2_inode *)
651 e2fsck_allocate_memory(ctx, inode_size, "scratch inode");
652
653 inodes_to_process = (struct process_inode_block *)
654 e2fsck_allocate_memory(ctx,
655 (ctx->process_inode_size *
656 sizeof(struct process_inode_block)),
657 "array of inodes to process");
658 process_inode_count = 0;
659
660 pctx.errcode = ext2fs_init_dblist(fs, 0);
661 if (pctx.errcode) {
662 fix_problem(ctx, PR_1_ALLOCATE_DBCOUNT, &pctx);
663 ctx->flags |= E2F_FLAG_ABORT;
664 ext2fs_free_mem(&inode);
665 return;
666 }
667
668 /*
669 * If the last orphan field is set, clear it, since the pass1
670 * processing will automatically find and clear the orphans.
671 * In the future, we may want to try using the last_orphan
672 * linked list ourselves, but for now, we clear it so that the
673 * ext3 mount code won't get confused.
674 */
675 if (!(ctx->options & E2F_OPT_READONLY)) {
676 if (fs->super->s_last_orphan) {
677 fs->super->s_last_orphan = 0;
678 ext2fs_mark_super_dirty(fs);
679 }
680 }
681
682 mark_table_blocks(ctx);
683 pctx.errcode = ext2fs_convert_subcluster_bitmap(fs,
684 &ctx->block_found_map);
685 if (pctx.errcode) {
686 fix_problem(ctx, PR_1_CONVERT_SUBCLUSTER, &pctx);
687 ctx->flags |= E2F_FLAG_ABORT;
688 ext2fs_free_mem(&inode);
689 return;
690 }
691 block_buf = (char *) e2fsck_allocate_memory(ctx, fs->blocksize * 3,
692 "block interate buffer");
693 e2fsck_use_inode_shortcuts(ctx, 1);
694 old_op = ehandler_operation(_("opening inode scan"));
695 pctx.errcode = ext2fs_open_inode_scan(fs, ctx->inode_buffer_blocks,
696 &scan);
697 ehandler_operation(old_op);
698 if (pctx.errcode) {
699 fix_problem(ctx, PR_1_ISCAN_ERROR, &pctx);
700 ctx->flags |= E2F_FLAG_ABORT;
701 ext2fs_free_mem(&block_buf);
702 ext2fs_free_mem(&inode);
703 return;
704 }
705 ext2fs_inode_scan_flags(scan, EXT2_SF_SKIP_MISSING_ITABLE, 0);
706 ctx->stashed_inode = inode;
707 scan_struct.ctx = ctx;
708 scan_struct.block_buf = block_buf;
709 ext2fs_set_inode_callback(scan, scan_callback, &scan_struct);
710 if (ctx->progress)
711 if ((ctx->progress)(ctx, 1, 0, ctx->fs->group_desc_count))
712 return;
713 if ((fs->super->s_wtime < fs->super->s_inodes_count) ||
714 (fs->super->s_mtime < fs->super->s_inodes_count))
715 busted_fs_time = 1;
716
717 if ((fs->super->s_feature_incompat & EXT4_FEATURE_INCOMPAT_MMP) &&
718 fs->super->s_mmp_block > fs->super->s_first_data_block &&
719 fs->super->s_mmp_block < ext2fs_blocks_count(fs->super))
720 ext2fs_mark_block_bitmap2(ctx->block_found_map,
721 fs->super->s_mmp_block);
722
723 while (1) {
724 if (ino % (fs->super->s_inodes_per_group * 4) == 1) {
725 if (e2fsck_mmp_update(fs))
726 fatal_error(ctx, 0);
727 }
728 old_op = ehandler_operation(_("getting next inode from scan"));
729 pctx.errcode = ext2fs_get_next_inode_full(scan, &ino,
730 inode, inode_size);
731 ehandler_operation(old_op);
732 if (ctx->flags & E2F_FLAG_SIGNAL_MASK)
733 return;
734 if (pctx.errcode == EXT2_ET_BAD_BLOCK_IN_INODE_TABLE) {
735 if (!ctx->inode_bb_map)
736 alloc_bb_map(ctx);
737 ext2fs_mark_inode_bitmap2(ctx->inode_bb_map, ino);
738 ext2fs_mark_inode_bitmap2(ctx->inode_used_map, ino);
739 continue;
740 }
741 if (pctx.errcode) {
742 fix_problem(ctx, PR_1_ISCAN_ERROR, &pctx);
743 ctx->flags |= E2F_FLAG_ABORT;
744 return;
745 }
746 if (!ino)
747 break;
748 pctx.ino = ino;
749 pctx.inode = inode;
750 ctx->stashed_ino = ino;
751 if (inode->i_links_count) {
752 pctx.errcode = ext2fs_icount_store(ctx->inode_link_info,
753 ino, inode->i_links_count);
754 if (pctx.errcode) {
755 pctx.num = inode->i_links_count;
756 fix_problem(ctx, PR_1_ICOUNT_STORE, &pctx);
757 ctx->flags |= E2F_FLAG_ABORT;
758 return;
759 }
760 }
761
762 /*
763 * Test for incorrect extent flag settings.
764 *
765 * On big-endian machines we must be careful:
766 * When the inode is read, the i_block array is not swapped
767 * if the extent flag is set. Therefore if we are testing
768 * for or fixing a wrongly-set flag, we must potentially
769 * (un)swap before testing, or after fixing.
770 */
771
772 /*
773 * In this case the extents flag was set when read, so
774 * extent_header_verify is ok. If the inode is cleared,
775 * no need to swap... so no extra swapping here.
776 */
777 if ((inode->i_flags & EXT4_EXTENTS_FL) && !extent_fs &&
778 (inode->i_links_count || (ino == EXT2_BAD_INO) ||
779 (ino == EXT2_ROOT_INO) || (ino == EXT2_JOURNAL_INO))) {
780 if ((ext2fs_extent_header_verify(inode->i_block,
781 sizeof(inode->i_block)) == 0) &&
782 fix_problem(ctx, PR_1_EXTENT_FEATURE, &pctx)) {
783 sb->s_feature_incompat |= EXT3_FEATURE_INCOMPAT_EXTENTS;
784 ext2fs_mark_super_dirty(fs);
785 extent_fs = 1;
786 } else if (fix_problem(ctx, PR_1_EXTENTS_SET, &pctx)) {
787 clear_inode:
788 e2fsck_clear_inode(ctx, ino, inode, 0, "pass1");
789 if (ino == EXT2_BAD_INO)
790 ext2fs_mark_inode_bitmap2(ctx->inode_used_map,
791 ino);
792 continue;
793 }
794 }
795
796 /*
797 * For big-endian machines:
798 * If the inode didn't have the extents flag set when it
799 * was read, then the i_blocks array was swapped. To test
800 * as an extents header, we must swap it back first.
801 * IF we then set the extents flag, the entire i_block
802 * array must be un/re-swapped to make it proper extents data.
803 */
804 if (extent_fs && !(inode->i_flags & EXT4_EXTENTS_FL) &&
805 (inode->i_links_count || (ino == EXT2_BAD_INO) ||
806 (ino == EXT2_ROOT_INO) || (ino == EXT2_JOURNAL_INO)) &&
807 (LINUX_S_ISREG(inode->i_mode) ||
808 LINUX_S_ISDIR(inode->i_mode))) {
809 void *ehp;
810 #ifdef WORDS_BIGENDIAN
811 __u32 tmp_block[EXT2_N_BLOCKS];
812
813 for (i = 0; i < EXT2_N_BLOCKS; i++)
814 tmp_block[i] = ext2fs_swab32(inode->i_block[i]);
815 ehp = tmp_block;
816 #else
817 ehp = inode->i_block;
818 #endif
819 if ((ext2fs_extent_header_verify(ehp,
820 sizeof(inode->i_block)) == 0) &&
821 (fix_problem(ctx, PR_1_UNSET_EXTENT_FL, &pctx))) {
822 inode->i_flags |= EXT4_EXTENTS_FL;
823 #ifdef WORDS_BIGENDIAN
824 memcpy(inode->i_block, tmp_block,
825 sizeof(inode->i_block));
826 #endif
827 e2fsck_write_inode(ctx, ino, inode, "pass1");
828 }
829 }
830
831 if (ino == EXT2_BAD_INO) {
832 struct process_block_struct pb;
833
834 if ((inode->i_mode || inode->i_uid || inode->i_gid ||
835 inode->i_links_count || inode->i_file_acl) &&
836 fix_problem(ctx, PR_1_INVALID_BAD_INODE, &pctx)) {
837 memset(inode, 0, sizeof(struct ext2_inode));
838 e2fsck_write_inode(ctx, ino, inode,
839 "clear bad inode");
840 }
841
842 pctx.errcode = ext2fs_copy_bitmap(ctx->block_found_map,
843 &pb.fs_meta_blocks);
844 if (pctx.errcode) {
845 pctx.num = 4;
846 fix_problem(ctx, PR_1_ALLOCATE_BBITMAP_ERROR, &pctx);
847 ctx->flags |= E2F_FLAG_ABORT;
848 return;
849 }
850 pb.ino = EXT2_BAD_INO;
851 pb.num_blocks = pb.last_block = 0;
852 pb.last_db_block = -1;
853 pb.num_illegal_blocks = 0;
854 pb.suppress = 0; pb.clear = 0; pb.is_dir = 0;
855 pb.is_reg = 0; pb.fragmented = 0; pb.bbcheck = 0;
856 pb.inode = inode;
857 pb.pctx = &pctx;
858 pb.ctx = ctx;
859 pctx.errcode = ext2fs_block_iterate3(fs, ino, 0,
860 block_buf, process_bad_block, &pb);
861 ext2fs_free_block_bitmap(pb.fs_meta_blocks);
862 if (pctx.errcode) {
863 fix_problem(ctx, PR_1_BLOCK_ITERATE, &pctx);
864 ctx->flags |= E2F_FLAG_ABORT;
865 return;
866 }
867 if (pb.bbcheck)
868 if (!fix_problem(ctx, PR_1_BBINODE_BAD_METABLOCK_PROMPT, &pctx)) {
869 ctx->flags |= E2F_FLAG_ABORT;
870 return;
871 }
872 ext2fs_mark_inode_bitmap2(ctx->inode_used_map, ino);
873 clear_problem_context(&pctx);
874 continue;
875 } else if (ino == EXT2_ROOT_INO) {
876 /*
877 * Make sure the root inode is a directory; if
878 * not, offer to clear it. It will be
879 * regnerated in pass #3.
880 */
881 if (!LINUX_S_ISDIR(inode->i_mode)) {
882 if (fix_problem(ctx, PR_1_ROOT_NO_DIR, &pctx))
883 goto clear_inode;
884 }
885 /*
886 * If dtime is set, offer to clear it. mke2fs
887 * version 0.2b created filesystems with the
888 * dtime field set for the root and lost+found
889 * directories. We won't worry about
890 * /lost+found, since that can be regenerated
891 * easily. But we will fix the root directory
892 * as a special case.
893 */
894 if (inode->i_dtime && inode->i_links_count) {
895 if (fix_problem(ctx, PR_1_ROOT_DTIME, &pctx)) {
896 inode->i_dtime = 0;
897 e2fsck_write_inode(ctx, ino, inode,
898 "pass1");
899 }
900 }
901 } else if (ino == EXT2_JOURNAL_INO) {
902 ext2fs_mark_inode_bitmap2(ctx->inode_used_map, ino);
903 if (fs->super->s_journal_inum == EXT2_JOURNAL_INO) {
904 if (!LINUX_S_ISREG(inode->i_mode) &&
905 fix_problem(ctx, PR_1_JOURNAL_BAD_MODE,
906 &pctx)) {
907 inode->i_mode = LINUX_S_IFREG;
908 e2fsck_write_inode(ctx, ino, inode,
909 "pass1");
910 }
911 check_blocks(ctx, &pctx, block_buf);
912 continue;
913 }
914 if ((inode->i_links_count ||
915 inode->i_blocks || inode->i_block[0]) &&
916 fix_problem(ctx, PR_1_JOURNAL_INODE_NOT_CLEAR,
917 &pctx)) {
918 memset(inode, 0, inode_size);
919 ext2fs_icount_store(ctx->inode_link_info,
920 ino, 0);
921 e2fsck_write_inode_full(ctx, ino, inode,
922 inode_size, "pass1");
923 }
924 } else if ((ino == EXT4_USR_QUOTA_INO) ||
925 (ino == EXT4_GRP_QUOTA_INO)) {
926 ext2fs_mark_inode_bitmap2(ctx->inode_used_map, ino);
927 if ((fs->super->s_feature_ro_compat &
928 EXT4_FEATURE_RO_COMPAT_QUOTA) &&
929 ((fs->super->s_usr_quota_inum == ino) ||
930 (fs->super->s_grp_quota_inum == ino))) {
931 if (!LINUX_S_ISREG(inode->i_mode) &&
932 fix_problem(ctx, PR_1_QUOTA_BAD_MODE,
933 &pctx)) {
934 inode->i_mode = LINUX_S_IFREG;
935 e2fsck_write_inode(ctx, ino, inode,
936 "pass1");
937 }
938 check_blocks(ctx, &pctx, block_buf);
939 continue;
940 }
941 if ((inode->i_links_count ||
942 inode->i_blocks || inode->i_block[0]) &&
943 fix_problem(ctx, PR_1_QUOTA_INODE_NOT_CLEAR,
944 &pctx)) {
945 memset(inode, 0, inode_size);
946 ext2fs_icount_store(ctx->inode_link_info,
947 ino, 0);
948 e2fsck_write_inode_full(ctx, ino, inode,
949 inode_size, "pass1");
950 }
951 } else if (ino < EXT2_FIRST_INODE(fs->super)) {
952 problem_t problem = 0;
953
954 ext2fs_mark_inode_bitmap2(ctx->inode_used_map, ino);
955 if (ino == EXT2_BOOT_LOADER_INO) {
956 if (LINUX_S_ISDIR(inode->i_mode))
957 problem = PR_1_RESERVED_BAD_MODE;
958 } else if (ino == EXT2_RESIZE_INO) {
959 if (inode->i_mode &&
960 !LINUX_S_ISREG(inode->i_mode))
961 problem = PR_1_RESERVED_BAD_MODE;
962 } else {
963 if (inode->i_mode != 0)
964 problem = PR_1_RESERVED_BAD_MODE;
965 }
966 if (problem) {
967 if (fix_problem(ctx, problem, &pctx)) {
968 inode->i_mode = 0;
969 e2fsck_write_inode(ctx, ino, inode,
970 "pass1");
971 }
972 }
973 check_blocks(ctx, &pctx, block_buf);
974 continue;
975 }
976
977 /*
978 * Check for inodes who might have been part of the
979 * orphaned list linked list. They should have gotten
980 * dealt with by now, unless the list had somehow been
981 * corrupted.
982 *
983 * FIXME: In the future, inodes which are still in use
984 * (and which are therefore) pending truncation should
985 * be handled specially. Right now we just clear the
986 * dtime field, and the normal e2fsck handling of
987 * inodes where i_size and the inode blocks are
988 * inconsistent is to fix i_size, instead of releasing
989 * the extra blocks. This won't catch the inodes that
990 * was at the end of the orphan list, but it's better
991 * than nothing. The right answer is that there
992 * shouldn't be any bugs in the orphan list handling. :-)
993 */
994 if (inode->i_dtime && !busted_fs_time &&
995 inode->i_dtime < ctx->fs->super->s_inodes_count) {
996 if (fix_problem(ctx, PR_1_LOW_DTIME, &pctx)) {
997 inode->i_dtime = inode->i_links_count ?
998 0 : ctx->now;
999 e2fsck_write_inode(ctx, ino, inode,
1000 "pass1");
1001 }
1002 }
1003
1004 /*
1005 * This code assumes that deleted inodes have
1006 * i_links_count set to 0.
1007 */
1008 if (!inode->i_links_count) {
1009 if (!inode->i_dtime && inode->i_mode) {
1010 if (fix_problem(ctx,
1011 PR_1_ZERO_DTIME, &pctx)) {
1012 inode->i_dtime = ctx->now;
1013 e2fsck_write_inode(ctx, ino, inode,
1014 "pass1");
1015 }
1016 }
1017 continue;
1018 }
1019 /*
1020 * n.b. 0.3c ext2fs code didn't clear i_links_count for
1021 * deleted files. Oops.
1022 *
1023 * Since all new ext2 implementations get this right,
1024 * we now assume that the case of non-zero
1025 * i_links_count and non-zero dtime means that we
1026 * should keep the file, not delete it.
1027 *
1028 */
1029 if (inode->i_dtime) {
1030 if (fix_problem(ctx, PR_1_SET_DTIME, &pctx)) {
1031 inode->i_dtime = 0;
1032 e2fsck_write_inode(ctx, ino, inode, "pass1");
1033 }
1034 }
1035
1036 ext2fs_mark_inode_bitmap2(ctx->inode_used_map, ino);
1037 switch (fs->super->s_creator_os) {
1038 case EXT2_OS_HURD:
1039 frag = inode->osd2.hurd2.h_i_frag;
1040 fsize = inode->osd2.hurd2.h_i_fsize;
1041 break;
1042 default:
1043 frag = fsize = 0;
1044 }
1045
1046 if (inode->i_faddr || frag || fsize ||
1047 (LINUX_S_ISDIR(inode->i_mode) && inode->i_dir_acl))
1048 mark_inode_bad(ctx, ino);
1049 if (!(fs->super->s_feature_incompat &
1050 EXT4_FEATURE_INCOMPAT_64BIT) &&
1051 inode->osd2.linux2.l_i_file_acl_high != 0)
1052 mark_inode_bad(ctx, ino);
1053 if ((fs->super->s_creator_os == EXT2_OS_LINUX) &&
1054 !(fs->super->s_feature_ro_compat &
1055 EXT4_FEATURE_RO_COMPAT_HUGE_FILE) &&
1056 (inode->osd2.linux2.l_i_blocks_hi != 0))
1057 mark_inode_bad(ctx, ino);
1058 if (inode->i_flags & EXT2_IMAGIC_FL) {
1059 if (imagic_fs) {
1060 if (!ctx->inode_imagic_map)
1061 alloc_imagic_map(ctx);
1062 ext2fs_mark_inode_bitmap2(ctx->inode_imagic_map,
1063 ino);
1064 } else {
1065 if (fix_problem(ctx, PR_1_SET_IMAGIC, &pctx)) {
1066 inode->i_flags &= ~EXT2_IMAGIC_FL;
1067 e2fsck_write_inode(ctx, ino,
1068 inode, "pass1");
1069 }
1070 }
1071 }
1072
1073 check_inode_extra_space(ctx, &pctx);
1074 check_is_really_dir(ctx, &pctx, block_buf);
1075
1076 /*
1077 * ext2fs_inode_has_valid_blocks2 does not actually look
1078 * at i_block[] values, so not endian-sensitive here.
1079 */
1080 if (extent_fs && (inode->i_flags & EXT4_EXTENTS_FL) &&
1081 LINUX_S_ISLNK(inode->i_mode) &&
1082 !ext2fs_inode_has_valid_blocks2(fs, inode) &&
1083 fix_problem(ctx, PR_1_FAST_SYMLINK_EXTENT_FL, &pctx)) {
1084 inode->i_flags &= ~EXT4_EXTENTS_FL;
1085 e2fsck_write_inode(ctx, ino, inode, "pass1");
1086 }
1087
1088 if (LINUX_S_ISDIR(inode->i_mode)) {
1089 ext2fs_mark_inode_bitmap2(ctx->inode_dir_map, ino);
1090 e2fsck_add_dir_info(ctx, ino, 0);
1091 ctx->fs_directory_count++;
1092 } else if (LINUX_S_ISREG (inode->i_mode)) {
1093 ext2fs_mark_inode_bitmap2(ctx->inode_reg_map, ino);
1094 ctx->fs_regular_count++;
1095 } else if (LINUX_S_ISCHR (inode->i_mode) &&
1096 e2fsck_pass1_check_device_inode(fs, inode)) {
1097 check_immutable(ctx, &pctx);
1098 check_size(ctx, &pctx);
1099 ctx->fs_chardev_count++;
1100 } else if (LINUX_S_ISBLK (inode->i_mode) &&
1101 e2fsck_pass1_check_device_inode(fs, inode)) {
1102 check_immutable(ctx, &pctx);
1103 check_size(ctx, &pctx);
1104 ctx->fs_blockdev_count++;
1105 } else if (LINUX_S_ISLNK (inode->i_mode) &&
1106 e2fsck_pass1_check_symlink(fs, ino, inode,
1107 block_buf)) {
1108 check_immutable(ctx, &pctx);
1109 ctx->fs_symlinks_count++;
1110 if (ext2fs_inode_data_blocks(fs, inode) == 0) {
1111 ctx->fs_fast_symlinks_count++;
1112 check_blocks(ctx, &pctx, block_buf);
1113 continue;
1114 }
1115 }
1116 else if (LINUX_S_ISFIFO (inode->i_mode) &&
1117 e2fsck_pass1_check_device_inode(fs, inode)) {
1118 check_immutable(ctx, &pctx);
1119 check_size(ctx, &pctx);
1120 ctx->fs_fifo_count++;
1121 } else if ((LINUX_S_ISSOCK (inode->i_mode)) &&
1122 e2fsck_pass1_check_device_inode(fs, inode)) {
1123 check_immutable(ctx, &pctx);
1124 check_size(ctx, &pctx);
1125 ctx->fs_sockets_count++;
1126 } else
1127 mark_inode_bad(ctx, ino);
1128 if (!(inode->i_flags & EXT4_EXTENTS_FL)) {
1129 if (inode->i_block[EXT2_IND_BLOCK])
1130 ctx->fs_ind_count++;
1131 if (inode->i_block[EXT2_DIND_BLOCK])
1132 ctx->fs_dind_count++;
1133 if (inode->i_block[EXT2_TIND_BLOCK])
1134 ctx->fs_tind_count++;
1135 }
1136 if (!(inode->i_flags & EXT4_EXTENTS_FL) &&
1137 (inode->i_block[EXT2_IND_BLOCK] ||
1138 inode->i_block[EXT2_DIND_BLOCK] ||
1139 inode->i_block[EXT2_TIND_BLOCK] ||
1140 ext2fs_file_acl_block(fs, inode))) {
1141 inodes_to_process[process_inode_count].ino = ino;
1142 inodes_to_process[process_inode_count].inode = *inode;
1143 process_inode_count++;
1144 } else
1145 check_blocks(ctx, &pctx, block_buf);
1146
1147 if (ctx->flags & E2F_FLAG_SIGNAL_MASK)
1148 return;
1149
1150 if (process_inode_count >= ctx->process_inode_size) {
1151 process_inodes(ctx, block_buf);
1152
1153 if (ctx->flags & E2F_FLAG_SIGNAL_MASK)
1154 return;
1155 }
1156 }
1157 process_inodes(ctx, block_buf);
1158 ext2fs_close_inode_scan(scan);
1159
1160 /*
1161 * If any extended attribute blocks' reference counts need to
1162 * be adjusted, either up (ctx->refcount_extra), or down
1163 * (ctx->refcount), then fix them.
1164 */
1165 if (ctx->refcount) {
1166 adjust_extattr_refcount(ctx, ctx->refcount, block_buf, -1);
1167 ea_refcount_free(ctx->refcount);
1168 ctx->refcount = 0;
1169 }
1170 if (ctx->refcount_extra) {
1171 adjust_extattr_refcount(ctx, ctx->refcount_extra,
1172 block_buf, +1);
1173 ea_refcount_free(ctx->refcount_extra);
1174 ctx->refcount_extra = 0;
1175 }
1176
1177 if (ctx->invalid_bitmaps)
1178 handle_fs_bad_blocks(ctx);
1179
1180 /* We don't need the block_ea_map any more */
1181 if (ctx->block_ea_map) {
1182 ext2fs_free_block_bitmap(ctx->block_ea_map);
1183 ctx->block_ea_map = 0;
1184 }
1185
1186 if (ctx->flags & E2F_FLAG_RESIZE_INODE) {
1187 ext2fs_block_bitmap save_bmap;
1188
1189 save_bmap = fs->block_map;
1190 fs->block_map = ctx->block_found_map;
1191 clear_problem_context(&pctx);
1192 pctx.errcode = ext2fs_create_resize_inode(fs);
1193 if (pctx.errcode) {
1194 if (!fix_problem(ctx, PR_1_RESIZE_INODE_CREATE,
1195 &pctx)) {
1196 ctx->flags |= E2F_FLAG_ABORT;
1197 return;
1198 }
1199 pctx.errcode = 0;
1200 }
1201 if (!pctx.errcode) {
1202 e2fsck_read_inode(ctx, EXT2_RESIZE_INO, inode,
1203 "recreate inode");
1204 inode->i_mtime = ctx->now;
1205 e2fsck_write_inode(ctx, EXT2_RESIZE_INO, inode,
1206 "recreate inode");
1207 }
1208 fs->block_map = save_bmap;
1209 ctx->flags &= ~E2F_FLAG_RESIZE_INODE;
1210 }
1211
1212 if (ctx->flags & E2F_FLAG_RESTART) {
1213 /*
1214 * Only the master copy of the superblock and block
1215 * group descriptors are going to be written during a
1216 * restart, so set the superblock to be used to be the
1217 * master superblock.
1218 */
1219 ctx->use_superblock = 0;
1220 unwind_pass1(fs);
1221 goto endit;
1222 }
1223
1224 if (ctx->block_dup_map) {
1225 if (ctx->options & E2F_OPT_PREEN) {
1226 clear_problem_context(&pctx);
1227 fix_problem(ctx, PR_1_DUP_BLOCKS_PREENSTOP, &pctx);
1228 }
1229 e2fsck_pass1_dupblocks(ctx, block_buf);
1230 }
1231 ext2fs_free_mem(&inodes_to_process);
1232 endit:
1233 e2fsck_use_inode_shortcuts(ctx, 0);
1234
1235 ext2fs_free_mem(&block_buf);
1236 ext2fs_free_mem(&inode);
1237
1238 print_resource_track(ctx, _("Pass 1"), &rtrack, ctx->fs->io);
1239 }
1240
1241 /*
1242 * When the inode_scan routines call this callback at the end of the
1243 * glock group, call process_inodes.
1244 */
scan_callback(ext2_filsys fs,ext2_inode_scan scan EXT2FS_ATTR ((unused)),dgrp_t group,void * priv_data)1245 static errcode_t scan_callback(ext2_filsys fs,
1246 ext2_inode_scan scan EXT2FS_ATTR((unused)),
1247 dgrp_t group, void * priv_data)
1248 {
1249 struct scan_callback_struct *scan_struct;
1250 e2fsck_t ctx;
1251
1252 scan_struct = (struct scan_callback_struct *) priv_data;
1253 ctx = scan_struct->ctx;
1254
1255 process_inodes((e2fsck_t) fs->priv_data, scan_struct->block_buf);
1256
1257 if (ctx->progress)
1258 if ((ctx->progress)(ctx, 1, group+1,
1259 ctx->fs->group_desc_count))
1260 return EXT2_ET_CANCEL_REQUESTED;
1261
1262 return 0;
1263 }
1264
1265 /*
1266 * Process the inodes in the "inodes to process" list.
1267 */
process_inodes(e2fsck_t ctx,char * block_buf)1268 static void process_inodes(e2fsck_t ctx, char *block_buf)
1269 {
1270 int i;
1271 struct ext2_inode *old_stashed_inode;
1272 ext2_ino_t old_stashed_ino;
1273 const char *old_operation;
1274 char buf[80];
1275 struct problem_context pctx;
1276
1277 #if 0
1278 printf("begin process_inodes: ");
1279 #endif
1280 if (process_inode_count == 0)
1281 return;
1282 old_operation = ehandler_operation(0);
1283 old_stashed_inode = ctx->stashed_inode;
1284 old_stashed_ino = ctx->stashed_ino;
1285 qsort(inodes_to_process, process_inode_count,
1286 sizeof(struct process_inode_block), process_inode_cmp);
1287 clear_problem_context(&pctx);
1288 for (i=0; i < process_inode_count; i++) {
1289 pctx.inode = ctx->stashed_inode = &inodes_to_process[i].inode;
1290 pctx.ino = ctx->stashed_ino = inodes_to_process[i].ino;
1291
1292 #if 0
1293 printf("%u ", pctx.ino);
1294 #endif
1295 sprintf(buf, _("reading indirect blocks of inode %u"),
1296 pctx.ino);
1297 ehandler_operation(buf);
1298 check_blocks(ctx, &pctx, block_buf);
1299 if (ctx->flags & E2F_FLAG_SIGNAL_MASK)
1300 break;
1301 }
1302 ctx->stashed_inode = old_stashed_inode;
1303 ctx->stashed_ino = old_stashed_ino;
1304 process_inode_count = 0;
1305 #if 0
1306 printf("end process inodes\n");
1307 #endif
1308 ehandler_operation(old_operation);
1309 }
1310
process_inode_cmp(const void * a,const void * b)1311 static EXT2_QSORT_TYPE process_inode_cmp(const void *a, const void *b)
1312 {
1313 const struct process_inode_block *ib_a =
1314 (const struct process_inode_block *) a;
1315 const struct process_inode_block *ib_b =
1316 (const struct process_inode_block *) b;
1317 int ret;
1318
1319 ret = (ib_a->inode.i_block[EXT2_IND_BLOCK] -
1320 ib_b->inode.i_block[EXT2_IND_BLOCK]);
1321 if (ret == 0)
1322 /*
1323 * We only call process_inodes() for non-extent
1324 * inodes, so it's OK to pass NULL to
1325 * ext2fs_file_acl_block() here.
1326 */
1327 ret = ext2fs_file_acl_block(0, &(ib_a->inode)) -
1328 ext2fs_file_acl_block(0, &(ib_b->inode));
1329 if (ret == 0)
1330 ret = ib_a->ino - ib_b->ino;
1331 return ret;
1332 }
1333
1334 /*
1335 * Mark an inode as being bad in some what
1336 */
mark_inode_bad(e2fsck_t ctx,ino_t ino)1337 static void mark_inode_bad(e2fsck_t ctx, ino_t ino)
1338 {
1339 struct problem_context pctx;
1340
1341 if (!ctx->inode_bad_map) {
1342 clear_problem_context(&pctx);
1343
1344 pctx.errcode = e2fsck_allocate_inode_bitmap(ctx->fs,
1345 _("bad inode map"), EXT2FS_BMAP64_RBTREE,
1346 "inode_bad_map", &ctx->inode_bad_map);
1347 if (pctx.errcode) {
1348 pctx.num = 3;
1349 fix_problem(ctx, PR_1_ALLOCATE_IBITMAP_ERROR, &pctx);
1350 /* Should never get here */
1351 ctx->flags |= E2F_FLAG_ABORT;
1352 return;
1353 }
1354 }
1355 ext2fs_mark_inode_bitmap2(ctx->inode_bad_map, ino);
1356 }
1357
1358
1359 /*
1360 * This procedure will allocate the inode "bb" (badblock) map table
1361 */
alloc_bb_map(e2fsck_t ctx)1362 static void alloc_bb_map(e2fsck_t ctx)
1363 {
1364 struct problem_context pctx;
1365
1366 clear_problem_context(&pctx);
1367 pctx.errcode = e2fsck_allocate_inode_bitmap(ctx->fs,
1368 _("inode in bad block map"), EXT2FS_BMAP64_RBTREE,
1369 "inode_bb_map", &ctx->inode_bb_map);
1370 if (pctx.errcode) {
1371 pctx.num = 4;
1372 fix_problem(ctx, PR_1_ALLOCATE_IBITMAP_ERROR, &pctx);
1373 /* Should never get here */
1374 ctx->flags |= E2F_FLAG_ABORT;
1375 return;
1376 }
1377 }
1378
1379 /*
1380 * This procedure will allocate the inode imagic table
1381 */
alloc_imagic_map(e2fsck_t ctx)1382 static void alloc_imagic_map(e2fsck_t ctx)
1383 {
1384 struct problem_context pctx;
1385
1386 clear_problem_context(&pctx);
1387 pctx.errcode = e2fsck_allocate_inode_bitmap(ctx->fs,
1388 _("imagic inode map"), EXT2FS_BMAP64_RBTREE,
1389 "inode_imagic_map", &ctx->inode_imagic_map);
1390 if (pctx.errcode) {
1391 pctx.num = 5;
1392 fix_problem(ctx, PR_1_ALLOCATE_IBITMAP_ERROR, &pctx);
1393 /* Should never get here */
1394 ctx->flags |= E2F_FLAG_ABORT;
1395 return;
1396 }
1397 }
1398
1399 /*
1400 * Marks a block as in use, setting the dup_map if it's been set
1401 * already. Called by process_block and process_bad_block.
1402 *
1403 * WARNING: Assumes checks have already been done to make sure block
1404 * is valid. This is true in both process_block and process_bad_block.
1405 */
mark_block_used(e2fsck_t ctx,blk64_t block)1406 static _INLINE_ void mark_block_used(e2fsck_t ctx, blk64_t block)
1407 {
1408 struct problem_context pctx;
1409
1410 clear_problem_context(&pctx);
1411
1412 if (ext2fs_fast_test_block_bitmap2(ctx->block_found_map, block)) {
1413 if (!ctx->block_dup_map) {
1414 pctx.errcode = e2fsck_allocate_block_bitmap(ctx->fs,
1415 _("multiply claimed block map"),
1416 EXT2FS_BMAP64_RBTREE, "block_dup_map",
1417 &ctx->block_dup_map);
1418 if (pctx.errcode) {
1419 pctx.num = 3;
1420 fix_problem(ctx, PR_1_ALLOCATE_BBITMAP_ERROR,
1421 &pctx);
1422 /* Should never get here */
1423 ctx->flags |= E2F_FLAG_ABORT;
1424 return;
1425 }
1426 }
1427 ext2fs_fast_mark_block_bitmap2(ctx->block_dup_map, block);
1428 } else {
1429 ext2fs_fast_mark_block_bitmap2(ctx->block_found_map, block);
1430 }
1431 }
1432
mark_blocks_used(e2fsck_t ctx,blk64_t block,unsigned int num)1433 static _INLINE_ void mark_blocks_used(e2fsck_t ctx, blk64_t block,
1434 unsigned int num)
1435 {
1436 if (ext2fs_test_block_bitmap_range2(ctx->block_found_map, block, num))
1437 ext2fs_mark_block_bitmap_range2(ctx->block_found_map, block, num);
1438 else
1439 while (num--)
1440 mark_block_used(ctx, block++);
1441 }
1442
1443 /*
1444 * Adjust the extended attribute block's reference counts at the end
1445 * of pass 1, either by subtracting out references for EA blocks that
1446 * are still referenced in ctx->refcount, or by adding references for
1447 * EA blocks that had extra references as accounted for in
1448 * ctx->refcount_extra.
1449 */
adjust_extattr_refcount(e2fsck_t ctx,ext2_refcount_t refcount,char * block_buf,int adjust_sign)1450 static void adjust_extattr_refcount(e2fsck_t ctx, ext2_refcount_t refcount,
1451 char *block_buf, int adjust_sign)
1452 {
1453 struct ext2_ext_attr_header *header;
1454 struct problem_context pctx;
1455 ext2_filsys fs = ctx->fs;
1456 blk64_t blk;
1457 __u32 should_be;
1458 int count;
1459
1460 clear_problem_context(&pctx);
1461
1462 ea_refcount_intr_begin(refcount);
1463 while (1) {
1464 if ((blk = ea_refcount_intr_next(refcount, &count)) == 0)
1465 break;
1466 pctx.blk = blk;
1467 pctx.errcode = ext2fs_read_ext_attr2(fs, blk, block_buf);
1468 if (pctx.errcode) {
1469 fix_problem(ctx, PR_1_EXTATTR_READ_ABORT, &pctx);
1470 return;
1471 }
1472 header = (struct ext2_ext_attr_header *) block_buf;
1473 pctx.blkcount = header->h_refcount;
1474 should_be = header->h_refcount + adjust_sign * count;
1475 pctx.num = should_be;
1476 if (fix_problem(ctx, PR_1_EXTATTR_REFCOUNT, &pctx)) {
1477 header->h_refcount = should_be;
1478 pctx.errcode = ext2fs_write_ext_attr2(fs, blk,
1479 block_buf);
1480 if (pctx.errcode) {
1481 fix_problem(ctx, PR_1_EXTATTR_WRITE_ABORT,
1482 &pctx);
1483 continue;
1484 }
1485 }
1486 }
1487 }
1488
1489 /*
1490 * Handle processing the extended attribute blocks
1491 */
check_ext_attr(e2fsck_t ctx,struct problem_context * pctx,char * block_buf)1492 static int check_ext_attr(e2fsck_t ctx, struct problem_context *pctx,
1493 char *block_buf)
1494 {
1495 ext2_filsys fs = ctx->fs;
1496 ext2_ino_t ino = pctx->ino;
1497 struct ext2_inode *inode = pctx->inode;
1498 blk64_t blk;
1499 char * end;
1500 struct ext2_ext_attr_header *header;
1501 struct ext2_ext_attr_entry *entry;
1502 int count;
1503 region_t region = 0;
1504
1505 blk = ext2fs_file_acl_block(fs, inode);
1506 if (blk == 0)
1507 return 0;
1508
1509 /*
1510 * If the Extended attribute flag isn't set, then a non-zero
1511 * file acl means that the inode is corrupted.
1512 *
1513 * Or if the extended attribute block is an invalid block,
1514 * then the inode is also corrupted.
1515 */
1516 if (!(fs->super->s_feature_compat & EXT2_FEATURE_COMPAT_EXT_ATTR) ||
1517 (blk < fs->super->s_first_data_block) ||
1518 (blk >= ext2fs_blocks_count(fs->super))) {
1519 mark_inode_bad(ctx, ino);
1520 return 0;
1521 }
1522
1523 /* If ea bitmap hasn't been allocated, create it */
1524 if (!ctx->block_ea_map) {
1525 pctx->errcode = e2fsck_allocate_block_bitmap(fs,
1526 _("ext attr block map"),
1527 EXT2FS_BMAP64_RBTREE, "block_ea_map",
1528 &ctx->block_ea_map);
1529 if (pctx->errcode) {
1530 pctx->num = 2;
1531 fix_problem(ctx, PR_1_ALLOCATE_BBITMAP_ERROR, pctx);
1532 ctx->flags |= E2F_FLAG_ABORT;
1533 return 0;
1534 }
1535 }
1536
1537 /* Create the EA refcount structure if necessary */
1538 if (!ctx->refcount) {
1539 pctx->errcode = ea_refcount_create(0, &ctx->refcount);
1540 if (pctx->errcode) {
1541 pctx->num = 1;
1542 fix_problem(ctx, PR_1_ALLOCATE_REFCOUNT, pctx);
1543 ctx->flags |= E2F_FLAG_ABORT;
1544 return 0;
1545 }
1546 }
1547
1548 #if 0
1549 /* Debugging text */
1550 printf("Inode %u has EA block %u\n", ino, blk);
1551 #endif
1552
1553 /* Have we seen this EA block before? */
1554 if (ext2fs_fast_test_block_bitmap2(ctx->block_ea_map, blk)) {
1555 if (ea_refcount_decrement(ctx->refcount, blk, 0) == 0)
1556 return 1;
1557 /* Ooops, this EA was referenced more than it stated */
1558 if (!ctx->refcount_extra) {
1559 pctx->errcode = ea_refcount_create(0,
1560 &ctx->refcount_extra);
1561 if (pctx->errcode) {
1562 pctx->num = 2;
1563 fix_problem(ctx, PR_1_ALLOCATE_REFCOUNT, pctx);
1564 ctx->flags |= E2F_FLAG_ABORT;
1565 return 0;
1566 }
1567 }
1568 ea_refcount_increment(ctx->refcount_extra, blk, 0);
1569 return 1;
1570 }
1571
1572 /*
1573 * OK, we haven't seen this EA block yet. So we need to
1574 * validate it
1575 */
1576 pctx->blk = blk;
1577 pctx->errcode = ext2fs_read_ext_attr2(fs, blk, block_buf);
1578 if (pctx->errcode && fix_problem(ctx, PR_1_READ_EA_BLOCK, pctx))
1579 goto clear_extattr;
1580 header = (struct ext2_ext_attr_header *) block_buf;
1581 pctx->blk = ext2fs_file_acl_block(fs, inode);
1582 if (((ctx->ext_attr_ver == 1) &&
1583 (header->h_magic != EXT2_EXT_ATTR_MAGIC_v1)) ||
1584 ((ctx->ext_attr_ver == 2) &&
1585 (header->h_magic != EXT2_EXT_ATTR_MAGIC))) {
1586 if (fix_problem(ctx, PR_1_BAD_EA_BLOCK, pctx))
1587 goto clear_extattr;
1588 }
1589
1590 if (header->h_blocks != 1) {
1591 if (fix_problem(ctx, PR_1_EA_MULTI_BLOCK, pctx))
1592 goto clear_extattr;
1593 }
1594
1595 region = region_create(0, fs->blocksize);
1596 if (!region) {
1597 fix_problem(ctx, PR_1_EA_ALLOC_REGION_ABORT, pctx);
1598 ctx->flags |= E2F_FLAG_ABORT;
1599 return 0;
1600 }
1601 if (region_allocate(region, 0, sizeof(struct ext2_ext_attr_header))) {
1602 if (fix_problem(ctx, PR_1_EA_ALLOC_COLLISION, pctx))
1603 goto clear_extattr;
1604 }
1605
1606 entry = (struct ext2_ext_attr_entry *)(header+1);
1607 end = block_buf + fs->blocksize;
1608 while ((char *)entry < end && *(__u32 *)entry) {
1609 __u32 hash;
1610
1611 if (region_allocate(region, (char *)entry - (char *)header,
1612 EXT2_EXT_ATTR_LEN(entry->e_name_len))) {
1613 if (fix_problem(ctx, PR_1_EA_ALLOC_COLLISION, pctx))
1614 goto clear_extattr;
1615 break;
1616 }
1617 if ((ctx->ext_attr_ver == 1 &&
1618 (entry->e_name_len == 0 || entry->e_name_index != 0)) ||
1619 (ctx->ext_attr_ver == 2 &&
1620 entry->e_name_index == 0)) {
1621 if (fix_problem(ctx, PR_1_EA_BAD_NAME, pctx))
1622 goto clear_extattr;
1623 break;
1624 }
1625 if (entry->e_value_block != 0) {
1626 if (fix_problem(ctx, PR_1_EA_BAD_VALUE, pctx))
1627 goto clear_extattr;
1628 }
1629 if (entry->e_value_offs + entry->e_value_size > fs->blocksize) {
1630 if (fix_problem(ctx, PR_1_EA_BAD_VALUE, pctx))
1631 goto clear_extattr;
1632 break;
1633 }
1634 if (entry->e_value_size &&
1635 region_allocate(region, entry->e_value_offs,
1636 EXT2_EXT_ATTR_SIZE(entry->e_value_size))) {
1637 if (fix_problem(ctx, PR_1_EA_ALLOC_COLLISION, pctx))
1638 goto clear_extattr;
1639 }
1640
1641 hash = ext2fs_ext_attr_hash_entry(entry, block_buf +
1642 entry->e_value_offs);
1643
1644 if (entry->e_hash != hash) {
1645 pctx->num = entry->e_hash;
1646 if (fix_problem(ctx, PR_1_ATTR_HASH, pctx))
1647 goto clear_extattr;
1648 entry->e_hash = hash;
1649 }
1650
1651 entry = EXT2_EXT_ATTR_NEXT(entry);
1652 }
1653 if (region_allocate(region, (char *)entry - (char *)header, 4)) {
1654 if (fix_problem(ctx, PR_1_EA_ALLOC_COLLISION, pctx))
1655 goto clear_extattr;
1656 }
1657 region_free(region);
1658
1659 count = header->h_refcount - 1;
1660 if (count)
1661 ea_refcount_store(ctx->refcount, blk, count);
1662 mark_block_used(ctx, blk);
1663 ext2fs_fast_mark_block_bitmap2(ctx->block_ea_map, blk);
1664 return 1;
1665
1666 clear_extattr:
1667 if (region)
1668 region_free(region);
1669 ext2fs_file_acl_block_set(fs, inode, 0);
1670 e2fsck_write_inode(ctx, ino, inode, "check_ext_attr");
1671 return 0;
1672 }
1673
1674 /* Returns 1 if bad htree, 0 if OK */
handle_htree(e2fsck_t ctx,struct problem_context * pctx,ext2_ino_t ino,struct ext2_inode * inode,char * block_buf)1675 static int handle_htree(e2fsck_t ctx, struct problem_context *pctx,
1676 ext2_ino_t ino, struct ext2_inode *inode,
1677 char *block_buf)
1678 {
1679 struct ext2_dx_root_info *root;
1680 ext2_filsys fs = ctx->fs;
1681 errcode_t retval;
1682 blk64_t blk;
1683
1684 if ((!LINUX_S_ISDIR(inode->i_mode) &&
1685 fix_problem(ctx, PR_1_HTREE_NODIR, pctx)) ||
1686 (!(fs->super->s_feature_compat & EXT2_FEATURE_COMPAT_DIR_INDEX) &&
1687 fix_problem(ctx, PR_1_HTREE_SET, pctx)))
1688 return 1;
1689
1690 pctx->errcode = ext2fs_bmap2(fs, ino, inode, 0, 0, 0, 0, &blk);
1691
1692 if ((pctx->errcode) ||
1693 (blk == 0) ||
1694 (blk < fs->super->s_first_data_block) ||
1695 (blk >= ext2fs_blocks_count(fs->super))) {
1696 if (fix_problem(ctx, PR_1_HTREE_BADROOT, pctx))
1697 return 1;
1698 else
1699 return 0;
1700 }
1701
1702 retval = io_channel_read_blk64(fs->io, blk, 1, block_buf);
1703 if (retval && fix_problem(ctx, PR_1_HTREE_BADROOT, pctx))
1704 return 1;
1705
1706 /* XXX should check that beginning matches a directory */
1707 root = (struct ext2_dx_root_info *) (block_buf + 24);
1708
1709 if ((root->reserved_zero || root->info_length < 8) &&
1710 fix_problem(ctx, PR_1_HTREE_BADROOT, pctx))
1711 return 1;
1712
1713 pctx->num = root->hash_version;
1714 if ((root->hash_version != EXT2_HASH_LEGACY) &&
1715 (root->hash_version != EXT2_HASH_HALF_MD4) &&
1716 (root->hash_version != EXT2_HASH_TEA) &&
1717 fix_problem(ctx, PR_1_HTREE_HASHV, pctx))
1718 return 1;
1719
1720 if ((root->unused_flags & EXT2_HASH_FLAG_INCOMPAT) &&
1721 fix_problem(ctx, PR_1_HTREE_INCOMPAT, pctx))
1722 return 1;
1723
1724 pctx->num = root->indirect_levels;
1725 if ((root->indirect_levels > 1) &&
1726 fix_problem(ctx, PR_1_HTREE_DEPTH, pctx))
1727 return 1;
1728
1729 return 0;
1730 }
1731
e2fsck_clear_inode(e2fsck_t ctx,ext2_ino_t ino,struct ext2_inode * inode,int restart_flag,const char * source)1732 void e2fsck_clear_inode(e2fsck_t ctx, ext2_ino_t ino,
1733 struct ext2_inode *inode, int restart_flag,
1734 const char *source)
1735 {
1736 inode->i_flags = 0;
1737 inode->i_links_count = 0;
1738 ext2fs_icount_store(ctx->inode_link_info, ino, 0);
1739 inode->i_dtime = ctx->now;
1740
1741 ext2fs_unmark_inode_bitmap2(ctx->inode_dir_map, ino);
1742 ext2fs_unmark_inode_bitmap2(ctx->inode_used_map, ino);
1743 if (ctx->inode_reg_map)
1744 ext2fs_unmark_inode_bitmap2(ctx->inode_reg_map, ino);
1745 if (ctx->inode_bad_map)
1746 ext2fs_unmark_inode_bitmap2(ctx->inode_bad_map, ino);
1747
1748 /*
1749 * If the inode was partially accounted for before processing
1750 * was aborted, we need to restart the pass 1 scan.
1751 */
1752 ctx->flags |= restart_flag;
1753
1754 if (ino == EXT2_BAD_INO)
1755 memset(inode, 0, sizeof(struct ext2_inode));
1756
1757 e2fsck_write_inode(ctx, ino, inode, source);
1758 }
1759
scan_extent_node(e2fsck_t ctx,struct problem_context * pctx,struct process_block_struct * pb,blk64_t start_block,blk64_t end_block,blk64_t eof_block,ext2_extent_handle_t ehandle)1760 static void scan_extent_node(e2fsck_t ctx, struct problem_context *pctx,
1761 struct process_block_struct *pb,
1762 blk64_t start_block, blk64_t end_block,
1763 blk64_t eof_block,
1764 ext2_extent_handle_t ehandle)
1765 {
1766 struct ext2fs_extent extent;
1767 blk64_t blk, last_lblk;
1768 e2_blkcnt_t blockcnt;
1769 unsigned int i;
1770 int is_dir, is_leaf;
1771 problem_t problem;
1772 struct ext2_extent_info info;
1773
1774 pctx->errcode = ext2fs_extent_get_info(ehandle, &info);
1775 if (pctx->errcode)
1776 return;
1777
1778 pctx->errcode = ext2fs_extent_get(ehandle, EXT2_EXTENT_FIRST_SIB,
1779 &extent);
1780 while (!pctx->errcode && info.num_entries-- > 0) {
1781 is_leaf = extent.e_flags & EXT2_EXTENT_FLAGS_LEAF;
1782 is_dir = LINUX_S_ISDIR(pctx->inode->i_mode);
1783 last_lblk = extent.e_lblk + extent.e_len - 1;
1784
1785 problem = 0;
1786 if (extent.e_pblk == 0 ||
1787 extent.e_pblk < ctx->fs->super->s_first_data_block ||
1788 extent.e_pblk >= ext2fs_blocks_count(ctx->fs->super))
1789 problem = PR_1_EXTENT_BAD_START_BLK;
1790 else if (extent.e_lblk < start_block)
1791 problem = PR_1_OUT_OF_ORDER_EXTENTS;
1792 else if ((end_block && last_lblk > end_block) &&
1793 (!(extent.e_flags & EXT2_EXTENT_FLAGS_UNINIT &&
1794 last_lblk > eof_block)))
1795 problem = PR_1_EXTENT_END_OUT_OF_BOUNDS;
1796 else if (is_leaf && extent.e_len == 0)
1797 problem = PR_1_EXTENT_LENGTH_ZERO;
1798 else if (is_leaf &&
1799 (extent.e_pblk + extent.e_len) >
1800 ext2fs_blocks_count(ctx->fs->super))
1801 problem = PR_1_EXTENT_ENDS_BEYOND;
1802 else if (is_leaf && is_dir &&
1803 ((extent.e_lblk + extent.e_len) >
1804 (1 << (21 - ctx->fs->super->s_log_block_size))))
1805 problem = PR_1_TOOBIG_DIR;
1806
1807 if (problem) {
1808 report_problem:
1809 pctx->blk = extent.e_pblk;
1810 pctx->blk2 = extent.e_lblk;
1811 pctx->num = extent.e_len;
1812 pctx->blkcount = extent.e_lblk + extent.e_len;
1813 if (fix_problem(ctx, problem, pctx)) {
1814 e2fsck_read_bitmaps(ctx);
1815 pctx->errcode =
1816 ext2fs_extent_delete(ehandle, 0);
1817 if (pctx->errcode) {
1818 pctx->str = "ext2fs_extent_delete";
1819 return;
1820 }
1821 ext2fs_extent_fix_parents(ehandle);
1822 pctx->errcode = ext2fs_extent_get(ehandle,
1823 EXT2_EXTENT_CURRENT,
1824 &extent);
1825 if (pctx->errcode == EXT2_ET_NO_CURRENT_NODE) {
1826 pctx->errcode = 0;
1827 break;
1828 }
1829 continue;
1830 }
1831 goto next;
1832 }
1833
1834 if (!is_leaf) {
1835 blk64_t lblk = extent.e_lblk;
1836
1837 blk = extent.e_pblk;
1838 pctx->errcode = ext2fs_extent_get(ehandle,
1839 EXT2_EXTENT_DOWN, &extent);
1840 if (pctx->errcode) {
1841 pctx->str = "EXT2_EXTENT_DOWN";
1842 problem = PR_1_EXTENT_HEADER_INVALID;
1843 if (pctx->errcode == EXT2_ET_EXTENT_HEADER_BAD)
1844 goto report_problem;
1845 return;
1846 }
1847 /* The next extent should match this index's logical start */
1848 if (extent.e_lblk != lblk) {
1849 struct ext2_extent_info e_info;
1850
1851 ext2fs_extent_get_info(ehandle, &e_info);
1852 pctx->blk = lblk;
1853 pctx->blk2 = extent.e_lblk;
1854 pctx->num = e_info.curr_level - 1;
1855 problem = PR_1_EXTENT_INDEX_START_INVALID;
1856 if (fix_problem(ctx, problem, pctx))
1857 ext2fs_extent_fix_parents(ehandle);
1858 }
1859 scan_extent_node(ctx, pctx, pb, extent.e_lblk,
1860 last_lblk, eof_block, ehandle);
1861 if (pctx->errcode)
1862 return;
1863 pctx->errcode = ext2fs_extent_get(ehandle,
1864 EXT2_EXTENT_UP, &extent);
1865 if (pctx->errcode) {
1866 pctx->str = "EXT2_EXTENT_UP";
1867 return;
1868 }
1869 mark_block_used(ctx, blk);
1870 pb->num_blocks++;
1871 goto next;
1872 }
1873
1874 if ((pb->previous_block != 0) &&
1875 (pb->previous_block+1 != extent.e_pblk)) {
1876 if (ctx->options & E2F_OPT_FRAGCHECK) {
1877 char type = '?';
1878
1879 if (pb->is_dir)
1880 type = 'd';
1881 else if (pb->is_reg)
1882 type = 'f';
1883
1884 printf(("%6lu(%c): expecting %6lu "
1885 "actual extent "
1886 "phys %6lu log %lu len %lu\n"),
1887 (unsigned long) pctx->ino, type,
1888 (unsigned long) pb->previous_block+1,
1889 (unsigned long) extent.e_pblk,
1890 (unsigned long) extent.e_lblk,
1891 (unsigned long) extent.e_len);
1892 }
1893 pb->fragmented = 1;
1894 }
1895 while (is_dir && (++pb->last_db_block <
1896 (e2_blkcnt_t) extent.e_lblk)) {
1897 pctx->errcode = ext2fs_add_dir_block2(ctx->fs->dblist,
1898 pb->ino, 0,
1899 pb->last_db_block);
1900 if (pctx->errcode) {
1901 pctx->blk = 0;
1902 pctx->num = pb->last_db_block;
1903 goto failed_add_dir_block;
1904 }
1905 }
1906 if (!ctx->fs->cluster_ratio_bits) {
1907 mark_blocks_used(ctx, extent.e_pblk, extent.e_len);
1908 pb->num_blocks += extent.e_len;
1909 }
1910 for (blk = extent.e_pblk, blockcnt = extent.e_lblk, i = 0;
1911 i < extent.e_len;
1912 blk++, blockcnt++, i++) {
1913 if (ctx->fs->cluster_ratio_bits &&
1914 !(pb->previous_block &&
1915 (EXT2FS_B2C(ctx->fs, blk) ==
1916 EXT2FS_B2C(ctx->fs, pb->previous_block)) &&
1917 (blk & EXT2FS_CLUSTER_MASK(ctx->fs)) ==
1918 ((unsigned) blockcnt & EXT2FS_CLUSTER_MASK(ctx->fs)))) {
1919 mark_block_used(ctx, blk);
1920 pb->num_blocks++;
1921 }
1922
1923 pb->previous_block = blk;
1924
1925 if (is_dir) {
1926 pctx->errcode = ext2fs_add_dir_block2(ctx->fs->dblist, pctx->ino, blk, blockcnt);
1927 if (pctx->errcode) {
1928 pctx->blk = blk;
1929 pctx->num = blockcnt;
1930 failed_add_dir_block:
1931 fix_problem(ctx, PR_1_ADD_DBLOCK, pctx);
1932 /* Should never get here */
1933 ctx->flags |= E2F_FLAG_ABORT;
1934 return;
1935 }
1936 }
1937 }
1938 if (is_dir && extent.e_len > 0)
1939 pb->last_db_block = blockcnt - 1;
1940 pb->previous_block = extent.e_pblk + extent.e_len - 1;
1941 start_block = pb->last_block = last_lblk;
1942 if (is_leaf && !is_dir &&
1943 !(extent.e_flags & EXT2_EXTENT_FLAGS_UNINIT))
1944 pb->last_init_lblock = last_lblk;
1945 next:
1946 pctx->errcode = ext2fs_extent_get(ehandle,
1947 EXT2_EXTENT_NEXT_SIB,
1948 &extent);
1949 }
1950 if (pctx->errcode == EXT2_ET_EXTENT_NO_NEXT)
1951 pctx->errcode = 0;
1952 }
1953
check_blocks_extents(e2fsck_t ctx,struct problem_context * pctx,struct process_block_struct * pb)1954 static void check_blocks_extents(e2fsck_t ctx, struct problem_context *pctx,
1955 struct process_block_struct *pb)
1956 {
1957 struct ext2_extent_info info;
1958 struct ext2_inode *inode = pctx->inode;
1959 ext2_extent_handle_t ehandle;
1960 ext2_filsys fs = ctx->fs;
1961 ext2_ino_t ino = pctx->ino;
1962 errcode_t retval;
1963 blk64_t eof_lblk;
1964
1965 pctx->errcode = ext2fs_extent_open2(fs, ino, inode, &ehandle);
1966 if (pctx->errcode) {
1967 if (fix_problem(ctx, PR_1_READ_EXTENT, pctx))
1968 e2fsck_clear_inode(ctx, ino, inode, 0,
1969 "check_blocks_extents");
1970 pctx->errcode = 0;
1971 return;
1972 }
1973
1974 retval = ext2fs_extent_get_info(ehandle, &info);
1975 if (retval == 0) {
1976 if (info.max_depth >= MAX_EXTENT_DEPTH_COUNT)
1977 info.max_depth = MAX_EXTENT_DEPTH_COUNT-1;
1978 ctx->extent_depth_count[info.max_depth]++;
1979 }
1980
1981 eof_lblk = ((EXT2_I_SIZE(inode) + fs->blocksize - 1) >>
1982 EXT2_BLOCK_SIZE_BITS(fs->super)) - 1;
1983 scan_extent_node(ctx, pctx, pb, 0, 0, eof_lblk, ehandle);
1984 if (pctx->errcode &&
1985 fix_problem(ctx, PR_1_EXTENT_ITERATE_FAILURE, pctx)) {
1986 pb->num_blocks = 0;
1987 inode->i_blocks = 0;
1988 e2fsck_clear_inode(ctx, ino, inode, E2F_FLAG_RESTART,
1989 "check_blocks_extents");
1990 pctx->errcode = 0;
1991 }
1992 ext2fs_extent_free(ehandle);
1993 }
1994
1995 /*
1996 * This subroutine is called on each inode to account for all of the
1997 * blocks used by that inode.
1998 */
check_blocks(e2fsck_t ctx,struct problem_context * pctx,char * block_buf)1999 static void check_blocks(e2fsck_t ctx, struct problem_context *pctx,
2000 char *block_buf)
2001 {
2002 ext2_filsys fs = ctx->fs;
2003 struct process_block_struct pb;
2004 ext2_ino_t ino = pctx->ino;
2005 struct ext2_inode *inode = pctx->inode;
2006 unsigned bad_size = 0;
2007 int dirty_inode = 0;
2008 int extent_fs;
2009 __u64 size;
2010
2011 pb.ino = ino;
2012 pb.num_blocks = 0;
2013 pb.last_block = -1;
2014 pb.last_init_lblock = -1;
2015 pb.last_db_block = -1;
2016 pb.num_illegal_blocks = 0;
2017 pb.suppress = 0; pb.clear = 0;
2018 pb.fragmented = 0;
2019 pb.compressed = 0;
2020 pb.previous_block = 0;
2021 pb.is_dir = LINUX_S_ISDIR(inode->i_mode);
2022 pb.is_reg = LINUX_S_ISREG(inode->i_mode);
2023 pb.max_blocks = 1 << (31 - fs->super->s_log_block_size);
2024 pb.inode = inode;
2025 pb.pctx = pctx;
2026 pb.ctx = ctx;
2027 pctx->ino = ino;
2028 pctx->errcode = 0;
2029
2030 extent_fs = (ctx->fs->super->s_feature_incompat &
2031 EXT3_FEATURE_INCOMPAT_EXTENTS);
2032
2033 if (inode->i_flags & EXT2_COMPRBLK_FL) {
2034 if (fs->super->s_feature_incompat &
2035 EXT2_FEATURE_INCOMPAT_COMPRESSION)
2036 pb.compressed = 1;
2037 else {
2038 if (fix_problem(ctx, PR_1_COMPR_SET, pctx)) {
2039 inode->i_flags &= ~EXT2_COMPRBLK_FL;
2040 dirty_inode++;
2041 }
2042 }
2043 }
2044
2045 if (ext2fs_file_acl_block(fs, inode) &&
2046 check_ext_attr(ctx, pctx, block_buf)) {
2047 if (ctx->flags & E2F_FLAG_SIGNAL_MASK)
2048 goto out;
2049 pb.num_blocks++;
2050 }
2051
2052 if (ext2fs_inode_has_valid_blocks2(fs, inode)) {
2053 if (extent_fs && (inode->i_flags & EXT4_EXTENTS_FL))
2054 check_blocks_extents(ctx, pctx, &pb);
2055 else {
2056 pctx->errcode = ext2fs_block_iterate3(fs, ino,
2057 pb.is_dir ? BLOCK_FLAG_HOLE : 0,
2058 block_buf, process_block, &pb);
2059 /*
2060 * We do not have uninitialized extents in non extent
2061 * files.
2062 */
2063 pb.last_init_lblock = pb.last_block;
2064 }
2065 }
2066 end_problem_latch(ctx, PR_LATCH_BLOCK);
2067 end_problem_latch(ctx, PR_LATCH_TOOBIG);
2068 if (ctx->flags & E2F_FLAG_SIGNAL_MASK)
2069 goto out;
2070 if (pctx->errcode)
2071 fix_problem(ctx, PR_1_BLOCK_ITERATE, pctx);
2072
2073 if (pb.fragmented && pb.num_blocks < fs->super->s_blocks_per_group) {
2074 if (LINUX_S_ISDIR(inode->i_mode))
2075 ctx->fs_fragmented_dir++;
2076 else
2077 ctx->fs_fragmented++;
2078 }
2079
2080 if (pb.clear) {
2081 e2fsck_clear_inode(ctx, ino, inode, E2F_FLAG_RESTART,
2082 "check_blocks");
2083 return;
2084 }
2085
2086 if (inode->i_flags & EXT2_INDEX_FL) {
2087 if (handle_htree(ctx, pctx, ino, inode, block_buf)) {
2088 inode->i_flags &= ~EXT2_INDEX_FL;
2089 dirty_inode++;
2090 } else {
2091 #ifdef ENABLE_HTREE
2092 e2fsck_add_dx_dir(ctx, ino, pb.last_block+1);
2093 #endif
2094 }
2095 }
2096
2097 if (!pb.num_blocks && pb.is_dir) {
2098 if (fix_problem(ctx, PR_1_ZERO_LENGTH_DIR, pctx)) {
2099 e2fsck_clear_inode(ctx, ino, inode, 0, "check_blocks");
2100 ctx->fs_directory_count--;
2101 return;
2102 }
2103 }
2104
2105 if (ino == EXT2_ROOT_INO || ino >= EXT2_FIRST_INODE(ctx->fs->super)) {
2106 quota_data_add(ctx->qctx, inode, ino,
2107 pb.num_blocks * fs->blocksize);
2108 quota_data_inodes(ctx->qctx, inode, ino, +1);
2109 }
2110
2111 if (!(fs->super->s_feature_ro_compat &
2112 EXT4_FEATURE_RO_COMPAT_HUGE_FILE) ||
2113 !(inode->i_flags & EXT4_HUGE_FILE_FL))
2114 pb.num_blocks *= (fs->blocksize / 512);
2115 pb.num_blocks *= EXT2FS_CLUSTER_RATIO(fs);
2116 #if 0
2117 printf("inode %u, i_size = %u, last_block = %lld, i_blocks=%llu, num_blocks = %llu\n",
2118 ino, inode->i_size, pb.last_block, ext2fs_inode_i_blocks(fs, inode),
2119 pb.num_blocks);
2120 #endif
2121 if (pb.is_dir) {
2122 int nblock = inode->i_size >> EXT2_BLOCK_SIZE_BITS(fs->super);
2123 if (inode->i_size & (fs->blocksize - 1))
2124 bad_size = 5;
2125 else if (nblock > (pb.last_block + 1))
2126 bad_size = 1;
2127 else if (nblock < (pb.last_block + 1)) {
2128 if (((pb.last_block + 1) - nblock) >
2129 fs->super->s_prealloc_dir_blocks)
2130 bad_size = 2;
2131 }
2132 } else {
2133 e2_blkcnt_t blkpg = ctx->blocks_per_page;
2134
2135 size = EXT2_I_SIZE(inode);
2136 if ((pb.last_init_lblock >= 0) &&
2137 /* allow allocated blocks to end of PAGE_SIZE */
2138 (size < (__u64)pb.last_init_lblock * fs->blocksize) &&
2139 (pb.last_init_lblock / blkpg * blkpg != pb.last_init_lblock ||
2140 size < (__u64)(pb.last_init_lblock & ~(blkpg-1)) *
2141 fs->blocksize))
2142 bad_size = 3;
2143 else if (!(extent_fs && (inode->i_flags & EXT4_EXTENTS_FL)) &&
2144 size > ext2_max_sizes[fs->super->s_log_block_size])
2145 /* too big for a direct/indirect-mapped file */
2146 bad_size = 4;
2147 else if ((extent_fs && (inode->i_flags & EXT4_EXTENTS_FL)) &&
2148 size >
2149 ((1ULL << (32 + EXT2_BLOCK_SIZE_BITS(fs->super))) - 1))
2150 /* too big for an extent-based file - 32bit ee_block */
2151 bad_size = 6;
2152 }
2153 /* i_size for symlinks is checked elsewhere */
2154 if (bad_size && !LINUX_S_ISLNK(inode->i_mode)) {
2155 pctx->num = (pb.last_block+1) * fs->blocksize;
2156 pctx->group = bad_size;
2157 if (fix_problem(ctx, PR_1_BAD_I_SIZE, pctx)) {
2158 inode->i_size = pctx->num;
2159 if (!LINUX_S_ISDIR(inode->i_mode))
2160 inode->i_size_high = pctx->num >> 32;
2161 dirty_inode++;
2162 }
2163 pctx->num = 0;
2164 }
2165 if (LINUX_S_ISREG(inode->i_mode) &&
2166 ext2fs_needs_large_file_feature(EXT2_I_SIZE(inode)))
2167 ctx->large_files++;
2168 if ((pb.num_blocks != ext2fs_inode_i_blocks(fs, inode)) ||
2169 ((fs->super->s_feature_ro_compat &
2170 EXT4_FEATURE_RO_COMPAT_HUGE_FILE) &&
2171 (inode->i_flags & EXT4_HUGE_FILE_FL) &&
2172 (inode->osd2.linux2.l_i_blocks_hi != 0))) {
2173 pctx->num = pb.num_blocks;
2174 if (fix_problem(ctx, PR_1_BAD_I_BLOCKS, pctx)) {
2175 inode->i_blocks = pb.num_blocks;
2176 inode->osd2.linux2.l_i_blocks_hi = pb.num_blocks >> 32;
2177 dirty_inode++;
2178 }
2179 pctx->num = 0;
2180 }
2181
2182 if (ctx->dirs_to_hash && pb.is_dir &&
2183 !(inode->i_flags & EXT2_INDEX_FL) &&
2184 ((inode->i_size / fs->blocksize) >= 3))
2185 ext2fs_u32_list_add(ctx->dirs_to_hash, ino);
2186
2187 out:
2188 if (dirty_inode)
2189 e2fsck_write_inode(ctx, ino, inode, "check_blocks");
2190 }
2191
2192 #if 0
2193 /*
2194 * Helper function called by process block when an illegal block is
2195 * found. It returns a description about why the block is illegal
2196 */
2197 static char *describe_illegal_block(ext2_filsys fs, blk64_t block)
2198 {
2199 blk64_t super;
2200 int i;
2201 static char problem[80];
2202
2203 super = fs->super->s_first_data_block;
2204 strcpy(problem, "PROGRAMMING ERROR: Unknown reason for illegal block");
2205 if (block < super) {
2206 sprintf(problem, "< FIRSTBLOCK (%u)", super);
2207 return(problem);
2208 } else if (block >= ext2fs_blocks_count(fs->super)) {
2209 sprintf(problem, "> BLOCKS (%u)", ext2fs_blocks_count(fs->super));
2210 return(problem);
2211 }
2212 for (i = 0; i < fs->group_desc_count; i++) {
2213 if (block == super) {
2214 sprintf(problem, "is the superblock in group %d", i);
2215 break;
2216 }
2217 if (block > super &&
2218 block <= (super + fs->desc_blocks)) {
2219 sprintf(problem, "is in the group descriptors "
2220 "of group %d", i);
2221 break;
2222 }
2223 if (block == ext2fs_block_bitmap_loc(fs, i)) {
2224 sprintf(problem, "is the block bitmap of group %d", i);
2225 break;
2226 }
2227 if (block == ext2fs_inode_bitmap_loc(fs, i)) {
2228 sprintf(problem, "is the inode bitmap of group %d", i);
2229 break;
2230 }
2231 if (block >= ext2fs_inode_table_loc(fs, i) &&
2232 (block < ext2fs_inode_table_loc(fs, i)
2233 + fs->inode_blocks_per_group)) {
2234 sprintf(problem, "is in the inode table of group %d",
2235 i);
2236 break;
2237 }
2238 super += fs->super->s_blocks_per_group;
2239 }
2240 return(problem);
2241 }
2242 #endif
2243
2244 /*
2245 * This is a helper function for check_blocks().
2246 */
process_block(ext2_filsys fs,blk64_t * block_nr,e2_blkcnt_t blockcnt,blk64_t ref_block EXT2FS_ATTR ((unused)),int ref_offset EXT2FS_ATTR ((unused)),void * priv_data)2247 static int process_block(ext2_filsys fs,
2248 blk64_t *block_nr,
2249 e2_blkcnt_t blockcnt,
2250 blk64_t ref_block EXT2FS_ATTR((unused)),
2251 int ref_offset EXT2FS_ATTR((unused)),
2252 void *priv_data)
2253 {
2254 struct process_block_struct *p;
2255 struct problem_context *pctx;
2256 blk64_t blk = *block_nr;
2257 int ret_code = 0;
2258 problem_t problem = 0;
2259 e2fsck_t ctx;
2260
2261 p = (struct process_block_struct *) priv_data;
2262 pctx = p->pctx;
2263 ctx = p->ctx;
2264
2265 if (p->compressed && (blk == EXT2FS_COMPRESSED_BLKADDR)) {
2266 /* todo: Check that the comprblk_fl is high, that the
2267 blkaddr pattern looks right (all non-holes up to
2268 first EXT2FS_COMPRESSED_BLKADDR, then all
2269 EXT2FS_COMPRESSED_BLKADDR up to end of cluster),
2270 that the feature_incompat bit is high, and that the
2271 inode is a regular file. If we're doing a "full
2272 check" (a concept introduced to e2fsck by e2compr,
2273 meaning that we look at data blocks as well as
2274 metadata) then call some library routine that
2275 checks the compressed data. I'll have to think
2276 about this, because one particularly important
2277 problem to be able to fix is to recalculate the
2278 cluster size if necessary. I think that perhaps
2279 we'd better do most/all e2compr-specific checks
2280 separately, after the non-e2compr checks. If not
2281 doing a full check, it may be useful to test that
2282 the personality is linux; e.g. if it isn't then
2283 perhaps this really is just an illegal block. */
2284 return 0;
2285 }
2286
2287 if (blk == 0)
2288 return 0;
2289
2290 #if 0
2291 printf("Process_block, inode %lu, block %u, #%d\n", p->ino, blk,
2292 blockcnt);
2293 #endif
2294
2295 /*
2296 * Simplistic fragmentation check. We merely require that the
2297 * file be contiguous. (Which can never be true for really
2298 * big files that are greater than a block group.)
2299 */
2300 if (!HOLE_BLKADDR(p->previous_block) && p->ino != EXT2_RESIZE_INO) {
2301 if (p->previous_block+1 != blk) {
2302 if (ctx->options & E2F_OPT_FRAGCHECK) {
2303 char type = '?';
2304
2305 if (p->is_dir)
2306 type = 'd';
2307 else if (p->is_reg)
2308 type = 'f';
2309
2310 printf(_("%6lu(%c): expecting %6lu "
2311 "got phys %6lu (blkcnt %lld)\n"),
2312 (unsigned long) pctx->ino, type,
2313 (unsigned long) p->previous_block+1,
2314 (unsigned long) blk,
2315 blockcnt);
2316 }
2317 p->fragmented = 1;
2318 }
2319 }
2320
2321 if (p->is_dir && blockcnt > (1 << (21 - fs->super->s_log_block_size)))
2322 problem = PR_1_TOOBIG_DIR;
2323 if (p->is_reg && p->num_blocks+1 >= p->max_blocks)
2324 problem = PR_1_TOOBIG_REG;
2325 if (!p->is_dir && !p->is_reg && blockcnt > 0)
2326 problem = PR_1_TOOBIG_SYMLINK;
2327
2328 if (blk < fs->super->s_first_data_block ||
2329 blk >= ext2fs_blocks_count(fs->super))
2330 problem = PR_1_ILLEGAL_BLOCK_NUM;
2331
2332 if (problem) {
2333 p->num_illegal_blocks++;
2334 if (!p->suppress && (p->num_illegal_blocks % 12) == 0) {
2335 if (fix_problem(ctx, PR_1_TOO_MANY_BAD_BLOCKS, pctx)) {
2336 p->clear = 1;
2337 return BLOCK_ABORT;
2338 }
2339 if (fix_problem(ctx, PR_1_SUPPRESS_MESSAGES, pctx)) {
2340 p->suppress = 1;
2341 set_latch_flags(PR_LATCH_BLOCK,
2342 PRL_SUPPRESS, 0);
2343 }
2344 }
2345 pctx->blk = blk;
2346 pctx->blkcount = blockcnt;
2347 if (fix_problem(ctx, problem, pctx)) {
2348 blk = *block_nr = 0;
2349 ret_code = BLOCK_CHANGED;
2350 goto mark_dir;
2351 } else
2352 return 0;
2353 }
2354
2355 if (p->ino == EXT2_RESIZE_INO) {
2356 /*
2357 * The resize inode has already be sanity checked
2358 * during pass #0 (the superblock checks). All we
2359 * have to do is mark the double indirect block as
2360 * being in use; all of the other blocks are handled
2361 * by mark_table_blocks()).
2362 */
2363 if (blockcnt == BLOCK_COUNT_DIND)
2364 mark_block_used(ctx, blk);
2365 p->num_blocks++;
2366 } else if (!(ctx->fs->cluster_ratio_bits &&
2367 p->previous_block &&
2368 (EXT2FS_B2C(ctx->fs, blk) ==
2369 EXT2FS_B2C(ctx->fs, p->previous_block)) &&
2370 (blk & EXT2FS_CLUSTER_MASK(ctx->fs)) ==
2371 ((unsigned) blockcnt & EXT2FS_CLUSTER_MASK(ctx->fs)))) {
2372 mark_block_used(ctx, blk);
2373 p->num_blocks++;
2374 }
2375 if (blockcnt >= 0)
2376 p->last_block = blockcnt;
2377 p->previous_block = blk;
2378 mark_dir:
2379 if (p->is_dir && (blockcnt >= 0)) {
2380 while (++p->last_db_block < blockcnt) {
2381 pctx->errcode = ext2fs_add_dir_block2(fs->dblist,
2382 p->ino, 0,
2383 p->last_db_block);
2384 if (pctx->errcode) {
2385 pctx->blk = 0;
2386 pctx->num = p->last_db_block;
2387 goto failed_add_dir_block;
2388 }
2389 }
2390 pctx->errcode = ext2fs_add_dir_block2(fs->dblist, p->ino,
2391 blk, blockcnt);
2392 if (pctx->errcode) {
2393 pctx->blk = blk;
2394 pctx->num = blockcnt;
2395 failed_add_dir_block:
2396 fix_problem(ctx, PR_1_ADD_DBLOCK, pctx);
2397 /* Should never get here */
2398 ctx->flags |= E2F_FLAG_ABORT;
2399 return BLOCK_ABORT;
2400 }
2401 }
2402 return ret_code;
2403 }
2404
process_bad_block(ext2_filsys fs,blk64_t * block_nr,e2_blkcnt_t blockcnt,blk64_t ref_block EXT2FS_ATTR ((unused)),int ref_offset EXT2FS_ATTR ((unused)),void * priv_data)2405 static int process_bad_block(ext2_filsys fs,
2406 blk64_t *block_nr,
2407 e2_blkcnt_t blockcnt,
2408 blk64_t ref_block EXT2FS_ATTR((unused)),
2409 int ref_offset EXT2FS_ATTR((unused)),
2410 void *priv_data)
2411 {
2412 struct process_block_struct *p;
2413 blk64_t blk = *block_nr;
2414 blk64_t first_block;
2415 dgrp_t i;
2416 struct problem_context *pctx;
2417 e2fsck_t ctx;
2418
2419 /*
2420 * Note: This function processes blocks for the bad blocks
2421 * inode, which is never compressed. So we don't use HOLE_BLKADDR().
2422 */
2423
2424 if (!blk)
2425 return 0;
2426
2427 p = (struct process_block_struct *) priv_data;
2428 ctx = p->ctx;
2429 pctx = p->pctx;
2430
2431 pctx->ino = EXT2_BAD_INO;
2432 pctx->blk = blk;
2433 pctx->blkcount = blockcnt;
2434
2435 if ((blk < fs->super->s_first_data_block) ||
2436 (blk >= ext2fs_blocks_count(fs->super))) {
2437 if (fix_problem(ctx, PR_1_BB_ILLEGAL_BLOCK_NUM, pctx)) {
2438 *block_nr = 0;
2439 return BLOCK_CHANGED;
2440 } else
2441 return 0;
2442 }
2443
2444 if (blockcnt < 0) {
2445 if (ext2fs_test_block_bitmap2(p->fs_meta_blocks, blk)) {
2446 p->bbcheck = 1;
2447 if (fix_problem(ctx, PR_1_BB_FS_BLOCK, pctx)) {
2448 *block_nr = 0;
2449 return BLOCK_CHANGED;
2450 }
2451 } else if (ext2fs_test_block_bitmap2(ctx->block_found_map,
2452 blk)) {
2453 p->bbcheck = 1;
2454 if (fix_problem(ctx, PR_1_BBINODE_BAD_METABLOCK,
2455 pctx)) {
2456 *block_nr = 0;
2457 return BLOCK_CHANGED;
2458 }
2459 if (ctx->flags & E2F_FLAG_SIGNAL_MASK)
2460 return BLOCK_ABORT;
2461 } else
2462 mark_block_used(ctx, blk);
2463 return 0;
2464 }
2465 #if 0
2466 printf ("DEBUG: Marking %u as bad.\n", blk);
2467 #endif
2468 ctx->fs_badblocks_count++;
2469 /*
2470 * If the block is not used, then mark it as used and return.
2471 * If it is already marked as found, this must mean that
2472 * there's an overlap between the filesystem table blocks
2473 * (bitmaps and inode table) and the bad block list.
2474 */
2475 if (!ext2fs_test_block_bitmap2(ctx->block_found_map, blk)) {
2476 ext2fs_mark_block_bitmap2(ctx->block_found_map, blk);
2477 return 0;
2478 }
2479 /*
2480 * Try to find the where the filesystem block was used...
2481 */
2482 first_block = fs->super->s_first_data_block;
2483
2484 for (i = 0; i < fs->group_desc_count; i++ ) {
2485 pctx->group = i;
2486 pctx->blk = blk;
2487 if (!ext2fs_bg_has_super(fs, i))
2488 goto skip_super;
2489 if (blk == first_block) {
2490 if (i == 0) {
2491 if (fix_problem(ctx,
2492 PR_1_BAD_PRIMARY_SUPERBLOCK,
2493 pctx)) {
2494 *block_nr = 0;
2495 return BLOCK_CHANGED;
2496 }
2497 return 0;
2498 }
2499 fix_problem(ctx, PR_1_BAD_SUPERBLOCK, pctx);
2500 return 0;
2501 }
2502 if ((blk > first_block) &&
2503 (blk <= first_block + fs->desc_blocks)) {
2504 if (i == 0) {
2505 pctx->blk = *block_nr;
2506 if (fix_problem(ctx,
2507 PR_1_BAD_PRIMARY_GROUP_DESCRIPTOR, pctx)) {
2508 *block_nr = 0;
2509 return BLOCK_CHANGED;
2510 }
2511 return 0;
2512 }
2513 fix_problem(ctx, PR_1_BAD_GROUP_DESCRIPTORS, pctx);
2514 return 0;
2515 }
2516 skip_super:
2517 if (blk == ext2fs_block_bitmap_loc(fs, i)) {
2518 if (fix_problem(ctx, PR_1_BB_BAD_BLOCK, pctx)) {
2519 ctx->invalid_block_bitmap_flag[i]++;
2520 ctx->invalid_bitmaps++;
2521 }
2522 return 0;
2523 }
2524 if (blk == ext2fs_inode_bitmap_loc(fs, i)) {
2525 if (fix_problem(ctx, PR_1_IB_BAD_BLOCK, pctx)) {
2526 ctx->invalid_inode_bitmap_flag[i]++;
2527 ctx->invalid_bitmaps++;
2528 }
2529 return 0;
2530 }
2531 if ((blk >= ext2fs_inode_table_loc(fs, i)) &&
2532 (blk < (ext2fs_inode_table_loc(fs, i) +
2533 fs->inode_blocks_per_group))) {
2534 /*
2535 * If there are bad blocks in the inode table,
2536 * the inode scan code will try to do
2537 * something reasonable automatically.
2538 */
2539 return 0;
2540 }
2541 first_block += fs->super->s_blocks_per_group;
2542 }
2543 /*
2544 * If we've gotten to this point, then the only
2545 * possibility is that the bad block inode meta data
2546 * is using a bad block.
2547 */
2548 if ((blk == p->inode->i_block[EXT2_IND_BLOCK]) ||
2549 (blk == p->inode->i_block[EXT2_DIND_BLOCK]) ||
2550 (blk == p->inode->i_block[EXT2_TIND_BLOCK])) {
2551 p->bbcheck = 1;
2552 if (fix_problem(ctx, PR_1_BBINODE_BAD_METABLOCK, pctx)) {
2553 *block_nr = 0;
2554 return BLOCK_CHANGED;
2555 }
2556 if (ctx->flags & E2F_FLAG_SIGNAL_MASK)
2557 return BLOCK_ABORT;
2558 return 0;
2559 }
2560
2561 pctx->group = -1;
2562
2563 /* Warn user that the block wasn't claimed */
2564 fix_problem(ctx, PR_1_PROGERR_CLAIMED_BLOCK, pctx);
2565
2566 return 0;
2567 }
2568
new_table_block(e2fsck_t ctx,blk64_t first_block,dgrp_t group,const char * name,int num,blk64_t * new_block)2569 static void new_table_block(e2fsck_t ctx, blk64_t first_block, dgrp_t group,
2570 const char *name, int num, blk64_t *new_block)
2571 {
2572 ext2_filsys fs = ctx->fs;
2573 dgrp_t last_grp;
2574 blk64_t old_block = *new_block;
2575 blk64_t last_block;
2576 dgrp_t flexbg;
2577 unsigned flexbg_size;
2578 int i, is_flexbg;
2579 char *buf;
2580 struct problem_context pctx;
2581
2582 clear_problem_context(&pctx);
2583
2584 pctx.group = group;
2585 pctx.blk = old_block;
2586 pctx.str = name;
2587
2588 /*
2589 * For flex_bg filesystems, first try to allocate the metadata
2590 * within the flex_bg, and if that fails then try finding the
2591 * space anywhere in the filesystem.
2592 */
2593 is_flexbg = EXT2_HAS_INCOMPAT_FEATURE(fs->super,
2594 EXT4_FEATURE_INCOMPAT_FLEX_BG);
2595 if (is_flexbg) {
2596 flexbg_size = 1 << fs->super->s_log_groups_per_flex;
2597 flexbg = group / flexbg_size;
2598 first_block = ext2fs_group_first_block2(fs,
2599 flexbg_size * flexbg);
2600 last_grp = group | (flexbg_size - 1);
2601 if (last_grp > fs->group_desc_count)
2602 last_grp = fs->group_desc_count;
2603 last_block = ext2fs_group_last_block2(fs, last_grp);
2604 } else
2605 last_block = ext2fs_group_last_block2(fs, group);
2606 pctx.errcode = ext2fs_get_free_blocks2(fs, first_block, last_block,
2607 num, ctx->block_found_map,
2608 new_block);
2609 if (is_flexbg && (pctx.errcode == EXT2_ET_BLOCK_ALLOC_FAIL))
2610 pctx.errcode = ext2fs_get_free_blocks2(fs,
2611 fs->super->s_first_data_block,
2612 ext2fs_blocks_count(fs->super),
2613 num, ctx->block_found_map, new_block);
2614 if (pctx.errcode) {
2615 pctx.num = num;
2616 fix_problem(ctx, PR_1_RELOC_BLOCK_ALLOCATE, &pctx);
2617 ext2fs_unmark_valid(fs);
2618 ctx->flags |= E2F_FLAG_ABORT;
2619 return;
2620 }
2621 pctx.errcode = ext2fs_get_mem(fs->blocksize, &buf);
2622 if (pctx.errcode) {
2623 fix_problem(ctx, PR_1_RELOC_MEMORY_ALLOCATE, &pctx);
2624 ext2fs_unmark_valid(fs);
2625 ctx->flags |= E2F_FLAG_ABORT;
2626 return;
2627 }
2628 ext2fs_mark_super_dirty(fs);
2629 fs->flags &= ~EXT2_FLAG_MASTER_SB_ONLY;
2630 pctx.blk2 = *new_block;
2631 fix_problem(ctx, (old_block ? PR_1_RELOC_FROM_TO :
2632 PR_1_RELOC_TO), &pctx);
2633 pctx.blk2 = 0;
2634 for (i = 0; i < num; i++) {
2635 pctx.blk = i;
2636 ext2fs_mark_block_bitmap2(ctx->block_found_map, (*new_block)+i);
2637 if (old_block) {
2638 pctx.errcode = io_channel_read_blk64(fs->io,
2639 old_block + i, 1, buf);
2640 if (pctx.errcode)
2641 fix_problem(ctx, PR_1_RELOC_READ_ERR, &pctx);
2642 } else
2643 memset(buf, 0, fs->blocksize);
2644
2645 pctx.blk = (*new_block) + i;
2646 pctx.errcode = io_channel_write_blk64(fs->io, pctx.blk,
2647 1, buf);
2648 if (pctx.errcode)
2649 fix_problem(ctx, PR_1_RELOC_WRITE_ERR, &pctx);
2650 }
2651 ext2fs_free_mem(&buf);
2652 }
2653
2654 /*
2655 * This routine gets called at the end of pass 1 if bad blocks are
2656 * detected in the superblock, group descriptors, inode_bitmaps, or
2657 * block bitmaps. At this point, all of the blocks have been mapped
2658 * out, so we can try to allocate new block(s) to replace the bad
2659 * blocks.
2660 */
handle_fs_bad_blocks(e2fsck_t ctx)2661 static void handle_fs_bad_blocks(e2fsck_t ctx)
2662 {
2663 ext2_filsys fs = ctx->fs;
2664 dgrp_t i;
2665 blk64_t first_block;
2666 blk64_t new_blk;
2667
2668 for (i = 0; i < fs->group_desc_count; i++) {
2669 first_block = ext2fs_group_first_block2(fs, i);
2670
2671 if (ctx->invalid_block_bitmap_flag[i]) {
2672 new_blk = ext2fs_block_bitmap_loc(fs, i);
2673 new_table_block(ctx, first_block, i, _("block bitmap"),
2674 1, &new_blk);
2675 ext2fs_block_bitmap_loc_set(fs, i, new_blk);
2676 }
2677 if (ctx->invalid_inode_bitmap_flag[i]) {
2678 new_blk = ext2fs_inode_bitmap_loc(fs, i);
2679 new_table_block(ctx, first_block, i, _("inode bitmap"),
2680 1, &new_blk);
2681 ext2fs_inode_bitmap_loc_set(fs, i, new_blk);
2682 }
2683 if (ctx->invalid_inode_table_flag[i]) {
2684 new_blk = ext2fs_inode_table_loc(fs, i);
2685 new_table_block(ctx, first_block, i, _("inode table"),
2686 fs->inode_blocks_per_group,
2687 &new_blk);
2688 ext2fs_inode_table_loc_set(fs, i, new_blk);
2689 ctx->flags |= E2F_FLAG_RESTART;
2690 }
2691 }
2692 ctx->invalid_bitmaps = 0;
2693 }
2694
2695 /*
2696 * This routine marks all blocks which are used by the superblock,
2697 * group descriptors, inode bitmaps, and block bitmaps.
2698 */
mark_table_blocks(e2fsck_t ctx)2699 static void mark_table_blocks(e2fsck_t ctx)
2700 {
2701 ext2_filsys fs = ctx->fs;
2702 blk64_t b;
2703 dgrp_t i;
2704 unsigned int j;
2705 struct problem_context pctx;
2706
2707 clear_problem_context(&pctx);
2708
2709 for (i = 0; i < fs->group_desc_count; i++) {
2710 pctx.group = i;
2711
2712 ext2fs_reserve_super_and_bgd(fs, i, ctx->block_found_map);
2713
2714 /*
2715 * Mark the blocks used for the inode table
2716 */
2717 if (ext2fs_inode_table_loc(fs, i)) {
2718 for (j = 0, b = ext2fs_inode_table_loc(fs, i);
2719 j < fs->inode_blocks_per_group;
2720 j++, b++) {
2721 if (ext2fs_test_block_bitmap2(ctx->block_found_map,
2722 b)) {
2723 pctx.blk = b;
2724 if (!ctx->invalid_inode_table_flag[i] &&
2725 fix_problem(ctx,
2726 PR_1_ITABLE_CONFLICT, &pctx)) {
2727 ctx->invalid_inode_table_flag[i]++;
2728 ctx->invalid_bitmaps++;
2729 }
2730 } else {
2731 ext2fs_mark_block_bitmap2(ctx->block_found_map,
2732 b);
2733 }
2734 }
2735 }
2736
2737 /*
2738 * Mark block used for the block bitmap
2739 */
2740 if (ext2fs_block_bitmap_loc(fs, i)) {
2741 if (ext2fs_test_block_bitmap2(ctx->block_found_map,
2742 ext2fs_block_bitmap_loc(fs, i))) {
2743 pctx.blk = ext2fs_block_bitmap_loc(fs, i);
2744 if (fix_problem(ctx, PR_1_BB_CONFLICT, &pctx)) {
2745 ctx->invalid_block_bitmap_flag[i]++;
2746 ctx->invalid_bitmaps++;
2747 }
2748 } else {
2749 ext2fs_mark_block_bitmap2(ctx->block_found_map,
2750 ext2fs_block_bitmap_loc(fs, i));
2751 }
2752
2753 }
2754 /*
2755 * Mark block used for the inode bitmap
2756 */
2757 if (ext2fs_inode_bitmap_loc(fs, i)) {
2758 if (ext2fs_test_block_bitmap2(ctx->block_found_map,
2759 ext2fs_inode_bitmap_loc(fs, i))) {
2760 pctx.blk = ext2fs_inode_bitmap_loc(fs, i);
2761 if (fix_problem(ctx, PR_1_IB_CONFLICT, &pctx)) {
2762 ctx->invalid_inode_bitmap_flag[i]++;
2763 ctx->invalid_bitmaps++;
2764 }
2765 } else {
2766 ext2fs_mark_block_bitmap2(ctx->block_found_map,
2767 ext2fs_inode_bitmap_loc(fs, i));
2768 }
2769 }
2770 }
2771 }
2772
2773 /*
2774 * Thes subroutines short circuits ext2fs_get_blocks and
2775 * ext2fs_check_directory; we use them since we already have the inode
2776 * structure, so there's no point in letting the ext2fs library read
2777 * the inode again.
2778 */
pass1_get_blocks(ext2_filsys fs,ext2_ino_t ino,blk_t * blocks)2779 static errcode_t pass1_get_blocks(ext2_filsys fs, ext2_ino_t ino,
2780 blk_t *blocks)
2781 {
2782 e2fsck_t ctx = (e2fsck_t) fs->priv_data;
2783 int i;
2784
2785 if ((ino != ctx->stashed_ino) || !ctx->stashed_inode)
2786 return EXT2_ET_CALLBACK_NOTHANDLED;
2787
2788 for (i=0; i < EXT2_N_BLOCKS; i++)
2789 blocks[i] = ctx->stashed_inode->i_block[i];
2790 return 0;
2791 }
2792
pass1_read_inode(ext2_filsys fs,ext2_ino_t ino,struct ext2_inode * inode)2793 static errcode_t pass1_read_inode(ext2_filsys fs, ext2_ino_t ino,
2794 struct ext2_inode *inode)
2795 {
2796 e2fsck_t ctx = (e2fsck_t) fs->priv_data;
2797
2798 if ((ino != ctx->stashed_ino) || !ctx->stashed_inode)
2799 return EXT2_ET_CALLBACK_NOTHANDLED;
2800 *inode = *ctx->stashed_inode;
2801 return 0;
2802 }
2803
pass1_write_inode(ext2_filsys fs,ext2_ino_t ino,struct ext2_inode * inode)2804 static errcode_t pass1_write_inode(ext2_filsys fs, ext2_ino_t ino,
2805 struct ext2_inode *inode)
2806 {
2807 e2fsck_t ctx = (e2fsck_t) fs->priv_data;
2808
2809 if ((ino == ctx->stashed_ino) && ctx->stashed_inode &&
2810 (inode != ctx->stashed_inode))
2811 *ctx->stashed_inode = *inode;
2812 return EXT2_ET_CALLBACK_NOTHANDLED;
2813 }
2814
pass1_check_directory(ext2_filsys fs,ext2_ino_t ino)2815 static errcode_t pass1_check_directory(ext2_filsys fs, ext2_ino_t ino)
2816 {
2817 e2fsck_t ctx = (e2fsck_t) fs->priv_data;
2818
2819 if ((ino != ctx->stashed_ino) || !ctx->stashed_inode)
2820 return EXT2_ET_CALLBACK_NOTHANDLED;
2821
2822 if (!LINUX_S_ISDIR(ctx->stashed_inode->i_mode))
2823 return EXT2_ET_NO_DIRECTORY;
2824 return 0;
2825 }
2826
e2fsck_get_alloc_block(ext2_filsys fs,blk64_t goal,blk64_t * ret)2827 static errcode_t e2fsck_get_alloc_block(ext2_filsys fs, blk64_t goal,
2828 blk64_t *ret)
2829 {
2830 e2fsck_t ctx = (e2fsck_t) fs->priv_data;
2831 errcode_t retval;
2832 blk64_t new_block;
2833
2834 if (ctx->block_found_map) {
2835 retval = ext2fs_new_block2(fs, goal, ctx->block_found_map,
2836 &new_block);
2837 if (retval)
2838 return retval;
2839 if (fs->block_map) {
2840 ext2fs_mark_block_bitmap2(fs->block_map, new_block);
2841 ext2fs_mark_bb_dirty(fs);
2842 }
2843 } else {
2844 if (!fs->block_map) {
2845 retval = ext2fs_read_block_bitmap(fs);
2846 if (retval)
2847 return retval;
2848 }
2849
2850 retval = ext2fs_new_block2(fs, goal, 0, &new_block);
2851 if (retval)
2852 return retval;
2853 }
2854
2855 *ret = new_block;
2856 return (0);
2857 }
2858
e2fsck_block_alloc_stats(ext2_filsys fs,blk64_t blk,int inuse)2859 static void e2fsck_block_alloc_stats(ext2_filsys fs, blk64_t blk, int inuse)
2860 {
2861 e2fsck_t ctx = (e2fsck_t) fs->priv_data;
2862
2863 if (ctx->block_found_map) {
2864 if (inuse > 0)
2865 ext2fs_mark_block_bitmap2(ctx->block_found_map, blk);
2866 else
2867 ext2fs_unmark_block_bitmap2(ctx->block_found_map, blk);
2868 }
2869 }
2870
e2fsck_use_inode_shortcuts(e2fsck_t ctx,int use_shortcuts)2871 void e2fsck_use_inode_shortcuts(e2fsck_t ctx, int use_shortcuts)
2872 {
2873 ext2_filsys fs = ctx->fs;
2874
2875 if (use_shortcuts) {
2876 fs->get_blocks = pass1_get_blocks;
2877 fs->check_directory = pass1_check_directory;
2878 fs->read_inode = pass1_read_inode;
2879 fs->write_inode = pass1_write_inode;
2880 ctx->stashed_ino = 0;
2881 ext2fs_set_alloc_block_callback(fs, e2fsck_get_alloc_block,
2882 0);
2883 ext2fs_set_block_alloc_stats_callback(fs,
2884 e2fsck_block_alloc_stats,
2885 0);
2886 } else {
2887 fs->get_blocks = 0;
2888 fs->check_directory = 0;
2889 fs->read_inode = 0;
2890 fs->write_inode = 0;
2891 }
2892 }
2893