From 48c57a4c92af3b0f0e68e1fb8195196f72a7cd6c Mon Sep 17 00:00:00 2001 From: Michael Adam Date: Sat, 21 Nov 2009 00:14:29 +0100 Subject: [PATCH] s3:fix endianness bug in dbwrap_change_int32_atomic() (bug #6901) Michael (cherry picked from commit 2abdeca7af052372b242981ff1ab7863a8951cfd) --- source3/lib/dbwrap_util.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/source3/lib/dbwrap_util.c b/source3/lib/dbwrap_util.c index 96888a4fb0b..74b22655e2b 100644 --- a/source3/lib/dbwrap_util.c +++ b/source3/lib/dbwrap_util.c @@ -204,7 +204,7 @@ static NTSTATUS dbwrap_change_int32_atomic_action(struct db_context *db, { struct db_record *rec; int32_t val = -1; - TDB_DATA data; + int32_t v_store; NTSTATUS ret; struct dbwrap_change_int32_atomic_context *state; @@ -227,10 +227,12 @@ static NTSTATUS dbwrap_change_int32_atomic_action(struct db_context *db, val += state->change_val; - data.dsize = sizeof(val); - data.dptr = (uint8 *)&val; + SIVAL(&v_store, 0, val); - ret = rec->store(rec, data, TDB_REPLACE); + ret = rec->store(rec, + make_tdb_data((const uint8_t *)&v_store, + sizeof(v_store)), + TDB_REPLACE); done: TALLOC_FREE(rec); -- 2.11.4.GIT