+2001-01-11    <tytso@snap.thunk.org>
+
+       * dirinfo.c, e2fsck.h, emptydir.c, iscan.c, jfs_user.h, journal.c,
+               message.c, pass1.c, pass1b.c, pass2.c, pass3.c, pass4.c,
+               pass5.c, problem.h, scantest.c, super.c, swapfs.c: Change
+               ino_t to ext2_ino_t.
+
 2001-01-09    <tytso@snap.thunk.org>
 
        * problem.c: Fix another broken @F vs @f problem.
 
  * entry.  During pass1, the passed-in parent is 0; it will get filled
  * in during pass2.  
  */
-void e2fsck_add_dir_info(e2fsck_t ctx, ino_t ino, ino_t parent)
+void e2fsck_add_dir_info(e2fsck_t ctx, ext2_ino_t ino, ext2_ino_t parent)
 {
        struct dir_info *dir;
        int             i, j;
-       ino_t           num_dirs;
+       ext2_ino_t      num_dirs;
        errcode_t       retval;
        unsigned long   old_size;
 
  * get_dir_info() --- given an inode number, try to find the directory
  * information entry for it.
  */
-struct dir_info *e2fsck_get_dir_info(e2fsck_t ctx, ino_t ino)
+struct dir_info *e2fsck_get_dir_info(e2fsck_t ctx, ext2_ino_t ino)
 {
        int     low, high, mid;
 
 
  * directory information.
  */
 struct dir_info {
-       ino_t                   ino;    /* Inode number */
-       ino_t                   dotdot; /* Parent according to '..' */
-       ino_t                   parent; /* Parent according to treewalk */
+       ext2_ino_t              ino;    /* Inode number */
+       ext2_ino_t              dotdot; /* Parent according to '..' */
+       ext2_ino_t              parent; /* Parent according to treewalk */
 };
 
 #ifdef RESOURCE_TRACK
        /*
         * For pass1_check_directory and pass1_get_blocks
         */
-       ino_t stashed_ino;
+       ext2_ino_t stashed_ino;
        struct ext2_inode *stashed_inode;
 
        /*
 extern void test_disk(e2fsck_t ctx);
 
 /* dirinfo.c */
-extern void e2fsck_add_dir_info(e2fsck_t ctx, ino_t ino, ino_t parent);
-extern struct dir_info *e2fsck_get_dir_info(e2fsck_t ctx, ino_t ino);
+extern void e2fsck_add_dir_info(e2fsck_t ctx, ext2_ino_t ino, ext2_ino_t parent);
+extern struct dir_info *e2fsck_get_dir_info(e2fsck_t ctx, ext2_ino_t ino);
 extern void e2fsck_free_dir_info(e2fsck_t ctx);
 extern int e2fsck_get_num_dirs(e2fsck_t ctx);
 extern int e2fsck_get_num_dirinfo(e2fsck_t ctx);
 extern int e2fsck_pass1_check_device_inode(struct ext2_inode *inode);
 
 /* pass2.c */
-extern int e2fsck_process_bad_inode(e2fsck_t ctx, ino_t dir, ino_t ino);
+extern int e2fsck_process_bad_inode(e2fsck_t ctx, ext2_ino_t dir, ext2_ino_t ino);
 
 /* pass3.c */
-extern int e2fsck_reconnect_file(e2fsck_t ctx, ino_t inode);
+extern int e2fsck_reconnect_file(e2fsck_t ctx, ext2_ino_t inode);
 
 /* super.c */
 void check_super_block(e2fsck_t ctx);
 
        ext2fs_block_bitmap empty_dir_blocks;
        ext2fs_inode_bitmap dir_map;
        char *block_buf;
-       ino_t   ino;
+       ext2_ino_t ino;
        struct ext2_inode inode;
        blk_t   logblk;
        blk_t   freed_blocks;
 
        errcode_t       retval = 0;
        int             exit_value = FSCK_OK;
        ext2_filsys     fs;
-       ino_t   ino;
+       ext2_ino_t      ino;
        int     num_inodes = 0;
        struct ext2_inode inode;
        ext2_inode_scan scan;
 
 };
 
 struct inode {
-       e2fsck_t i_ctx;
-       ino_t    i_ino;
+       e2fsck_t        i_ctx;
+       ext2_ino_t      i_ino;
        struct ext2_inode i_ext2;
 };
 
 
 
 static int e2fsck_journal_init_inode(e2fsck_t ctx,
                                     struct ext2_super_block *s,
-                                    ino_t journal_inum, journal_t **journal)
+                                    ext2_ino_t journal_inum,
+                                    journal_t **journal)
 {
        struct inode *inode;
        struct buffer_head *bh;
        blk_t start;
        int retval;
 
-       jfs_debug(1, "Using journal inode %lu\n", journal_inum);
+       jfs_debug(1, "Using journal inode %u\n", journal_inum);
        *journal = e2fsck_allocate_memory(ctx, sizeof(journal_t), "journal");
        if (!*journal) {
                return EXT2_ET_NO_MEMORY;
 
  * This function prints a pathname, using the ext2fs_get_pathname
  * function
  */
-static void print_pathname(ext2_filsys fs, ino_t dir, ino_t ino)
+static void print_pathname(ext2_filsys fs, ext2_ino_t dir, ext2_ino_t ino)
 {
        errcode_t       retval;
        char            *path;
                printf("%u", ctx->blk2);
                break;
        case 'd':
-               printf("%lu", ctx->dir);
+               printf("%u", ctx->dir);
                break;
        case 'g':
                printf("%d", ctx->group);
                break;
        case 'i':
-               printf("%lu", ctx->ino);
+               printf("%u", ctx->ino);
                break;
        case 'j':
-               printf("%lu", ctx->ino2);
+               printf("%u", ctx->ino2);
                break;
        case 'm':
                printf("%s", error_message(ctx->errcode));
 
 /* static char *describe_illegal_block(ext2_filsys fs, blk_t block); */
 
 struct process_block_struct {
-       ino_t           ino;
+       ext2_ino_t      ino;
        int             is_dir:1, clear:1, suppress:1,
                                fragmented:1, compressed:1;
        blk_t           num_blocks;
 };
 
 struct process_inode_block {
-       ino_t   ino;
+       ext2_ino_t ino;
        struct ext2_inode inode;
 };
 
        int     i;
        __u64   max_sizes;
        ext2_filsys fs = ctx->fs;
-       ino_t   ino;
+       ext2_ino_t      ino;
        struct ext2_inode inode;
        ext2_inode_scan scan;
        char            *block_buf;
 {
        int                     i;
        struct ext2_inode       *old_stashed_inode;
-       ino_t                   old_stashed_ino;
+       ext2_ino_t              old_stashed_ino;
        const char              *old_operation;
        char                    buf[80];
        struct problem_context  pctx;
 #if 0
                printf("%u ", pctx.ino);
 #endif
-               sprintf(buf, _("reading indirect blocks of inode %lu"),
+               sprintf(buf, _("reading indirect blocks of inode %u"),
                        pctx.ino);
                ehandler_operation(buf);
                check_blocks(ctx, &pctx, block_buf);
 {
        ext2_filsys fs = ctx->fs;
        struct process_block_struct pb;
-       ino_t           ino = pctx->ino;
+       ext2_ino_t      ino = pctx->ino;
        struct ext2_inode *inode = pctx->inode;
        int             bad_size = 0;
        __u64           size;
  * structure, so there's no point in letting the ext2fs library read
  * the inode again.
  */
-static errcode_t pass1_get_blocks(ext2_filsys fs, ino_t ino, blk_t *blocks)
+static errcode_t pass1_get_blocks(ext2_filsys fs, ext2_ino_t ino,
+                                 blk_t *blocks)
 {
        e2fsck_t ctx = (e2fsck_t) fs->priv_data;
        int     i;
        return 0;
 }
 
-static errcode_t pass1_read_inode(ext2_filsys fs, ino_t ino,
+static errcode_t pass1_read_inode(ext2_filsys fs, ext2_ino_t ino,
                                  struct ext2_inode *inode)
 {
        e2fsck_t ctx = (e2fsck_t) fs->priv_data;
        return 0;
 }
 
-static errcode_t pass1_write_inode(ext2_filsys fs, ino_t ino,
+static errcode_t pass1_write_inode(ext2_filsys fs, ext2_ino_t ino,
                            struct ext2_inode *inode)
 {
        e2fsck_t ctx = (e2fsck_t) fs->priv_data;
        return EXT2_ET_CALLBACK_NOTHANDLED;
 }
 
-static errcode_t pass1_check_directory(ext2_filsys fs, ino_t ino)
+static errcode_t pass1_check_directory(ext2_filsys fs, ext2_ino_t ino)
 {
        e2fsck_t ctx = (e2fsck_t) fs->priv_data;
 
 
  */
 struct dup_block {
        blk_t           block;          /* Block number */
-       ino_t           ino;            /* Inode number */
+       ext2_ino_t      ino;            /* Inode number */
        int             num_bad;
        /* Pointer to next dup record with different block */
        struct dup_block *next_block;
  * of multiply-claimed blocks.
  */
 struct dup_inode {
-       ino_t                   ino, dir;
+       ext2_ino_t              ino, dir;
        int                     num_dupblocks;
        struct ext2_inode       inode;
        struct dup_inode        *next;
  * Scan the inodes looking for inodes that contain duplicate blocks.
  */
 struct process_block_struct {
-       ino_t   ino;
-       int     dup_blocks;
-       e2fsck_t ctx;
+       ext2_ino_t      ino;
+       int             dup_blocks;
+       e2fsck_t        ctx;
        struct problem_context *pctx;
 };
 
 static void pass1b(e2fsck_t ctx, char *block_buf)
 {
        ext2_filsys fs = ctx->fs;
-       ino_t   ino;
+       ext2_ino_t ino;
        struct ext2_inode inode;
        ext2_inode_scan scan;
        struct process_block_struct pb;
  */
 struct search_dir_struct {
        int             count;
-       ino_t           first_inode;
-       ino_t           max_inode;
+       ext2_ino_t      first_inode;
+       ext2_ino_t      max_inode;
 };
 
-static int search_dirent_proc(ino_t dir, int entry,
+static int search_dirent_proc(ext2_ino_t dir, int entry,
                              struct ext2_dir_entry *dirent,
                              int offset, int blocksize,
                              char *buf, void *priv_data)
        ext2_filsys fs = ctx->fs;
        struct dup_inode        *p, *s;
        struct dup_block        *q, *r;
-       ino_t   *shared;
+       ext2_ino_t              *shared;
        int     shared_len;
        int     i;
        int     file_ok;
 
        pctx.num = dup_inode_count;
        fix_problem(ctx, PR_1D_NUM_DUP_INODES, &pctx);
-       shared = (ino_t *) e2fsck_allocate_memory(ctx,
-                               sizeof(ino_t) * dup_inode_count,
+       shared = (ext2_ino_t *) e2fsck_allocate_memory(ctx,
+                               sizeof(ext2_ino_t) * dup_inode_count,
                                "Shared inode list");
        for (p = dup_ino; p; p = p->next) {
                shared_len = 0;
 
 struct clone_struct {
        errcode_t       errcode;
-       ino_t           dir;
+       ext2_ino_t      dir;
        char    *buf;
        e2fsck_t ctx;
 };
 
 /*
  * Keeps track of how many times an inode is referenced.
  */
-static void deallocate_inode(e2fsck_t ctx, ino_t ino,
+static void deallocate_inode(e2fsck_t ctx, ext2_ino_t ino,
                             char* block_buf);
 static int check_dir_block(ext2_filsys fs,
                           struct ext2_db_entry *dir_blocks_info,
  */
 static int check_dot(e2fsck_t ctx,
                     struct ext2_dir_entry *dirent,
-                    ino_t ino, struct problem_context *pctx)
+                    ext2_ino_t ino, struct problem_context *pctx)
 {
        struct ext2_dir_entry *nextdir;
        int     status = 0;
  */
 static int check_name(e2fsck_t ctx,
                      struct ext2_dir_entry *dirent,
-                     ino_t dir_ino, struct problem_context *pctx)
+                     ext2_ino_t dir_ino, struct problem_context *pctx)
 {
        int     i;
        int     fixup = -1;
  */
 static _INLINE_ int check_filetype(e2fsck_t ctx,
                      struct ext2_dir_entry *dirent,
-                     ino_t dir_ino, struct problem_context *pctx)
+                     ext2_ino_t dir_ino, struct problem_context *pctx)
 {
        int     filetype = dirent->name_len >> 8;
        int     should_be = EXT2_FT_UNKNOWN;
        int                     dir_modified = 0;
        int                     dot_state;
        blk_t                   block_nr = db->blk;
-       ino_t                   ino = db->ino;
+       ext2_ino_t              ino = db->ino;
        __u16                   links;
        struct check_dir_struct *cd;
        char                    *buf;
 /*
  * This fuction deallocates an inode
  */
-static void deallocate_inode(e2fsck_t ctx, ino_t ino,
+static void deallocate_inode(e2fsck_t ctx, ext2_ino_t ino,
                             char* block_buf)
 {
        ext2_filsys fs = ctx->fs;
        }
 }
 
-extern int e2fsck_process_bad_inode(e2fsck_t ctx, ino_t dir, ino_t ino)
+extern int e2fsck_process_bad_inode(e2fsck_t ctx, ext2_ino_t dir,
+                                   ext2_ino_t ino)
 {
        ext2_filsys fs = ctx->fs;
        struct ext2_inode       inode;
 
 static void check_root(e2fsck_t ctx);
 static int check_directory(e2fsck_t ctx, struct dir_info *dir,
                           struct problem_context *pctx);
-static ino_t get_lost_and_found(e2fsck_t ctx);
-static void fix_dotdot(e2fsck_t ctx, struct dir_info *dir, ino_t parent);
-static errcode_t adjust_inode_count(e2fsck_t ctx, ino_t ino, int adj);
-static errcode_t expand_directory(e2fsck_t ctx, ino_t dir);
+static ext2_ino_t get_lost_and_found(e2fsck_t ctx);
+static void fix_dotdot(e2fsck_t ctx, struct dir_info *dir, ext2_ino_t parent);
+static errcode_t adjust_inode_count(e2fsck_t ctx, ext2_ino_t ino, int adj);
+static errcode_t expand_directory(e2fsck_t ctx, ext2_ino_t dir);
 
-static ino_t lost_and_found = 0;
+static ext2_ino_t lost_and_found = 0;
 static int bad_lost_and_found = 0;
 
 static ext2fs_inode_bitmap inode_loop_detect = 0;
  * This routine gets the lost_and_found inode, making it a directory
  * if necessary
  */
-static ino_t get_lost_and_found(e2fsck_t ctx)
+static ext2_ino_t get_lost_and_found(e2fsck_t ctx)
 {
        ext2_filsys fs = ctx->fs;
-       ino_t                   ino;
+       ext2_ino_t                      ino;
        blk_t                   blk;
        errcode_t               retval;
        struct ext2_inode       inode;
 /*
  * This routine will connect a file to lost+found
  */
-int e2fsck_reconnect_file(e2fsck_t ctx, ino_t ino)
+int e2fsck_reconnect_file(e2fsck_t ctx, ext2_ino_t ino)
 {
        ext2_filsys fs = ctx->fs;
        errcode_t       retval;
                return 1;
        }
        
-       sprintf(name, "#%lu", ino);
+       sprintf(name, "#%u", ino);
        if (ext2fs_read_inode(fs, ino, &inode) == 0)
                file_type = ext2_file_type(inode.i_mode);
        retval = ext2fs_link(fs, lost_and_found, name, ino, file_type);
 /*
  * Utility routine to adjust the inode counts on an inode.
  */
-static errcode_t adjust_inode_count(e2fsck_t ctx, ino_t ino, int adj)
+static errcode_t adjust_inode_count(e2fsck_t ctx, ext2_ino_t ino, int adj)
 {
        ext2_filsys fs = ctx->fs;
        errcode_t               retval;
  */
 struct fix_dotdot_struct {
        ext2_filsys     fs;
-       ino_t           parent;
+       ext2_ino_t      parent;
        int             done;
        e2fsck_t        ctx;
 };
        return DIRENT_ABORT | DIRENT_CHANGED;
 }
 
-static void fix_dotdot(e2fsck_t ctx, struct dir_info *dir, ino_t parent)
+static void fix_dotdot(e2fsck_t ctx, struct dir_info *dir, ext2_ino_t parent)
 {
        ext2_filsys fs = ctx->fs;
        errcode_t       retval;
                return BLOCK_CHANGED;
 }
 
-static errcode_t expand_directory(e2fsck_t ctx, ino_t dir)
+static errcode_t expand_directory(e2fsck_t ctx, ext2_ino_t dir)
 {
        ext2_filsys fs = ctx->fs;
        errcode_t       retval;
 
  * This subroutine returns 1 then the caller shouldn't bother with the
  * rest of the pass 4 tests.
  */
-static int disconnect_inode(e2fsck_t ctx, ino_t i)
+static int disconnect_inode(e2fsck_t ctx, ext2_ino_t i)
 {
        ext2_filsys fs = ctx->fs;
        struct ext2_inode       inode;
 void e2fsck_pass4(e2fsck_t ctx)
 {
        ext2_filsys fs = ctx->fs;
-       ino_t   i;
+       ext2_ino_t      i;
        struct ext2_inode       inode;
 #ifdef RESOURCE_TRACK
        struct resource_track   rtrack;
 
 static void check_inode_bitmaps(e2fsck_t ctx)
 {
        ext2_filsys fs = ctx->fs;
-       ino_t   i;
+       ext2_ino_t      i;
        int     free_inodes = 0;
        int     group_free = 0;
        int     dirs_count = 0;
 static void check_inode_end(e2fsck_t ctx)
 {
        ext2_filsys fs = ctx->fs;
-       ino_t   end, save_inodes_count, i;
+       ext2_ino_t      end, save_inodes_count, i;
        struct problem_context  pctx;
 
        clear_problem_context(&pctx);
 
 
 struct problem_context {
        errcode_t       errcode;
-       ino_t ino, ino2, dir;
+       ext2_ino_t ino, ino2, dir;
        struct ext2_inode *inode;
        struct ext2_dir_entry *dirent;
        blk_t   blk, blk2;
 
        int             i;
        ext2_filsys     fs;
        ext2_inode_scan scan;
-       ino_t   ino;
+       ext2_ino_t      ino;
        struct ext2_inode inode;
 
        printf(_("size of inode=%d\n"), sizeof(inode));
 
  * found.  If the inode has a link count, then it is being truncated and
  * not deleted.
  */
-static int release_inode_blocks(e2fsck_t ctx, ino_t ino,
+static int release_inode_blocks(e2fsck_t ctx, ext2_ino_t ino,
                                struct ext2_inode *inode, char* block_buf,
                                struct problem_context *pctx)
 {
 {
        ext2_filsys fs = ctx->fs;
        int group;
-       ino_t   ino, next_ino;
+       ext2_ino_t      ino, next_ino;
        struct ext2_inode inode;
        struct problem_context pctx;
        char *block_buf;
 
 #include "e2fsck.h"
 
 struct swap_block_struct {
-       ino_t           ino;
+       ext2_ino_t      ino;
        int             isdir;
        errcode_t       errcode;
        char            *dir_buf;
  * This function is responsible for byte-swapping all of the indirect,
  * block pointers.  It is also responsible for byte-swapping directories.
  */
-static void swap_inode_blocks(e2fsck_t ctx, ino_t ino, char *block_buf,
+static void swap_inode_blocks(e2fsck_t ctx, ext2_ino_t ino, char *block_buf,
                              struct ext2_inode *inode)
 {
        errcode_t                       retval;
 {
        ext2_filsys fs = ctx->fs;
        int                     i, group;
-       ino_t                   ino = 1;
+       ext2_ino_t              ino = 1;
        char                    *buf, *block_buf;
        errcode_t               retval;
        struct ext2_inode *     inode;