1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-28 17:47:29 +03:00

merged changes from v3-2-test

(This used to be commit 7077df3e2e3f171532f6a5ac87d45201736c9c11)
This commit is contained in:
Andrew Tridgell 2008-01-18 15:45:22 +11:00
parent 524d280ad0
commit 61a015a786
8 changed files with 18 additions and 53 deletions

View File

@ -179,9 +179,7 @@ struct tdb_context *tdb_open_ex(const char *name, int hash_size, int tdb_flags,
tdb->page_size = 0x2000; tdb->page_size = 0x2000;
} }
if (open_flags & TDB_VOLATILE) { tdb->max_dead_records = (tdb_flags & TDB_VOLATILE) ? 5 : 0;
tdb->max_dead_records = 5;
}
if ((open_flags & O_ACCMODE) == O_WRONLY) { if ((open_flags & O_ACCMODE) == O_WRONLY) {
TDB_LOG((tdb, TDB_DEBUG_ERROR, "tdb_open_ex: can't open tdb %s write-only\n", TDB_LOG((tdb, TDB_DEBUG_ERROR, "tdb_open_ex: can't open tdb %s write-only\n",
@ -229,6 +227,7 @@ struct tdb_context *tdb_open_ex(const char *name, int hash_size, int tdb_flags,
/* we need to zero database if we are the only one with it open */ /* we need to zero database if we are the only one with it open */
if ((tdb_flags & TDB_CLEAR_IF_FIRST) && if ((tdb_flags & TDB_CLEAR_IF_FIRST) &&
(!tdb->read_only) &&
(locked = (tdb->methods->tdb_brlock(tdb, ACTIVE_LOCK, F_WRLCK, F_SETLK, 0, 1) == 0))) { (locked = (tdb->methods->tdb_brlock(tdb, ACTIVE_LOCK, F_WRLCK, F_SETLK, 0, 1) == 0))) {
open_flags |= O_CREAT; open_flags |= O_CREAT;
if (ftruncate(tdb->fd, 0) == -1) { if (ftruncate(tdb->fd, 0) == -1) {
@ -288,7 +287,6 @@ struct tdb_context *tdb_open_ex(const char *name, int hash_size, int tdb_flags,
tdb->map_size = st.st_size; tdb->map_size = st.st_size;
tdb->device = st.st_dev; tdb->device = st.st_dev;
tdb->inode = st.st_ino; tdb->inode = st.st_ino;
tdb->max_dead_records = 0;
tdb_mmap(tdb); tdb_mmap(tdb);
if (locked) { if (locked) {
if (tdb->methods->tdb_brlock(tdb, ACTIVE_LOCK, F_UNLCK, F_SETLK, 0, 1) == -1) { if (tdb->methods->tdb_brlock(tdb, ACTIVE_LOCK, F_UNLCK, F_SETLK, 0, 1) == -1) {

View File

@ -743,45 +743,3 @@ failed:
tdb_unlockall(tdb); tdb_unlockall(tdb);
return -1; return -1;
} }
/*
validate the integrity of all tdb hash chains. Useful when debugging
*/
int tdb_validate(struct tdb_context *tdb)
{
int h;
for (h=-1;h<(int)tdb->header.hash_size;h++) {
tdb_off_t rec_ptr;
uint32_t count = 0;
if (tdb_ofs_read(tdb, TDB_HASH_TOP(h), &rec_ptr) == -1) {
TDB_LOG((tdb, TDB_DEBUG_FATAL, "tdb_validate: failed ofs_read at top of hash %d\n", h));
return -1;
}
while (rec_ptr) {
struct list_struct r;
tdb_off_t size;
if (tdb_rec_read(tdb, rec_ptr, &r) == -1) {
TDB_LOG((tdb, TDB_DEBUG_FATAL, "tdb_validate: failed rec_read h=%d rec_ptr=%u count=%u\n",
h, rec_ptr, count));
return -1;
}
if (tdb_ofs_read(tdb, rec_ptr + sizeof(r) + r.rec_len - sizeof(tdb_off_t), &size) == -1) {
TDB_LOG((tdb, TDB_DEBUG_FATAL, "tdb_validate: failed ofs_read h=%d rec_ptr=%u count=%u\n",
h, rec_ptr, count));
return -1;
}
if (size != r.rec_len + sizeof(r)) {
TDB_LOG((tdb, TDB_DEBUG_FATAL, "tdb_validate: failed size check size=%u h=%d rec_ptr=%u count=%u\n",
size, h, rec_ptr, count));
return -1;
}
rec_ptr = r.next;
count++;
}
}
return 0;
}

View File

@ -177,6 +177,7 @@ struct tdb_context {
int tdb_munmap(struct tdb_context *tdb); int tdb_munmap(struct tdb_context *tdb);
void tdb_mmap(struct tdb_context *tdb); void tdb_mmap(struct tdb_context *tdb);
int tdb_lock(struct tdb_context *tdb, int list, int ltype); int tdb_lock(struct tdb_context *tdb, int list, int ltype);
int tdb_lock_nonblock(struct tdb_context *tdb, int list, int ltype);
int tdb_unlock(struct tdb_context *tdb, int list, int ltype); int tdb_unlock(struct tdb_context *tdb, int list, int ltype);
int tdb_brlock(struct tdb_context *tdb, tdb_off_t offset, int rw_type, int lck_type, int probe, size_t len); int tdb_brlock(struct tdb_context *tdb, tdb_off_t offset, int rw_type, int lck_type, int probe, size_t len);
int tdb_transaction_lock(struct tdb_context *tdb, int ltype); int tdb_transaction_lock(struct tdb_context *tdb, int ltype);

View File

@ -219,9 +219,12 @@ static int transaction_write(struct tdb_context *tdb, tdb_off_t off,
uint8_t **new_blocks; uint8_t **new_blocks;
/* expand the blocks array */ /* expand the blocks array */
if (tdb->transaction->blocks == NULL) { if (tdb->transaction->blocks == NULL) {
new_blocks = malloc((blk+1)*sizeof(uint8_t *)); new_blocks = (uint8_t **)malloc(
(blk+1)*sizeof(uint8_t *));
} else { } else {
new_blocks = realloc(tdb->transaction->blocks, (blk+1)*sizeof(uint8_t *)); new_blocks = (uint8_t **)realloc(
tdb->transaction->blocks,
(blk+1)*sizeof(uint8_t *));
} }
if (new_blocks == NULL) { if (new_blocks == NULL) {
tdb->ecode = TDB_ERR_OOM; tdb->ecode = TDB_ERR_OOM;

View File

@ -223,6 +223,9 @@ int tdb_traverse_read(struct tdb_context *tdb,
/* /*
a write style traverse - needs to get the transaction lock to a write style traverse - needs to get the transaction lock to
prevent deadlocks prevent deadlocks
WARNING: The data buffer given to the callback fn does NOT meet the
alignment restrictions malloc gives you.
*/ */
int tdb_traverse(struct tdb_context *tdb, int tdb_traverse(struct tdb_context *tdb,
tdb_traverse_func fn, void *private_data) tdb_traverse_func fn, void *private_data)

View File

@ -130,6 +130,9 @@ int tdb_traverse(TDB_CONTEXT *tdb, int (*fn)(TDB_CONTEXT *tdb,
a non-zero return value from fn() indicates that the traversal a non-zero return value from fn() indicates that the traversal
should stop. Traversal callbacks may not start transactions. should stop. Traversal callbacks may not start transactions.
WARNING: The data buffer given to the callback fn does NOT meet the
alignment restrictions malloc gives you.
---------------------------------------------------------------------- ----------------------------------------------------------------------
int tdb_traverse_read(TDB_CONTEXT *tdb, int (*fn)(TDB_CONTEXT *tdb, int tdb_traverse_read(TDB_CONTEXT *tdb, int (*fn)(TDB_CONTEXT *tdb,
TDB_DATA key, TDB_DATA dbuf, void *state), void *state); TDB_DATA key, TDB_DATA dbuf, void *state), void *state);

View File

@ -32,9 +32,9 @@ extern "C" {
/* flags to tdb_store() */ /* flags to tdb_store() */
#define TDB_REPLACE 1 #define TDB_REPLACE 1 /* Unused */
#define TDB_INSERT 2 #define TDB_INSERT 2 /* Don't overwrite an existing entry */
#define TDB_MODIFY 3 #define TDB_MODIFY 3 /* Don't create an existing entry */
/* flags for tdb_open() */ /* flags for tdb_open() */
#define TDB_DEFAULT 0 /* just a readability place holder */ #define TDB_DEFAULT 0 /* just a readability place holder */
@ -157,7 +157,6 @@ int tdb_printfreelist(struct tdb_context *tdb);
int tdb_validate_freelist(struct tdb_context *tdb, int *pnum_entries); int tdb_validate_freelist(struct tdb_context *tdb, int *pnum_entries);
int tdb_wipe_all(struct tdb_context *tdb); int tdb_wipe_all(struct tdb_context *tdb);
int tdb_freelist_size(struct tdb_context *tdb); int tdb_freelist_size(struct tdb_context *tdb);
int tdb_validate(struct tdb_context *tdb);
extern TDB_DATA tdb_null; extern TDB_DATA tdb_null;

View File

@ -135,7 +135,7 @@ static void print_data(const char *buf,int len)
if (len<=0) return; if (len<=0) return;
printf("[%03X] ",i); printf("[%03X] ",i);
for (i=0;i<len;) { for (i=0;i<len;) {
printf("%02X ",(int)buf[i]); printf("%02X ",(int)((unsigned char)buf[i]));
i++; i++;
if (i%8 == 0) printf(" "); if (i%8 == 0) printf(" ");
if (i%16 == 0) { if (i%16 == 0) {