From: Hallvard Furuseth Date: Sat, 16 Feb 2013 18:08:54 +0000 (+0100) Subject: ITS#7377 Catch MDB failure updating root pointers. X-Git-Tag: OPENLDAP_REL_ENG_2_4_34~3^2~15 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=d90581fa5a9ae42b87325f18259553bc80d89a14;p=openldap ITS#7377 Catch MDB failure updating root pointers. "cannot fail" was wrong, it fails at least when exceeding mapsize. --- diff --git a/libraries/liblmdb/mdb.c b/libraries/liblmdb/mdb.c index 715d1c811a..083b25bb8d 100644 --- a/libraries/liblmdb/mdb.c +++ b/libraries/liblmdb/mdb.c @@ -2124,9 +2124,7 @@ mdb_txn_commit(MDB_txn *txn) DPRINTF("committing txn %zu %p on mdbenv %p, root page %zu", txn->mt_txnid, (void *)txn, (void *)env, txn->mt_dbs[MAIN_DBI].md_root); - /* Update DB root pointers. Their pages have already been - * touched so this is all in-place and cannot fail. - */ + /* Update DB root pointers */ if (txn->mt_numdbs > 2) { MDB_dbi i; MDB_val data; @@ -2136,7 +2134,9 @@ mdb_txn_commit(MDB_txn *txn) for (i = 2; i < txn->mt_numdbs; i++) { if (txn->mt_dbflags[i] & DB_DIRTY) { data.mv_data = &txn->mt_dbs[i]; - mdb_cursor_put(&mc, &txn->mt_dbxs[i].md_name, &data, 0); + rc = mdb_cursor_put(&mc, &txn->mt_dbxs[i].md_name, &data, 0); + if (rc) + goto fail; } } }