Tweak reader checks

Use mti_numreaders for loop limit, not me_maxreaders.
vmware
Howard Chu 12 years ago
parent a4bbe57f8b
commit 5ca73f864f
  1. 4
      libraries/liblmdb/mdb.c

@ -7999,7 +7999,7 @@ int mdb_reader_list(MDB_env *env, MDB_msg_func *func, void *ctx)
if (!env->me_txns) { if (!env->me_txns) {
return func("(no reader locks)\n", ctx); return func("(no reader locks)\n", ctx);
} }
rdrs = env->me_maxreaders; rdrs = env->me_txns->mti_numreaders;
mr = env->me_txns->mti_readers; mr = env->me_txns->mti_readers;
for (i=0; i<rdrs; i++) { for (i=0; i<rdrs; i++) {
if (mr[i].mr_pid) { if (mr[i].mr_pid) {
@ -8078,7 +8078,7 @@ int mdb_reader_check(MDB_env *env, int *dead)
*dead = 0; *dead = 0;
if (!env->me_txns) if (!env->me_txns)
return MDB_SUCCESS; return MDB_SUCCESS;
rdrs = env->me_maxreaders; rdrs = env->me_txns->mti_numreaders;
pids = malloc((rdrs+1) * sizeof(pid_t)); pids = malloc((rdrs+1) * sizeof(pid_t));
if (!pids) if (!pids)
return ENOMEM; return ENOMEM;

Loading…
Cancel
Save