]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/back-ldbm/close.c
ITS#4310 seems to affect also back-ldbm
[openldap] / servers / slapd / back-ldbm / close.c
index 7a2a83e12119d8a3a71125c2d2db77aee3d92d7a..9ed651de3fcdcbf8d33bb2f14a5c3edc22771930 100644 (file)
@@ -1,8 +1,17 @@
 /* close.c - close ldbm backend */
 /* $OpenLDAP$ */
-/*
- * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved.
- * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
+/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
+ *
+ * Copyright 1998-2006 The OpenLDAP Foundation.
+ * 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"
 int
 ldbm_back_db_close( Backend *be )
 {
-       struct ldbminfo *li = (struct ldbminfo *) be->be_private;
-       if ( li->li_dbsyncfreq > 0 )
-       {
-               li->li_dbshutdown++;
-               ldap_pvt_thread_join( li->li_dbsynctid, (void *) NULL );
-       }
-#ifdef NEW_LOGGING
-       LDAP_LOG(( "backend", LDAP_LEVEL_CRIT,
-                  "ldbm_back_db_close: ldbm backend syncing\n" ));
-#else
+       struct ldbminfo *li = be->be_private;
+
        Debug( LDAP_DEBUG_TRACE, "ldbm backend syncing\n", 0, 0, 0 );
-#endif
 
        ldbm_cache_flush_all( be );
-#ifdef NEW_LOGGING
-       LDAP_LOG(( "backend", LDAP_LEVEL_CRIT,
-                  "ldbm_back_db_close: ldbm backend synch'ed\n" ));
-#else
        Debug( LDAP_DEBUG_TRACE, "ldbm backend done syncing\n", 0, 0, 0 );
-#endif
 
-
-       cache_release_all( &((struct ldbminfo *) be->be_private)->li_cache );
+       cache_release_all( &li->li_cache );
+       if ( alock_close( &li->li_alock_info )) {
+               Debug( LDAP_DEBUG_ANY,
+                       "ldbm_back_db_close: alock_close failed\n", 0, 0, 0 );
+       }
 
        return 0;
 }