{
struct bdb_info *bdb = (struct bdb_info *) op->o_bd->be_private;
Entry *ep = NULL;
- int rc = 0, load = 0;
+ int rc = 0, load = 0, added = 0;
EntryInfo ei = { 0 };
ei.bei_id = id;
* loading it, i.e it is already cached or
* another thread is currently loading it.
*/
- (*eip)->bei_state &= ~CACHE_ENTRY_NOT_CACHED;
+ if ( (*eip)->bei_state & CACHE_ENTRY_NOT_CACHED ) {
+ (*eip)->bei_state &= ~CACHE_ENTRY_NOT_CACHED;
+ added = 1;
+ }
flag &= ~ID_NOCACHE;
}
#endif
ep = NULL;
bdb_cache_lru_link( bdb, *eip );
+ added = 1;
if (( flag & ID_NOCACHE ) &&
( bdb_cache_entryinfo_trylock( *eip ) == 0 )) {
/* Set the cached state only if no other thread
if ( rc == 0 ) {
int purge = 0;
- if ( load ) {
+ if ( added ) {
ldap_pvt_thread_mutex_lock( &bdb->bi_cache.c_count_mutex );
if ( !( flag & ID_NOCACHE )) {
bdb->bi_cache.c_cursize++;