2 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
4 * Copyright 2000-2004 The OpenLDAP Foundation.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted only as authorized by the OpenLDAP
11 * A copy of this license is available in the file LICENSE in the
12 * top-level directory of the distribution or, alternatively, at
13 * <http://www.OpenLDAP.org/license.html>.
22 #define BDB_SYMBOL(x) LDAP_CONCAT(hdb_,x)
24 #define BDB_SYMBOL(x) LDAP_CONCAT(bdb_,x)
31 #define bdb_attr_mask BDB_SYMBOL(attr_mask)
32 #define bdb_attr_index_config BDB_SYMBOL(attr_index_config)
33 #define bdb_attr_index_destroy BDB_SYMBOL(attr_index_destroy)
35 void bdb_attr_mask( struct bdb_info *bdb,
36 AttributeDescription *desc,
37 slap_mask_t *indexmask );
39 int bdb_attr_index_config LDAP_P(( struct bdb_info *bdb,
40 const char *fname, int lineno,
41 int argc, char **argv ));
43 void bdb_attr_index_destroy LDAP_P(( Avlnode *tree ));
48 #define bdb_csn_commit BDB_SYMBOL(csn_commit)
49 #define bdb_get_commit_csn BDB_SYMBOL(get_commit_csn)
51 int bdb_csn_commit LDAP_P(( Operation *op, SlapReply *rs, DB_TXN *tid,
52 EntryInfo *ei, EntryInfo **suffix_ei, Entry **ctxcsn_e,
53 int *ctxcsn_added, u_int32_t locker ));
55 int bdb_get_commit_csn LDAP_P(( Operation *op, SlapReply *rs,
56 struct berval **search_context_csn,
57 u_int32_t locker, DB_LOCK *ctxcsn_lock ));
62 #define bdb_db_cache BDB_SYMBOL(db_cache)
73 #define bdb_dn2entry BDB_SYMBOL(dn2entry)
75 int bdb_dn2entry LDAP_P(( Operation *op, DB_TXN *tid,
76 struct berval *dn, EntryInfo **e, int matched,
77 u_int32_t locker, DB_LOCK *lock ));
82 #define bdb_dn2id BDB_SYMBOL(dn2id)
83 #define bdb_dn2id_add BDB_SYMBOL(dn2id_add)
84 #define bdb_dn2id_delete BDB_SYMBOL(dn2id_delete)
85 #define bdb_dn2id_children BDB_SYMBOL(dn2id_children)
86 #define bdb_dn2idl BDB_SYMBOL(dn2idl)
100 int bdb_dn2id_delete(
106 int bdb_dn2id_children(
118 #define bdb_dn2id_parent BDB_SYMBOL(dn2id_parent)
119 #define bdb_dup_compare BDB_SYMBOL(dup_compare)
120 #define bdb_fix_dn BDB_SYMBOL(fix_dn)
122 int bdb_dn2id_parent(
133 int bdb_fix_dn( Entry *e, int checkit );
140 #define bdb_errcall BDB_SYMBOL(errcall)
142 void bdb_errcall( const char *pfx, char * msg );
145 #define ebcdic_dberror BDB_SYMBOL(ebcdic_dberror)
147 char *ebcdic_dberror( int rc );
148 #define db_strerror(x) ebcdic_dberror(x)
154 #define bdb_filter_candidates BDB_SYMBOL(filter_candidates)
156 int bdb_filter_candidates(
166 #define bdb_id2entry BDB_SYMBOL(id2entry)
167 #define bdb_id2entry_add BDB_SYMBOL(id2entry_add)
168 #define bdb_id2entry_update BDB_SYMBOL(id2entry_update)
169 #define bdb_id2entry_delete BDB_SYMBOL(id2entry_delete)
171 int bdb_id2entry_add(
176 int bdb_id2entry_update(
181 int bdb_id2entry_delete(
192 #define bdb_entry_free BDB_SYMBOL(entry_free)
193 #define bdb_entry_return BDB_SYMBOL(entry_return)
194 #define bdb_entry_release BDB_SYMBOL(entry_release)
195 #define bdb_entry_get BDB_SYMBOL(entry_get)
197 void bdb_entry_free ( Entry *e );
198 int bdb_entry_return( Entry *e );
199 BI_entry_release_rw bdb_entry_release;
200 BI_entry_get_rw bdb_entry_get;
206 #ifdef SLAP_IDL_CACHE
208 #define bdb_idl_cache_get BDB_SYMBOL(idl_cache_get)
209 #define bdb_idl_cache_put BDB_SYMBOL(idl_cache_put)
210 #define bdb_idl_cache_del BDB_SYMBOL(idl_cache_del)
212 int bdb_idl_cache_get(
213 struct bdb_info *bdb,
220 struct bdb_info *bdb,
228 struct bdb_info *bdb,
233 #define bdb_idl_first BDB_SYMBOL(idl_first)
234 #define bdb_idl_next BDB_SYMBOL(idl_next)
235 #define bdb_idl_search BDB_SYMBOL(idl_search)
236 #define bdb_idl_insert BDB_SYMBOL(idl_insert)
237 #define bdb_idl_intersection BDB_SYMBOL(idl_intersection)
238 #define bdb_idl_union BDB_SYMBOL(idl_union)
240 #define bdb_idl_fetch_key BDB_SYMBOL(idl_fetch_key)
241 #define bdb_idl_insert_key BDB_SYMBOL(idl_insert_key)
242 #define bdb_idl_delete_key BDB_SYMBOL(idl_delete_key)
244 unsigned bdb_idl_search( ID *ids, ID id );
246 int bdb_idl_fetch_key(
253 int bdb_idl_insert( ID *ids, ID id );
255 int bdb_idl_insert_key(
262 int bdb_idl_delete_key(
270 bdb_idl_intersection(
279 ID bdb_idl_first( ID *ids, ID *cursor );
280 ID bdb_idl_next( ID *ids, ID *cursor );
283 #define bdb_bt_compare BDB_SYMBOL(bt_compare)
294 #define bdb_index_is_indexed BDB_SYMBOL(index_is_indexed)
295 #define bdb_index_param BDB_SYMBOL(index_param)
296 #define bdb_index_values BDB_SYMBOL(index_values)
297 #define bdb_index_entry BDB_SYMBOL(index_entry)
300 bdb_index_is_indexed LDAP_P((
302 AttributeDescription *desc ));
305 bdb_index_param LDAP_P((
307 AttributeDescription *desc,
311 struct berval *prefix ));
314 bdb_index_values LDAP_P((
317 AttributeDescription *desc,
322 int bdb_index_entry LDAP_P(( Operation *op, DB_TXN *t, int r, Entry *e ));
324 #define bdb_index_entry_add(op,t,e) \
325 bdb_index_entry((op),(t),SLAP_INDEX_ADD_OP,(e))
326 #define bdb_index_entry_del(op,t,e) \
327 bdb_index_entry((op),(t),SLAP_INDEX_DELETE_OP,(e))
332 #define bdb_uuid BDB_SYMBOL(uuid)
334 extern struct berval bdb_uuid;
339 #define bdb_key_read BDB_SYMBOL(key_read)
340 #define bdb_key_change BDB_SYMBOL(key_change)
362 #define bdb_next_id BDB_SYMBOL(next_id)
363 #define bdb_last_id BDB_SYMBOL(last_id)
365 int bdb_next_id( BackendDB *be, DB_TXN *tid, ID *id );
366 int bdb_last_id( BackendDB *be, DB_TXN *tid );
371 #define bdb_modify_internal BDB_SYMBOL(modify_internal)
373 int bdb_modify_internal(
376 Modifications *modlist,
386 #define bdb_cache_entry_db_unlock BDB_SYMBOL(cache_entry_db_unlock)
388 #define bdb_cache_entryinfo_lock(e) \
389 ldap_pvt_thread_mutex_lock( &(e)->bei_kids_mutex )
390 #define bdb_cache_entryinfo_unlock(e) \
391 ldap_pvt_thread_mutex_unlock( &(e)->bei_kids_mutex )
393 /* What a mess. Hopefully the current cache scheme will stabilize
394 * and we can trim out all of this stuff.
397 void bdb_cache_return_entry_rw( DB_ENV *env, Cache *cache, Entry *e,
398 int rw, DB_LOCK *lock );
400 #define bdb_cache_return_entry_rw( env, cache, e, rw, lock ) \
401 bdb_cache_entry_db_unlock( env, lock )
402 #define bdb_cache_return_entry( env, lock ) \
403 bdb_cache_entry_db_unlock( env, lock )
405 #define bdb_cache_return_entry_r(env, c, e, l) \
406 bdb_cache_return_entry_rw((env), (c), (e), 0, (l))
407 #define bdb_cache_return_entry_w(env, c, e, l) \
408 bdb_cache_return_entry_rw((env), (c), (e), 1, (l))
410 void bdb_unlocked_cache_return_entry_rw( Cache *cache, Entry *e, int rw );
412 #define bdb_unlocked_cache_return_entry_rw( a, b, c )
414 #define bdb_unlocked_cache_return_entry_r( c, e ) \
415 bdb_unlocked_cache_return_entry_rw((c), (e), 0)
416 #define bdb_unlocked_cache_return_entry_w( c, e ) \
417 bdb_unlocked_cache_return_entry_rw((c), (e), 1)
419 #define bdb_cache_add BDB_SYMBOL(cache_add)
420 #define bdb_cache_children BDB_SYMBOL(cache_children)
421 #define bdb_cache_delete BDB_SYMBOL(cache_delete)
422 #define bdb_cache_delete_cleanup BDB_SYMBOL(cache_delete_cleanup)
423 #define bdb_cache_find_id BDB_SYMBOL(cache_find_id)
424 #define bdb_cache_find_info BDB_SYMBOL(cache_find_info)
425 #define bdb_cache_find_ndn BDB_SYMBOL(cache_find_ndn)
426 #define bdb_cache_modify BDB_SYMBOL(cache_modify)
427 #define bdb_cache_modrdn BDB_SYMBOL(cache_modrdn)
428 #define bdb_cache_release_all BDB_SYMBOL(cache_release_all)
429 #define bdb_cache_delete_entry BDB_SYMBOL(cache_delete_entry)
431 int bdb_cache_children(
437 struct bdb_info *bdb,
443 int bdb_cache_modrdn(
452 int bdb_cache_modify(
459 int bdb_cache_find_ndn(
465 EntryInfo * bdb_cache_find_info(
466 struct bdb_info *bdb,
469 int bdb_cache_find_id(
478 int bdb_cache_delete(
485 void bdb_cache_delete_cleanup(
489 void bdb_cache_release_all( Cache *cache );
490 void bdb_cache_delete_entry(
491 struct bdb_info *bdb,
499 struct bdb_info *bdb,
505 #define bdb_cache_entry_db_relock BDB_SYMBOL(cache_entry_db_relock)
506 int bdb_cache_entry_db_relock(
514 int bdb_cache_entry_db_unlock(
518 #ifdef BDB_REUSE_LOCKERS
520 #define bdb_locker_id BDB_SYMBOL(locker_id)
521 int bdb_locker_id( Operation *op, DB_ENV *env, int *locker );
523 #define LOCK_ID_FREE(env, locker)
524 #define LOCK_ID(env, locker) bdb_locker_id(op, env, locker)
528 #define LOCK_ID_FREE(env, locker) XLOCK_ID_FREE(env, locker)
529 #define LOCK_ID(env, locker) XLOCK_ID(env, locker)
537 #define bdb_abandon BDB_SYMBOL(abandon)
538 #define bdb_cancel BDB_SYMBOL(cancel)
539 #define bdb_do_search BDB_SYMBOL(do_search)
541 BI_op_abandon bdb_abandon;
542 BI_op_cancel bdb_cancel;
551 #define bdb_psearch(op, rs, sop, e, ps_type) bdb_do_search(op, rs, sop, e, ps_type)
556 #define bdb_trans_backoff BDB_SYMBOL(trans_backoff)
559 bdb_trans_backoff( int num_retries );
563 #endif /* _PROTO_BDB_H */