Whamcloud - gitweb
git://git.whamcloud.com
/
tools
/
e2fsprogs.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
debugfs: fix set_inode_field so it can set the checksum field
[tools/e2fsprogs.git]
/
debugfs
/
icheck.c
diff --git
a/debugfs/icheck.c
b/debugfs/icheck.c
index
2f880c0
..
71164cf
100644
(file)
--- a/
debugfs/icheck.c
+++ b/
debugfs/icheck.c
@@
-5,6
+5,7
@@
* under the terms of the GNU Public License.
*/
* under the terms of the GNU Public License.
*/
+#include "config.h"
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
@@
-19,7
+20,7
@@
#include "debugfs.h"
struct block_info {
#include "debugfs.h"
struct block_info {
- blk
_t
blk;
+ blk
64_t
blk;
ext2_ino_t ino;
};
ext2_ino_t ino;
};
@@
-31,9
+32,9
@@
struct block_walk_struct {
};
static int icheck_proc(ext2_filsys fs EXT2FS_ATTR((unused)),
};
static int icheck_proc(ext2_filsys fs EXT2FS_ATTR((unused)),
- blk
_t
*block_nr,
+ blk
64_t
*block_nr,
e2_blkcnt_t blockcnt EXT2FS_ATTR((unused)),
e2_blkcnt_t blockcnt EXT2FS_ATTR((unused)),
- blk_t ref_block EXT2FS_ATTR((unused)),
+ blk
64
_t ref_block EXT2FS_ATTR((unused)),
int ref_offset EXT2FS_ATTR((unused)),
void *private)
{
int ref_offset EXT2FS_ATTR((unused)),
void *private)
{
@@
-52,7
+53,8
@@
static int icheck_proc(ext2_filsys fs EXT2FS_ATTR((unused)),
return 0;
}
return 0;
}
-void do_icheck(int argc, char **argv)
+void do_icheck(int argc, char **argv, int sci_idx EXT2FS_ATTR((unused)),
+ void *infop EXT2FS_ATTR((unused)))
{
struct block_walk_struct bw;
struct block_info *binfo;
{
struct block_walk_struct bw;
struct block_info *binfo;
@@
-85,7
+87,7
@@
void do_icheck(int argc, char **argv)
}
for (i=1; i < argc; i++) {
}
for (i=1; i < argc; i++) {
- if (strtoblk(argv[0], argv[i], &bw.barray[i-1].blk))
+ if (strtoblk(argv[0], argv[i],
NULL,
&bw.barray[i-1].blk))
goto error_out;
}
goto error_out;
}
@@
-106,19
+108,23
@@
void do_icheck(int argc, char **argv)
}
while (ino) {
}
while (ino) {
+ blk64_t blk;
+
if (!inode.i_links_count)
goto next;
bw.inode = ino;
if (!inode.i_links_count)
goto next;
bw.inode = ino;
- if (inode.i_file_acl) {
- icheck_proc(current_fs, &inode.i_file_acl, 0,
+ blk = ext2fs_file_acl_block(current_fs, &inode);
+ if (blk) {
+ icheck_proc(current_fs, &blk, 0,
0, 0, &bw);
if (bw.blocks_left == 0)
break;
0, 0, &bw);
if (bw.blocks_left == 0)
break;
+ ext2fs_file_acl_block_set(current_fs, &inode, blk);
}
}
- if (!ext2fs_inode_has_valid_blocks
(
&inode))
+ if (!ext2fs_inode_has_valid_blocks
2(current_fs,
&inode))
goto next;
/*
* To handle filesystems touched by 0.3c extfs; can be
goto next;
/*
* To handle filesystems touched by 0.3c extfs; can be
@@
-127,7
+133,7
@@
void do_icheck(int argc, char **argv)
if (inode.i_dtime)
goto next;
if (inode.i_dtime)
goto next;
- retval = ext2fs_block_iterate
2
(current_fs, ino,
+ retval = ext2fs_block_iterate
3
(current_fs, ino,
BLOCK_FLAG_READ_ONLY, block_buf,
icheck_proc, &bw);
if (retval) {
BLOCK_FLAG_READ_ONLY, block_buf,
icheck_proc, &bw);
if (retval) {
@@
-153,16
+159,15
@@
void do_icheck(int argc, char **argv)
printf("Block\tInode number\n");
for (i=0, binfo = bw.barray; i < bw.num_blocks; i++, binfo++) {
if (binfo->ino == 0) {
printf("Block\tInode number\n");
for (i=0, binfo = bw.barray; i < bw.num_blocks; i++, binfo++) {
if (binfo->ino == 0) {
- printf("%u\t<block not found>\n", binfo->blk);
+ printf("%
ll
u\t<block not found>\n", binfo->blk);
continue;
}
continue;
}
- printf("%u\t%u\n", binfo->blk, binfo->ino);
+ printf("%
ll
u\t%u\n", binfo->blk, binfo->ino);
}
error_out:
free(bw.barray);
}
error_out:
free(bw.barray);
- if (block_buf)
- free(block_buf);
+ free(block_buf);
if (scan)
ext2fs_close_inode_scan(scan);
return;
if (scan)
ext2fs_close_inode_scan(scan);
return;