]> git.ipfire.org Git - thirdparty/e2fsprogs.git/blobdiff - resize/extent.c
AOSP: Turn off some more warnings on Windows.
[thirdparty/e2fsprogs.git] / resize / extent.c
index 0f0ef4cd7372f188ab96c7dff625024762016261..e5ca16c0a954bec313f4a242b9944004830abb93 100644 (file)
@@ -5,52 +5,60 @@
  * translation table, for moving multiple contiguous ranges (extents)
  * of blocks or inodes.
  *
- * Copyright (C) 1997 Theodore Ts'o
- * 
+ * Copyright (C) 1997, 1998 by Theodore Ts'o and
+ *     PowerQuest, Inc.
+ *
+ * Copyright (C) 1999, 2000 by Theodore Ts'o
+ *
  * %Begin-Header%
- * All rights reserved.
+ * This file may be redistributed under the terms of the GNU Public
+ * License.
  * %End-Header%
  */
 
+#include "config.h"
 #include "resize2fs.h"
 
 struct ext2_extent_entry {
-       __u32   old, new;
-       int     size;
+       __u64   old_loc, new_loc;
+       __u64   size;
 };
 
 struct _ext2_extent {
        struct ext2_extent_entry *list;
-       int     cursor;
-       int     size;
-       int     num;
-       int     sorted;
+       __u64   cursor;
+       __u64   size;
+       __u64   num;
+       __u64   sorted;
 };
 
 /*
  * Create an extent table
  */
-errcode_t ext2fs_create_extent_table(ext2_extent *ret_extent, int size) 
+errcode_t ext2fs_create_extent_table(ext2_extent *ret_extent, __u64 size)
 {
-       ext2_extent     new;
-
-       new = malloc(sizeof(struct _ext2_extent));
-       if (!new)
-               return ENOMEM;
-       memset(new, 0, sizeof(struct _ext2_extent));
-
-       new->size = size ? size : 50;
-       new->cursor = 0;
-       new->num = 0;
-       new->sorted = 1;
-
-       new->list = malloc(sizeof(struct ext2_extent_entry) * new->size);
-       if (!new->list) {
-               free(new);
-               return ENOMEM;
+       ext2_extent     extent;
+       errcode_t       retval;
+
+       retval = ext2fs_get_mem(sizeof(struct _ext2_extent), &extent);
+       if (retval)
+               return retval;
+       memset(extent, 0, sizeof(struct _ext2_extent));
+
+       extent->size = size ? size : 50;
+       extent->cursor = 0;
+       extent->num = 0;
+       extent->sorted = 1;
+
+       retval = ext2fs_get_array(sizeof(struct ext2_extent_entry),
+                               extent->size, &extent->list);
+       if (retval) {
+               ext2fs_free_mem(&extent);
+               return retval;
        }
-       memset(new->list, 0, sizeof(struct ext2_extent_entry) * new->size);
-       *ret_extent = new;
+       memset(extent->list, 0,
+              sizeof(struct ext2_extent_entry) * extent->size);
+       *ret_extent = extent;
        return 0;
 }
 
@@ -60,30 +68,31 @@ errcode_t ext2fs_create_extent_table(ext2_extent *ret_extent, int size)
 void ext2fs_free_extent_table(ext2_extent extent)
 {
        if (extent->list)
-               free(extent->list);
+               ext2fs_free_mem(&extent->list);
        extent->list = 0;
        extent->size = 0;
        extent->num = 0;
-       free(extent);
+       ext2fs_free_mem(&extent);
 }
 
 /*
  * Add an entry to the extent table
  */
-errcode_t ext2fs_add_extent_entry(ext2_extent extent, __u32 old, __u32 new)
+errcode_t ext2fs_add_extent_entry(ext2_extent extent, __u64 old_loc, __u64 new_loc)
 {
-       struct ext2_extent_entry *p;
-       int     newsize;
-       int     curr;
-       struct  ext2_extent_entry *ent;
+       struct  ext2_extent_entry       *ent;
+       errcode_t                       retval;
+       __u64                           newsize;
+       __u64                           curr;
 
        if (extent->num >= extent->size) {
                newsize = extent->size + 100;
-               p = realloc(extent->list,
-                           sizeof(struct ext2_extent_entry) * newsize);
-               if (!p)
-                       return ENOMEM;
-               extent->list = p;
+               retval = ext2fs_resize_mem(sizeof(struct ext2_extent_entry) *
+                                          extent->size,
+                                          sizeof(struct ext2_extent_entry) *
+                                          newsize, &extent->list);
+               if (retval)
+                       return retval;
                extent->size = newsize;
        }
        curr = extent->num;
@@ -94,20 +103,20 @@ errcode_t ext2fs_add_extent_entry(ext2_extent extent, __u32 old, __u32 new)
                 * extent
                 */
                ent--;
-               if ((ent->old + ent->size == old) &&
-                   (ent->new + ent->size == new)) {
+               if ((ent->old_loc + ent->size == old_loc) &&
+                   (ent->new_loc + ent->size == new_loc)) {
                        ent->size++;
                        return 0;
                }
                /*
                 * Now see if we're going to ruin the sorting
                 */
-               if (ent->old + ent->size > old)
+               if (ent->old_loc + ent->size > old_loc)
                        extent->sorted = 0;
                ent++;
        }
-       ent->old = old;
-       ent->new = new;
+       ent->old_loc = old_loc;
+       ent->new_loc = new_loc;
        ent->size = 1;
        extent->num++;
        return 0;
@@ -116,22 +125,25 @@ errcode_t ext2fs_add_extent_entry(ext2_extent extent, __u32 old, __u32 new)
 /*
  * Helper function for qsort
  */
-static int extent_cmp(const void *a, const void *b)
+static EXT2_QSORT_TYPE extent_cmp(const void *a, const void *b)
 {
-       const struct ext2_extent_entry *db_a = a;
-       const struct ext2_extent_entry *db_b = b;
-       
-       return (db_a->old - db_b->old);
-}      
+       const struct ext2_extent_entry *db_a;
+       const struct ext2_extent_entry *db_b;
+
+       db_a = (const struct ext2_extent_entry *) a;
+       db_b = (const struct ext2_extent_entry *) b;
+
+       return (db_a->old_loc - db_b->old_loc);
+}
 
 /*
  * Given an inode map and inode number, look up the old inode number
- * and return the new inode number
+ * and return the new inode number.
  */
-__u32 ext2fs_extent_translate(ext2_extent extent, __u32 old)
+__u64 ext2fs_extent_translate(ext2_extent extent, __u64 old_loc)
 {
-       int     low, high, mid;
-       ino_t   lowval, highval;
+       __s64   low, high, mid;
+       __u64   lowval, highval;
        float   range;
 
        if (!extent->sorted) {
@@ -149,24 +161,29 @@ __u32 ext2fs_extent_translate(ext2_extent extent, __u32 old)
                        mid = low;
                else {
                        /* Interpolate for efficiency */
-                       lowval = extent->list[low].old;
-                       highval = extent->list[high].old;
+                       lowval = extent->list[low].old_loc;
+                       highval = extent->list[high].old_loc;
 
-                       if (old < lowval)
+                       if (old_loc < lowval)
                                range = 0;
-                       else if (old > highval)
+                       else if (old_loc > highval)
                                range = 1;
-                       else 
-                               range = ((float) (old - lowval)) /
+                       else {
+                               range = ((float) (old_loc - lowval)) /
                                        (highval - lowval);
-                       mid = low + ((int) (range * (high-low)));
+                               if (range > 0.9)
+                                       range = 0.9;
+                               if (range < 0.1)
+                                       range = 0.1;
+                       }
+                       mid = low + ((__u64) (range * (high-low)));
                }
 #endif
-               if ((old >= extent->list[mid].old) &&
-                   (old < extent->list[mid].old + extent->list[mid].size))
-                       return (extent->list[mid].new +
-                               (old - extent->list[mid].old));
-               if (old < extent->list[mid].old)
+               if ((old_loc >= extent->list[mid].old_loc) &&
+                   (old_loc < extent->list[mid].old_loc + extent->list[mid].size))
+                       return (extent->list[mid].new_loc +
+                               (old_loc - extent->list[mid].old_loc));
+               if (old_loc < extent->list[mid].old_loc)
                        high = mid-1;
                else
                        low = mid+1;
@@ -179,46 +196,46 @@ __u32 ext2fs_extent_translate(ext2_extent extent, __u32 old)
  */
 void ext2fs_extent_dump(ext2_extent extent, FILE *out)
 {
-       int     i;
+       __u64   i;
        struct ext2_extent_entry *ent;
-       
-       fputs("# Extent dump:\n", out);
-       fprintf(out, "#\tNum=%d, Size=%d, Cursor=%d, Sorted=%d\n",
+
+       fputs(_("# Extent dump:\n"), out);
+       fprintf(out, _("#\tNum=%llu, Size=%llu, Cursor=%llu, Sorted=%llu\n"),
               extent->num, extent->size, extent->cursor, extent->sorted);
        for (i=0, ent=extent->list; i < extent->num; i++, ent++) {
-               fprintf(out, "#\t\t %u -> %u (%d)\n", ent->old,
-                       ent->new, ent->size);
+               fprintf(out, "#\t\t %llu -> %llu (%llu)\n", ent->old_loc,
+                       ent->new_loc, ent->size);
        }
 }
 
 /*
  * Iterate over the contents of the extent table
  */
-errcode_t ext2fs_iterate_extent(ext2_extent extent, __u32 *old,
-                               __u32 *new, int *size)
+errcode_t ext2fs_iterate_extent(ext2_extent extent, __u64 *old_loc,
+                               __u64 *new_loc, __u64 *size)
 {
        struct ext2_extent_entry *ent;
-       
-       if (!old) {
+
+       if (!old_loc) {
                extent->cursor = 0;
                return 0;
        }
 
        if (extent->cursor >= extent->num) {
-               *old = 0;
-               *new = 0;
+               *old_loc = 0;
+               *new_loc = 0;
                *size = 0;
                return 0;
        }
 
        ent = extent->list + extent->cursor++;
 
-       *old = ent->old;
-       *new = ent->new;
+       *old_loc = ent->old_loc;
+       *new_loc = ent->new_loc;
        *size = ent->size;
        return 0;
 }
-       
-       
-               
-              
+
+
+
+