+1998-04-26 Theodore Ts'o <tytso@rsts-11.mit.edu>
+
+ * dirinfo.c (e2fsck_add_dir_info): Update function to pass the old
+ size of the memory to be resized to ext2fs_resize_mem().
+
1998-03-30 Theodore Ts'o <tytso@rsts-11.mit.edu>
* Makefile.in: Change to use new installation directory variables
int i, j;
ino_t num_dirs;
errcode_t retval;
+ unsigned long old_size;
#if 0
printf("add_dir_info for inode %lu...\n", ino);
}
if (ctx->dir_info_count >= ctx->dir_info_size) {
+ old_size = ctx->dir_info_size * sizeof(struct dir_info);
ctx->dir_info_size += 10;
- retval = ext2fs_resize_mem(ctx->dir_info_size *
+ retval = ext2fs_resize_mem(old_size, ctx->dir_info_size *
sizeof(struct dir_info),
(void **) &ctx->dir_info);
if (retval) {
+1998-04-26 Theodore Ts'o <tytso@rsts-11.mit.edu>
+
+ * ext2fs.h, bitops.h: Add support for the Watcom C compiler to do
+ inline functions.
+
+ * ext2fs.h, dosio.c: Use asm/types.h instead of linux/types.h to
+ evade a potential problem with glibc's header files trying
+ to spike out linux/types.h.
+
+ * ext2fs.h (ext2fs_resize_mem): Change the function prototype to
+ include the old size of the memory, which is needed for
+ some braindamaged memory allocation systems that don't
+ support realloc().
+
+ * badblocks.c (ext2fs_badblocks_list_add):
+ bb_inode.c (clear_bad_block_proc):
+ dblist.c (ext2fs_add_dir_block):
+ icount.c (insert_icount_el):
+ irel_ma.c (ima_put):
+ rs_bitmap.c (ext2fs_resize_generic_bitmap): Update functions to
+ pass the old size of the memory to be resized to
+ ext2fs_resize_mem().
+
1998-03-30 Theodore Ts'o <tytso@rsts-11.mit.edu>
* Makefile.in: Change to use new installation directory variables
{
errcode_t retval;
int i, j;
+ unsigned long old_size;
EXT2_CHECK_MAGIC(bb, EXT2_ET_MAGIC_BADBLOCKS_LIST);
if (bb->num >= bb->size) {
+ old_size = bb->size * sizeof(blk_t);
bb->size += 10;
- retval = ext2fs_resize_mem(bb->size * sizeof(blk_t),
+ retval = ext2fs_resize_mem(old_size, bb->size * sizeof(blk_t),
(void **) &bb->list);
- if (retval)
+ if (retval) {
+ bb->size -= 10;
return retval;
+ }
}
j = bb->num;
priv_data;
errcode_t retval;
int group;
+ unsigned long old_size;
if (!*block_nr)
return 0;
if (blockcnt < 0) {
if (rec->ind_blocks_size >= rec->max_ind_blocks) {
+ old_size = rec->max_ind_blocks * sizeof(blk_t);
rec->max_ind_blocks += 10;
- retval = ext2fs_resize_mem(rec->max_ind_blocks
- * sizeof(blk_t),
- (void **) &rec->ind_blocks);
+ retval = ext2fs_resize_mem(old_size,
+ rec->max_ind_blocks * sizeof(blk_t),
+ (void **) &rec->ind_blocks);
if (retval) {
+ rec->max_ind_blocks -= 10;
rec->err = retval;
return BLOCK_ABORT;
}
#ifdef INCLUDE_INLINE_FUNCS
#define _INLINE_ extern
#else
+#ifdef __GNUC__
#define _INLINE_ extern __inline__
+#else /* For Watcom C */
+#define _INLINE_ extern inline
+#endif
#endif
#if ((defined __GNUC__) && (defined(__i386__) || defined(__i486__) || \
{
struct ext2_db_entry *new_entry;
errcode_t retval;
+ unsigned long old_size;
EXT2_CHECK_MAGIC(dblist, EXT2_ET_MAGIC_DBLIST);
if (dblist->count >= dblist->size) {
+ old_size = dblist->size * sizeof(struct ext2_db_entry);
dblist->size += 100;
- retval = ext2fs_resize_mem((size_t) dblist->size *
+ retval = ext2fs_resize_mem(old_size, (size_t) dblist->size *
sizeof(struct ext2_db_entry),
(void **) &dblist->list);
if (retval) {
#include <errno.h>
#endif
-#include <linux/types.h>
+#include <asm/types.h>
#include "utils.h"
#include "dosio.h"
#include "et/com_err.h"
/*
* Non-GNU C compilers won't necessarily understand inline
*/
-#ifndef __GNUC__
+#if (!defined(__GNUC__) && !defined(__WATCOMC__))
#define NO_INLINE_FUNCS
#endif
#if EXT2_FLAT_INCLUDES
#include "e2_types.h"
#else
-#include <linux/types.h>
+#include <asm/types.h>
#if (defined(__GNUC__) && defined(__STRICT_ANSI__) && ((~0UL) == 0xffffffff))
typedef __signed__ long long __s64;
typedef unsigned long long __u64;
/* inline functions */
extern errcode_t ext2fs_get_mem(unsigned long size, void **ptr);
extern errcode_t ext2fs_free_mem(void **ptr);
-extern errcode_t ext2fs_resize_mem(unsigned long size, void **ptr);
+extern errcode_t ext2fs_resize_mem(unsigned long old_size,
+ unsigned long size, void **ptr);
extern void ext2fs_mark_super_dirty(ext2_filsys fs);
extern void ext2fs_mark_changed(ext2_filsys fs);
extern int ext2fs_test_changed(ext2_filsys fs);
#ifdef INCLUDE_INLINE_FUNCS
#define _INLINE_ extern
#else
+#ifdef __GNUC__
#define _INLINE_ extern __inline__
+#else /* For Watcom C */
+#define _INLINE_ extern inline
+#endif
#endif
#ifndef EXT2_CUSTOM_MEMORY_ROUTINES
/*
* Resize memory
*/
-_INLINE_ errcode_t ext2fs_resize_mem(unsigned long size, void **ptr)
+_INLINE_ errcode_t ext2fs_resize_mem(unsigned long old_size,
+ unsigned long size, void **ptr)
{
void *p;
#if 0
printf("Reallocating icount %d entries...\n", new_size);
#endif
- retval = ext2fs_resize_mem((size_t) new_size *
+ retval = ext2fs_resize_mem((size_t) icount->size *
+ sizeof(struct ext2_icount_el),
+ (size_t) new_size *
sizeof(struct ext2_icount_el),
(void **) &icount->list);
if (retval)
struct inode_reference_entry *ref_ent;
struct irel_ma *ma;
errcode_t retval;
- int size;
+ size_t size, old_size;
ma = irel->priv_data;
if (old > ma->max_inode)
if (ref_ent->refs && ent->max_refs !=
ma->entries[(unsigned) old].max_refs) {
size = (sizeof(struct ext2_inode_reference) * ent->max_refs);
- retval = ext2fs_resize_mem(size, (void **) &ref_ent->refs);
+ old_size = (sizeof(struct ext2_inode_reference) *
+ ma->entries[(unsigned) old].max_refs);
+ retval = ext2fs_resize_mem(old_size, size,
+ (void **) &ref_ent->refs);
if (retval)
return retval;
}
size = ((bmap->real_end - bmap->start) / 8) + 1;
new_size = ((new_real_end - bmap->start) / 8) + 1;
- retval = ext2fs_resize_mem(new_size, (void **) &bmap->bitmap);
- if (retval)
- return retval;
+ if (size != new_size) {
+ retval = ext2fs_resize_mem(size, new_size,
+ (void **) &bmap->bitmap);
+ if (retval)
+ return retval;
+ }
if (new_size > size)
memset(bmap->bitmap + size, 0, new_size - size);
+1998-04-26 Theodore Ts'o <tytso@rsts-11.mit.edu>
+
+ * resize2fs.c (adjust_superblock):
+ * extent.c (ext2fs_add_extent_entry): Update functions to
+ pass the old size of the memory to be resized to
+ ext2fs_resize_mem().
+
1998-03-30 Theodore Ts'o <tytso@rsts-11.mit.edu>
* Makefile.in: Change to use new installation directory variables
if (extent->num >= extent->size) {
newsize = extent->size + 100;
retval = ext2fs_resize_mem(sizeof(struct ext2_extent_entry) *
+ extent->size,
+ sizeof(struct ext2_extent_entry) *
newsize, (void **) &extent->list);
if (retval)
return retval;
* Reallocate the group descriptors as necessary.
*/
if (rfs->old_fs->desc_blocks != fs->desc_blocks) {
- retval = ext2fs_resize_mem(fs->desc_blocks * fs->blocksize,
+ retval = ext2fs_resize_mem(rfs->old_fs->desc_blocks *
+ fs->blocksize,
+ fs->desc_blocks * fs->blocksize,
(void **) &fs->group_desc);
if (retval)
goto errout;