Diff for /servers/slapd/back-bdb/dbcache.c between versions 1.28.2.6 and 1.29

version 1.28.2.6, 2005/01/20 17:01:11 version 1.29, 2003/06/05 09:55:27
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.28.2.5 2004/02/23 22:08:06 kurt Exp $ */  /* $OpenLDAP: pkg/ldap/servers/slapd/back-bdb/dbcache.c,v 1.28 2003/04/17 03:15:12 hyc Exp $ */
 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.  /*
  *   * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.
  * Copyright 2000-2005 The OpenLDAP Foundation.   * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
  * All rights reserved.  
  *  
  * Redistribution and use in source and binary forms, with or without  
  * modification, are permitted only as authorized by the OpenLDAP  
  * Public License.  
  *  
  * A copy of this license is available in the file LICENSE in the  
  * top-level directory of the distribution or, alternatively, at  
  * <http://www.OpenLDAP.org/license.html>.  
  */   */
   
 #include "portable.h"  #include "portable.h"
Line 28 Line 19
 #include "back-bdb.h"  #include "back-bdb.h"
 #include "lutil_hash.h"  #include "lutil_hash.h"
   
 #ifdef BDB_INDEX_USE_HASH  
 /* Pass-thru hash function. Since the indexer is already giving us hash  /* Pass-thru hash function. Since the indexer is already giving us hash
  * values as keys, we don't need BDB to re-hash them.   * values as keys, we don't need BDB to re-hash them.
  */   */
Line 39  bdb_db_hash( Line 29  bdb_db_hash(
         u_int32_t length          u_int32_t length
 )  )
 {  {
         u_int32_t ret = 0;          u_int32_t i, ret = 0;
         unsigned char *dst = (unsigned char *)&ret;  
         const unsigned char *src = (const unsigned char *)bytes;  
   
         if ( length > sizeof(u_int32_t) )          if ( length > sizeof(u_int32_t) )
                 length = sizeof(u_int32_t);                  length = sizeof(u_int32_t);
   
         while ( length ) {          for( i = 0; i < length; i++ )
                 *dst++ = *src++;                  ret = (ret << 8) + ((const unsigned char *)bytes)[i];
                 length--;  
         }  
         return ret;          return ret;
 }  }
 #define BDB_INDEXTYPE   DB_HASH  
 #else  
 #define BDB_INDEXTYPE   DB_BTREE  
 #endif  
   
 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 78  bdb_db_cache( Line 65  bdb_db_cache(
                 }                  }
         }          }
   
         ldap_pvt_thread_mutex_lock( &bdb->bi_database_mutex );          lockobj.data = "bdb_db_cache";
           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;
                         ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );                          LOCK_PUT( bdb->bi_dbenv, &lock);
                         return 0;                          return 0;
                 }                  }
         }          }
   
         if( i >= BDB_INDICES ) {          if( i >= BDB_INDICES ) {
                 ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );                  LOCK_PUT( bdb->bi_dbenv, &lock);
                 return -1;                  return -1;
         }          }
   
Line 109  bdb_db_cache( Line 110  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
                 ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );                  LOCK_PUT( bdb->bi_dbenv, &lock);
                 return rc;                  return rc;
         }          }
   
         rc = db->bdi_db->set_pagesize( db->bdi_db, BDB_PAGESIZE );          rc = db->bdi_db->set_pagesize( db->bdi_db, BDB_PAGESIZE );
 #ifdef BDB_INDEX_USE_HASH  
         rc = db->bdi_db->set_h_hash( db->bdi_db, bdb_db_hash );          rc = db->bdi_db->set_h_hash( db->bdi_db, bdb_db_hash );
 #endif  
         rc = db->bdi_db->set_flags( db->bdi_db, DB_DUP | DB_DUPSORT );          rc = db->bdi_db->set_flags( db->bdi_db, DB_DUP | DB_DUPSORT );
         rc = db->bdi_db->set_dup_compare( db->bdi_db, bdb_bt_compare );          rc = db->bdi_db->set_dup_compare( db->bdi_db, bdb_bt_compare );
   
Line 126  bdb_db_cache( Line 125  bdb_db_cache(
 #ifdef HAVE_EBCDIC  #ifdef HAVE_EBCDIC
         __atoe( file );          __atoe( file );
 #endif  #endif
         rc = DB_OPEN( db->bdi_db,          flags = bdb->bi_db_opflags | DB_CREATE | DB_THREAD;
           if ( !tid ) flags |= DB_AUTO_COMMIT;
           rc = DB_OPEN( db->bdi_db, tid,
                 file, NULL /* name */,                  file, NULL /* name */,
                 BDB_INDEXTYPE, bdb->bi_db_opflags | DB_CREATE | DB_THREAD,                  DB_HASH, flags,
                 bdb->bi_dbenv_mode );                  bdb->bi_dbenv_mode );
   
         ch_free( file );          ch_free( file );
Line 143  bdb_db_cache( Line 144  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
                 ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );                  LOCK_PUT( bdb->bi_dbenv, &lock);
                 return rc;                  return rc;
         }          }
   
Line 152  bdb_db_cache( Line 153  bdb_db_cache(
   
         *dbout = db->bdi_db;          *dbout = db->bdi_db;
   
         ldap_pvt_thread_mutex_unlock( &bdb->bi_database_mutex );          LOCK_PUT( bdb->bi_dbenv, &lock );
         return 0;          return 0;
 }  }

Removed from v.1.28.2.6  
changed lines
  Added in v.1.29


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