X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;ds=sidebyside;f=ccan%2Ftdb%2Ftdb_private.h;h=b6eae478736696541d0767f5a90a529ba5b1d459;hb=c5316eef05ab024c44224a165282e8df8ad30285;hp=4993ff811041e8d4fcdaf375a246a705eb9a0069;hpb=6d35d746f123291ba93a592997dcd5b6fe7828cf;p=ccan diff --git a/ccan/tdb/tdb_private.h b/ccan/tdb/tdb_private.h index 4993ff81..b6eae478 100644 --- a/ccan/tdb/tdb_private.h +++ b/ccan/tdb/tdb_private.h @@ -49,7 +49,7 @@ #endif #include "tdb.h" -/* #define TDB_TRACE 1 */ +#define TDB_TRACE 1 #if HAVE_GETPAGESIZE #define getpagesize() 0x2000 @@ -89,15 +89,34 @@ typedef uint32_t tdb_off_t; #define TDB_LOG(x) tdb->log.log_fn x #ifdef TDB_TRACE -void tdb_trace(const struct tdb_context *tdb, const char *fmt, ...); -void tdb_trace_record(const struct tdb_context *tdb, TDB_DATA rec); +void tdb_trace(struct tdb_context *tdb, const char *op); +void tdb_trace_seqnum(struct tdb_context *tdb, uint32_t seqnum, const char *op); +void tdb_trace_open(struct tdb_context *tdb, const char *op, + unsigned hash_size, unsigned tdb_flags, unsigned open_flags); +void tdb_trace_ret(struct tdb_context *tdb, const char *op, int ret); +void tdb_trace_retrec(struct tdb_context *tdb, const char *op, TDB_DATA ret); +void tdb_trace_1rec(struct tdb_context *tdb, const char *op, + TDB_DATA rec); +void tdb_trace_1rec_ret(struct tdb_context *tdb, const char *op, + TDB_DATA rec, int ret); +void tdb_trace_1rec_retrec(struct tdb_context *tdb, const char *op, + TDB_DATA rec, TDB_DATA ret); +void tdb_trace_2rec_flag_ret(struct tdb_context *tdb, const char *op, + TDB_DATA rec1, TDB_DATA rec2, unsigned flag, + int ret); +void tdb_trace_2rec_retrec(struct tdb_context *tdb, const char *op, + TDB_DATA rec1, TDB_DATA rec2, TDB_DATA ret); #else -static inline void tdb_trace(const struct tdb_context *tdb, const char *fmt, ...) -{ -} -static inline void tdb_trace_record(const struct tdb_context *tdb, TDB_DATA rec) -{ -} +#define tdb_trace(tdb, op) +#define tdb_trace_seqnum(tdb, seqnum, op) +#define tdb_trace_open(tdb, op, hash_size, tdb_flags, open_flags) +#define tdb_trace_ret(tdb, op, ret) +#define tdb_trace_retrec(tdb, op, ret) +#define tdb_trace_1rec(tdb, op, rec) +#define tdb_trace_1rec_ret(tdb, op, rec, ret) +#define tdb_trace_1rec_retrec(tdb, op, rec, ret) +#define tdb_trace_2rec_flag_ret(tdb, op, rec1, rec2, flag, ret) +#define tdb_trace_2rec_retrec(tdb, op, rec1, rec2, ret) #endif /* !TDB_TRACE */ /* lock offsets */ @@ -198,8 +217,11 @@ struct tdb_context { struct tdb_transaction *transaction; int page_size; int max_dead_records; - bool have_transaction_lock; + int transaction_lock_count; +#ifdef TDB_TRACE int tracefd; + uint32_t transaction_prepare_seqnum; +#endif volatile sig_atomic_t *interrupt_sig_ptr; };