From: Howard Chu Date: Tue, 2 Mar 2010 21:29:32 +0000 (+0000) Subject: ITS#6484 - cache DB needs to release its own entries X-Git-Tag: MIGRATION_CVS2GIT~680 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=f992b66f05f0cac2aa8ed950bbea7bd243931e40;p=openldap ITS#6484 - cache DB needs to release its own entries --- diff --git a/servers/slapd/overlays/pcache.c b/servers/slapd/overlays/pcache.c index 351d68a84a..3623f37245 100644 --- a/servers/slapd/overlays/pcache.c +++ b/servers/slapd/overlays/pcache.c @@ -5219,6 +5219,20 @@ pcache_op_extended( Operation *op, SlapReply *rs ) return SLAP_CB_CONTINUE; } +static int +pcache_entry_release( Operation *op, Entry *e, int rw ) +{ + slap_overinst *on = (slap_overinst *)op->o_bd->bd_info; + cache_manager *cm = on->on_bi.bi_private; + BackendDB *db = op->o_bd; + int rc; + + op->o_bd = &cm->db; + rc = be_entry_release_rw( op, e, rw ); + op->o_bd = db; + return rc; +} + #ifdef PCACHE_MONITOR static int @@ -5605,6 +5619,7 @@ pcache_initialize() #endif /* PCACHE_CONTROL_PRIVDB */ pcache.on_bi.bi_extended = pcache_op_extended; + pcache.on_bi.bi_entry_release_rw = pcache_entry_release; pcache.on_bi.bi_chk_controls = pcache_chk_controls; pcache.on_bi.bi_cf_ocs = pcocs;