Diff for /servers/slapd/back-bdb/dbcache.c between versions 1.28 and 1.28.2.2

version 1.28, 2003/04/17 03:15:12 version 1.28.2.2, 2003/10/06 14:57:30
Line 1 Line 1
 /* dbcache.c - manage cache of open databases */  /* dbcache.c - manage cache of open databases */
 /* $OpenLDAP: pkg/ldap/servers/slapd/back-bdb/dbcache.c,v 1.27 2003/04/17 02:55:39 hyc Exp $ */  /* $OpenLDAP: pkg/ldap/servers/slapd/back-bdb/dbcache.c,v 1.28.2.1 2003/09/18 15:43:36 kurt Exp $ */
 /*  /*
  * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.   * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.
  * COPYING RESTRICTIONS APPLY, see COPYRIGHT file   * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
Line 46  bdb_db_hash( Line 46  bdb_db_hash(
 int  int
 bdb_db_cache(  bdb_db_cache(
         Backend *be,          Backend *be,
         DB_TXN *tid,  
         const char *name,          const char *name,
         DB **dbout )          DB **dbout )
 {  {
         int i;          int i;
         int rc;          int rc;
         int flags;  
         struct bdb_info *bdb = (struct bdb_info *) be->be_private;          struct bdb_info *bdb = (struct bdb_info *) be->be_private;
         struct bdb_db_info *db;          struct bdb_db_info *db;
         char *file;          char *file;
         DBT lockobj;  
         DB_LOCK lock;  
         u_int32_t locker = 0;  
   
         *dbout = NULL;          *dbout = NULL;
   
Line 69  bdb_db_cache( Line 64  bdb_db_cache(
                 }                  }
         }          }
   
         lockobj.data = "bdb_db_cache";          ldap_pvt_thread_mutex_lock( &bdb->bi_database_mutex );
         lockobj.size = sizeof("bdb_db_cache");  
   
         if (tid) {  
                 locker = TXN_ID( tid );  
         } else {  
 #ifdef BDB_REUSE_LOCKERS  
 #define op      NULL    /* implicit arg in LOCK_ID */  
 #endif  
                 rc = LOCK_ID( bdb->bi_dbenv, &locker );  
                 if (rc) return rc;  
         }  
         rc = LOCK_GET( bdb->bi_dbenv, locker, 0, &lockobj,  
                 DB_LOCK_WRITE, &lock );  
         if (rc) return rc;  
   
         /* check again! may have been added by another thread */          /* check again! may have been added by another thread */
         for( i=BDB_NDB; i < bdb->bi_ndatabases; i++ ) {          for( i=BDB_NDB; i < bdb->bi_ndatabases; i++ ) {
                 if( !strcmp( bdb->bi_databases[i]->bdi_name, name) ) {                  if( !strcmp( bdb->bi_databases[i]->bdi_name, name) ) {
                         *dbout = bdb->bi_databases[i]->bdi_db;                          *dbout = bdb->bi_databases[i]->bdi_db;
                         LOCK_PUT( bdb->bi_dbenv, &lock);                          ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );
                         return 0;                          return 0;
                 }                  }
         }          }
   
         if( i >= BDB_INDICES ) {          if( i >= BDB_INDICES ) {
                 LOCK_PUT( bdb->bi_dbenv, &lock);                  ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );
                 return -1;                  return -1;
         }          }
   
Line 114  bdb_db_cache( Line 95  bdb_db_cache(
                         "bdb_db_cache: db_create(%s) failed: %s (%d)\n",                          "bdb_db_cache: db_create(%s) failed: %s (%d)\n",
                         bdb->bi_dbenv_home, db_strerror(rc), rc );                          bdb->bi_dbenv_home, db_strerror(rc), rc );
 #endif  #endif
                 LOCK_PUT( bdb->bi_dbenv, &lock);                  ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );
                 return rc;                  return rc;
         }          }
   
Line 129  bdb_db_cache( Line 110  bdb_db_cache(
 #ifdef HAVE_EBCDIC  #ifdef HAVE_EBCDIC
         __atoe( file );          __atoe( file );
 #endif  #endif
         flags = bdb->bi_db_opflags | DB_CREATE | DB_THREAD;          rc = DB_OPEN( db->bdi_db,
         if ( !tid ) flags |= DB_AUTO_COMMIT;  
         rc = DB_OPEN( db->bdi_db, tid,  
                 file, NULL /* name */,                  file, NULL /* name */,
                 DB_HASH, flags,                  DB_HASH, bdb->bi_db_opflags | DB_CREATE | DB_THREAD,
                 bdb->bi_dbenv_mode );                  bdb->bi_dbenv_mode );
   
         ch_free( file );          ch_free( file );
Line 148  bdb_db_cache( Line 127  bdb_db_cache(
                         "bdb_db_cache: db_open(%s) failed: %s (%d)\n",                          "bdb_db_cache: db_open(%s) failed: %s (%d)\n",
                         name, db_strerror(rc), rc );                          name, db_strerror(rc), rc );
 #endif  #endif
                 LOCK_PUT( bdb->bi_dbenv, &lock);                  ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );
                 return rc;                  return rc;
         }          }
   
Line 157  bdb_db_cache( Line 136  bdb_db_cache(
   
         *dbout = db->bdi_db;          *dbout = db->bdi_db;
   
         LOCK_PUT( bdb->bi_dbenv, &lock );          ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );
         return 0;          return 0;
 }  }

Removed from v.1.28  
changed lines
  Added in v.1.28.2.2


______________
© Copyright 1998-2020, OpenLDAP Foundation, info@OpenLDAP.org