summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeremy Allison <jra@samba.org>2005-04-07 19:50:54 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 13:11:28 -0500
commite3775ee8501e2f15ee172970085c2c12e50da1cf (patch)
tree6cd6a342510047c258e354ab6ea7f3ffcd6d1683
parentc46c6e23ba7b962e20f49eeff3c3842ce905ec4a (diff)
downloadsamba-e3775ee8501e2f15ee172970085c2c12e50da1cf.tar.gz
samba-e3775ee8501e2f15ee172970085c2c12e50da1cf.tar.bz2
samba-e3775ee8501e2f15ee172970085c2c12e50da1cf.zip
r6238: Ensure if realloc fails on an internal
tdb we fail gracefully. Jeremy. (This used to be commit d69f7c05468ae54e0474b188fedabe14e7297d53)
-rw-r--r--source4/lib/tdb/common/tdb.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/source4/lib/tdb/common/tdb.c b/source4/lib/tdb/common/tdb.c
index d9fabaeda9..6554ec5697 100644
--- a/source4/lib/tdb/common/tdb.c
+++ b/source4/lib/tdb/common/tdb.c
@@ -802,9 +802,14 @@ static int tdb_expand(TDB_CONTEXT *tdb, tdb_off size)
tdb->map_size += size;
- if (tdb->flags & TDB_INTERNAL)
- tdb->map_ptr = realloc(tdb->map_ptr, tdb->map_size);
- else {
+ if (tdb->flags & TDB_INTERNAL) {
+ char *new_map_ptr = realloc(tdb->map_ptr, tdb->map_size);
+ if (!new_map_ptr) {
+ tdb->map_size -= size;
+ goto fail;
+ }
+ tdb->map_ptr = new_map_ptr;
+ } else {
/*
* We must ensure the file is remapped before adding the space
* to ensure consistency with systems like OpenBSD where