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_db_cache BDB_SYMBOL(db_cache)
51 #define bdb_dn2entry BDB_SYMBOL(dn2entry)
53 int bdb_dn2entry LDAP_P(( Operation *op, DB_TXN *tid,
54 struct berval *dn, EntryInfo **e, int matched,
55 u_int32_t locker, DB_LOCK *lock ));
60 #define bdb_dn2id BDB_SYMBOL(dn2id)
61 #define bdb_dn2id_add BDB_SYMBOL(dn2id_add)
62 #define bdb_dn2id_delete BDB_SYMBOL(dn2id_delete)
63 #define bdb_dn2id_children BDB_SYMBOL(dn2id_children)
64 #define bdb_dn2idl BDB_SYMBOL(dn2idl)
84 int bdb_dn2id_children(
96 #define bdb_dn2id_parent BDB_SYMBOL(dn2id_parent)
97 #define bdb_dup_compare BDB_SYMBOL(dup_compare)
98 #define bdb_fix_dn BDB_SYMBOL(fix_dn)
100 int bdb_dn2id_parent(
111 int bdb_fix_dn( Entry *e, int checkit );
118 #define bdb_errcall BDB_SYMBOL(errcall)
120 void bdb_errcall( const char *pfx, char * msg );
123 #define ebcdic_dberror BDB_SYMBOL(ebcdic_dberror)
125 char *ebcdic_dberror( int rc );
126 #define db_strerror(x) ebcdic_dberror(x)
132 #define bdb_filter_candidates BDB_SYMBOL(filter_candidates)
134 int bdb_filter_candidates(
144 #define bdb_id2entry BDB_SYMBOL(id2entry)
145 #define bdb_id2entry_add BDB_SYMBOL(id2entry_add)
146 #define bdb_id2entry_update BDB_SYMBOL(id2entry_update)
147 #define bdb_id2entry_delete BDB_SYMBOL(id2entry_delete)
149 int bdb_id2entry_add(
154 int bdb_id2entry_update(
159 int bdb_id2entry_delete(
170 #define bdb_entry_free BDB_SYMBOL(entry_free)
171 #define bdb_entry_return BDB_SYMBOL(entry_return)
172 #define bdb_entry_release BDB_SYMBOL(entry_release)
173 #define bdb_entry_get BDB_SYMBOL(entry_get)
175 void bdb_entry_free ( Entry *e );
176 int bdb_entry_return( Entry *e );
177 BI_entry_release_rw bdb_entry_release;
178 BI_entry_get_rw bdb_entry_get;
184 #ifdef SLAP_IDL_CACHE
186 #define bdb_idl_cache_get BDB_SYMBOL(idl_cache_get)
187 #define bdb_idl_cache_put BDB_SYMBOL(idl_cache_put)
188 #define bdb_idl_cache_del BDB_SYMBOL(idl_cache_del)
190 int bdb_idl_cache_get(
191 struct bdb_info *bdb,
198 struct bdb_info *bdb,
206 struct bdb_info *bdb,
211 #define bdb_idl_first BDB_SYMBOL(idl_first)
212 #define bdb_idl_next BDB_SYMBOL(idl_next)
213 #define bdb_idl_search BDB_SYMBOL(idl_search)
214 #define bdb_idl_insert BDB_SYMBOL(idl_insert)
215 #define bdb_idl_intersection BDB_SYMBOL(idl_intersection)
216 #define bdb_idl_union BDB_SYMBOL(idl_union)
218 #define bdb_idl_fetch_key BDB_SYMBOL(idl_fetch_key)
219 #define bdb_idl_insert_key BDB_SYMBOL(idl_insert_key)
220 #define bdb_idl_delete_key BDB_SYMBOL(idl_delete_key)
222 unsigned bdb_idl_search( ID *ids, ID id );
224 int bdb_idl_fetch_key(
231 int bdb_idl_insert( ID *ids, ID id );
233 int bdb_idl_insert_key(
240 int bdb_idl_delete_key(
248 bdb_idl_intersection(
257 ID bdb_idl_first( ID *ids, ID *cursor );
258 ID bdb_idl_next( ID *ids, ID *cursor );
261 #define bdb_bt_compare BDB_SYMBOL(bt_compare)
272 #define bdb_index_is_indexed BDB_SYMBOL(index_is_indexed)
273 #define bdb_index_param BDB_SYMBOL(index_param)
274 #define bdb_index_values BDB_SYMBOL(index_values)
275 #define bdb_index_entry BDB_SYMBOL(index_entry)
278 bdb_index_is_indexed LDAP_P((
280 AttributeDescription *desc ));
283 bdb_index_param LDAP_P((
285 AttributeDescription *desc,
289 struct berval *prefix ));
292 bdb_index_values LDAP_P((
295 AttributeDescription *desc,
301 int bdb_index_entry LDAP_P(( Operation *op, DB_TXN *t, int r, Entry *e ));
303 #define bdb_index_entry_add(be,t,e) \
304 bdb_index_entry((be),(t),SLAP_INDEX_ADD_OP,(e))
305 #define bdb_index_entry_del(be,t,e) \
306 bdb_index_entry((be),(t),SLAP_INDEX_DELETE_OP,(e))
311 #define bdb_uuid BDB_SYMBOL(uuid)
313 extern struct berval bdb_uuid;
318 #define bdb_key_read BDB_SYMBOL(key_read)
319 #define bdb_key_change BDB_SYMBOL(key_change)
341 #define bdb_next_id BDB_SYMBOL(next_id)
342 #define bdb_last_id BDB_SYMBOL(last_id)
344 int bdb_next_id( BackendDB *be, DB_TXN *tid, ID *id );
345 int bdb_last_id( BackendDB *be, DB_TXN *tid );
350 #define bdb_modify_internal BDB_SYMBOL(modify_internal)
352 int bdb_modify_internal(
355 Modifications *modlist,
364 #define bdb_exop_passwd BDB_SYMBOL(exop_passwd)
366 BI_op_extended bdb_exop_passwd;
372 #define bdb_cache_entry_db_unlock BDB_SYMBOL(cache_entry_db_unlock)
374 #define bdb_cache_entryinfo_lock(e) \
375 ldap_pvt_thread_mutex_lock( &(e)->bei_kids_mutex )
376 #define bdb_cache_entryinfo_unlock(e) \
377 ldap_pvt_thread_mutex_unlock( &(e)->bei_kids_mutex )
379 /* What a mess. Hopefully the current cache scheme will stabilize
380 * and we can trim out all of this stuff.
383 void bdb_cache_return_entry_rw( DB_ENV *env, Cache *cache, Entry *e,
384 int rw, DB_LOCK *lock );
386 #define bdb_cache_return_entry_rw( env, cache, e, rw, lock ) \
387 bdb_cache_entry_db_unlock( env, lock )
388 #define bdb_cache_return_entry( env, lock ) \
389 bdb_cache_entry_db_unlock( env, lock )
391 #define bdb_cache_return_entry_r(env, c, e, l) \
392 bdb_cache_return_entry_rw((env), (c), (e), 0, (l))
393 #define bdb_cache_return_entry_w(env, c, e, l) \
394 bdb_cache_return_entry_rw((env), (c), (e), 1, (l))
396 void bdb_unlocked_cache_return_entry_rw( Cache *cache, Entry *e, int rw );
398 #define bdb_unlocked_cache_return_entry_rw( a, b, c )
400 #define bdb_unlocked_cache_return_entry_r( c, e ) \
401 bdb_unlocked_cache_return_entry_rw((c), (e), 0)
402 #define bdb_unlocked_cache_return_entry_w( c, e ) \
403 bdb_unlocked_cache_return_entry_rw((c), (e), 1)
405 #define bdb_cache_add BDB_SYMBOL(cache_add)
406 #define bdb_cache_children BDB_SYMBOL(cache_children)
407 #define bdb_cache_delete BDB_SYMBOL(cache_delete)
408 #define bdb_cache_delete_cleanup BDB_SYMBOL(cache_delete_cleanup)
409 #define bdb_cache_find_id BDB_SYMBOL(cache_find_id)
410 #define bdb_cache_find_ndn BDB_SYMBOL(cache_find_ndn)
411 #define bdb_cache_modify BDB_SYMBOL(cache_modify)
412 #define bdb_cache_modrdn BDB_SYMBOL(cache_modrdn)
413 #define bdb_cache_release_all BDB_SYMBOL(cache_release_all)
415 int bdb_cache_children(
421 struct bdb_info *bdb,
427 int bdb_cache_modrdn(
436 int bdb_cache_modify(
443 int bdb_cache_find_ndn(
450 int bdb_cache_find_id(
459 int bdb_cache_delete(
466 void bdb_cache_delete_cleanup(
469 void bdb_cache_release_all( Cache *cache );
472 #define bdb_cache_entry_db_relock BDB_SYMBOL(cache_entry_db_relock)
473 int bdb_cache_entry_db_relock(
482 #ifdef BDB_REUSE_LOCKERS
484 #define bdb_locker_id BDB_SYMBOL(locker_id)
485 int bdb_locker_id( Operation *op, DB_ENV *env, int *locker );
487 #define LOCK_ID_FREE(env, locker)
488 #define LOCK_ID(env, locker) bdb_locker_id(op, env, locker)
492 #define LOCK_ID_FREE(env, locker) XLOCK_ID_FREE(env, locker)
493 #define LOCK_ID(env, locker) XLOCK_ID(env, locker)
503 #define bdb_abandon BDB_SYMBOL(abandon)
504 #define bdb_cancel BDB_SYMBOL(cancel)
505 #define bdb_do_search BDB_SYMBOL(do_search)
507 BI_op_abandon bdb_abandon;
508 BI_op_cancel bdb_cancel;
517 #define bdb_psearch(op, rs, sop, e, ps_type) bdb_do_search(op, rs, sop, e, ps_type)
522 #define bdb_build_sync_state_ctrl BDB_SYMBOL(build_sync_state_ctrl)
523 #define bdb_build_sync_done_ctrl BDB_SYMBOL(build_sync_done_ctrl)
524 #define bdb_send_ldap_intermediate BDB_SYMBOL(send_ldap_intermediate)
527 bdb_build_sync_state_ctrl(
531 int entry_sync_state,
535 struct berval *csn );
538 bdb_build_sync_done_ctrl(
544 struct berval *latest_entrycsn_bv );
547 bdb_send_ldap_intermediate(
551 struct berval *cookie );
559 bdb_trans_backoff( int num_retries );
563 #endif /* _PROTO_BDB_H */