ITS#6758 back-bdb: Delay setting sr->sr_entry until we know it will be used

This commit is contained in:
Hallvard Furuseth 2010-12-31 00:04:38 +00:00
parent 1ea8de9fda
commit abf7f2efce

View File

@ -748,8 +748,6 @@ fetch_entry_retry:
goto loop_continue; goto loop_continue;
} }
rs->sr_entry = e;
if ( is_entry_subentry( e ) ) { if ( is_entry_subentry( e ) ) {
if( op->oq_search.rs_scope != LDAP_SCOPE_BASE ) { if( op->oq_search.rs_scope != LDAP_SCOPE_BASE ) {
if(!get_subentries_visibility( op )) { if(!get_subentries_visibility( op )) {
@ -881,6 +879,7 @@ fetch_entry_retry:
blis.bli_lock = lock; blis.bli_lock = lock;
blis.bli_flag = BLI_DONTFREE; blis.bli_flag = BLI_DONTFREE;
rs->sr_entry = e;
rs->sr_flags = REP_ENTRY_MUSTRELEASE; rs->sr_flags = REP_ENTRY_MUSTRELEASE;
send_search_reference( op, rs ); send_search_reference( op, rs );
@ -912,7 +911,7 @@ fetch_entry_retry:
} }
/* if it matches the filter and scope, send it */ /* if it matches the filter and scope, send it */
rs->sr_err = test_filter( op, rs->sr_entry, op->oq_search.rs_filter ); rs->sr_err = test_filter( op, e, op->oq_search.rs_filter );
if ( rs->sr_err == LDAP_COMPARE_TRUE ) { if ( rs->sr_err == LDAP_COMPARE_TRUE ) {
/* check size limit */ /* check size limit */
@ -956,10 +955,13 @@ fetch_entry_retry:
rs->sr_attrs = op->oq_search.rs_attrs; rs->sr_attrs = op->oq_search.rs_attrs;
rs->sr_operational_attrs = NULL; rs->sr_operational_attrs = NULL;
rs->sr_ctrls = NULL; rs->sr_ctrls = NULL;
rs->sr_entry = e;
RS_ASSERT( e->e_private != NULL );
rs->sr_flags = REP_ENTRY_MUSTRELEASE; rs->sr_flags = REP_ENTRY_MUSTRELEASE;
rs->sr_err = LDAP_SUCCESS; rs->sr_err = LDAP_SUCCESS;
rs->sr_err = send_search_entry( op, rs ); rs->sr_err = send_search_entry( op, rs );
rs->sr_attrs = NULL; rs->sr_attrs = NULL;
rs->sr_entry = NULL;
/* send_search_entry will usually free it. /* send_search_entry will usually free it.
* an overlay might leave its own copy here; * an overlay might leave its own copy here;
@ -977,7 +979,6 @@ fetch_entry_retry:
OpExtra, oe_next ); OpExtra, oe_next );
} }
} }
rs->sr_entry = NULL;
e = NULL; e = NULL;
switch ( rs->sr_err ) { switch ( rs->sr_err ) {
@ -1013,6 +1014,7 @@ loop_continue:
slap_zn_runlock(bdb->bi_cache.c_zctx, e); slap_zn_runlock(bdb->bi_cache.c_zctx, e);
#endif #endif
bdb_cache_return_entry_r( bdb, e , &lock ); bdb_cache_return_entry_r( bdb, e , &lock );
RS_ASSERT( rs->sr_entry == NULL );
e = NULL; e = NULL;
rs->sr_entry = NULL; rs->sr_entry = NULL;
} }
@ -1327,4 +1329,3 @@ send_paged_response(
done: done:
(void) ber_free_buf( ber ); (void) ber_free_buf( ber );
} }