Merge pull request #1656
edfd7f6e
Workaround VL32 cursor refcounting miscount (Howard Chu)
This commit is contained in:
commit
da9174c8ee
1 changed files with 9 additions and 7 deletions
2
external/db_drivers/liblmdb/mdb.c
vendored
2
external/db_drivers/liblmdb/mdb.c
vendored
|
@ -1953,6 +1953,7 @@ static void
|
||||||
mdb_cursor_unref(MDB_cursor *mc)
|
mdb_cursor_unref(MDB_cursor *mc)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
if (mc->mc_txn->mt_rpages[0].mid) {
|
||||||
if (!mc->mc_snum || !mc->mc_pg[0] || IS_SUBP(mc->mc_pg[0]))
|
if (!mc->mc_snum || !mc->mc_pg[0] || IS_SUBP(mc->mc_pg[0]))
|
||||||
return;
|
return;
|
||||||
for (i=0; i<mc->mc_snum; i++)
|
for (i=0; i<mc->mc_snum; i++)
|
||||||
|
@ -1961,6 +1962,7 @@ mdb_cursor_unref(MDB_cursor *mc)
|
||||||
mdb_page_unref(mc->mc_txn, mc->mc_ovpg);
|
mdb_page_unref(mc->mc_txn, mc->mc_ovpg);
|
||||||
mc->mc_ovpg = 0;
|
mc->mc_ovpg = 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
mc->mc_snum = mc->mc_top = 0;
|
mc->mc_snum = mc->mc_top = 0;
|
||||||
mc->mc_pg[0] = NULL;
|
mc->mc_pg[0] = NULL;
|
||||||
mc->mc_flags &= ~C_INITIALIZED;
|
mc->mc_flags &= ~C_INITIALIZED;
|
||||||
|
|
Loading…
Reference in a new issue