3 * Copyright 2000-2003 The OpenLDAP Foundation, All Rights Reserved.
4 * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
13 #define BDB_SYMBOL(x) LDAP_CONCAT(hdb_,x)
15 #define BDB_SYMBOL(x) LDAP_CONCAT(bdb_,x)
22 #define bdb_attr_mask BDB_SYMBOL(attr_mask)
23 #define bdb_attr_index_config BDB_SYMBOL(attr_index_config)
24 #define bdb_attr_index_destroy BDB_SYMBOL(attr_index_destroy)
26 void bdb_attr_mask( struct bdb_info *bdb,
27 AttributeDescription *desc,
28 slap_mask_t *indexmask );
30 int bdb_attr_index_config LDAP_P(( struct bdb_info *bdb,
31 const char *fname, int lineno,
32 int argc, char **argv ));
34 void bdb_attr_index_destroy LDAP_P(( Avlnode *tree ));
39 #define bdb_csn_commit BDB_SYMBOL(csn_commit)
41 int bdb_csn_commit LDAP_P(( Operation *op, SlapReply *rs, DB_TXN *tid,
42 EntryInfo *ei, EntryInfo **suffix_ei, Entry **ctxcsn_e,
43 int *ctxcsn_added, u_int32_t locker ));
48 #define bdb_db_cache BDB_SYMBOL(db_cache)
60 #define bdb_dn2entry BDB_SYMBOL(dn2entry)
62 int bdb_dn2entry LDAP_P(( Operation *op, DB_TXN *tid,
63 struct berval *dn, EntryInfo **e, int matched,
64 u_int32_t locker, DB_LOCK *lock ));
69 #define bdb_dn2id BDB_SYMBOL(dn2id)
70 #define bdb_dn2id_add BDB_SYMBOL(dn2id_add)
71 #define bdb_dn2id_delete BDB_SYMBOL(dn2id_delete)
72 #define bdb_dn2id_children BDB_SYMBOL(dn2id_children)
73 #define bdb_dn2idl BDB_SYMBOL(dn2idl)
93 int bdb_dn2id_children(
105 #define bdb_dn2id_parent BDB_SYMBOL(dn2id_parent)
106 #define bdb_dup_compare BDB_SYMBOL(dup_compare)
107 #define bdb_fix_dn BDB_SYMBOL(fix_dn)
109 int bdb_dn2id_parent(
120 int bdb_fix_dn( Entry *e, int checkit );
127 #define bdb_errcall BDB_SYMBOL(errcall)
129 void bdb_errcall( const char *pfx, char * msg );
132 #define ebcdic_dberror BDB_SYMBOL(ebcdic_dberror)
134 char *ebcdic_dberror( int rc );
135 #define db_strerror(x) ebcdic_dberror(x)
141 #define bdb_filter_candidates BDB_SYMBOL(filter_candidates)
143 int bdb_filter_candidates(
153 #define bdb_id2entry BDB_SYMBOL(id2entry)
154 #define bdb_id2entry_add BDB_SYMBOL(id2entry_add)
155 #define bdb_id2entry_update BDB_SYMBOL(id2entry_update)
156 #define bdb_id2entry_delete BDB_SYMBOL(id2entry_delete)
158 int bdb_id2entry_add(
163 int bdb_id2entry_update(
168 int bdb_id2entry_delete(
179 #define bdb_entry_free BDB_SYMBOL(entry_free)
180 #define bdb_entry_return BDB_SYMBOL(entry_return)
181 #define bdb_entry_release BDB_SYMBOL(entry_release)
182 #define bdb_entry_get BDB_SYMBOL(entry_get)
184 void bdb_entry_free ( Entry *e );
185 int bdb_entry_return( Entry *e );
186 BI_entry_release_rw bdb_entry_release;
187 BI_entry_get_rw bdb_entry_get;
193 #ifdef SLAP_IDL_CACHE
195 #define bdb_idl_cache_get BDB_SYMBOL(idl_cache_get)
196 #define bdb_idl_cache_put BDB_SYMBOL(idl_cache_put)
197 #define bdb_idl_cache_del BDB_SYMBOL(idl_cache_del)
199 int bdb_idl_cache_get(
200 struct bdb_info *bdb,
207 struct bdb_info *bdb,
215 struct bdb_info *bdb,
220 #define bdb_idl_first BDB_SYMBOL(idl_first)
221 #define bdb_idl_next BDB_SYMBOL(idl_next)
222 #define bdb_idl_search BDB_SYMBOL(idl_search)
223 #define bdb_idl_insert BDB_SYMBOL(idl_insert)
224 #define bdb_idl_intersection BDB_SYMBOL(idl_intersection)
225 #define bdb_idl_union BDB_SYMBOL(idl_union)
227 #define bdb_idl_fetch_key BDB_SYMBOL(idl_fetch_key)
228 #define bdb_idl_insert_key BDB_SYMBOL(idl_insert_key)
229 #define bdb_idl_delete_key BDB_SYMBOL(idl_delete_key)
231 unsigned bdb_idl_search( ID *ids, ID id );
233 int bdb_idl_fetch_key(
240 int bdb_idl_insert( ID *ids, ID id );
242 int bdb_idl_insert_key(
249 int bdb_idl_delete_key(
257 bdb_idl_intersection(
266 ID bdb_idl_first( ID *ids, ID *cursor );
267 ID bdb_idl_next( ID *ids, ID *cursor );
270 #define bdb_bt_compare BDB_SYMBOL(bt_compare)
281 #define bdb_index_is_indexed BDB_SYMBOL(index_is_indexed)
282 #define bdb_index_param BDB_SYMBOL(index_param)
283 #define bdb_index_values BDB_SYMBOL(index_values)
284 #define bdb_index_entry BDB_SYMBOL(index_entry)
287 bdb_index_is_indexed LDAP_P((
289 AttributeDescription *desc ));
292 bdb_index_param LDAP_P((
294 AttributeDescription *desc,
298 struct berval *prefix ));
301 bdb_index_values LDAP_P((
304 AttributeDescription *desc,
310 int bdb_index_entry LDAP_P(( Operation *op, DB_TXN *t, int r, Entry *e ));
312 #define bdb_index_entry_add(op,t,e) \
313 bdb_index_entry((op),(t),SLAP_INDEX_ADD_OP,(e))
314 #define bdb_index_entry_del(op,t,e) \
315 bdb_index_entry((op),(t),SLAP_INDEX_DELETE_OP,(e))
320 #define bdb_uuid BDB_SYMBOL(uuid)
322 extern struct berval bdb_uuid;
327 #define bdb_key_read BDB_SYMBOL(key_read)
328 #define bdb_key_change BDB_SYMBOL(key_change)
350 #define bdb_next_id BDB_SYMBOL(next_id)
351 #define bdb_last_id BDB_SYMBOL(last_id)
353 int bdb_next_id( BackendDB *be, DB_TXN *tid, ID *id );
354 int bdb_last_id( BackendDB *be, DB_TXN *tid );
359 #define bdb_modify_internal BDB_SYMBOL(modify_internal)
361 int bdb_modify_internal(
364 Modifications *modlist,
373 #define bdb_exop_passwd BDB_SYMBOL(exop_passwd)
375 BI_op_extended bdb_exop_passwd;
381 #define bdb_cache_entry_db_unlock BDB_SYMBOL(cache_entry_db_unlock)
383 #define bdb_cache_entryinfo_lock(e) \
384 ldap_pvt_thread_mutex_lock( &(e)->bei_kids_mutex )
385 #define bdb_cache_entryinfo_unlock(e) \
386 ldap_pvt_thread_mutex_unlock( &(e)->bei_kids_mutex )
388 /* What a mess. Hopefully the current cache scheme will stabilize
389 * and we can trim out all of this stuff.
392 void bdb_cache_return_entry_rw( DB_ENV *env, Cache *cache, Entry *e,
393 int rw, DB_LOCK *lock );
395 #define bdb_cache_return_entry_rw( env, cache, e, rw, lock ) \
396 bdb_cache_entry_db_unlock( env, lock )
397 #define bdb_cache_return_entry( env, lock ) \
398 bdb_cache_entry_db_unlock( env, lock )
400 #define bdb_cache_return_entry_r(env, c, e, l) \
401 bdb_cache_return_entry_rw((env), (c), (e), 0, (l))
402 #define bdb_cache_return_entry_w(env, c, e, l) \
403 bdb_cache_return_entry_rw((env), (c), (e), 1, (l))
405 void bdb_unlocked_cache_return_entry_rw( Cache *cache, Entry *e, int rw );
407 #define bdb_unlocked_cache_return_entry_rw( a, b, c )
409 #define bdb_unlocked_cache_return_entry_r( c, e ) \
410 bdb_unlocked_cache_return_entry_rw((c), (e), 0)
411 #define bdb_unlocked_cache_return_entry_w( c, e ) \
412 bdb_unlocked_cache_return_entry_rw((c), (e), 1)
414 #define bdb_cache_add BDB_SYMBOL(cache_add)
415 #define bdb_cache_children BDB_SYMBOL(cache_children)
416 #define bdb_cache_delete BDB_SYMBOL(cache_delete)
417 #define bdb_cache_delete_cleanup BDB_SYMBOL(cache_delete_cleanup)
418 #define bdb_cache_find_id BDB_SYMBOL(cache_find_id)
419 #define bdb_cache_find_ndn BDB_SYMBOL(cache_find_ndn)
420 #define bdb_cache_modify BDB_SYMBOL(cache_modify)
421 #define bdb_cache_modrdn BDB_SYMBOL(cache_modrdn)
422 #define bdb_cache_release_all BDB_SYMBOL(cache_release_all)
424 int bdb_cache_children(
430 struct bdb_info *bdb,
436 int bdb_cache_modrdn(
445 int bdb_cache_modify(
452 int bdb_cache_find_ndn(
459 int bdb_cache_find_id(
468 int bdb_cache_delete(
475 void bdb_cache_delete_cleanup(
478 void bdb_cache_release_all( Cache *cache );
480 #define bdb_cache_entry_db_relock BDB_SYMBOL(cache_entry_db_relock)
481 int bdb_cache_entry_db_relock(
489 #ifdef BDB_REUSE_LOCKERS
491 #define bdb_locker_id BDB_SYMBOL(locker_id)
492 int bdb_locker_id( Operation *op, DB_ENV *env, int *locker );
494 #define LOCK_ID_FREE(env, locker)
495 #define LOCK_ID(env, locker) bdb_locker_id(op, env, locker)
499 #define LOCK_ID_FREE(env, locker) XLOCK_ID_FREE(env, locker)
500 #define LOCK_ID(env, locker) XLOCK_ID(env, locker)
508 #define bdb_abandon BDB_SYMBOL(abandon)
509 #define bdb_cancel BDB_SYMBOL(cancel)
510 #define bdb_do_search BDB_SYMBOL(do_search)
512 BI_op_abandon bdb_abandon;
513 BI_op_cancel bdb_cancel;
522 #define bdb_psearch(op, rs, sop, e, ps_type) bdb_do_search(op, rs, sop, e, ps_type)
524 #define bdb_build_sync_state_ctrl BDB_SYMBOL(build_sync_state_ctrl)
525 #define bdb_build_sync_done_ctrl BDB_SYMBOL(build_sync_done_ctrl)
526 #define bdb_send_ldap_intermediate BDB_SYMBOL(send_ldap_intermediate)
529 bdb_build_sync_state_ctrl(
533 int entry_sync_state,
537 struct berval *csn );
540 bdb_build_sync_done_ctrl(
546 struct berval *latest_entrycsn_bv );
549 bdb_send_ldap_intermediate(
553 struct berval *cookie );
558 #define bdb_trans_backoff BDB_SYMBOL(trans_backoff)
561 bdb_trans_backoff( int num_retries );
565 #endif /* _PROTO_BDB_H */