X-Git-Url: https://git.whamcloud.com/?a=blobdiff_plain;f=lib%2Fext2fs%2Fbmove.c;h=e2ea405a59105323a91dd9a913b07bd74e5d1423;hb=9db53e3fec3413572a2240bd374e76353fab9cbe;hp=2745307c4d0bee358b50b2e4040394b03bf4ab96;hpb=4a31c48b827f378f386b28461fd14b41d709e4eb;p=tools%2Fe2fsprogs.git diff --git a/lib/ext2fs/bmove.c b/lib/ext2fs/bmove.c index 2745307..e2ea405 100644 --- a/lib/ext2fs/bmove.c +++ b/lib/ext2fs/bmove.c @@ -2,10 +2,15 @@ * bmove.c --- Move blocks around to make way for a particular * filesystem structure. * - * Copyright (C) 1997 Theodore Ts'o. This file may be redistributed - * under the terms of the GNU Public License. + * Copyright (C) 1997 Theodore Ts'o. + * + * %Begin-Header% + * This file may be redistributed under the terms of the GNU Library + * General Public License, version 2. + * %End-Header% */ +#include "config.h" #include #include #if HAVE_UNISTD_H @@ -18,16 +23,11 @@ #include #endif -#if EXT2_FLAT_INCLUDES #include "ext2_fs.h" -#else -#include -#endif - #include "ext2fsP.h" struct process_block_struct { - ino_t ino; + ext2_ino_t ino; struct ext2_inode * inode; ext2fs_block_bitmap reserve; ext2fs_block_bitmap alloc_map; @@ -37,53 +37,55 @@ struct process_block_struct { int flags; }; -static int process_block(ext2_filsys fs, blk_t *block_nr, - blkcnt_t blockcnt, blk_t ref_block, +static int process_block(ext2_filsys fs, blk64_t *block_nr, + e2_blkcnt_t blockcnt, blk64_t ref_block, int ref_offset, void *priv_data) { struct process_block_struct *pb; errcode_t retval; int ret; - blk_t block, orig; + blk64_t block, orig; pb = (struct process_block_struct *) priv_data; block = orig = *block_nr; ret = 0; - + /* * Let's see if this is one which we need to relocate */ - if (ext2fs_test_block_bitmap(pb->reserve, block)) { + if (ext2fs_test_block_bitmap2(pb->reserve, block)) { do { - if (++block >= fs->super->s_blocks_count) + if (++block >= ext2fs_blocks_count(fs->super)) block = fs->super->s_first_data_block; if (block == orig) { pb->error = EXT2_ET_BLOCK_ALLOC_FAIL; return BLOCK_ABORT; } - } while (ext2fs_test_block_bitmap(pb->reserve, block) || - ext2fs_test_block_bitmap(pb->alloc_map, block)); + } while (ext2fs_test_block_bitmap2(pb->reserve, block) || + ext2fs_test_block_bitmap2(pb->alloc_map, block)); - retval = io_channel_read_blk(fs->io, orig, 1, pb->buf); + retval = io_channel_read_blk64(fs->io, orig, 1, pb->buf); if (retval) { pb->error = retval; return BLOCK_ABORT; } - retval = io_channel_write_blk(fs->io, block, 1, pb->buf); + retval = io_channel_write_blk64(fs->io, block, 1, pb->buf); if (retval) { pb->error = retval; return BLOCK_ABORT; } *block_nr = block; - ext2fs_mark_block_bitmap(pb->alloc_map, block); + ext2fs_mark_block_bitmap2(pb->alloc_map, block); ret = BLOCK_CHANGED; if (pb->flags & EXT2_BMOVE_DEBUG) - printf("ino=%ld, blockcnt=%lld, %d->%d\n", pb->ino, - blockcnt, orig, block); + printf("ino=%u, blockcnt=%lld, %llu->%llu\n", + (unsigned) pb->ino, blockcnt, + (unsigned long long) orig, + (unsigned long long) block); } if (pb->add_dir) { - retval = ext2fs_add_dir_block(fs->dblist, pb->ino, - block, (int) blockcnt); + retval = ext2fs_add_dir_block2(fs->dblist, pb->ino, + block, blockcnt); if (retval) { pb->error = retval; ret |= BLOCK_ABORT; @@ -97,13 +99,13 @@ errcode_t ext2fs_move_blocks(ext2_filsys fs, ext2fs_block_bitmap alloc_map, int flags) { - ino_t ino; + ext2_ino_t ino; struct ext2_inode inode; errcode_t retval; struct process_block_struct pb; ext2_inode_scan scan; char *block_buf; - + retval = ext2fs_open_inode_scan(fs, 0, &scan); if (retval) return retval; @@ -112,8 +114,8 @@ errcode_t ext2fs_move_blocks(ext2_filsys fs, pb.error = 0; pb.alloc_map = alloc_map ? alloc_map : fs->block_map; pb.flags = flags; - - retval = ext2fs_get_mem(fs->blocksize * 4, (void **) &block_buf); + + retval = ext2fs_get_array(4, fs->blocksize, &block_buf); if (retval) return retval; pb.buf = block_buf + fs->blocksize * 3; @@ -136,20 +138,20 @@ errcode_t ext2fs_move_blocks(ext2_filsys fs, retval = ext2fs_get_next_inode(scan, &ino, &inode); if (retval) return retval; - + while (ino) { if ((inode.i_links_count == 0) || - !ext2fs_inode_has_valid_blocks(&inode)) + !ext2fs_inode_has_valid_blocks2(fs, &inode)) goto next; - + pb.ino = ino; pb.inode = &inode; pb.add_dir = (LINUX_S_ISDIR(inode.i_mode) && flags & EXT2_BMOVE_GET_DBLIST); - retval = ext2fs_block_iterate2(fs, ino, 0, block_buf, - process_block, &pb); + retval = ext2fs_block_iterate3(fs, ino, 0, block_buf, + process_block, &pb); if (retval) return retval; if (pb.error)