diff options
-rw-r--r-- | mkfs/meta.c | 25 | ||||
-rw-r--r-- | mkfs/mkfs.c | 4 | ||||
-rw-r--r-- | mkfs/mkfs.h | 5 |
3 files changed, 19 insertions, 15 deletions
diff --git a/mkfs/meta.c b/mkfs/meta.c index 2d969a3..369149f 100644 --- a/mkfs/meta.c +++ b/mkfs/meta.c @@ -2,7 +2,8 @@ #include "mkfs.h" #include "util.h" -int sqfs_write_inodes(sqfs_info_t *info) +int sqfs_write_inodes(sqfs_super_t *super, fstree_t *fs, int outfd, + compressor_t *cmp, id_table_t *idtbl) { meta_writer_t *im, *dm; uint8_t buffer[1024]; @@ -21,17 +22,17 @@ int sqfs_write_inodes(sqfs_info_t *info) tmpfd = fileno(tmp); - im = meta_writer_create(info->outfd, info->cmp); + im = meta_writer_create(outfd, cmp); if (im == NULL) goto fail_tmp; - dm = meta_writer_create(tmpfd, info->cmp); + dm = meta_writer_create(tmpfd, cmp); if (dm == NULL) goto fail_im; - for (i = 2; i < info->fs.inode_tbl_size; ++i) { - if (write_inode(&info->fs, &info->idtbl, im, dm, - info->fs.inode_table[i])) { + for (i = 2; i < fs->inode_tbl_size; ++i) { + if (write_inode(fs, idtbl, im, dm, + fs->inode_table[i])) { goto fail; } } @@ -42,15 +43,15 @@ int sqfs_write_inodes(sqfs_info_t *info) if (meta_writer_flush(dm)) goto fail; - info->super.root_inode_ref = info->fs.root->inode_ref; + super->root_inode_ref = fs->root->inode_ref; meta_writer_get_position(im, &block, &offset); - info->super.inode_table_start = info->super.bytes_used; - info->super.bytes_used += block; + super->inode_table_start = super->bytes_used; + super->bytes_used += block; - info->super.directory_table_start = info->super.bytes_used; + super->directory_table_start = super->bytes_used; meta_writer_get_position(dm, &block, &offset); - info->super.bytes_used += block; + super->bytes_used += block; if (lseek(tmpfd, 0, SEEK_SET) == (off_t)-1) { perror("rewind on directory temp file"); @@ -68,7 +69,7 @@ int sqfs_write_inodes(sqfs_info_t *info) break; diff = ret; - ret = write_retry(info->outfd, buffer, diff); + ret = write_retry(outfd, buffer, diff); if (ret < 0) { perror("write to image file"); diff --git a/mkfs/mkfs.c b/mkfs/mkfs.c index 405d6fd..7c3fa28 100644 --- a/mkfs/mkfs.c +++ b/mkfs/mkfs.c @@ -114,8 +114,10 @@ int main(int argc, char **argv) if (write_data_to_image(&info)) goto out_cmp; - if (sqfs_write_inodes(&info)) + if (sqfs_write_inodes(&info.super, &info.fs, info.outfd, + info.cmp, &info.idtbl)) { goto out_cmp; + } info.super.fragment_entry_count = info.num_fragments; diff --git a/mkfs/mkfs.h b/mkfs/mkfs.h index 13eb690..36f412d 100644 --- a/mkfs/mkfs.h +++ b/mkfs/mkfs.h @@ -73,8 +73,6 @@ void process_command_line(options_t *opt, int argc, char **argv); int write_data_to_image(sqfs_info_t *info); -int sqfs_write_inodes(sqfs_info_t *info); - int write_xattr(sqfs_info_t *info); int write_dir(meta_writer_t *dm, dir_info_t *dir, dir_index_t **index); @@ -82,4 +80,7 @@ int write_dir(meta_writer_t *dm, dir_info_t *dir, dir_index_t **index); int write_inode(fstree_t *fs, id_table_t *idtbl, meta_writer_t *im, meta_writer_t *dm, tree_node_t *node); +int sqfs_write_inodes(sqfs_super_t *super, fstree_t *fs, int outfd, + compressor_t *cmp, id_table_t *idtbl); + #endif /* MKFS_H */ |