From: Martin Schwenke Date: Mon, 24 Jun 2019 20:35:04 +0000 (+1000) Subject: ctdb-daemon: Don't check if lock_ctx->ctdb_db is NULL X-Git-Tag: samba-4.11.0rc1~35 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=755a9e654feaa7265975a1f02ea2f59fd30d09a9;p=thirdparty%2Fsamba.git ctdb-daemon: Don't check if lock_ctx->ctdb_db is NULL This can never be NULL. It could probably be NULL in the past when "all database" locks existed. There are paths where is is checked for NULL and then later dereferenced, causing static analysers to produce spurious warnings. Signed-off-by: Martin Schwenke Reviewed-by: Amitay Isaacs --- diff --git a/ctdb/server/ctdb_lock.c b/ctdb/server/ctdb_lock.c index d42d47af85f..5f032ae568b 100644 --- a/ctdb/server/ctdb_lock.c +++ b/ctdb/server/ctdb_lock.c @@ -198,13 +198,9 @@ static int ctdb_lock_context_destructor(struct lock_context *lock_ctx) } else { DLIST_REMOVE(lock_ctx->ctdb->lock_current, lock_ctx); } - if (lock_ctx->ctdb_db) { - lock_ctx->ctdb_db->lock_num_current--; - } + lock_ctx->ctdb_db->lock_num_current--; CTDB_DECREMENT_STAT(lock_ctx->ctdb, locks.num_current); - if (lock_ctx->ctdb_db) { - CTDB_DECREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_current); - } + CTDB_DECREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_current); } else { if (lock_ctx->type == LOCK_RECORD) { DLIST_REMOVE(lock_ctx->ctdb_db->lock_pending, lock_ctx); @@ -212,9 +208,7 @@ static int ctdb_lock_context_destructor(struct lock_context *lock_ctx) DLIST_REMOVE(lock_ctx->ctdb->lock_pending, lock_ctx); } CTDB_DECREMENT_STAT(lock_ctx->ctdb, locks.num_pending); - if (lock_ctx->ctdb_db) { - CTDB_DECREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_pending); - } + CTDB_DECREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_pending); } ctdb_lock_schedule(lock_ctx->ctdb); @@ -357,25 +351,19 @@ static void ctdb_lock_handler(struct tevent_context *ev, /* Update statistics */ CTDB_INCREMENT_STAT(lock_ctx->ctdb, locks.num_calls); - if (lock_ctx->ctdb_db) { - CTDB_INCREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_calls); - } + CTDB_INCREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_calls); if (locked) { - if (lock_ctx->ctdb_db) { - CTDB_INCREMENT_STAT(lock_ctx->ctdb, locks.buckets[id]); - CTDB_UPDATE_LATENCY(lock_ctx->ctdb, lock_ctx->ctdb_db, - lock_type_str[lock_ctx->type], locks.latency, - lock_ctx->start_time); - - CTDB_UPDATE_DB_LATENCY(lock_ctx->ctdb_db, lock_type_str[lock_ctx->type], locks.latency, t); - CTDB_INCREMENT_DB_STAT(lock_ctx->ctdb_db, locks.buckets[id]); - } + CTDB_INCREMENT_STAT(lock_ctx->ctdb, locks.buckets[id]); + CTDB_UPDATE_LATENCY(lock_ctx->ctdb, lock_ctx->ctdb_db, + lock_type_str[lock_ctx->type], locks.latency, + lock_ctx->start_time); + + CTDB_UPDATE_DB_LATENCY(lock_ctx->ctdb_db, lock_type_str[lock_ctx->type], locks.latency, t); + CTDB_INCREMENT_DB_STAT(lock_ctx->ctdb_db, locks.buckets[id]); } else { CTDB_INCREMENT_STAT(lock_ctx->ctdb, locks.num_failed); - if (lock_ctx->ctdb_db) { - CTDB_INCREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_failed); - } + CTDB_INCREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_failed); } process_callbacks(lock_ctx, locked); @@ -674,10 +662,7 @@ static struct lock_context *ctdb_find_lock_context(struct ctdb_context *ctdb) "request\n")); DLIST_REMOVE(ctdb->lock_pending, lock_ctx); CTDB_DECREMENT_STAT(ctdb, locks.num_pending); - if (lock_ctx->ctdb_db) { - CTDB_DECREMENT_DB_STAT(lock_ctx->ctdb_db, - locks.num_pending); - } + CTDB_DECREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_pending); talloc_free(lock_ctx); } @@ -825,11 +810,9 @@ static void ctdb_lock_schedule(struct ctdb_context *ctdb) } CTDB_DECREMENT_STAT(lock_ctx->ctdb, locks.num_pending); CTDB_INCREMENT_STAT(lock_ctx->ctdb, locks.num_current); - if (lock_ctx->ctdb_db) { - lock_ctx->ctdb_db->lock_num_current++; - CTDB_DECREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_pending); - CTDB_INCREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_current); - } + lock_ctx->ctdb_db->lock_num_current++; + CTDB_DECREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_pending); + CTDB_INCREMENT_DB_STAT(lock_ctx->ctdb_db, locks.num_current); }