Commit 6a79248b authored by Mike Snitzer's avatar Mike Snitzer

dm vdo permassert: audit all of ASSERT to test for VDO_SUCCESS

Also rename ASSERT to VDO_ASSERT and ASSERT_LOG_ONLY to
VDO_ASSERT_LOG_ONLY.

But re-introduce ASSERT and ASSERT_LOG_ONLY as a placeholder
for the benefit of dm-vdo/indexer.
Signed-off-by: default avatarMike Snitzer <snitzer@kernel.org>
Signed-off-by: default avatarMatthew Sakai <msakai@redhat.com>
parent a958c53a
...@@ -177,7 +177,7 @@ static void apply_to_zone(struct vdo_completion *completion) ...@@ -177,7 +177,7 @@ static void apply_to_zone(struct vdo_completion *completion)
zone_count_t zone; zone_count_t zone;
struct action_manager *manager = as_action_manager(completion); struct action_manager *manager = as_action_manager(completion);
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == get_acting_zone_thread_id(manager)), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == get_acting_zone_thread_id(manager)),
"%s() called on acting zones's thread", __func__); "%s() called on acting zones's thread", __func__);
zone = manager->acting_zone++; zone = manager->acting_zone++;
...@@ -357,7 +357,7 @@ bool vdo_schedule_operation_with_context(struct action_manager *manager, ...@@ -357,7 +357,7 @@ bool vdo_schedule_operation_with_context(struct action_manager *manager,
{ {
struct action *current_action; struct action *current_action;
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == manager->initiator_thread_id), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == manager->initiator_thread_id),
"action initiated from correct thread"); "action initiated from correct thread");
if (!manager->current_action->in_use) { if (!manager->current_action->in_use) {
current_action = manager->current_action; current_action = manager->current_action;
......
...@@ -246,7 +246,7 @@ static inline void assert_on_cache_thread(struct vdo_page_cache *cache, ...@@ -246,7 +246,7 @@ static inline void assert_on_cache_thread(struct vdo_page_cache *cache,
{ {
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((thread_id == cache->zone->thread_id), VDO_ASSERT_LOG_ONLY((thread_id == cache->zone->thread_id),
"%s() must only be called on cache thread %d, not thread %d", "%s() must only be called on cache thread %d, not thread %d",
function_name, cache->zone->thread_id, thread_id); function_name, cache->zone->thread_id, thread_id);
} }
...@@ -254,7 +254,7 @@ static inline void assert_on_cache_thread(struct vdo_page_cache *cache, ...@@ -254,7 +254,7 @@ static inline void assert_on_cache_thread(struct vdo_page_cache *cache,
/** assert_io_allowed() - Assert that a page cache may issue I/O. */ /** assert_io_allowed() - Assert that a page cache may issue I/O. */
static inline void assert_io_allowed(struct vdo_page_cache *cache) static inline void assert_io_allowed(struct vdo_page_cache *cache)
{ {
ASSERT_LOG_ONLY(!vdo_is_state_quiescent(&cache->zone->state), VDO_ASSERT_LOG_ONLY(!vdo_is_state_quiescent(&cache->zone->state),
"VDO page cache may issue I/O"); "VDO page cache may issue I/O");
} }
...@@ -287,9 +287,9 @@ static const char * __must_check get_page_state_name(enum vdo_page_buffer_state ...@@ -287,9 +287,9 @@ static const char * __must_check get_page_state_name(enum vdo_page_buffer_state
BUILD_BUG_ON(ARRAY_SIZE(state_names) != PAGE_STATE_COUNT); BUILD_BUG_ON(ARRAY_SIZE(state_names) != PAGE_STATE_COUNT);
result = ASSERT(state < ARRAY_SIZE(state_names), result = VDO_ASSERT(state < ARRAY_SIZE(state_names),
"Unknown page_state value %d", state); "Unknown page_state value %d", state);
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return "[UNKNOWN PAGE STATE]"; return "[UNKNOWN PAGE STATE]";
return state_names[state]; return state_names[state];
...@@ -378,7 +378,7 @@ static int __must_check set_info_pbn(struct page_info *info, physical_block_numb ...@@ -378,7 +378,7 @@ static int __must_check set_info_pbn(struct page_info *info, physical_block_numb
struct vdo_page_cache *cache = info->cache; struct vdo_page_cache *cache = info->cache;
/* Either the new or the old page number must be NO_PAGE. */ /* Either the new or the old page number must be NO_PAGE. */
int result = ASSERT((pbn == NO_PAGE) || (info->pbn == NO_PAGE), int result = VDO_ASSERT((pbn == NO_PAGE) || (info->pbn == NO_PAGE),
"Must free a page before reusing it."); "Must free a page before reusing it.");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -401,13 +401,13 @@ static int reset_page_info(struct page_info *info) ...@@ -401,13 +401,13 @@ static int reset_page_info(struct page_info *info)
{ {
int result; int result;
result = ASSERT(info->busy == 0, "VDO Page must not be busy"); result = VDO_ASSERT(info->busy == 0, "VDO Page must not be busy");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(!vdo_waitq_has_waiters(&info->waiting), result = VDO_ASSERT(!vdo_waitq_has_waiters(&info->waiting),
"VDO Page must not have waiters"); "VDO Page must not have waiters");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = set_info_pbn(info, NO_PAGE); result = set_info_pbn(info, NO_PAGE);
...@@ -592,29 +592,29 @@ static int __must_check validate_completed_page(struct vdo_page_completion *comp ...@@ -592,29 +592,29 @@ static int __must_check validate_completed_page(struct vdo_page_completion *comp
{ {
int result; int result;
result = ASSERT(completion->ready, "VDO Page completion not ready"); result = VDO_ASSERT(completion->ready, "VDO Page completion not ready");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(completion->info != NULL, result = VDO_ASSERT(completion->info != NULL,
"VDO Page Completion must be complete"); "VDO Page Completion must be complete");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(completion->info->pbn == completion->pbn, result = VDO_ASSERT(completion->info->pbn == completion->pbn,
"VDO Page Completion pbn must be consistent"); "VDO Page Completion pbn must be consistent");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(is_valid(completion->info), result = VDO_ASSERT(is_valid(completion->info),
"VDO Page Completion page must be valid"); "VDO Page Completion page must be valid");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
if (writable) { if (writable) {
result = ASSERT(completion->writable, result = VDO_ASSERT(completion->writable,
"VDO Page Completion must be writable"); "VDO Page Completion must be writable");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
} }
...@@ -776,7 +776,7 @@ static int __must_check launch_page_load(struct page_info *info, ...@@ -776,7 +776,7 @@ static int __must_check launch_page_load(struct page_info *info,
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT((info->busy == 0), "Page is not busy before loading."); result = VDO_ASSERT((info->busy == 0), "Page is not busy before loading.");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -949,7 +949,7 @@ static void discard_a_page(struct vdo_page_cache *cache) ...@@ -949,7 +949,7 @@ static void discard_a_page(struct vdo_page_cache *cache)
return; return;
} }
ASSERT_LOG_ONLY(!is_in_flight(info), VDO_ASSERT_LOG_ONLY(!is_in_flight(info),
"page selected for discard is not in flight"); "page selected for discard is not in flight");
cache->discard_count++; cache->discard_count++;
...@@ -1153,7 +1153,7 @@ void vdo_release_page_completion(struct vdo_completion *completion) ...@@ -1153,7 +1153,7 @@ void vdo_release_page_completion(struct vdo_completion *completion)
discard_info = page_completion->info; discard_info = page_completion->info;
} }
ASSERT_LOG_ONLY((page_completion->waiter.next_waiter == NULL), VDO_ASSERT_LOG_ONLY((page_completion->waiter.next_waiter == NULL),
"Page being released after leaving all queues"); "Page being released after leaving all queues");
page_completion->info = NULL; page_completion->info = NULL;
...@@ -1217,7 +1217,7 @@ void vdo_get_page(struct vdo_page_completion *page_completion, ...@@ -1217,7 +1217,7 @@ void vdo_get_page(struct vdo_page_completion *page_completion,
struct page_info *info; struct page_info *info;
assert_on_cache_thread(cache, __func__); assert_on_cache_thread(cache, __func__);
ASSERT_LOG_ONLY((page_completion->waiter.next_waiter == NULL), VDO_ASSERT_LOG_ONLY((page_completion->waiter.next_waiter == NULL),
"New page completion was not already on a wait queue"); "New page completion was not already on a wait queue");
*page_completion = (struct vdo_page_completion) { *page_completion = (struct vdo_page_completion) {
...@@ -1265,7 +1265,7 @@ void vdo_get_page(struct vdo_page_completion *page_completion, ...@@ -1265,7 +1265,7 @@ void vdo_get_page(struct vdo_page_completion *page_completion,
} }
/* Something horrible has gone wrong. */ /* Something horrible has gone wrong. */
ASSERT_LOG_ONLY(false, "Info found in a usable state."); VDO_ASSERT_LOG_ONLY(false, "Info found in a usable state.");
} }
/* The page must be fetched. */ /* The page must be fetched. */
...@@ -1334,7 +1334,7 @@ int vdo_invalidate_page_cache(struct vdo_page_cache *cache) ...@@ -1334,7 +1334,7 @@ int vdo_invalidate_page_cache(struct vdo_page_cache *cache)
/* Make sure we don't throw away any dirty pages. */ /* Make sure we don't throw away any dirty pages. */
for (info = cache->infos; info < cache->infos + cache->page_count; info++) { for (info = cache->infos; info < cache->infos + cache->page_count; info++) {
int result = ASSERT(!is_dirty(info), "cache must have no dirty pages"); int result = VDO_ASSERT(!is_dirty(info), "cache must have no dirty pages");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -1440,7 +1440,7 @@ static bool __must_check is_not_older(struct block_map_zone *zone, u8 a, u8 b) ...@@ -1440,7 +1440,7 @@ static bool __must_check is_not_older(struct block_map_zone *zone, u8 a, u8 b)
{ {
int result; int result;
result = ASSERT((in_cyclic_range(zone->oldest_generation, a, zone->generation, 1 << 8) && result = VDO_ASSERT((in_cyclic_range(zone->oldest_generation, a, zone->generation, 1 << 8) &&
in_cyclic_range(zone->oldest_generation, b, zone->generation, 1 << 8)), in_cyclic_range(zone->oldest_generation, b, zone->generation, 1 << 8)),
"generation(s) %u, %u are out of range [%u, %u]", "generation(s) %u, %u are out of range [%u, %u]",
a, b, zone->oldest_generation, zone->generation); a, b, zone->oldest_generation, zone->generation);
...@@ -1456,7 +1456,7 @@ static void release_generation(struct block_map_zone *zone, u8 generation) ...@@ -1456,7 +1456,7 @@ static void release_generation(struct block_map_zone *zone, u8 generation)
{ {
int result; int result;
result = ASSERT((zone->dirty_page_counts[generation] > 0), result = VDO_ASSERT((zone->dirty_page_counts[generation] > 0),
"dirty page count underflow for generation %u", generation); "dirty page count underflow for generation %u", generation);
if (result != VDO_SUCCESS) { if (result != VDO_SUCCESS) {
enter_zone_read_only_mode(zone, result); enter_zone_read_only_mode(zone, result);
...@@ -1482,7 +1482,7 @@ static void set_generation(struct block_map_zone *zone, struct tree_page *page, ...@@ -1482,7 +1482,7 @@ static void set_generation(struct block_map_zone *zone, struct tree_page *page,
page->generation = new_generation; page->generation = new_generation;
new_count = ++zone->dirty_page_counts[new_generation]; new_count = ++zone->dirty_page_counts[new_generation];
result = ASSERT((new_count != 0), "dirty page count overflow for generation %u", result = VDO_ASSERT((new_count != 0), "dirty page count overflow for generation %u",
new_generation); new_generation);
if (result != VDO_SUCCESS) { if (result != VDO_SUCCESS) {
enter_zone_read_only_mode(zone, result); enter_zone_read_only_mode(zone, result);
...@@ -1698,13 +1698,13 @@ static void release_page_lock(struct data_vio *data_vio, char *what) ...@@ -1698,13 +1698,13 @@ static void release_page_lock(struct data_vio *data_vio, char *what)
struct tree_lock *lock_holder; struct tree_lock *lock_holder;
struct tree_lock *lock = &data_vio->tree_lock; struct tree_lock *lock = &data_vio->tree_lock;
ASSERT_LOG_ONLY(lock->locked, VDO_ASSERT_LOG_ONLY(lock->locked,
"release of unlocked block map page %s for key %llu in tree %u", "release of unlocked block map page %s for key %llu in tree %u",
what, (unsigned long long) lock->key, lock->root_index); what, (unsigned long long) lock->key, lock->root_index);
zone = data_vio->logical.zone->block_map_zone; zone = data_vio->logical.zone->block_map_zone;
lock_holder = vdo_int_map_remove(zone->loading_pages, lock->key); lock_holder = vdo_int_map_remove(zone->loading_pages, lock->key);
ASSERT_LOG_ONLY((lock_holder == lock), VDO_ASSERT_LOG_ONLY((lock_holder == lock),
"block map page %s mismatch for key %llu in tree %u", "block map page %s mismatch for key %llu in tree %u",
what, (unsigned long long) lock->key, lock->root_index); what, (unsigned long long) lock->key, lock->root_index);
lock->locked = false; lock->locked = false;
...@@ -2008,7 +2008,7 @@ static void write_expired_elements(struct block_map_zone *zone) ...@@ -2008,7 +2008,7 @@ static void write_expired_elements(struct block_map_zone *zone)
list_del_init(&page->entry); list_del_init(&page->entry);
result = ASSERT(!vdo_waiter_is_waiting(&page->waiter), result = VDO_ASSERT(!vdo_waiter_is_waiting(&page->waiter),
"Newly expired page not already waiting to write"); "Newly expired page not already waiting to write");
if (result != VDO_SUCCESS) { if (result != VDO_SUCCESS) {
enter_zone_read_only_mode(zone, result); enter_zone_read_only_mode(zone, result);
...@@ -2867,8 +2867,8 @@ int vdo_decode_block_map(struct block_map_state_2_0 state, block_count_t logical ...@@ -2867,8 +2867,8 @@ int vdo_decode_block_map(struct block_map_state_2_0 state, block_count_t logical
BUILD_BUG_ON(VDO_BLOCK_MAP_ENTRIES_PER_PAGE != BUILD_BUG_ON(VDO_BLOCK_MAP_ENTRIES_PER_PAGE !=
((VDO_BLOCK_SIZE - sizeof(struct block_map_page)) / ((VDO_BLOCK_SIZE - sizeof(struct block_map_page)) /
sizeof(struct block_map_entry))); sizeof(struct block_map_entry)));
result = ASSERT(cache_size > 0, "block map cache size is specified"); result = VDO_ASSERT(cache_size > 0, "block map cache size is specified");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = vdo_allocate_extended(struct block_map, result = vdo_allocate_extended(struct block_map,
...@@ -2937,7 +2937,7 @@ void vdo_initialize_block_map_from_journal(struct block_map *map, ...@@ -2937,7 +2937,7 @@ void vdo_initialize_block_map_from_journal(struct block_map *map,
for (z = 0; z < map->zone_count; z++) { for (z = 0; z < map->zone_count; z++) {
struct dirty_lists *dirty_lists = map->zones[z].dirty_lists; struct dirty_lists *dirty_lists = map->zones[z].dirty_lists;
ASSERT_LOG_ONLY(dirty_lists->next_period == 0, "current period not set"); VDO_ASSERT_LOG_ONLY(dirty_lists->next_period == 0, "current period not set");
dirty_lists->oldest_period = map->current_era_point; dirty_lists->oldest_period = map->current_era_point;
dirty_lists->next_period = map->current_era_point + 1; dirty_lists->next_period = map->current_era_point + 1;
dirty_lists->offset = map->current_era_point % dirty_lists->maximum_age; dirty_lists->offset = map->current_era_point % dirty_lists->maximum_age;
...@@ -2971,7 +2971,7 @@ static void initiate_drain(struct admin_state *state) ...@@ -2971,7 +2971,7 @@ static void initiate_drain(struct admin_state *state)
{ {
struct block_map_zone *zone = container_of(state, struct block_map_zone, state); struct block_map_zone *zone = container_of(state, struct block_map_zone, state);
ASSERT_LOG_ONLY((zone->active_lookups == 0), VDO_ASSERT_LOG_ONLY((zone->active_lookups == 0),
"%s() called with no active lookups", __func__); "%s() called with no active lookups", __func__);
if (!vdo_is_state_suspending(state)) { if (!vdo_is_state_suspending(state)) {
......
...@@ -60,7 +60,7 @@ void vdo_initialize_completion(struct vdo_completion *completion, ...@@ -60,7 +60,7 @@ void vdo_initialize_completion(struct vdo_completion *completion,
static inline void assert_incomplete(struct vdo_completion *completion) static inline void assert_incomplete(struct vdo_completion *completion)
{ {
ASSERT_LOG_ONLY(!completion->complete, "completion is not complete"); VDO_ASSERT_LOG_ONLY(!completion->complete, "completion is not complete");
} }
/** /**
...@@ -111,10 +111,10 @@ void vdo_enqueue_completion(struct vdo_completion *completion, ...@@ -111,10 +111,10 @@ void vdo_enqueue_completion(struct vdo_completion *completion,
struct vdo *vdo = completion->vdo; struct vdo *vdo = completion->vdo;
thread_id_t thread_id = completion->callback_thread_id; thread_id_t thread_id = completion->callback_thread_id;
if (ASSERT(thread_id < vdo->thread_config.thread_count, if (VDO_ASSERT(thread_id < vdo->thread_config.thread_count,
"thread_id %u (completion type %d) is less than thread count %u", "thread_id %u (completion type %d) is less than thread count %u",
thread_id, completion->type, thread_id, completion->type,
vdo->thread_config.thread_count) != UDS_SUCCESS) vdo->thread_config.thread_count) != VDO_SUCCESS)
BUG(); BUG();
completion->requeue = false; completion->requeue = false;
......
...@@ -85,7 +85,7 @@ static inline void vdo_fail_completion(struct vdo_completion *completion, int re ...@@ -85,7 +85,7 @@ static inline void vdo_fail_completion(struct vdo_completion *completion, int re
static inline int vdo_assert_completion_type(struct vdo_completion *completion, static inline int vdo_assert_completion_type(struct vdo_completion *completion,
enum vdo_completion_type expected) enum vdo_completion_type expected)
{ {
return ASSERT(expected == completion->type, return VDO_ASSERT(expected == completion->type,
"completion type should be %u, not %u", expected, "completion type should be %u, not %u", expected,
completion->type); completion->type);
} }
......
...@@ -232,7 +232,7 @@ static bool check_for_drain_complete_locked(struct data_vio_pool *pool) ...@@ -232,7 +232,7 @@ static bool check_for_drain_complete_locked(struct data_vio_pool *pool)
if (pool->limiter.busy > 0) if (pool->limiter.busy > 0)
return false; return false;
ASSERT_LOG_ONLY((pool->discard_limiter.busy == 0), VDO_ASSERT_LOG_ONLY((pool->discard_limiter.busy == 0),
"no outstanding discard permits"); "no outstanding discard permits");
return (bio_list_empty(&pool->limiter.new_waiters) && return (bio_list_empty(&pool->limiter.new_waiters) &&
...@@ -277,7 +277,7 @@ static void acknowledge_data_vio(struct data_vio *data_vio) ...@@ -277,7 +277,7 @@ static void acknowledge_data_vio(struct data_vio *data_vio)
if (bio == NULL) if (bio == NULL)
return; return;
ASSERT_LOG_ONLY((data_vio->remaining_discard <= VDO_ASSERT_LOG_ONLY((data_vio->remaining_discard <=
(u32) (VDO_BLOCK_SIZE - data_vio->offset)), (u32) (VDO_BLOCK_SIZE - data_vio->offset)),
"data_vio to acknowledge is not an incomplete discard"); "data_vio to acknowledge is not an incomplete discard");
...@@ -443,7 +443,7 @@ static void attempt_logical_block_lock(struct vdo_completion *completion) ...@@ -443,7 +443,7 @@ static void attempt_logical_block_lock(struct vdo_completion *completion)
return; return;
} }
result = ASSERT(lock_holder->logical.locked, "logical block lock held"); result = VDO_ASSERT(lock_holder->logical.locked, "logical block lock held");
if (result != VDO_SUCCESS) { if (result != VDO_SUCCESS) {
continue_data_vio_with_error(data_vio, result); continue_data_vio_with_error(data_vio, result);
return; return;
...@@ -627,7 +627,7 @@ static void update_limiter(struct limiter *limiter) ...@@ -627,7 +627,7 @@ static void update_limiter(struct limiter *limiter)
struct bio_list *waiters = &limiter->waiters; struct bio_list *waiters = &limiter->waiters;
data_vio_count_t available = limiter->limit - limiter->busy; data_vio_count_t available = limiter->limit - limiter->busy;
ASSERT_LOG_ONLY((limiter->release_count <= limiter->busy), VDO_ASSERT_LOG_ONLY((limiter->release_count <= limiter->busy),
"Release count %u is not more than busy count %u", "Release count %u is not more than busy count %u",
limiter->release_count, limiter->busy); limiter->release_count, limiter->busy);
...@@ -850,7 +850,7 @@ int make_data_vio_pool(struct vdo *vdo, data_vio_count_t pool_size, ...@@ -850,7 +850,7 @@ int make_data_vio_pool(struct vdo *vdo, data_vio_count_t pool_size,
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
ASSERT_LOG_ONLY((discard_limit <= pool_size), VDO_ASSERT_LOG_ONLY((discard_limit <= pool_size),
"discard limit does not exceed pool size"); "discard limit does not exceed pool size");
initialize_limiter(&pool->discard_limiter, pool, assign_discard_permit, initialize_limiter(&pool->discard_limiter, pool, assign_discard_permit,
discard_limit); discard_limit);
...@@ -908,13 +908,13 @@ void free_data_vio_pool(struct data_vio_pool *pool) ...@@ -908,13 +908,13 @@ void free_data_vio_pool(struct data_vio_pool *pool)
BUG_ON(atomic_read(&pool->processing)); BUG_ON(atomic_read(&pool->processing));
spin_lock(&pool->lock); spin_lock(&pool->lock);
ASSERT_LOG_ONLY((pool->limiter.busy == 0), VDO_ASSERT_LOG_ONLY((pool->limiter.busy == 0),
"data_vio pool must not have %u busy entries when being freed", "data_vio pool must not have %u busy entries when being freed",
pool->limiter.busy); pool->limiter.busy);
ASSERT_LOG_ONLY((bio_list_empty(&pool->limiter.waiters) && VDO_ASSERT_LOG_ONLY((bio_list_empty(&pool->limiter.waiters) &&
bio_list_empty(&pool->limiter.new_waiters)), bio_list_empty(&pool->limiter.new_waiters)),
"data_vio pool must not have threads waiting to read or write when being freed"); "data_vio pool must not have threads waiting to read or write when being freed");
ASSERT_LOG_ONLY((bio_list_empty(&pool->discard_limiter.waiters) && VDO_ASSERT_LOG_ONLY((bio_list_empty(&pool->discard_limiter.waiters) &&
bio_list_empty(&pool->discard_limiter.new_waiters)), bio_list_empty(&pool->discard_limiter.new_waiters)),
"data_vio pool must not have threads waiting to discard when being freed"); "data_vio pool must not have threads waiting to discard when being freed");
spin_unlock(&pool->lock); spin_unlock(&pool->lock);
...@@ -961,7 +961,7 @@ void vdo_launch_bio(struct data_vio_pool *pool, struct bio *bio) ...@@ -961,7 +961,7 @@ void vdo_launch_bio(struct data_vio_pool *pool, struct bio *bio)
{ {
struct data_vio *data_vio; struct data_vio *data_vio;
ASSERT_LOG_ONLY(!vdo_is_state_quiescent(&pool->state), VDO_ASSERT_LOG_ONLY(!vdo_is_state_quiescent(&pool->state),
"data_vio_pool not quiescent on acquire"); "data_vio_pool not quiescent on acquire");
bio->bi_private = (void *) jiffies; bio->bi_private = (void *) jiffies;
...@@ -998,7 +998,7 @@ static void initiate_drain(struct admin_state *state) ...@@ -998,7 +998,7 @@ static void initiate_drain(struct admin_state *state)
static void assert_on_vdo_cpu_thread(const struct vdo *vdo, const char *name) static void assert_on_vdo_cpu_thread(const struct vdo *vdo, const char *name)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == vdo->thread_config.cpu_thread), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == vdo->thread_config.cpu_thread),
"%s called on cpu thread", name); "%s called on cpu thread", name);
} }
...@@ -1173,7 +1173,7 @@ static void release_lock(struct data_vio *data_vio, struct lbn_lock *lock) ...@@ -1173,7 +1173,7 @@ static void release_lock(struct data_vio *data_vio, struct lbn_lock *lock)
/* The lock is not locked, so it had better not be registered in the lock map. */ /* The lock is not locked, so it had better not be registered in the lock map. */
struct data_vio *lock_holder = vdo_int_map_get(lock_map, lock->lbn); struct data_vio *lock_holder = vdo_int_map_get(lock_map, lock->lbn);
ASSERT_LOG_ONLY((data_vio != lock_holder), VDO_ASSERT_LOG_ONLY((data_vio != lock_holder),
"no logical block lock held for block %llu", "no logical block lock held for block %llu",
(unsigned long long) lock->lbn); (unsigned long long) lock->lbn);
return; return;
...@@ -1181,7 +1181,7 @@ static void release_lock(struct data_vio *data_vio, struct lbn_lock *lock) ...@@ -1181,7 +1181,7 @@ static void release_lock(struct data_vio *data_vio, struct lbn_lock *lock)
/* Release the lock by removing the lock from the map. */ /* Release the lock by removing the lock from the map. */
lock_holder = vdo_int_map_remove(lock_map, lock->lbn); lock_holder = vdo_int_map_remove(lock_map, lock->lbn);
ASSERT_LOG_ONLY((data_vio == lock_holder), VDO_ASSERT_LOG_ONLY((data_vio == lock_holder),
"logical block lock mismatch for block %llu", "logical block lock mismatch for block %llu",
(unsigned long long) lock->lbn); (unsigned long long) lock->lbn);
lock->locked = false; lock->locked = false;
...@@ -1193,7 +1193,7 @@ static void transfer_lock(struct data_vio *data_vio, struct lbn_lock *lock) ...@@ -1193,7 +1193,7 @@ static void transfer_lock(struct data_vio *data_vio, struct lbn_lock *lock)
struct data_vio *lock_holder, *next_lock_holder; struct data_vio *lock_holder, *next_lock_holder;
int result; int result;
ASSERT_LOG_ONLY(lock->locked, "lbn_lock with waiters is not locked"); VDO_ASSERT_LOG_ONLY(lock->locked, "lbn_lock with waiters is not locked");
/* Another data_vio is waiting for the lock, transfer it in a single lock map operation. */ /* Another data_vio is waiting for the lock, transfer it in a single lock map operation. */
next_lock_holder = next_lock_holder =
...@@ -1210,7 +1210,7 @@ static void transfer_lock(struct data_vio *data_vio, struct lbn_lock *lock) ...@@ -1210,7 +1210,7 @@ static void transfer_lock(struct data_vio *data_vio, struct lbn_lock *lock)
return; return;
} }
ASSERT_LOG_ONLY((lock_holder == data_vio), VDO_ASSERT_LOG_ONLY((lock_holder == data_vio),
"logical block lock mismatch for block %llu", "logical block lock mismatch for block %llu",
(unsigned long long) lock->lbn); (unsigned long long) lock->lbn);
lock->locked = false; lock->locked = false;
...@@ -1275,9 +1275,9 @@ static void finish_cleanup(struct data_vio *data_vio) ...@@ -1275,9 +1275,9 @@ static void finish_cleanup(struct data_vio *data_vio)
{ {
struct vdo_completion *completion = &data_vio->vio.completion; struct vdo_completion *completion = &data_vio->vio.completion;
ASSERT_LOG_ONLY(data_vio->allocation.lock == NULL, VDO_ASSERT_LOG_ONLY(data_vio->allocation.lock == NULL,
"complete data_vio has no allocation lock"); "complete data_vio has no allocation lock");
ASSERT_LOG_ONLY(data_vio->hash_lock == NULL, VDO_ASSERT_LOG_ONLY(data_vio->hash_lock == NULL,
"complete data_vio has no hash lock"); "complete data_vio has no hash lock");
if ((data_vio->remaining_discard <= VDO_BLOCK_SIZE) || if ((data_vio->remaining_discard <= VDO_BLOCK_SIZE) ||
(completion->result != VDO_SUCCESS)) { (completion->result != VDO_SUCCESS)) {
...@@ -1404,7 +1404,7 @@ void data_vio_allocate_data_block(struct data_vio *data_vio, ...@@ -1404,7 +1404,7 @@ void data_vio_allocate_data_block(struct data_vio *data_vio,
{ {
struct allocation *allocation = &data_vio->allocation; struct allocation *allocation = &data_vio->allocation;
ASSERT_LOG_ONLY((allocation->pbn == VDO_ZERO_BLOCK), VDO_ASSERT_LOG_ONLY((allocation->pbn == VDO_ZERO_BLOCK),
"data_vio does not have an allocation"); "data_vio does not have an allocation");
allocation->write_lock_type = write_lock_type; allocation->write_lock_type = write_lock_type;
allocation->zone = vdo_get_next_allocation_zone(data_vio->logical.zone); allocation->zone = vdo_get_next_allocation_zone(data_vio->logical.zone);
...@@ -1796,10 +1796,10 @@ static void compress_data_vio(struct vdo_completion *completion) ...@@ -1796,10 +1796,10 @@ static void compress_data_vio(struct vdo_completion *completion)
*/ */
void launch_compress_data_vio(struct data_vio *data_vio) void launch_compress_data_vio(struct data_vio *data_vio)
{ {
ASSERT_LOG_ONLY(!data_vio->is_duplicate, "compressing a non-duplicate block"); VDO_ASSERT_LOG_ONLY(!data_vio->is_duplicate, "compressing a non-duplicate block");
ASSERT_LOG_ONLY(data_vio->hash_lock != NULL, VDO_ASSERT_LOG_ONLY(data_vio->hash_lock != NULL,
"data_vio to compress has a hash_lock"); "data_vio to compress has a hash_lock");
ASSERT_LOG_ONLY(data_vio_has_allocation(data_vio), VDO_ASSERT_LOG_ONLY(data_vio_has_allocation(data_vio),
"data_vio to compress has an allocation"); "data_vio to compress has an allocation");
/* /*
...@@ -1841,7 +1841,7 @@ static void hash_data_vio(struct vdo_completion *completion) ...@@ -1841,7 +1841,7 @@ static void hash_data_vio(struct vdo_completion *completion)
struct data_vio *data_vio = as_data_vio(completion); struct data_vio *data_vio = as_data_vio(completion);
assert_data_vio_on_cpu_thread(data_vio); assert_data_vio_on_cpu_thread(data_vio);
ASSERT_LOG_ONLY(!data_vio->is_zero, "zero blocks should not be hashed"); VDO_ASSERT_LOG_ONLY(!data_vio->is_zero, "zero blocks should not be hashed");
murmurhash3_128(data_vio->vio.data, VDO_BLOCK_SIZE, 0x62ea60be, murmurhash3_128(data_vio->vio.data, VDO_BLOCK_SIZE, 0x62ea60be,
&data_vio->record_name); &data_vio->record_name);
...@@ -1856,7 +1856,7 @@ static void hash_data_vio(struct vdo_completion *completion) ...@@ -1856,7 +1856,7 @@ static void hash_data_vio(struct vdo_completion *completion)
static void prepare_for_dedupe(struct data_vio *data_vio) static void prepare_for_dedupe(struct data_vio *data_vio)
{ {
/* We don't care what thread we are on. */ /* We don't care what thread we are on. */
ASSERT_LOG_ONLY(!data_vio->is_zero, "must not prepare to dedupe zero blocks"); VDO_ASSERT_LOG_ONLY(!data_vio->is_zero, "must not prepare to dedupe zero blocks");
/* /*
* Before we can dedupe, we need to know the record name, so the first * Before we can dedupe, we need to know the record name, so the first
...@@ -1929,10 +1929,10 @@ static void acknowledge_write_callback(struct vdo_completion *completion) ...@@ -1929,10 +1929,10 @@ static void acknowledge_write_callback(struct vdo_completion *completion)
struct data_vio *data_vio = as_data_vio(completion); struct data_vio *data_vio = as_data_vio(completion);
struct vdo *vdo = completion->vdo; struct vdo *vdo = completion->vdo;
ASSERT_LOG_ONLY((!vdo_uses_bio_ack_queue(vdo) || VDO_ASSERT_LOG_ONLY((!vdo_uses_bio_ack_queue(vdo) ||
(vdo_get_callback_thread_id() == vdo->thread_config.bio_ack_thread)), (vdo_get_callback_thread_id() == vdo->thread_config.bio_ack_thread)),
"%s() called on bio ack queue", __func__); "%s() called on bio ack queue", __func__);
ASSERT_LOG_ONLY(data_vio_has_flush_generation_lock(data_vio), VDO_ASSERT_LOG_ONLY(data_vio_has_flush_generation_lock(data_vio),
"write VIO to be acknowledged has a flush generation lock"); "write VIO to be acknowledged has a flush generation lock");
acknowledge_data_vio(data_vio); acknowledge_data_vio(data_vio);
if (data_vio->new_mapped.pbn == VDO_ZERO_BLOCK) { if (data_vio->new_mapped.pbn == VDO_ZERO_BLOCK) {
...@@ -1998,7 +1998,7 @@ static void handle_allocation_error(struct vdo_completion *completion) ...@@ -1998,7 +1998,7 @@ static void handle_allocation_error(struct vdo_completion *completion)
static int assert_is_discard(struct data_vio *data_vio) static int assert_is_discard(struct data_vio *data_vio)
{ {
int result = ASSERT(data_vio->is_discard, int result = VDO_ASSERT(data_vio->is_discard,
"data_vio with no block map page is a discard"); "data_vio with no block map page is a discard");
return ((result == VDO_SUCCESS) ? result : VDO_READ_ONLY); return ((result == VDO_SUCCESS) ? result : VDO_READ_ONLY);
......
...@@ -280,7 +280,7 @@ struct data_vio { ...@@ -280,7 +280,7 @@ struct data_vio {
static inline struct data_vio *vio_as_data_vio(struct vio *vio) static inline struct data_vio *vio_as_data_vio(struct vio *vio)
{ {
ASSERT_LOG_ONLY((vio->type == VIO_TYPE_DATA), "vio is a data_vio"); VDO_ASSERT_LOG_ONLY((vio->type == VIO_TYPE_DATA), "vio is a data_vio");
return container_of(vio, struct data_vio, vio); return container_of(vio, struct data_vio, vio);
} }
...@@ -374,7 +374,7 @@ static inline void assert_data_vio_in_hash_zone(struct data_vio *data_vio) ...@@ -374,7 +374,7 @@ static inline void assert_data_vio_in_hash_zone(struct data_vio *data_vio)
* It's odd to use the LBN, but converting the record name to hex is a bit clunky for an * It's odd to use the LBN, but converting the record name to hex is a bit clunky for an
* inline, and the LBN better than nothing as an identifier. * inline, and the LBN better than nothing as an identifier.
*/ */
ASSERT_LOG_ONLY((expected == thread_id), VDO_ASSERT_LOG_ONLY((expected == thread_id),
"data_vio for logical block %llu on thread %u, should be on hash zone thread %u", "data_vio for logical block %llu on thread %u, should be on hash zone thread %u",
(unsigned long long) data_vio->logical.lbn, thread_id, expected); (unsigned long long) data_vio->logical.lbn, thread_id, expected);
} }
...@@ -402,7 +402,7 @@ static inline void assert_data_vio_in_logical_zone(struct data_vio *data_vio) ...@@ -402,7 +402,7 @@ static inline void assert_data_vio_in_logical_zone(struct data_vio *data_vio)
thread_id_t expected = data_vio->logical.zone->thread_id; thread_id_t expected = data_vio->logical.zone->thread_id;
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((expected == thread_id), VDO_ASSERT_LOG_ONLY((expected == thread_id),
"data_vio for logical block %llu on thread %u, should be on thread %u", "data_vio for logical block %llu on thread %u, should be on thread %u",
(unsigned long long) data_vio->logical.lbn, thread_id, expected); (unsigned long long) data_vio->logical.lbn, thread_id, expected);
} }
...@@ -430,7 +430,7 @@ static inline void assert_data_vio_in_allocated_zone(struct data_vio *data_vio) ...@@ -430,7 +430,7 @@ static inline void assert_data_vio_in_allocated_zone(struct data_vio *data_vio)
thread_id_t expected = data_vio->allocation.zone->thread_id; thread_id_t expected = data_vio->allocation.zone->thread_id;
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((expected == thread_id), VDO_ASSERT_LOG_ONLY((expected == thread_id),
"struct data_vio for allocated physical block %llu on thread %u, should be on thread %u", "struct data_vio for allocated physical block %llu on thread %u, should be on thread %u",
(unsigned long long) data_vio->allocation.pbn, thread_id, (unsigned long long) data_vio->allocation.pbn, thread_id,
expected); expected);
...@@ -460,7 +460,7 @@ static inline void assert_data_vio_in_duplicate_zone(struct data_vio *data_vio) ...@@ -460,7 +460,7 @@ static inline void assert_data_vio_in_duplicate_zone(struct data_vio *data_vio)
thread_id_t expected = data_vio->duplicate.zone->thread_id; thread_id_t expected = data_vio->duplicate.zone->thread_id;
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((expected == thread_id), VDO_ASSERT_LOG_ONLY((expected == thread_id),
"data_vio for duplicate physical block %llu on thread %u, should be on thread %u", "data_vio for duplicate physical block %llu on thread %u, should be on thread %u",
(unsigned long long) data_vio->duplicate.pbn, thread_id, (unsigned long long) data_vio->duplicate.pbn, thread_id,
expected); expected);
...@@ -490,7 +490,7 @@ static inline void assert_data_vio_in_mapped_zone(struct data_vio *data_vio) ...@@ -490,7 +490,7 @@ static inline void assert_data_vio_in_mapped_zone(struct data_vio *data_vio)
thread_id_t expected = data_vio->mapped.zone->thread_id; thread_id_t expected = data_vio->mapped.zone->thread_id;
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((expected == thread_id), VDO_ASSERT_LOG_ONLY((expected == thread_id),
"data_vio for mapped physical block %llu on thread %u, should be on thread %u", "data_vio for mapped physical block %llu on thread %u, should be on thread %u",
(unsigned long long) data_vio->mapped.pbn, thread_id, expected); (unsigned long long) data_vio->mapped.pbn, thread_id, expected);
} }
...@@ -507,7 +507,7 @@ static inline void assert_data_vio_in_new_mapped_zone(struct data_vio *data_vio) ...@@ -507,7 +507,7 @@ static inline void assert_data_vio_in_new_mapped_zone(struct data_vio *data_vio)
thread_id_t expected = data_vio->new_mapped.zone->thread_id; thread_id_t expected = data_vio->new_mapped.zone->thread_id;
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((expected == thread_id), VDO_ASSERT_LOG_ONLY((expected == thread_id),
"data_vio for new_mapped physical block %llu on thread %u, should be on thread %u", "data_vio for new_mapped physical block %llu on thread %u, should be on thread %u",
(unsigned long long) data_vio->new_mapped.pbn, thread_id, (unsigned long long) data_vio->new_mapped.pbn, thread_id,
expected); expected);
...@@ -525,7 +525,7 @@ static inline void assert_data_vio_in_journal_zone(struct data_vio *data_vio) ...@@ -525,7 +525,7 @@ static inline void assert_data_vio_in_journal_zone(struct data_vio *data_vio)
thread_id_t journal_thread = vdo_from_data_vio(data_vio)->thread_config.journal_thread; thread_id_t journal_thread = vdo_from_data_vio(data_vio)->thread_config.journal_thread;
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((journal_thread == thread_id), VDO_ASSERT_LOG_ONLY((journal_thread == thread_id),
"data_vio for logical block %llu on thread %u, should be on journal thread %u", "data_vio for logical block %llu on thread %u, should be on journal thread %u",
(unsigned long long) data_vio->logical.lbn, thread_id, (unsigned long long) data_vio->logical.lbn, thread_id,
journal_thread); journal_thread);
...@@ -555,7 +555,7 @@ static inline void assert_data_vio_in_packer_zone(struct data_vio *data_vio) ...@@ -555,7 +555,7 @@ static inline void assert_data_vio_in_packer_zone(struct data_vio *data_vio)
thread_id_t packer_thread = vdo_from_data_vio(data_vio)->thread_config.packer_thread; thread_id_t packer_thread = vdo_from_data_vio(data_vio)->thread_config.packer_thread;
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((packer_thread == thread_id), VDO_ASSERT_LOG_ONLY((packer_thread == thread_id),
"data_vio for logical block %llu on thread %u, should be on packer thread %u", "data_vio for logical block %llu on thread %u, should be on packer thread %u",
(unsigned long long) data_vio->logical.lbn, thread_id, (unsigned long long) data_vio->logical.lbn, thread_id,
packer_thread); packer_thread);
...@@ -585,7 +585,7 @@ static inline void assert_data_vio_on_cpu_thread(struct data_vio *data_vio) ...@@ -585,7 +585,7 @@ static inline void assert_data_vio_on_cpu_thread(struct data_vio *data_vio)
thread_id_t cpu_thread = vdo_from_data_vio(data_vio)->thread_config.cpu_thread; thread_id_t cpu_thread = vdo_from_data_vio(data_vio)->thread_config.cpu_thread;
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((cpu_thread == thread_id), VDO_ASSERT_LOG_ONLY((cpu_thread == thread_id),
"data_vio for logical block %llu on thread %u, should be on cpu thread %u", "data_vio for logical block %llu on thread %u, should be on cpu thread %u",
(unsigned long long) data_vio->logical.lbn, thread_id, (unsigned long long) data_vio->logical.lbn, thread_id,
cpu_thread); cpu_thread);
......
...@@ -327,7 +327,7 @@ static inline struct hash_zones *as_hash_zones(struct vdo_completion *completion ...@@ -327,7 +327,7 @@ static inline struct hash_zones *as_hash_zones(struct vdo_completion *completion
static inline void assert_in_hash_zone(struct hash_zone *zone, const char *name) static inline void assert_in_hash_zone(struct hash_zone *zone, const char *name)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == zone->thread_id), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == zone->thread_id),
"%s called on hash zone thread", name); "%s called on hash zone thread", name);
} }
...@@ -404,7 +404,7 @@ static void assert_hash_lock_agent(struct data_vio *data_vio, const char *where) ...@@ -404,7 +404,7 @@ static void assert_hash_lock_agent(struct data_vio *data_vio, const char *where)
{ {
/* Not safe to access the agent field except from the hash zone. */ /* Not safe to access the agent field except from the hash zone. */
assert_data_vio_in_hash_zone(data_vio); assert_data_vio_in_hash_zone(data_vio);
ASSERT_LOG_ONLY(data_vio == data_vio->hash_lock->agent, VDO_ASSERT_LOG_ONLY(data_vio == data_vio->hash_lock->agent,
"%s must be for the hash lock agent", where); "%s must be for the hash lock agent", where);
} }
...@@ -416,9 +416,8 @@ static void assert_hash_lock_agent(struct data_vio *data_vio, const char *where) ...@@ -416,9 +416,8 @@ static void assert_hash_lock_agent(struct data_vio *data_vio, const char *where)
*/ */
static void set_duplicate_lock(struct hash_lock *hash_lock, struct pbn_lock *pbn_lock) static void set_duplicate_lock(struct hash_lock *hash_lock, struct pbn_lock *pbn_lock)
{ {
ASSERT_LOG_ONLY((hash_lock->duplicate_lock == NULL), VDO_ASSERT_LOG_ONLY((hash_lock->duplicate_lock == NULL),
"hash lock must not already hold a duplicate lock"); "hash lock must not already hold a duplicate lock");
pbn_lock->holder_count += 1; pbn_lock->holder_count += 1;
hash_lock->duplicate_lock = pbn_lock; hash_lock->duplicate_lock = pbn_lock;
} }
...@@ -446,11 +445,11 @@ static void set_hash_lock(struct data_vio *data_vio, struct hash_lock *new_lock) ...@@ -446,11 +445,11 @@ static void set_hash_lock(struct data_vio *data_vio, struct hash_lock *new_lock)
struct hash_lock *old_lock = data_vio->hash_lock; struct hash_lock *old_lock = data_vio->hash_lock;
if (old_lock != NULL) { if (old_lock != NULL) {
ASSERT_LOG_ONLY(data_vio->hash_zone != NULL, VDO_ASSERT_LOG_ONLY(data_vio->hash_zone != NULL,
"must have a hash zone when holding a hash lock"); "must have a hash zone when holding a hash lock");
ASSERT_LOG_ONLY(!list_empty(&data_vio->hash_lock_entry), VDO_ASSERT_LOG_ONLY(!list_empty(&data_vio->hash_lock_entry),
"must be on a hash lock ring when holding a hash lock"); "must be on a hash lock ring when holding a hash lock");
ASSERT_LOG_ONLY(old_lock->reference_count > 0, VDO_ASSERT_LOG_ONLY(old_lock->reference_count > 0,
"hash lock reference must be counted"); "hash lock reference must be counted");
if ((old_lock->state != VDO_HASH_LOCK_BYPASSING) && if ((old_lock->state != VDO_HASH_LOCK_BYPASSING) &&
...@@ -459,7 +458,7 @@ static void set_hash_lock(struct data_vio *data_vio, struct hash_lock *new_lock) ...@@ -459,7 +458,7 @@ static void set_hash_lock(struct data_vio *data_vio, struct hash_lock *new_lock)
* If the reference count goes to zero in a non-terminal state, we're most * If the reference count goes to zero in a non-terminal state, we're most
* likely leaking this lock. * likely leaking this lock.
*/ */
ASSERT_LOG_ONLY(old_lock->reference_count > 1, VDO_ASSERT_LOG_ONLY(old_lock->reference_count > 1,
"hash locks should only become unreferenced in a terminal state, not state %s", "hash locks should only become unreferenced in a terminal state, not state %s",
get_hash_lock_state_name(old_lock->state)); get_hash_lock_state_name(old_lock->state));
} }
...@@ -641,7 +640,7 @@ static void finish_unlocking(struct vdo_completion *completion) ...@@ -641,7 +640,7 @@ static void finish_unlocking(struct vdo_completion *completion)
assert_hash_lock_agent(agent, __func__); assert_hash_lock_agent(agent, __func__);
ASSERT_LOG_ONLY(lock->duplicate_lock == NULL, VDO_ASSERT_LOG_ONLY(lock->duplicate_lock == NULL,
"must have released the duplicate lock for the hash lock"); "must have released the duplicate lock for the hash lock");
if (!lock->verified) { if (!lock->verified) {
...@@ -696,7 +695,7 @@ static void unlock_duplicate_pbn(struct vdo_completion *completion) ...@@ -696,7 +695,7 @@ static void unlock_duplicate_pbn(struct vdo_completion *completion)
struct hash_lock *lock = agent->hash_lock; struct hash_lock *lock = agent->hash_lock;
assert_data_vio_in_duplicate_zone(agent); assert_data_vio_in_duplicate_zone(agent);
ASSERT_LOG_ONLY(lock->duplicate_lock != NULL, VDO_ASSERT_LOG_ONLY(lock->duplicate_lock != NULL,
"must have a duplicate lock to release"); "must have a duplicate lock to release");
vdo_release_physical_zone_pbn_lock(agent->duplicate.zone, agent->duplicate.pbn, vdo_release_physical_zone_pbn_lock(agent->duplicate.zone, agent->duplicate.pbn,
...@@ -799,8 +798,8 @@ static void start_updating(struct hash_lock *lock, struct data_vio *agent) ...@@ -799,8 +798,8 @@ static void start_updating(struct hash_lock *lock, struct data_vio *agent)
{ {
lock->state = VDO_HASH_LOCK_UPDATING; lock->state = VDO_HASH_LOCK_UPDATING;
ASSERT_LOG_ONLY(lock->verified, "new advice should have been verified"); VDO_ASSERT_LOG_ONLY(lock->verified, "new advice should have been verified");
ASSERT_LOG_ONLY(lock->update_advice, "should only update advice if needed"); VDO_ASSERT_LOG_ONLY(lock->update_advice, "should only update advice if needed");
agent->last_async_operation = VIO_ASYNC_OP_UPDATE_DEDUPE_INDEX; agent->last_async_operation = VIO_ASYNC_OP_UPDATE_DEDUPE_INDEX;
set_data_vio_hash_zone_callback(agent, finish_updating); set_data_vio_hash_zone_callback(agent, finish_updating);
...@@ -822,8 +821,8 @@ static void finish_deduping(struct hash_lock *lock, struct data_vio *data_vio) ...@@ -822,8 +821,8 @@ static void finish_deduping(struct hash_lock *lock, struct data_vio *data_vio)
{ {
struct data_vio *agent = data_vio; struct data_vio *agent = data_vio;
ASSERT_LOG_ONLY(lock->agent == NULL, "shouldn't have an agent in DEDUPING"); VDO_ASSERT_LOG_ONLY(lock->agent == NULL, "shouldn't have an agent in DEDUPING");
ASSERT_LOG_ONLY(!vdo_waitq_has_waiters(&lock->waiters), VDO_ASSERT_LOG_ONLY(!vdo_waitq_has_waiters(&lock->waiters),
"shouldn't have any lock waiters in DEDUPING"); "shouldn't have any lock waiters in DEDUPING");
/* Just release the lock reference if other data_vios are still deduping. */ /* Just release the lock reference if other data_vios are still deduping. */
...@@ -879,7 +878,7 @@ static int __must_check acquire_lock(struct hash_zone *zone, ...@@ -879,7 +878,7 @@ static int __must_check acquire_lock(struct hash_zone *zone,
* Borrow and prepare a lock from the pool so we don't have to do two int_map accesses * Borrow and prepare a lock from the pool so we don't have to do two int_map accesses
* in the common case of no lock contention. * in the common case of no lock contention.
*/ */
result = ASSERT(!list_empty(&zone->lock_pool), result = VDO_ASSERT(!list_empty(&zone->lock_pool),
"never need to wait for a free hash lock"); "never need to wait for a free hash lock");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -902,10 +901,10 @@ static int __must_check acquire_lock(struct hash_zone *zone, ...@@ -902,10 +901,10 @@ static int __must_check acquire_lock(struct hash_zone *zone,
if (replace_lock != NULL) { if (replace_lock != NULL) {
/* On mismatch put the old lock back and return a severe error */ /* On mismatch put the old lock back and return a severe error */
ASSERT_LOG_ONLY(lock == replace_lock, VDO_ASSERT_LOG_ONLY(lock == replace_lock,
"old lock must have been in the lock map"); "old lock must have been in the lock map");
/* TODO: Check earlier and bail out? */ /* TODO: Check earlier and bail out? */
ASSERT_LOG_ONLY(replace_lock->registered, VDO_ASSERT_LOG_ONLY(replace_lock->registered,
"old lock must have been marked registered"); "old lock must have been marked registered");
replace_lock->registered = false; replace_lock->registered = false;
} }
...@@ -1018,14 +1017,14 @@ static void start_deduping(struct hash_lock *lock, struct data_vio *agent, ...@@ -1018,14 +1017,14 @@ static void start_deduping(struct hash_lock *lock, struct data_vio *agent,
* deduplicate against it. * deduplicate against it.
*/ */
if (lock->duplicate_lock == NULL) { if (lock->duplicate_lock == NULL) {
ASSERT_LOG_ONLY(!vdo_is_state_compressed(agent->new_mapped.state), VDO_ASSERT_LOG_ONLY(!vdo_is_state_compressed(agent->new_mapped.state),
"compression must have shared a lock"); "compression must have shared a lock");
ASSERT_LOG_ONLY(agent_is_done, VDO_ASSERT_LOG_ONLY(agent_is_done,
"agent must have written the new duplicate"); "agent must have written the new duplicate");
transfer_allocation_lock(agent); transfer_allocation_lock(agent);
} }
ASSERT_LOG_ONLY(vdo_is_pbn_read_lock(lock->duplicate_lock), VDO_ASSERT_LOG_ONLY(vdo_is_pbn_read_lock(lock->duplicate_lock),
"duplicate_lock must be a PBN read lock"); "duplicate_lock must be a PBN read lock");
/* /*
...@@ -1204,7 +1203,7 @@ static void start_verifying(struct hash_lock *lock, struct data_vio *agent) ...@@ -1204,7 +1203,7 @@ static void start_verifying(struct hash_lock *lock, struct data_vio *agent)
agent->scratch_block); agent->scratch_block);
lock->state = VDO_HASH_LOCK_VERIFYING; lock->state = VDO_HASH_LOCK_VERIFYING;
ASSERT_LOG_ONLY(!lock->verified, "hash lock only verifies advice once"); VDO_ASSERT_LOG_ONLY(!lock->verified, "hash lock only verifies advice once");
agent->last_async_operation = VIO_ASYNC_OP_VERIFY_DUPLICATION; agent->last_async_operation = VIO_ASYNC_OP_VERIFY_DUPLICATION;
result = vio_reset_bio(vio, buffer, verify_endio, REQ_OP_READ, result = vio_reset_bio(vio, buffer, verify_endio, REQ_OP_READ,
...@@ -1234,7 +1233,7 @@ static void finish_locking(struct vdo_completion *completion) ...@@ -1234,7 +1233,7 @@ static void finish_locking(struct vdo_completion *completion)
assert_hash_lock_agent(agent, __func__); assert_hash_lock_agent(agent, __func__);
if (!agent->is_duplicate) { if (!agent->is_duplicate) {
ASSERT_LOG_ONLY(lock->duplicate_lock == NULL, VDO_ASSERT_LOG_ONLY(lock->duplicate_lock == NULL,
"must not hold duplicate_lock if not flagged as a duplicate"); "must not hold duplicate_lock if not flagged as a duplicate");
/* /*
* LOCKING -> WRITING transition: The advice block is being modified or has no * LOCKING -> WRITING transition: The advice block is being modified or has no
...@@ -1247,7 +1246,7 @@ static void finish_locking(struct vdo_completion *completion) ...@@ -1247,7 +1246,7 @@ static void finish_locking(struct vdo_completion *completion)
return; return;
} }
ASSERT_LOG_ONLY(lock->duplicate_lock != NULL, VDO_ASSERT_LOG_ONLY(lock->duplicate_lock != NULL,
"must hold duplicate_lock if flagged as a duplicate"); "must hold duplicate_lock if flagged as a duplicate");
if (!lock->verified) { if (!lock->verified) {
...@@ -1418,7 +1417,7 @@ static void lock_duplicate_pbn(struct vdo_completion *completion) ...@@ -1418,7 +1417,7 @@ static void lock_duplicate_pbn(struct vdo_completion *completion)
*/ */
static void start_locking(struct hash_lock *lock, struct data_vio *agent) static void start_locking(struct hash_lock *lock, struct data_vio *agent)
{ {
ASSERT_LOG_ONLY(lock->duplicate_lock == NULL, VDO_ASSERT_LOG_ONLY(lock->duplicate_lock == NULL,
"must not acquire a duplicate lock when already holding it"); "must not acquire a duplicate lock when already holding it");
lock->state = VDO_HASH_LOCK_LOCKING; lock->state = VDO_HASH_LOCK_LOCKING;
...@@ -1725,7 +1724,7 @@ static void start_querying(struct hash_lock *lock, struct data_vio *data_vio) ...@@ -1725,7 +1724,7 @@ static void start_querying(struct hash_lock *lock, struct data_vio *data_vio)
*/ */
static void report_bogus_lock_state(struct hash_lock *lock, struct data_vio *data_vio) static void report_bogus_lock_state(struct hash_lock *lock, struct data_vio *data_vio)
{ {
ASSERT_LOG_ONLY(false, "hash lock must not be in unimplemented state %s", VDO_ASSERT_LOG_ONLY(false, "hash lock must not be in unimplemented state %s",
get_hash_lock_state_name(lock->state)); get_hash_lock_state_name(lock->state));
continue_data_vio_with_error(data_vio, VDO_LOCK_ERROR); continue_data_vio_with_error(data_vio, VDO_LOCK_ERROR);
} }
...@@ -1748,7 +1747,7 @@ void vdo_continue_hash_lock(struct vdo_completion *completion) ...@@ -1748,7 +1747,7 @@ void vdo_continue_hash_lock(struct vdo_completion *completion)
switch (lock->state) { switch (lock->state) {
case VDO_HASH_LOCK_WRITING: case VDO_HASH_LOCK_WRITING:
ASSERT_LOG_ONLY(data_vio == lock->agent, VDO_ASSERT_LOG_ONLY(data_vio == lock->agent,
"only the lock agent may continue the lock"); "only the lock agent may continue the lock");
finish_writing(lock, data_vio); finish_writing(lock, data_vio);
break; break;
...@@ -1815,17 +1814,17 @@ static inline int assert_hash_lock_preconditions(const struct data_vio *data_vio ...@@ -1815,17 +1814,17 @@ static inline int assert_hash_lock_preconditions(const struct data_vio *data_vio
int result; int result;
/* FIXME: BUG_ON() and/or enter read-only mode? */ /* FIXME: BUG_ON() and/or enter read-only mode? */
result = ASSERT(data_vio->hash_lock == NULL, result = VDO_ASSERT(data_vio->hash_lock == NULL,
"must not already hold a hash lock"); "must not already hold a hash lock");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(list_empty(&data_vio->hash_lock_entry), result = VDO_ASSERT(list_empty(&data_vio->hash_lock_entry),
"must not already be a member of a hash lock ring"); "must not already be a member of a hash lock ring");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
return ASSERT(data_vio->recovery_sequence_number == 0, return VDO_ASSERT(data_vio->recovery_sequence_number == 0,
"must not hold a recovery lock when getting a hash lock"); "must not hold a recovery lock when getting a hash lock");
} }
...@@ -1933,23 +1932,23 @@ void vdo_release_hash_lock(struct data_vio *data_vio) ...@@ -1933,23 +1932,23 @@ void vdo_release_hash_lock(struct data_vio *data_vio)
struct hash_lock *removed; struct hash_lock *removed;
removed = vdo_int_map_remove(zone->hash_lock_map, lock_key); removed = vdo_int_map_remove(zone->hash_lock_map, lock_key);
ASSERT_LOG_ONLY(lock == removed, VDO_ASSERT_LOG_ONLY(lock == removed,
"hash lock being released must have been mapped"); "hash lock being released must have been mapped");
} else { } else {
ASSERT_LOG_ONLY(lock != vdo_int_map_get(zone->hash_lock_map, lock_key), VDO_ASSERT_LOG_ONLY(lock != vdo_int_map_get(zone->hash_lock_map, lock_key),
"unregistered hash lock must not be in the lock map"); "unregistered hash lock must not be in the lock map");
} }
ASSERT_LOG_ONLY(!vdo_waitq_has_waiters(&lock->waiters), VDO_ASSERT_LOG_ONLY(!vdo_waitq_has_waiters(&lock->waiters),
"hash lock returned to zone must have no waiters"); "hash lock returned to zone must have no waiters");
ASSERT_LOG_ONLY((lock->duplicate_lock == NULL), VDO_ASSERT_LOG_ONLY((lock->duplicate_lock == NULL),
"hash lock returned to zone must not reference a PBN lock"); "hash lock returned to zone must not reference a PBN lock");
ASSERT_LOG_ONLY((lock->state == VDO_HASH_LOCK_BYPASSING), VDO_ASSERT_LOG_ONLY((lock->state == VDO_HASH_LOCK_BYPASSING),
"returned hash lock must not be in use with state %s", "returned hash lock must not be in use with state %s",
get_hash_lock_state_name(lock->state)); get_hash_lock_state_name(lock->state));
ASSERT_LOG_ONLY(list_empty(&lock->pool_node), VDO_ASSERT_LOG_ONLY(list_empty(&lock->pool_node),
"hash lock returned to zone must not be in a pool ring"); "hash lock returned to zone must not be in a pool ring");
ASSERT_LOG_ONLY(list_empty(&lock->duplicate_ring), VDO_ASSERT_LOG_ONLY(list_empty(&lock->duplicate_ring),
"hash lock returned to zone must not reference DataVIOs"); "hash lock returned to zone must not reference DataVIOs");
return_hash_lock_to_pool(zone, lock); return_hash_lock_to_pool(zone, lock);
...@@ -1965,12 +1964,12 @@ static void transfer_allocation_lock(struct data_vio *data_vio) ...@@ -1965,12 +1964,12 @@ static void transfer_allocation_lock(struct data_vio *data_vio)
struct allocation *allocation = &data_vio->allocation; struct allocation *allocation = &data_vio->allocation;
struct hash_lock *hash_lock = data_vio->hash_lock; struct hash_lock *hash_lock = data_vio->hash_lock;
ASSERT_LOG_ONLY(data_vio->new_mapped.pbn == allocation->pbn, VDO_ASSERT_LOG_ONLY(data_vio->new_mapped.pbn == allocation->pbn,
"transferred lock must be for the block written"); "transferred lock must be for the block written");
allocation->pbn = VDO_ZERO_BLOCK; allocation->pbn = VDO_ZERO_BLOCK;
ASSERT_LOG_ONLY(vdo_is_pbn_read_lock(allocation->lock), VDO_ASSERT_LOG_ONLY(vdo_is_pbn_read_lock(allocation->lock),
"must have downgraded the allocation lock before transfer"); "must have downgraded the allocation lock before transfer");
hash_lock->duplicate = data_vio->new_mapped; hash_lock->duplicate = data_vio->new_mapped;
...@@ -1997,9 +1996,9 @@ void vdo_share_compressed_write_lock(struct data_vio *data_vio, ...@@ -1997,9 +1996,9 @@ void vdo_share_compressed_write_lock(struct data_vio *data_vio,
{ {
bool claimed; bool claimed;
ASSERT_LOG_ONLY(vdo_get_duplicate_lock(data_vio) == NULL, VDO_ASSERT_LOG_ONLY(vdo_get_duplicate_lock(data_vio) == NULL,
"a duplicate PBN lock should not exist when writing"); "a duplicate PBN lock should not exist when writing");
ASSERT_LOG_ONLY(vdo_is_state_compressed(data_vio->new_mapped.state), VDO_ASSERT_LOG_ONLY(vdo_is_state_compressed(data_vio->new_mapped.state),
"lock transfer must be for a compressed write"); "lock transfer must be for a compressed write");
assert_data_vio_in_new_mapped_zone(data_vio); assert_data_vio_in_new_mapped_zone(data_vio);
...@@ -2020,7 +2019,7 @@ void vdo_share_compressed_write_lock(struct data_vio *data_vio, ...@@ -2020,7 +2019,7 @@ void vdo_share_compressed_write_lock(struct data_vio *data_vio,
* deduplicating against it before our incRef. * deduplicating against it before our incRef.
*/ */
claimed = vdo_claim_pbn_lock_increment(pbn_lock); claimed = vdo_claim_pbn_lock_increment(pbn_lock);
ASSERT_LOG_ONLY(claimed, "impossible to fail to claim an initial increment"); VDO_ASSERT_LOG_ONLY(claimed, "impossible to fail to claim an initial increment");
} }
static void dedupe_kobj_release(struct kobject *directory) static void dedupe_kobj_release(struct kobject *directory)
...@@ -2296,7 +2295,7 @@ static void finish_index_operation(struct uds_request *request) ...@@ -2296,7 +2295,7 @@ static void finish_index_operation(struct uds_request *request)
*/ */
if (!change_context_state(context, DEDUPE_CONTEXT_TIMED_OUT, if (!change_context_state(context, DEDUPE_CONTEXT_TIMED_OUT,
DEDUPE_CONTEXT_TIMED_OUT_COMPLETE)) { DEDUPE_CONTEXT_TIMED_OUT_COMPLETE)) {
ASSERT_LOG_ONLY(false, "uds request was timed out (state %d)", VDO_ASSERT_LOG_ONLY(false, "uds request was timed out (state %d)",
atomic_read(&context->state)); atomic_read(&context->state));
} }
...@@ -2341,7 +2340,7 @@ static void check_for_drain_complete(struct hash_zone *zone) ...@@ -2341,7 +2340,7 @@ static void check_for_drain_complete(struct hash_zone *zone)
if (recycled > 0) if (recycled > 0)
WRITE_ONCE(zone->active, zone->active - recycled); WRITE_ONCE(zone->active, zone->active - recycled);
ASSERT_LOG_ONLY(READ_ONCE(zone->active) == 0, "all contexts inactive"); VDO_ASSERT_LOG_ONLY(READ_ONCE(zone->active) == 0, "all contexts inactive");
vdo_finish_draining(&zone->state); vdo_finish_draining(&zone->state);
} }
......
...@@ -904,7 +904,7 @@ static int vdo_map_bio(struct dm_target *ti, struct bio *bio) ...@@ -904,7 +904,7 @@ static int vdo_map_bio(struct dm_target *ti, struct bio *bio)
struct vdo_work_queue *current_work_queue; struct vdo_work_queue *current_work_queue;
const struct admin_state_code *code = vdo_get_admin_state_code(&vdo->admin.state); const struct admin_state_code *code = vdo_get_admin_state_code(&vdo->admin.state);
ASSERT_LOG_ONLY(code->normal, "vdo should not receive bios while in state %s", VDO_ASSERT_LOG_ONLY(code->normal, "vdo should not receive bios while in state %s",
code->name); code->name);
/* Count all incoming bios. */ /* Count all incoming bios. */
...@@ -1244,7 +1244,7 @@ static int perform_admin_operation(struct vdo *vdo, u32 starting_phase, ...@@ -1244,7 +1244,7 @@ static int perform_admin_operation(struct vdo *vdo, u32 starting_phase,
/* Assert that we are operating on the correct thread for the current phase. */ /* Assert that we are operating on the correct thread for the current phase. */
static void assert_admin_phase_thread(struct vdo *vdo, const char *what) static void assert_admin_phase_thread(struct vdo *vdo, const char *what)
{ {
ASSERT_LOG_ONLY(vdo_get_callback_thread_id() == get_thread_id_for_phase(vdo), VDO_ASSERT_LOG_ONLY(vdo_get_callback_thread_id() == get_thread_id_for_phase(vdo),
"%s on correct thread for %s", what, "%s on correct thread for %s", what,
ADMIN_PHASE_NAMES[vdo->admin.phase]); ADMIN_PHASE_NAMES[vdo->admin.phase]);
} }
...@@ -1424,11 +1424,11 @@ static void release_instance(unsigned int instance) ...@@ -1424,11 +1424,11 @@ static void release_instance(unsigned int instance)
{ {
mutex_lock(&instances_lock); mutex_lock(&instances_lock);
if (instance >= instances.bit_count) { if (instance >= instances.bit_count) {
ASSERT_LOG_ONLY(false, VDO_ASSERT_LOG_ONLY(false,
"instance number %u must be less than bit count %u", "instance number %u must be less than bit count %u",
instance, instances.bit_count); instance, instances.bit_count);
} else if (test_bit(instance, instances.words) == 0) { } else if (test_bit(instance, instances.words) == 0) {
ASSERT_LOG_ONLY(false, "instance number %u must be allocated", instance); VDO_ASSERT_LOG_ONLY(false, "instance number %u must be allocated", instance);
} else { } else {
__clear_bit(instance, instances.words); __clear_bit(instance, instances.words);
instances.count -= 1; instances.count -= 1;
...@@ -1577,9 +1577,9 @@ static int allocate_instance(unsigned int *instance_ptr) ...@@ -1577,9 +1577,9 @@ static int allocate_instance(unsigned int *instance_ptr)
if (instance >= instances.bit_count) { if (instance >= instances.bit_count) {
/* Nothing free after next, so wrap around to instance zero. */ /* Nothing free after next, so wrap around to instance zero. */
instance = find_first_zero_bit(instances.words, instances.bit_count); instance = find_first_zero_bit(instances.words, instances.bit_count);
result = ASSERT(instance < instances.bit_count, result = VDO_ASSERT(instance < instances.bit_count,
"impossibly, no zero bit found"); "impossibly, no zero bit found");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
} }
...@@ -1729,7 +1729,7 @@ static int prepare_to_grow_physical(struct vdo *vdo, block_count_t new_physical_ ...@@ -1729,7 +1729,7 @@ static int prepare_to_grow_physical(struct vdo *vdo, block_count_t new_physical_
uds_log_info("Preparing to resize physical to %llu", uds_log_info("Preparing to resize physical to %llu",
(unsigned long long) new_physical_blocks); (unsigned long long) new_physical_blocks);
ASSERT_LOG_ONLY((new_physical_blocks > current_physical_blocks), VDO_ASSERT_LOG_ONLY((new_physical_blocks > current_physical_blocks),
"New physical size is larger than current physical size"); "New physical size is larger than current physical size");
result = perform_admin_operation(vdo, PREPARE_GROW_PHYSICAL_PHASE_START, result = perform_admin_operation(vdo, PREPARE_GROW_PHYSICAL_PHASE_START,
check_may_grow_physical, check_may_grow_physical,
...@@ -1829,7 +1829,7 @@ static int prepare_to_modify(struct dm_target *ti, struct device_config *config, ...@@ -1829,7 +1829,7 @@ static int prepare_to_modify(struct dm_target *ti, struct device_config *config,
uds_log_info("Preparing to resize logical to %llu", uds_log_info("Preparing to resize logical to %llu",
(unsigned long long) config->logical_blocks); (unsigned long long) config->logical_blocks);
ASSERT_LOG_ONLY((config->logical_blocks > logical_blocks), VDO_ASSERT_LOG_ONLY((config->logical_blocks > logical_blocks),
"New logical size is larger than current size"); "New logical size is larger than current size");
result = vdo_prepare_to_grow_block_map(vdo->block_map, result = vdo_prepare_to_grow_block_map(vdo->block_map,
...@@ -2890,7 +2890,7 @@ static void vdo_module_destroy(void) ...@@ -2890,7 +2890,7 @@ static void vdo_module_destroy(void)
if (dm_registered) if (dm_registered)
dm_unregister_target(&vdo_target_bio); dm_unregister_target(&vdo_target_bio);
ASSERT_LOG_ONLY(instances.count == 0, VDO_ASSERT_LOG_ONLY(instances.count == 0,
"should have no instance numbers still in use, but have %u", "should have no instance numbers still in use, but have %u",
instances.count); instances.count);
vdo_free(instances.words); vdo_free(instances.words);
......
...@@ -320,7 +320,7 @@ int __must_check vdo_parse_geometry_block(u8 *block, struct volume_geometry *geo ...@@ -320,7 +320,7 @@ int __must_check vdo_parse_geometry_block(u8 *block, struct volume_geometry *geo
decode_volume_geometry(block, &offset, geometry, header.version.major_version); decode_volume_geometry(block, &offset, geometry, header.version.major_version);
result = ASSERT(header.size == offset + sizeof(u32), result = VDO_ASSERT(header.size == offset + sizeof(u32),
"should have decoded up to the geometry checksum"); "should have decoded up to the geometry checksum");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -380,24 +380,24 @@ static int decode_block_map_state_2_0(u8 *buffer, size_t *offset, ...@@ -380,24 +380,24 @@ static int decode_block_map_state_2_0(u8 *buffer, size_t *offset,
initial_offset = *offset; initial_offset = *offset;
decode_u64_le(buffer, offset, &flat_page_origin); decode_u64_le(buffer, offset, &flat_page_origin);
result = ASSERT(flat_page_origin == VDO_BLOCK_MAP_FLAT_PAGE_ORIGIN, result = VDO_ASSERT(flat_page_origin == VDO_BLOCK_MAP_FLAT_PAGE_ORIGIN,
"Flat page origin must be %u (recorded as %llu)", "Flat page origin must be %u (recorded as %llu)",
VDO_BLOCK_MAP_FLAT_PAGE_ORIGIN, VDO_BLOCK_MAP_FLAT_PAGE_ORIGIN,
(unsigned long long) state->flat_page_origin); (unsigned long long) state->flat_page_origin);
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
decode_u64_le(buffer, offset, &flat_page_count); decode_u64_le(buffer, offset, &flat_page_count);
result = ASSERT(flat_page_count == 0, result = VDO_ASSERT(flat_page_count == 0,
"Flat page count must be 0 (recorded as %llu)", "Flat page count must be 0 (recorded as %llu)",
(unsigned long long) state->flat_page_count); (unsigned long long) state->flat_page_count);
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
decode_u64_le(buffer, offset, &root_origin); decode_u64_le(buffer, offset, &root_origin);
decode_u64_le(buffer, offset, &root_count); decode_u64_le(buffer, offset, &root_count);
result = ASSERT(VDO_BLOCK_MAP_HEADER_2_0.size == *offset - initial_offset, result = VDO_ASSERT(VDO_BLOCK_MAP_HEADER_2_0.size == *offset - initial_offset,
"decoded block map component size must match header size"); "decoded block map component size must match header size");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -425,7 +425,7 @@ static void encode_block_map_state_2_0(u8 *buffer, size_t *offset, ...@@ -425,7 +425,7 @@ static void encode_block_map_state_2_0(u8 *buffer, size_t *offset,
encode_u64_le(buffer, offset, state.root_origin); encode_u64_le(buffer, offset, state.root_origin);
encode_u64_le(buffer, offset, state.root_count); encode_u64_le(buffer, offset, state.root_count);
ASSERT_LOG_ONLY(VDO_BLOCK_MAP_HEADER_2_0.size == *offset - initial_offset, VDO_ASSERT_LOG_ONLY(VDO_BLOCK_MAP_HEADER_2_0.size == *offset - initial_offset,
"encoded block map component size must match header size"); "encoded block map component size must match header size");
} }
...@@ -477,7 +477,7 @@ static void encode_recovery_journal_state_7_0(u8 *buffer, size_t *offset, ...@@ -477,7 +477,7 @@ static void encode_recovery_journal_state_7_0(u8 *buffer, size_t *offset,
encode_u64_le(buffer, offset, state.logical_blocks_used); encode_u64_le(buffer, offset, state.logical_blocks_used);
encode_u64_le(buffer, offset, state.block_map_data_blocks); encode_u64_le(buffer, offset, state.block_map_data_blocks);
ASSERT_LOG_ONLY(VDO_RECOVERY_JOURNAL_HEADER_7_0.size == *offset - initial_offset, VDO_ASSERT_LOG_ONLY(VDO_RECOVERY_JOURNAL_HEADER_7_0.size == *offset - initial_offset,
"encoded recovery journal component size must match header size"); "encoded recovery journal component size must match header size");
} }
...@@ -508,9 +508,9 @@ static int __must_check decode_recovery_journal_state_7_0(u8 *buffer, size_t *of ...@@ -508,9 +508,9 @@ static int __must_check decode_recovery_journal_state_7_0(u8 *buffer, size_t *of
decode_u64_le(buffer, offset, &logical_blocks_used); decode_u64_le(buffer, offset, &logical_blocks_used);
decode_u64_le(buffer, offset, &block_map_data_blocks); decode_u64_le(buffer, offset, &block_map_data_blocks);
result = ASSERT(VDO_RECOVERY_JOURNAL_HEADER_7_0.size == *offset - initial_offset, result = VDO_ASSERT(VDO_RECOVERY_JOURNAL_HEADER_7_0.size == *offset - initial_offset,
"decoded recovery journal component size must match header size"); "decoded recovery journal component size must match header size");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
*state = (struct recovery_journal_state_7_0) { *state = (struct recovery_journal_state_7_0) {
...@@ -566,7 +566,7 @@ static void encode_slab_depot_state_2_0(u8 *buffer, size_t *offset, ...@@ -566,7 +566,7 @@ static void encode_slab_depot_state_2_0(u8 *buffer, size_t *offset,
encode_u64_le(buffer, offset, state.last_block); encode_u64_le(buffer, offset, state.last_block);
buffer[(*offset)++] = state.zone_count; buffer[(*offset)++] = state.zone_count;
ASSERT_LOG_ONLY(VDO_SLAB_DEPOT_HEADER_2_0.size == *offset - initial_offset, VDO_ASSERT_LOG_ONLY(VDO_SLAB_DEPOT_HEADER_2_0.size == *offset - initial_offset,
"encoded block map component size must match header size"); "encoded block map component size must match header size");
} }
...@@ -618,9 +618,9 @@ static int decode_slab_depot_state_2_0(u8 *buffer, size_t *offset, ...@@ -618,9 +618,9 @@ static int decode_slab_depot_state_2_0(u8 *buffer, size_t *offset,
decode_u64_le(buffer, offset, &last_block); decode_u64_le(buffer, offset, &last_block);
zone_count = buffer[(*offset)++]; zone_count = buffer[(*offset)++];
result = ASSERT(VDO_SLAB_DEPOT_HEADER_2_0.size == *offset - initial_offset, result = VDO_ASSERT(VDO_SLAB_DEPOT_HEADER_2_0.size == *offset - initial_offset,
"decoded slab depot component size must match header size"); "decoded slab depot component size must match header size");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
*state = (struct slab_depot_state_2_0) { *state = (struct slab_depot_state_2_0) {
...@@ -970,7 +970,7 @@ struct partition *vdo_get_known_partition(struct layout *layout, enum partition_ ...@@ -970,7 +970,7 @@ struct partition *vdo_get_known_partition(struct layout *layout, enum partition_
struct partition *partition; struct partition *partition;
int result = vdo_get_partition(layout, id, &partition); int result = vdo_get_partition(layout, id, &partition);
ASSERT_LOG_ONLY(result == VDO_SUCCESS, "layout has expected partition: %u", id); VDO_ASSERT_LOG_ONLY(result == VDO_SUCCESS, "layout has expected partition: %u", id);
return partition; return partition;
} }
...@@ -982,7 +982,7 @@ static void encode_layout(u8 *buffer, size_t *offset, const struct layout *layou ...@@ -982,7 +982,7 @@ static void encode_layout(u8 *buffer, size_t *offset, const struct layout *layou
struct header header = VDO_LAYOUT_HEADER_3_0; struct header header = VDO_LAYOUT_HEADER_3_0;
BUILD_BUG_ON(sizeof(enum partition_id) != sizeof(u8)); BUILD_BUG_ON(sizeof(enum partition_id) != sizeof(u8));
ASSERT_LOG_ONLY(layout->num_partitions <= U8_MAX, VDO_ASSERT_LOG_ONLY(layout->num_partitions <= U8_MAX,
"layout partition count must fit in a byte"); "layout partition count must fit in a byte");
vdo_encode_header(buffer, offset, &header); vdo_encode_header(buffer, offset, &header);
...@@ -992,7 +992,7 @@ static void encode_layout(u8 *buffer, size_t *offset, const struct layout *layou ...@@ -992,7 +992,7 @@ static void encode_layout(u8 *buffer, size_t *offset, const struct layout *layou
encode_u64_le(buffer, offset, layout->last_free); encode_u64_le(buffer, offset, layout->last_free);
buffer[(*offset)++] = layout->num_partitions; buffer[(*offset)++] = layout->num_partitions;
ASSERT_LOG_ONLY(sizeof(struct layout_3_0) == *offset - initial_offset, VDO_ASSERT_LOG_ONLY(sizeof(struct layout_3_0) == *offset - initial_offset,
"encoded size of a layout header must match structure"); "encoded size of a layout header must match structure");
for (partition = layout->head; partition != NULL; partition = partition->next) { for (partition = layout->head; partition != NULL; partition = partition->next) {
...@@ -1003,7 +1003,7 @@ static void encode_layout(u8 *buffer, size_t *offset, const struct layout *layou ...@@ -1003,7 +1003,7 @@ static void encode_layout(u8 *buffer, size_t *offset, const struct layout *layou
encode_u64_le(buffer, offset, partition->count); encode_u64_le(buffer, offset, partition->count);
} }
ASSERT_LOG_ONLY(header.size == *offset - initial_offset, VDO_ASSERT_LOG_ONLY(header.size == *offset - initial_offset,
"encoded size of a layout must match header size"); "encoded size of a layout must match header size");
} }
...@@ -1035,7 +1035,7 @@ static int decode_layout(u8 *buffer, size_t *offset, physical_block_number_t sta ...@@ -1035,7 +1035,7 @@ static int decode_layout(u8 *buffer, size_t *offset, physical_block_number_t sta
.partition_count = partition_count, .partition_count = partition_count,
}; };
result = ASSERT(sizeof(struct layout_3_0) == *offset - initial_offset, result = VDO_ASSERT(sizeof(struct layout_3_0) == *offset - initial_offset,
"decoded size of a layout header must match structure"); "decoded size of a layout header must match structure");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -1208,29 +1208,29 @@ int vdo_validate_config(const struct vdo_config *config, ...@@ -1208,29 +1208,29 @@ int vdo_validate_config(const struct vdo_config *config,
struct slab_config slab_config; struct slab_config slab_config;
int result; int result;
result = ASSERT(config->slab_size > 0, "slab size unspecified"); result = VDO_ASSERT(config->slab_size > 0, "slab size unspecified");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(is_power_of_2(config->slab_size), result = VDO_ASSERT(is_power_of_2(config->slab_size),
"slab size must be a power of two"); "slab size must be a power of two");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(config->slab_size <= (1 << MAX_VDO_SLAB_BITS), result = VDO_ASSERT(config->slab_size <= (1 << MAX_VDO_SLAB_BITS),
"slab size must be less than or equal to 2^%d", "slab size must be less than or equal to 2^%d",
MAX_VDO_SLAB_BITS); MAX_VDO_SLAB_BITS);
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(config->slab_journal_blocks >= MINIMUM_VDO_SLAB_JOURNAL_BLOCKS, result = VDO_ASSERT(config->slab_journal_blocks >= MINIMUM_VDO_SLAB_JOURNAL_BLOCKS,
"slab journal size meets minimum size"); "slab journal size meets minimum size");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(config->slab_journal_blocks <= config->slab_size, result = VDO_ASSERT(config->slab_journal_blocks <= config->slab_size,
"slab journal size is within expected bound"); "slab journal size is within expected bound");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = vdo_configure_slab(config->slab_size, config->slab_journal_blocks, result = vdo_configure_slab(config->slab_size, config->slab_journal_blocks,
...@@ -1238,20 +1238,20 @@ int vdo_validate_config(const struct vdo_config *config, ...@@ -1238,20 +1238,20 @@ int vdo_validate_config(const struct vdo_config *config,
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT((slab_config.data_blocks >= 1), result = VDO_ASSERT((slab_config.data_blocks >= 1),
"slab must be able to hold at least one block"); "slab must be able to hold at least one block");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(config->physical_blocks > 0, "physical blocks unspecified"); result = VDO_ASSERT(config->physical_blocks > 0, "physical blocks unspecified");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(config->physical_blocks <= MAXIMUM_VDO_PHYSICAL_BLOCKS, result = VDO_ASSERT(config->physical_blocks <= MAXIMUM_VDO_PHYSICAL_BLOCKS,
"physical block count %llu exceeds maximum %llu", "physical block count %llu exceeds maximum %llu",
(unsigned long long) config->physical_blocks, (unsigned long long) config->physical_blocks,
(unsigned long long) MAXIMUM_VDO_PHYSICAL_BLOCKS); (unsigned long long) MAXIMUM_VDO_PHYSICAL_BLOCKS);
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return VDO_OUT_OF_RANGE; return VDO_OUT_OF_RANGE;
if (physical_block_count != config->physical_blocks) { if (physical_block_count != config->physical_blocks) {
...@@ -1262,9 +1262,9 @@ int vdo_validate_config(const struct vdo_config *config, ...@@ -1262,9 +1262,9 @@ int vdo_validate_config(const struct vdo_config *config,
} }
if (logical_block_count > 0) { if (logical_block_count > 0) {
result = ASSERT((config->logical_blocks > 0), result = VDO_ASSERT((config->logical_blocks > 0),
"logical blocks unspecified"); "logical blocks unspecified");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
if (logical_block_count != config->logical_blocks) { if (logical_block_count != config->logical_blocks) {
...@@ -1275,19 +1275,19 @@ int vdo_validate_config(const struct vdo_config *config, ...@@ -1275,19 +1275,19 @@ int vdo_validate_config(const struct vdo_config *config,
} }
} }
result = ASSERT(config->logical_blocks <= MAXIMUM_VDO_LOGICAL_BLOCKS, result = VDO_ASSERT(config->logical_blocks <= MAXIMUM_VDO_LOGICAL_BLOCKS,
"logical blocks too large"); "logical blocks too large");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(config->recovery_journal_size > 0, result = VDO_ASSERT(config->recovery_journal_size > 0,
"recovery journal size unspecified"); "recovery journal size unspecified");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(is_power_of_2(config->recovery_journal_size), result = VDO_ASSERT(is_power_of_2(config->recovery_journal_size),
"recovery journal size must be a power of two"); "recovery journal size must be a power of two");
if (result != UDS_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
return result; return result;
...@@ -1341,7 +1341,7 @@ static int __must_check decode_components(u8 *buffer, size_t *offset, ...@@ -1341,7 +1341,7 @@ static int __must_check decode_components(u8 *buffer, size_t *offset,
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
ASSERT_LOG_ONLY(*offset == VDO_COMPONENT_DATA_OFFSET + VDO_COMPONENT_DATA_SIZE, VDO_ASSERT_LOG_ONLY(*offset == VDO_COMPONENT_DATA_OFFSET + VDO_COMPONENT_DATA_SIZE,
"All decoded component data was used"); "All decoded component data was used");
return VDO_SUCCESS; return VDO_SUCCESS;
} }
...@@ -1416,7 +1416,7 @@ static void vdo_encode_component_states(u8 *buffer, size_t *offset, ...@@ -1416,7 +1416,7 @@ static void vdo_encode_component_states(u8 *buffer, size_t *offset,
encode_slab_depot_state_2_0(buffer, offset, states->slab_depot); encode_slab_depot_state_2_0(buffer, offset, states->slab_depot);
encode_block_map_state_2_0(buffer, offset, states->block_map); encode_block_map_state_2_0(buffer, offset, states->block_map);
ASSERT_LOG_ONLY(*offset == VDO_COMPONENT_DATA_OFFSET + VDO_COMPONENT_DATA_SIZE, VDO_ASSERT_LOG_ONLY(*offset == VDO_COMPONENT_DATA_OFFSET + VDO_COMPONENT_DATA_SIZE,
"All super block component data was encoded"); "All super block component data was encoded");
} }
...@@ -1440,7 +1440,7 @@ void vdo_encode_super_block(u8 *buffer, struct vdo_component_states *states) ...@@ -1440,7 +1440,7 @@ void vdo_encode_super_block(u8 *buffer, struct vdo_component_states *states)
* Even though the buffer is a full block, to avoid the potential corruption from a torn * Even though the buffer is a full block, to avoid the potential corruption from a torn
* write, the entire encoding must fit in the first sector. * write, the entire encoding must fit in the first sector.
*/ */
ASSERT_LOG_ONLY(offset <= VDO_SECTOR_SIZE, VDO_ASSERT_LOG_ONLY(offset <= VDO_SECTOR_SIZE,
"entire superblock must fit in one sector"); "entire superblock must fit in one sector");
} }
...@@ -1476,7 +1476,7 @@ int vdo_decode_super_block(u8 *buffer) ...@@ -1476,7 +1476,7 @@ int vdo_decode_super_block(u8 *buffer)
checksum = vdo_crc32(buffer, offset); checksum = vdo_crc32(buffer, offset);
decode_u32_le(buffer, &offset, &saved_checksum); decode_u32_le(buffer, &offset, &saved_checksum);
result = ASSERT(offset == VDO_SUPER_BLOCK_FIXED_SIZE + VDO_COMPONENT_DATA_SIZE, result = VDO_ASSERT(offset == VDO_SUPER_BLOCK_FIXED_SIZE + VDO_COMPONENT_DATA_SIZE,
"must have decoded entire superblock payload"); "must have decoded entire superblock payload");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
......
...@@ -281,8 +281,9 @@ int uds_register_error_block(const char *block_name, int first_error, ...@@ -281,8 +281,9 @@ int uds_register_error_block(const char *block_name, int first_error,
.infos = infos, .infos = infos,
}; };
result = ASSERT(first_error < next_free_error, "well-defined error block range"); result = VDO_ASSERT(first_error < next_free_error,
if (result != UDS_SUCCESS) "well-defined error block range");
if (result != VDO_SUCCESS)
return result; return result;
if (registered_errors.count == registered_errors.allocated) { if (registered_errors.count == registered_errors.allocated) {
......
...@@ -59,7 +59,7 @@ struct flusher { ...@@ -59,7 +59,7 @@ struct flusher {
*/ */
static inline void assert_on_flusher_thread(struct flusher *flusher, const char *caller) static inline void assert_on_flusher_thread(struct flusher *flusher, const char *caller)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == flusher->thread_id), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == flusher->thread_id),
"%s() called from flusher thread", caller); "%s() called from flusher thread", caller);
} }
...@@ -272,7 +272,7 @@ static void flush_vdo(struct vdo_completion *completion) ...@@ -272,7 +272,7 @@ static void flush_vdo(struct vdo_completion *completion)
int result; int result;
assert_on_flusher_thread(flusher, __func__); assert_on_flusher_thread(flusher, __func__);
result = ASSERT(vdo_is_state_normal(&flusher->state), result = VDO_ASSERT(vdo_is_state_normal(&flusher->state),
"flusher is in normal operation"); "flusher is in normal operation");
if (result != VDO_SUCCESS) { if (result != VDO_SUCCESS) {
vdo_enter_read_only_mode(flusher->vdo, result); vdo_enter_read_only_mode(flusher->vdo, result);
...@@ -330,7 +330,7 @@ void vdo_complete_flushes(struct flusher *flusher) ...@@ -330,7 +330,7 @@ void vdo_complete_flushes(struct flusher *flusher)
if (flush->flush_generation >= oldest_active_generation) if (flush->flush_generation >= oldest_active_generation)
return; return;
ASSERT_LOG_ONLY((flush->flush_generation == VDO_ASSERT_LOG_ONLY((flush->flush_generation ==
flusher->first_unacknowledged_generation), flusher->first_unacknowledged_generation),
"acknowledged next expected flush, %llu, was: %llu", "acknowledged next expected flush, %llu, was: %llu",
(unsigned long long) flusher->first_unacknowledged_generation, (unsigned long long) flusher->first_unacknowledged_generation,
...@@ -400,7 +400,7 @@ void vdo_launch_flush(struct vdo *vdo, struct bio *bio) ...@@ -400,7 +400,7 @@ void vdo_launch_flush(struct vdo *vdo, struct bio *bio)
struct flusher *flusher = vdo->flusher; struct flusher *flusher = vdo->flusher;
const struct admin_state_code *code = vdo_get_admin_state_code(&flusher->state); const struct admin_state_code *code = vdo_get_admin_state_code(&flusher->state);
ASSERT_LOG_ONLY(!code->quiescent, "Flushing not allowed in state %s", VDO_ASSERT_LOG_ONLY(!code->quiescent, "Flushing not allowed in state %s",
code->name); code->name);
spin_lock(&flusher->lock); spin_lock(&flusher->lock);
......
...@@ -110,13 +110,13 @@ static struct vdo_completion *poll_for_completion(struct simple_work_queue *queu ...@@ -110,13 +110,13 @@ static struct vdo_completion *poll_for_completion(struct simple_work_queue *queu
static void enqueue_work_queue_completion(struct simple_work_queue *queue, static void enqueue_work_queue_completion(struct simple_work_queue *queue,
struct vdo_completion *completion) struct vdo_completion *completion)
{ {
ASSERT_LOG_ONLY(completion->my_queue == NULL, VDO_ASSERT_LOG_ONLY(completion->my_queue == NULL,
"completion %px (fn %px) to enqueue (%px) is not already queued (%px)", "completion %px (fn %px) to enqueue (%px) is not already queued (%px)",
completion, completion->callback, queue, completion->my_queue); completion, completion->callback, queue, completion->my_queue);
if (completion->priority == VDO_WORK_Q_DEFAULT_PRIORITY) if (completion->priority == VDO_WORK_Q_DEFAULT_PRIORITY)
completion->priority = queue->common.type->default_priority; completion->priority = queue->common.type->default_priority;
if (ASSERT(completion->priority <= queue->common.type->max_priority, if (VDO_ASSERT(completion->priority <= queue->common.type->max_priority,
"priority is in range for queue") != VDO_SUCCESS) "priority is in range for queue") != VDO_SUCCESS)
completion->priority = 0; completion->priority = 0;
...@@ -222,9 +222,9 @@ static struct vdo_completion *wait_for_next_completion(struct simple_work_queue ...@@ -222,9 +222,9 @@ static struct vdo_completion *wait_for_next_completion(struct simple_work_queue
static void process_completion(struct simple_work_queue *queue, static void process_completion(struct simple_work_queue *queue,
struct vdo_completion *completion) struct vdo_completion *completion)
{ {
if (ASSERT(completion->my_queue == &queue->common, if (VDO_ASSERT(completion->my_queue == &queue->common,
"completion %px from queue %px marked as being in this queue (%px)", "completion %px from queue %px marked as being in this queue (%px)",
completion, queue, completion->my_queue) == UDS_SUCCESS) completion, queue, completion->my_queue) == VDO_SUCCESS)
completion->my_queue = NULL; completion->my_queue = NULL;
vdo_run_completion(completion); vdo_run_completion(completion);
...@@ -319,7 +319,7 @@ static int make_simple_work_queue(const char *thread_name_prefix, const char *na ...@@ -319,7 +319,7 @@ static int make_simple_work_queue(const char *thread_name_prefix, const char *na
struct task_struct *thread = NULL; struct task_struct *thread = NULL;
int result; int result;
ASSERT_LOG_ONLY((type->max_priority <= VDO_WORK_Q_MAX_PRIORITY), VDO_ASSERT_LOG_ONLY((type->max_priority <= VDO_WORK_Q_MAX_PRIORITY),
"queue priority count %u within limit %u", type->max_priority, "queue priority count %u within limit %u", type->max_priority,
VDO_WORK_Q_MAX_PRIORITY); VDO_WORK_Q_MAX_PRIORITY);
......
...@@ -94,7 +94,7 @@ static void count_all_bios(struct vio *vio, struct bio *bio) ...@@ -94,7 +94,7 @@ static void count_all_bios(struct vio *vio, struct bio *bio)
*/ */
static void assert_in_bio_zone(struct vio *vio) static void assert_in_bio_zone(struct vio *vio)
{ {
ASSERT_LOG_ONLY(!in_interrupt(), "not in interrupt context"); VDO_ASSERT_LOG_ONLY(!in_interrupt(), "not in interrupt context");
assert_vio_in_bio_zone(vio); assert_vio_in_bio_zone(vio);
} }
...@@ -300,7 +300,7 @@ static bool try_bio_map_merge(struct vio *vio) ...@@ -300,7 +300,7 @@ static bool try_bio_map_merge(struct vio *vio)
mutex_unlock(&bio_queue_data->lock); mutex_unlock(&bio_queue_data->lock);
/* We don't care about failure of int_map_put in this case. */ /* We don't care about failure of int_map_put in this case. */
ASSERT_LOG_ONLY(result == VDO_SUCCESS, "bio map insertion succeeds"); VDO_ASSERT_LOG_ONLY(result == VDO_SUCCESS, "bio map insertion succeeds");
return merged; return merged;
} }
...@@ -345,8 +345,8 @@ void __submit_metadata_vio(struct vio *vio, physical_block_number_t physical, ...@@ -345,8 +345,8 @@ void __submit_metadata_vio(struct vio *vio, physical_block_number_t physical,
const struct admin_state_code *code = vdo_get_admin_state(completion->vdo); const struct admin_state_code *code = vdo_get_admin_state(completion->vdo);
ASSERT_LOG_ONLY(!code->quiescent, "I/O not allowed in state %s", code->name); VDO_ASSERT_LOG_ONLY(!code->quiescent, "I/O not allowed in state %s", code->name);
ASSERT_LOG_ONLY(vio->bio->bi_next == NULL, "metadata bio has no next bio"); VDO_ASSERT_LOG_ONLY(vio->bio->bi_next == NULL, "metadata bio has no next bio");
vdo_reset_completion(completion); vdo_reset_completion(completion);
completion->error_handler = error_handler; completion->error_handler = error_handler;
......
...@@ -142,7 +142,7 @@ void vdo_free_logical_zones(struct logical_zones *zones) ...@@ -142,7 +142,7 @@ void vdo_free_logical_zones(struct logical_zones *zones)
static inline void assert_on_zone_thread(struct logical_zone *zone, const char *what) static inline void assert_on_zone_thread(struct logical_zone *zone, const char *what)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == zone->thread_id), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == zone->thread_id),
"%s() called on correct thread", what); "%s() called on correct thread", what);
} }
...@@ -247,7 +247,7 @@ void vdo_increment_logical_zone_flush_generation(struct logical_zone *zone, ...@@ -247,7 +247,7 @@ void vdo_increment_logical_zone_flush_generation(struct logical_zone *zone,
sequence_number_t expected_generation) sequence_number_t expected_generation)
{ {
assert_on_zone_thread(zone, __func__); assert_on_zone_thread(zone, __func__);
ASSERT_LOG_ONLY((zone->flush_generation == expected_generation), VDO_ASSERT_LOG_ONLY((zone->flush_generation == expected_generation),
"logical zone %u flush generation %llu should be %llu before increment", "logical zone %u flush generation %llu should be %llu before increment",
zone->zone_number, (unsigned long long) zone->flush_generation, zone->zone_number, (unsigned long long) zone->flush_generation,
(unsigned long long) expected_generation); (unsigned long long) expected_generation);
...@@ -267,7 +267,7 @@ void vdo_acquire_flush_generation_lock(struct data_vio *data_vio) ...@@ -267,7 +267,7 @@ void vdo_acquire_flush_generation_lock(struct data_vio *data_vio)
struct logical_zone *zone = data_vio->logical.zone; struct logical_zone *zone = data_vio->logical.zone;
assert_on_zone_thread(zone, __func__); assert_on_zone_thread(zone, __func__);
ASSERT_LOG_ONLY(vdo_is_state_normal(&zone->state), "vdo state is normal"); VDO_ASSERT_LOG_ONLY(vdo_is_state_normal(&zone->state), "vdo state is normal");
data_vio->flush_generation = zone->flush_generation; data_vio->flush_generation = zone->flush_generation;
list_add_tail(&data_vio->write_entry, &zone->write_vios); list_add_tail(&data_vio->write_entry, &zone->write_vios);
...@@ -332,7 +332,7 @@ void vdo_release_flush_generation_lock(struct data_vio *data_vio) ...@@ -332,7 +332,7 @@ void vdo_release_flush_generation_lock(struct data_vio *data_vio)
return; return;
list_del_init(&data_vio->write_entry); list_del_init(&data_vio->write_entry);
ASSERT_LOG_ONLY((zone->oldest_active_generation <= data_vio->flush_generation), VDO_ASSERT_LOG_ONLY((zone->oldest_active_generation <= data_vio->flush_generation),
"data_vio releasing lock on generation %llu is not older than oldest active generation %llu", "data_vio releasing lock on generation %llu is not older than oldest active generation %llu",
(unsigned long long) data_vio->flush_generation, (unsigned long long) data_vio->flush_generation,
(unsigned long long) zone->oldest_active_generation); (unsigned long long) zone->oldest_active_generation);
......
...@@ -385,10 +385,10 @@ void vdo_memory_init(void) ...@@ -385,10 +385,10 @@ void vdo_memory_init(void)
void vdo_memory_exit(void) void vdo_memory_exit(void)
{ {
ASSERT_LOG_ONLY(memory_stats.kmalloc_bytes == 0, VDO_ASSERT_LOG_ONLY(memory_stats.kmalloc_bytes == 0,
"kmalloc memory used (%zd bytes in %zd blocks) is returned to the kernel", "kmalloc memory used (%zd bytes in %zd blocks) is returned to the kernel",
memory_stats.kmalloc_bytes, memory_stats.kmalloc_blocks); memory_stats.kmalloc_bytes, memory_stats.kmalloc_blocks);
ASSERT_LOG_ONLY(memory_stats.vmalloc_bytes == 0, VDO_ASSERT_LOG_ONLY(memory_stats.vmalloc_bytes == 0,
"vmalloc memory used (%zd bytes in %zd blocks) is returned to the kernel", "vmalloc memory used (%zd bytes in %zd blocks) is returned to the kernel",
memory_stats.vmalloc_bytes, memory_stats.vmalloc_blocks); memory_stats.vmalloc_bytes, memory_stats.vmalloc_blocks);
uds_log_debug("peak usage %zd bytes", memory_stats.peak_bytes); uds_log_debug("peak usage %zd bytes", memory_stats.peak_bytes);
......
...@@ -86,7 +86,7 @@ int vdo_get_compressed_block_fragment(enum block_mapping_state mapping_state, ...@@ -86,7 +86,7 @@ int vdo_get_compressed_block_fragment(enum block_mapping_state mapping_state,
*/ */
static inline void assert_on_packer_thread(struct packer *packer, const char *caller) static inline void assert_on_packer_thread(struct packer *packer, const char *caller)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == packer->thread_id), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == packer->thread_id),
"%s() called from packer thread", caller); "%s() called from packer thread", caller);
} }
...@@ -569,7 +569,7 @@ void vdo_attempt_packing(struct data_vio *data_vio) ...@@ -569,7 +569,7 @@ void vdo_attempt_packing(struct data_vio *data_vio)
assert_on_packer_thread(packer, __func__); assert_on_packer_thread(packer, __func__);
result = ASSERT((status.stage == DATA_VIO_COMPRESSING), result = VDO_ASSERT((status.stage == DATA_VIO_COMPRESSING),
"attempt to pack data_vio not ready for packing, stage: %u", "attempt to pack data_vio not ready for packing, stage: %u",
status.stage); status.stage);
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
...@@ -671,7 +671,7 @@ void vdo_remove_lock_holder_from_packer(struct vdo_completion *completion) ...@@ -671,7 +671,7 @@ void vdo_remove_lock_holder_from_packer(struct vdo_completion *completion)
lock_holder = vdo_forget(data_vio->compression.lock_holder); lock_holder = vdo_forget(data_vio->compression.lock_holder);
bin = lock_holder->compression.bin; bin = lock_holder->compression.bin;
ASSERT_LOG_ONLY((bin != NULL), "data_vio in packer has a bin"); VDO_ASSERT_LOG_ONLY((bin != NULL), "data_vio in packer has a bin");
slot = lock_holder->compression.slot; slot = lock_holder->compression.slot;
bin->slots_used--; bin->slots_used--;
......
...@@ -13,7 +13,6 @@ ...@@ -13,7 +13,6 @@
/* Utilities for asserting that certain conditions are met */ /* Utilities for asserting that certain conditions are met */
#define STRINGIFY(X) #X #define STRINGIFY(X) #X
#define STRINGIFY_VALUE(X) STRINGIFY(X)
/* /*
* A hack to apply the "warn if unused" attribute to an integral expression. * A hack to apply the "warn if unused" attribute to an integral expression.
...@@ -23,19 +22,23 @@ ...@@ -23,19 +22,23 @@
* expression. With optimization enabled, this function contributes no additional instructions, but * expression. With optimization enabled, this function contributes no additional instructions, but
* the warn_unused_result attribute still applies to the code calling it. * the warn_unused_result attribute still applies to the code calling it.
*/ */
static inline int __must_check uds_must_use(int value) static inline int __must_check vdo_must_use(int value)
{ {
return value; return value;
} }
/* Assert that an expression is true and return an error if it is not. */ /* Assert that an expression is true and return an error if it is not. */
#define ASSERT(expr, ...) uds_must_use(__UDS_ASSERT(expr, __VA_ARGS__)) #define VDO_ASSERT(expr, ...) vdo_must_use(__VDO_ASSERT(expr, __VA_ARGS__))
/* Log a message if the expression is not true. */ /* Log a message if the expression is not true. */
#define ASSERT_LOG_ONLY(expr, ...) __UDS_ASSERT(expr, __VA_ARGS__) #define VDO_ASSERT_LOG_ONLY(expr, ...) __VDO_ASSERT(expr, __VA_ARGS__)
#define __UDS_ASSERT(expr, ...) \ /* For use by UDS */
(likely(expr) ? UDS_SUCCESS \ #define ASSERT(expr, ...) VDO_ASSERT(expr, __VA_ARGS__)
#define ASSERT_LOG_ONLY(expr, ...) __VDO_ASSERT(expr, __VA_ARGS__)
#define __VDO_ASSERT(expr, ...) \
(likely(expr) ? VDO_SUCCESS \
: uds_assertion_failed(STRINGIFY(expr), __FILE__, __LINE__, __VA_ARGS__)) : uds_assertion_failed(STRINGIFY(expr), __FILE__, __LINE__, __VA_ARGS__))
/* Log an assertion failure message. */ /* Log an assertion failure message. */
......
...@@ -80,11 +80,11 @@ static inline void set_pbn_lock_type(struct pbn_lock *lock, enum pbn_lock_type t ...@@ -80,11 +80,11 @@ static inline void set_pbn_lock_type(struct pbn_lock *lock, enum pbn_lock_type t
*/ */
void vdo_downgrade_pbn_write_lock(struct pbn_lock *lock, bool compressed_write) void vdo_downgrade_pbn_write_lock(struct pbn_lock *lock, bool compressed_write)
{ {
ASSERT_LOG_ONLY(!vdo_is_pbn_read_lock(lock), VDO_ASSERT_LOG_ONLY(!vdo_is_pbn_read_lock(lock),
"PBN lock must not already have been downgraded"); "PBN lock must not already have been downgraded");
ASSERT_LOG_ONLY(!has_lock_type(lock, VIO_BLOCK_MAP_WRITE_LOCK), VDO_ASSERT_LOG_ONLY(!has_lock_type(lock, VIO_BLOCK_MAP_WRITE_LOCK),
"must not downgrade block map write locks"); "must not downgrade block map write locks");
ASSERT_LOG_ONLY(lock->holder_count == 1, VDO_ASSERT_LOG_ONLY(lock->holder_count == 1,
"PBN write lock should have one holder but has %u", "PBN write lock should have one holder but has %u",
lock->holder_count); lock->holder_count);
/* /*
...@@ -128,7 +128,7 @@ bool vdo_claim_pbn_lock_increment(struct pbn_lock *lock) ...@@ -128,7 +128,7 @@ bool vdo_claim_pbn_lock_increment(struct pbn_lock *lock)
*/ */
void vdo_assign_pbn_lock_provisional_reference(struct pbn_lock *lock) void vdo_assign_pbn_lock_provisional_reference(struct pbn_lock *lock)
{ {
ASSERT_LOG_ONLY(!lock->has_provisional_reference, VDO_ASSERT_LOG_ONLY(!lock->has_provisional_reference,
"lock does not have a provisional reference"); "lock does not have a provisional reference");
lock->has_provisional_reference = true; lock->has_provisional_reference = true;
} }
...@@ -221,7 +221,7 @@ static void return_pbn_lock_to_pool(struct pbn_lock_pool *pool, struct pbn_lock ...@@ -221,7 +221,7 @@ static void return_pbn_lock_to_pool(struct pbn_lock_pool *pool, struct pbn_lock
INIT_LIST_HEAD(&idle->entry); INIT_LIST_HEAD(&idle->entry);
list_add_tail(&idle->entry, &pool->idle_list); list_add_tail(&idle->entry, &pool->idle_list);
ASSERT_LOG_ONLY(pool->borrowed > 0, "shouldn't return more than borrowed"); VDO_ASSERT_LOG_ONLY(pool->borrowed > 0, "shouldn't return more than borrowed");
pool->borrowed -= 1; pool->borrowed -= 1;
} }
...@@ -267,7 +267,7 @@ static void free_pbn_lock_pool(struct pbn_lock_pool *pool) ...@@ -267,7 +267,7 @@ static void free_pbn_lock_pool(struct pbn_lock_pool *pool)
if (pool == NULL) if (pool == NULL)
return; return;
ASSERT_LOG_ONLY(pool->borrowed == 0, VDO_ASSERT_LOG_ONLY(pool->borrowed == 0,
"All PBN locks must be returned to the pool before it is freed, but %zu locks are still on loan", "All PBN locks must be returned to the pool before it is freed, but %zu locks are still on loan",
pool->borrowed); pool->borrowed);
vdo_free(pool); vdo_free(pool);
...@@ -298,7 +298,7 @@ static int __must_check borrow_pbn_lock_from_pool(struct pbn_lock_pool *pool, ...@@ -298,7 +298,7 @@ static int __must_check borrow_pbn_lock_from_pool(struct pbn_lock_pool *pool,
"no free PBN locks left to borrow"); "no free PBN locks left to borrow");
pool->borrowed += 1; pool->borrowed += 1;
result = ASSERT(!list_empty(&pool->idle_list), result = VDO_ASSERT(!list_empty(&pool->idle_list),
"idle list should not be empty if pool not at capacity"); "idle list should not be empty if pool not at capacity");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -447,7 +447,7 @@ int vdo_attempt_physical_zone_pbn_lock(struct physical_zone *zone, ...@@ -447,7 +447,7 @@ int vdo_attempt_physical_zone_pbn_lock(struct physical_zone *zone,
result = borrow_pbn_lock_from_pool(zone->lock_pool, type, &new_lock); result = borrow_pbn_lock_from_pool(zone->lock_pool, type, &new_lock);
if (result != VDO_SUCCESS) { if (result != VDO_SUCCESS) {
ASSERT_LOG_ONLY(false, "must always be able to borrow a PBN lock"); VDO_ASSERT_LOG_ONLY(false, "must always be able to borrow a PBN lock");
return result; return result;
} }
...@@ -461,7 +461,7 @@ int vdo_attempt_physical_zone_pbn_lock(struct physical_zone *zone, ...@@ -461,7 +461,7 @@ int vdo_attempt_physical_zone_pbn_lock(struct physical_zone *zone,
if (lock != NULL) { if (lock != NULL) {
/* The lock is already held, so we don't need the borrowed one. */ /* The lock is already held, so we don't need the borrowed one. */
return_pbn_lock_to_pool(zone->lock_pool, vdo_forget(new_lock)); return_pbn_lock_to_pool(zone->lock_pool, vdo_forget(new_lock));
result = ASSERT(lock->holder_count > 0, "physical block %llu lock held", result = VDO_ASSERT(lock->holder_count > 0, "physical block %llu lock held",
(unsigned long long) pbn); (unsigned long long) pbn);
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -485,7 +485,7 @@ static int allocate_and_lock_block(struct allocation *allocation) ...@@ -485,7 +485,7 @@ static int allocate_and_lock_block(struct allocation *allocation)
int result; int result;
struct pbn_lock *lock; struct pbn_lock *lock;
ASSERT_LOG_ONLY(allocation->lock == NULL, VDO_ASSERT_LOG_ONLY(allocation->lock == NULL,
"must not allocate a block while already holding a lock on one"); "must not allocate a block while already holding a lock on one");
result = vdo_allocate_block(allocation->zone->allocator, &allocation->pbn); result = vdo_allocate_block(allocation->zone->allocator, &allocation->pbn);
...@@ -617,7 +617,7 @@ void vdo_release_physical_zone_pbn_lock(struct physical_zone *zone, ...@@ -617,7 +617,7 @@ void vdo_release_physical_zone_pbn_lock(struct physical_zone *zone,
if (lock == NULL) if (lock == NULL)
return; return;
ASSERT_LOG_ONLY(lock->holder_count > 0, VDO_ASSERT_LOG_ONLY(lock->holder_count > 0,
"should not be releasing a lock that is not held"); "should not be releasing a lock that is not held");
lock->holder_count -= 1; lock->holder_count -= 1;
...@@ -627,7 +627,7 @@ void vdo_release_physical_zone_pbn_lock(struct physical_zone *zone, ...@@ -627,7 +627,7 @@ void vdo_release_physical_zone_pbn_lock(struct physical_zone *zone,
} }
holder = vdo_int_map_remove(zone->pbn_operations, locked_pbn); holder = vdo_int_map_remove(zone->pbn_operations, locked_pbn);
ASSERT_LOG_ONLY((lock == holder), "physical block lock mismatch for block %llu", VDO_ASSERT_LOG_ONLY((lock == holder), "physical block lock mismatch for block %llu",
(unsigned long long) locked_pbn); (unsigned long long) locked_pbn);
release_pbn_lock_provisional_reference(lock, locked_pbn, zone->allocator); release_pbn_lock_provisional_reference(lock, locked_pbn, zone->allocator);
......
...@@ -127,7 +127,7 @@ void vdo_reset_priority_table(struct priority_table *table) ...@@ -127,7 +127,7 @@ void vdo_reset_priority_table(struct priority_table *table)
void vdo_priority_table_enqueue(struct priority_table *table, unsigned int priority, void vdo_priority_table_enqueue(struct priority_table *table, unsigned int priority,
struct list_head *entry) struct list_head *entry)
{ {
ASSERT_LOG_ONLY((priority <= table->max_priority), VDO_ASSERT_LOG_ONLY((priority <= table->max_priority),
"entry priority must be valid for the table"); "entry priority must be valid for the table");
/* Append the entry to the queue in the specified bucket. */ /* Append the entry to the queue in the specified bucket. */
......
...@@ -119,7 +119,7 @@ static bool is_journal_zone_locked(struct recovery_journal *journal, ...@@ -119,7 +119,7 @@ static bool is_journal_zone_locked(struct recovery_journal *journal,
/* Pairs with barrier in vdo_release_journal_entry_lock() */ /* Pairs with barrier in vdo_release_journal_entry_lock() */
smp_rmb(); smp_rmb();
ASSERT_LOG_ONLY((decrements <= journal_value), VDO_ASSERT_LOG_ONLY((decrements <= journal_value),
"journal zone lock counter must not underflow"); "journal zone lock counter must not underflow");
return (journal_value != decrements); return (journal_value != decrements);
} }
...@@ -150,7 +150,7 @@ void vdo_release_recovery_journal_block_reference(struct recovery_journal *journ ...@@ -150,7 +150,7 @@ void vdo_release_recovery_journal_block_reference(struct recovery_journal *journ
lock_number = vdo_get_recovery_journal_block_number(journal, sequence_number); lock_number = vdo_get_recovery_journal_block_number(journal, sequence_number);
current_value = get_counter(journal, lock_number, zone_type, zone_id); current_value = get_counter(journal, lock_number, zone_type, zone_id);
ASSERT_LOG_ONLY((*current_value >= 1), VDO_ASSERT_LOG_ONLY((*current_value >= 1),
"decrement of lock counter must not underflow"); "decrement of lock counter must not underflow");
*current_value -= 1; *current_value -= 1;
...@@ -254,7 +254,7 @@ static inline bool __must_check is_block_full(const struct recovery_journal_bloc ...@@ -254,7 +254,7 @@ static inline bool __must_check is_block_full(const struct recovery_journal_bloc
static void assert_on_journal_thread(struct recovery_journal *journal, static void assert_on_journal_thread(struct recovery_journal *journal,
const char *function_name) const char *function_name)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == journal->thread_id), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == journal->thread_id),
"%s() called on journal thread", function_name); "%s() called on journal thread", function_name);
} }
...@@ -353,13 +353,13 @@ static void check_for_drain_complete(struct recovery_journal *journal) ...@@ -353,13 +353,13 @@ static void check_for_drain_complete(struct recovery_journal *journal)
if (vdo_is_state_saving(&journal->state)) { if (vdo_is_state_saving(&journal->state)) {
if (journal->active_block != NULL) { if (journal->active_block != NULL) {
ASSERT_LOG_ONLY(((result == VDO_READ_ONLY) || VDO_ASSERT_LOG_ONLY(((result == VDO_READ_ONLY) ||
!is_block_dirty(journal->active_block)), !is_block_dirty(journal->active_block)),
"journal being saved has clean active block"); "journal being saved has clean active block");
recycle_journal_block(journal->active_block); recycle_journal_block(journal->active_block);
} }
ASSERT_LOG_ONLY(list_empty(&journal->active_tail_blocks), VDO_ASSERT_LOG_ONLY(list_empty(&journal->active_tail_blocks),
"all blocks in a journal being saved must be inactive"); "all blocks in a journal being saved must be inactive");
} }
...@@ -800,7 +800,7 @@ void vdo_free_recovery_journal(struct recovery_journal *journal) ...@@ -800,7 +800,7 @@ void vdo_free_recovery_journal(struct recovery_journal *journal)
* requires opening before use. * requires opening before use.
*/ */
if (!vdo_is_state_quiescent(&journal->state)) { if (!vdo_is_state_quiescent(&journal->state)) {
ASSERT_LOG_ONLY(list_empty(&journal->active_tail_blocks), VDO_ASSERT_LOG_ONLY(list_empty(&journal->active_tail_blocks),
"journal being freed has no active tail blocks"); "journal being freed has no active tail blocks");
} else if (!vdo_is_state_saved(&journal->state) && } else if (!vdo_is_state_saved(&journal->state) &&
!list_empty(&journal->active_tail_blocks)) { !list_empty(&journal->active_tail_blocks)) {
...@@ -989,7 +989,7 @@ static void initialize_lock_count(struct recovery_journal *journal) ...@@ -989,7 +989,7 @@ static void initialize_lock_count(struct recovery_journal *journal)
atomic_t *decrement_counter = get_decrement_counter(journal, lock_number); atomic_t *decrement_counter = get_decrement_counter(journal, lock_number);
journal_value = get_counter(journal, lock_number, VDO_ZONE_TYPE_JOURNAL, 0); journal_value = get_counter(journal, lock_number, VDO_ZONE_TYPE_JOURNAL, 0);
ASSERT_LOG_ONLY((*journal_value == atomic_read(decrement_counter)), VDO_ASSERT_LOG_ONLY((*journal_value == atomic_read(decrement_counter)),
"count to be initialized not in use"); "count to be initialized not in use");
*journal_value = journal->entries_per_block + 1; *journal_value = journal->entries_per_block + 1;
atomic_set(decrement_counter, 0); atomic_set(decrement_counter, 0);
...@@ -1175,7 +1175,7 @@ static void continue_committed_waiter(struct vdo_waiter *waiter, void *context) ...@@ -1175,7 +1175,7 @@ static void continue_committed_waiter(struct vdo_waiter *waiter, void *context)
int result = (is_read_only(journal) ? VDO_READ_ONLY : VDO_SUCCESS); int result = (is_read_only(journal) ? VDO_READ_ONLY : VDO_SUCCESS);
bool has_decrement; bool has_decrement;
ASSERT_LOG_ONLY(vdo_before_journal_point(&journal->commit_point, VDO_ASSERT_LOG_ONLY(vdo_before_journal_point(&journal->commit_point,
&data_vio->recovery_journal_point), &data_vio->recovery_journal_point),
"DataVIOs released from recovery journal in order. Recovery journal point is (%llu, %u), but commit waiter point is (%llu, %u)", "DataVIOs released from recovery journal in order. Recovery journal point is (%llu, %u), but commit waiter point is (%llu, %u)",
(unsigned long long) journal->commit_point.sequence_number, (unsigned long long) journal->commit_point.sequence_number,
...@@ -1281,7 +1281,7 @@ static void complete_write(struct vdo_completion *completion) ...@@ -1281,7 +1281,7 @@ static void complete_write(struct vdo_completion *completion)
journal->last_write_acknowledged = block->sequence_number; journal->last_write_acknowledged = block->sequence_number;
last_active_block = get_journal_block(&journal->active_tail_blocks); last_active_block = get_journal_block(&journal->active_tail_blocks);
ASSERT_LOG_ONLY((block->sequence_number >= last_active_block->sequence_number), VDO_ASSERT_LOG_ONLY((block->sequence_number >= last_active_block->sequence_number),
"completed journal write is still active"); "completed journal write is still active");
notify_commit_waiters(journal); notify_commit_waiters(journal);
...@@ -1456,7 +1456,7 @@ void vdo_add_recovery_journal_entry(struct recovery_journal *journal, ...@@ -1456,7 +1456,7 @@ void vdo_add_recovery_journal_entry(struct recovery_journal *journal,
return; return;
} }
ASSERT_LOG_ONLY(data_vio->recovery_sequence_number == 0, VDO_ASSERT_LOG_ONLY(data_vio->recovery_sequence_number == 0,
"journal lock not held for new entry"); "journal lock not held for new entry");
vdo_advance_journal_point(&journal->append_point, journal->entries_per_block); vdo_advance_journal_point(&journal->append_point, journal->entries_per_block);
...@@ -1564,12 +1564,12 @@ void vdo_acquire_recovery_journal_block_reference(struct recovery_journal *journ ...@@ -1564,12 +1564,12 @@ void vdo_acquire_recovery_journal_block_reference(struct recovery_journal *journ
if (sequence_number == 0) if (sequence_number == 0)
return; return;
ASSERT_LOG_ONLY((zone_type != VDO_ZONE_TYPE_JOURNAL), VDO_ASSERT_LOG_ONLY((zone_type != VDO_ZONE_TYPE_JOURNAL),
"invalid lock count increment from journal zone"); "invalid lock count increment from journal zone");
lock_number = vdo_get_recovery_journal_block_number(journal, sequence_number); lock_number = vdo_get_recovery_journal_block_number(journal, sequence_number);
current_value = get_counter(journal, lock_number, zone_type, zone_id); current_value = get_counter(journal, lock_number, zone_type, zone_id);
ASSERT_LOG_ONLY(*current_value < U16_MAX, VDO_ASSERT_LOG_ONLY(*current_value < U16_MAX,
"increment of lock counter must not overflow"); "increment of lock counter must not overflow");
if (*current_value == 0) { if (*current_value == 0) {
......
...@@ -976,7 +976,7 @@ find_entry_starting_next_page(struct repair_completion *repair, ...@@ -976,7 +976,7 @@ find_entry_starting_next_page(struct repair_completion *repair,
if (needs_sort) { if (needs_sort) {
struct numbered_block_mapping *just_sorted_entry = struct numbered_block_mapping *just_sorted_entry =
sort_next_heap_element(repair); sort_next_heap_element(repair);
ASSERT_LOG_ONLY(just_sorted_entry < current_entry, VDO_ASSERT_LOG_ONLY(just_sorted_entry < current_entry,
"heap is returning elements in an unexpected order"); "heap is returning elements in an unexpected order");
} }
...@@ -1129,7 +1129,7 @@ static void recover_block_map(struct vdo_completion *completion) ...@@ -1129,7 +1129,7 @@ static void recover_block_map(struct vdo_completion *completion)
repair->current_entry = &repair->entries[repair->block_map_entry_count - 1]; repair->current_entry = &repair->entries[repair->block_map_entry_count - 1];
first_sorted_entry = sort_next_heap_element(repair); first_sorted_entry = sort_next_heap_element(repair);
ASSERT_LOG_ONLY(first_sorted_entry == repair->current_entry, VDO_ASSERT_LOG_ONLY(first_sorted_entry == repair->current_entry,
"heap is returning elements in an unexpected order"); "heap is returning elements in an unexpected order");
/* Prevent any page from being processed until all pages have been launched. */ /* Prevent any page from being processed until all pages have been launched. */
...@@ -1489,7 +1489,7 @@ static int extract_new_mappings(struct repair_completion *repair) ...@@ -1489,7 +1489,7 @@ static int extract_new_mappings(struct repair_completion *repair)
repair->block_map_entry_count++; repair->block_map_entry_count++;
} }
result = ASSERT((repair->block_map_entry_count <= repair->entry_count), result = VDO_ASSERT((repair->block_map_entry_count <= repair->entry_count),
"approximate entry count is an upper bound"); "approximate entry count is an upper bound");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
vdo_enter_read_only_mode(vdo, result); vdo_enter_read_only_mode(vdo, result);
......
...@@ -149,7 +149,7 @@ static void mark_slab_journal_dirty(struct slab_journal *journal, sequence_numbe ...@@ -149,7 +149,7 @@ static void mark_slab_journal_dirty(struct slab_journal *journal, sequence_numbe
struct slab_journal *dirty_journal; struct slab_journal *dirty_journal;
struct list_head *dirty_list = &journal->slab->allocator->dirty_slab_journals; struct list_head *dirty_list = &journal->slab->allocator->dirty_slab_journals;
ASSERT_LOG_ONLY(journal->recovery_lock == 0, "slab journal was clean"); VDO_ASSERT_LOG_ONLY(journal->recovery_lock == 0, "slab journal was clean");
journal->recovery_lock = lock; journal->recovery_lock = lock;
list_for_each_entry_reverse(dirty_journal, dirty_list, dirty_entry) { list_for_each_entry_reverse(dirty_journal, dirty_list, dirty_entry) {
...@@ -216,7 +216,7 @@ static u8 __must_check compute_fullness_hint(struct slab_depot *depot, ...@@ -216,7 +216,7 @@ static u8 __must_check compute_fullness_hint(struct slab_depot *depot,
{ {
block_count_t hint; block_count_t hint;
ASSERT_LOG_ONLY((free_blocks < (1 << 23)), "free blocks must be less than 2^23"); VDO_ASSERT_LOG_ONLY((free_blocks < (1 << 23)), "free blocks must be less than 2^23");
if (free_blocks == 0) if (free_blocks == 0)
return 0; return 0;
...@@ -532,10 +532,10 @@ static void adjust_slab_journal_block_reference(struct slab_journal *journal, ...@@ -532,10 +532,10 @@ static void adjust_slab_journal_block_reference(struct slab_journal *journal,
return; return;
} }
ASSERT_LOG_ONLY((adjustment != 0), "adjustment must be non-zero"); VDO_ASSERT_LOG_ONLY((adjustment != 0), "adjustment must be non-zero");
lock = get_lock(journal, sequence_number); lock = get_lock(journal, sequence_number);
if (adjustment < 0) { if (adjustment < 0) {
ASSERT_LOG_ONLY((-adjustment <= lock->count), VDO_ASSERT_LOG_ONLY((-adjustment <= lock->count),
"adjustment %d of lock count %u for slab journal block %llu must not underflow", "adjustment %d of lock count %u for slab journal block %llu must not underflow",
adjustment, lock->count, adjustment, lock->count,
(unsigned long long) sequence_number); (unsigned long long) sequence_number);
...@@ -661,14 +661,14 @@ static void reopen_slab_journal(struct vdo_slab *slab) ...@@ -661,14 +661,14 @@ static void reopen_slab_journal(struct vdo_slab *slab)
struct slab_journal *journal = &slab->journal; struct slab_journal *journal = &slab->journal;
sequence_number_t block; sequence_number_t block;
ASSERT_LOG_ONLY(journal->tail_header.entry_count == 0, VDO_ASSERT_LOG_ONLY(journal->tail_header.entry_count == 0,
"vdo_slab journal's active block empty before reopening"); "vdo_slab journal's active block empty before reopening");
journal->head = journal->tail; journal->head = journal->tail;
initialize_journal_state(journal); initialize_journal_state(journal);
/* Ensure no locks are spuriously held on an empty journal. */ /* Ensure no locks are spuriously held on an empty journal. */
for (block = 1; block <= journal->size; block++) { for (block = 1; block <= journal->size; block++) {
ASSERT_LOG_ONLY((get_lock(journal, block)->count == 0), VDO_ASSERT_LOG_ONLY((get_lock(journal, block)->count == 0),
"Scrubbed journal's block %llu is not locked", "Scrubbed journal's block %llu is not locked",
(unsigned long long) block); (unsigned long long) block);
} }
...@@ -757,7 +757,7 @@ static void write_slab_journal_block(struct vdo_waiter *waiter, void *context) ...@@ -757,7 +757,7 @@ static void write_slab_journal_block(struct vdo_waiter *waiter, void *context)
/* Copy the tail block into the vio. */ /* Copy the tail block into the vio. */
memcpy(pooled->vio.data, journal->block, VDO_BLOCK_SIZE); memcpy(pooled->vio.data, journal->block, VDO_BLOCK_SIZE);
ASSERT_LOG_ONLY(unused_entries >= 0, "vdo_slab journal block is not overfull"); VDO_ASSERT_LOG_ONLY(unused_entries >= 0, "vdo_slab journal block is not overfull");
if (unused_entries > 0) { if (unused_entries > 0) {
/* /*
* Release the per-entry locks for any unused entries in the block we are about to * Release the per-entry locks for any unused entries in the block we are about to
...@@ -907,7 +907,7 @@ static void add_entry(struct slab_journal *journal, physical_block_number_t pbn, ...@@ -907,7 +907,7 @@ static void add_entry(struct slab_journal *journal, physical_block_number_t pbn,
struct packed_slab_journal_block *block = journal->block; struct packed_slab_journal_block *block = journal->block;
int result; int result;
result = ASSERT(vdo_before_journal_point(&journal->tail_header.recovery_point, result = VDO_ASSERT(vdo_before_journal_point(&journal->tail_header.recovery_point,
&recovery_point), &recovery_point),
"recovery journal point is monotonically increasing, recovery point: %llu.%u, block recovery point: %llu.%u", "recovery journal point is monotonically increasing, recovery point: %llu.%u, block recovery point: %llu.%u",
(unsigned long long) recovery_point.sequence_number, (unsigned long long) recovery_point.sequence_number,
...@@ -920,7 +920,7 @@ static void add_entry(struct slab_journal *journal, physical_block_number_t pbn, ...@@ -920,7 +920,7 @@ static void add_entry(struct slab_journal *journal, physical_block_number_t pbn,
} }
if (operation == VDO_JOURNAL_BLOCK_MAP_REMAPPING) { if (operation == VDO_JOURNAL_BLOCK_MAP_REMAPPING) {
result = ASSERT((journal->tail_header.entry_count < result = VDO_ASSERT((journal->tail_header.entry_count <
journal->full_entries_per_block), journal->full_entries_per_block),
"block has room for full entries"); "block has room for full entries");
if (result != VDO_SUCCESS) { if (result != VDO_SUCCESS) {
...@@ -1371,7 +1371,7 @@ static unsigned int calculate_slab_priority(struct vdo_slab *slab) ...@@ -1371,7 +1371,7 @@ static unsigned int calculate_slab_priority(struct vdo_slab *slab)
*/ */
static void prioritize_slab(struct vdo_slab *slab) static void prioritize_slab(struct vdo_slab *slab)
{ {
ASSERT_LOG_ONLY(list_empty(&slab->allocq_entry), VDO_ASSERT_LOG_ONLY(list_empty(&slab->allocq_entry),
"a slab must not already be on a ring when prioritizing"); "a slab must not already be on a ring when prioritizing");
slab->priority = calculate_slab_priority(slab); slab->priority = calculate_slab_priority(slab);
vdo_priority_table_enqueue(slab->allocator->prioritized_slabs, vdo_priority_table_enqueue(slab->allocator->prioritized_slabs,
...@@ -1655,7 +1655,7 @@ static int __must_check adjust_reference_count(struct vdo_slab *slab, ...@@ -1655,7 +1655,7 @@ static int __must_check adjust_reference_count(struct vdo_slab *slab,
* the last time it was clean. We must release the per-entry slab journal lock for * the last time it was clean. We must release the per-entry slab journal lock for
* the entry associated with the update we are now doing. * the entry associated with the update we are now doing.
*/ */
result = ASSERT(is_valid_journal_point(slab_journal_point), result = VDO_ASSERT(is_valid_journal_point(slab_journal_point),
"Reference count adjustments need slab journal points."); "Reference count adjustments need slab journal points.");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -1825,7 +1825,7 @@ static void add_entries(struct slab_journal *journal) ...@@ -1825,7 +1825,7 @@ static void add_entries(struct slab_journal *journal)
* scrubbing thresholds, this should never happen. * scrubbing thresholds, this should never happen.
*/ */
if (lock->count > 0) { if (lock->count > 0) {
ASSERT_LOG_ONLY((journal->head + journal->size) == journal->tail, VDO_ASSERT_LOG_ONLY((journal->head + journal->size) == journal->tail,
"New block has locks, but journal is not full"); "New block has locks, but journal is not full");
/* /*
...@@ -1833,7 +1833,7 @@ static void add_entries(struct slab_journal *journal) ...@@ -1833,7 +1833,7 @@ static void add_entries(struct slab_journal *journal)
* block has locks; if the blocking threshold is smaller than the * block has locks; if the blocking threshold is smaller than the
* journal size, the new block cannot possibly have locks already. * journal size, the new block cannot possibly have locks already.
*/ */
ASSERT_LOG_ONLY((journal->blocking_threshold >= journal->size), VDO_ASSERT_LOG_ONLY((journal->blocking_threshold >= journal->size),
"New block can have locks already iff blocking threshold is at the end of the journal"); "New block can have locks already iff blocking threshold is at the end of the journal");
WRITE_ONCE(journal->events->disk_full_count, WRITE_ONCE(journal->events->disk_full_count,
...@@ -2361,7 +2361,7 @@ static int allocate_slab_counters(struct vdo_slab *slab) ...@@ -2361,7 +2361,7 @@ static int allocate_slab_counters(struct vdo_slab *slab)
int result; int result;
size_t index, bytes; size_t index, bytes;
result = ASSERT(slab->reference_blocks == NULL, result = VDO_ASSERT(slab->reference_blocks == NULL,
"vdo_slab %u doesn't allocate refcounts twice", "vdo_slab %u doesn't allocate refcounts twice",
slab->slab_number); slab->slab_number);
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
...@@ -2503,7 +2503,7 @@ static void load_slab_journal(struct vdo_slab *slab) ...@@ -2503,7 +2503,7 @@ static void load_slab_journal(struct vdo_slab *slab)
* 1. This is impossible, due to the scrubbing threshold, on a real system, so * 1. This is impossible, due to the scrubbing threshold, on a real system, so
* don't bother reading the (bogus) data off disk. * don't bother reading the (bogus) data off disk.
*/ */
ASSERT_LOG_ONLY(((journal->size < 16) || VDO_ASSERT_LOG_ONLY(((journal->size < 16) ||
(journal->scrubbing_threshold < (journal->size - 1))), (journal->scrubbing_threshold < (journal->size - 1))),
"Scrubbing threshold protects against reads of unwritten slab journal blocks"); "Scrubbing threshold protects against reads of unwritten slab journal blocks");
vdo_finish_loading_with_result(&slab->state, vdo_finish_loading_with_result(&slab->state,
...@@ -2519,7 +2519,7 @@ static void register_slab_for_scrubbing(struct vdo_slab *slab, bool high_priorit ...@@ -2519,7 +2519,7 @@ static void register_slab_for_scrubbing(struct vdo_slab *slab, bool high_priorit
{ {
struct slab_scrubber *scrubber = &slab->allocator->scrubber; struct slab_scrubber *scrubber = &slab->allocator->scrubber;
ASSERT_LOG_ONLY((slab->status != VDO_SLAB_REBUILT), VDO_ASSERT_LOG_ONLY((slab->status != VDO_SLAB_REBUILT),
"slab to be scrubbed is unrecovered"); "slab to be scrubbed is unrecovered");
if (slab->status != VDO_SLAB_REQUIRES_SCRUBBING) if (slab->status != VDO_SLAB_REQUIRES_SCRUBBING)
...@@ -2547,14 +2547,14 @@ static void queue_slab(struct vdo_slab *slab) ...@@ -2547,14 +2547,14 @@ static void queue_slab(struct vdo_slab *slab)
block_count_t free_blocks; block_count_t free_blocks;
int result; int result;
ASSERT_LOG_ONLY(list_empty(&slab->allocq_entry), VDO_ASSERT_LOG_ONLY(list_empty(&slab->allocq_entry),
"a requeued slab must not already be on a ring"); "a requeued slab must not already be on a ring");
if (vdo_is_read_only(allocator->depot->vdo)) if (vdo_is_read_only(allocator->depot->vdo))
return; return;
free_blocks = slab->free_blocks; free_blocks = slab->free_blocks;
result = ASSERT((free_blocks <= allocator->depot->slab_config.data_blocks), result = VDO_ASSERT((free_blocks <= allocator->depot->slab_config.data_blocks),
"rebuilt slab %u must have a valid free block count (has %llu, expected maximum %llu)", "rebuilt slab %u must have a valid free block count (has %llu, expected maximum %llu)",
slab->slab_number, (unsigned long long) free_blocks, slab->slab_number, (unsigned long long) free_blocks,
(unsigned long long) allocator->depot->slab_config.data_blocks); (unsigned long long) allocator->depot->slab_config.data_blocks);
...@@ -2880,7 +2880,7 @@ static void apply_journal_entries(struct vdo_completion *completion) ...@@ -2880,7 +2880,7 @@ static void apply_journal_entries(struct vdo_completion *completion)
* At the end of rebuild, the reference counters should be accurate to the end of the * At the end of rebuild, the reference counters should be accurate to the end of the
* journal we just applied. * journal we just applied.
*/ */
result = ASSERT(!vdo_before_journal_point(&last_entry_applied, result = VDO_ASSERT(!vdo_before_journal_point(&last_entry_applied,
&ref_counts_point), &ref_counts_point),
"Refcounts are not more accurate than the slab journal"); "Refcounts are not more accurate than the slab journal");
if (result != VDO_SUCCESS) { if (result != VDO_SUCCESS) {
...@@ -2993,7 +2993,7 @@ static void scrub_slabs(struct block_allocator *allocator, struct vdo_completion ...@@ -2993,7 +2993,7 @@ static void scrub_slabs(struct block_allocator *allocator, struct vdo_completion
static inline void assert_on_allocator_thread(thread_id_t thread_id, static inline void assert_on_allocator_thread(thread_id_t thread_id,
const char *function_name) const char *function_name)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == thread_id), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == thread_id),
"%s called on correct thread", function_name); "%s called on correct thread", function_name);
} }
...@@ -3142,7 +3142,7 @@ static int __must_check allocate_slab_block(struct vdo_slab *slab, ...@@ -3142,7 +3142,7 @@ static int __must_check allocate_slab_block(struct vdo_slab *slab,
if (!search_reference_blocks(slab, &free_index)) if (!search_reference_blocks(slab, &free_index))
return VDO_NO_SPACE; return VDO_NO_SPACE;
ASSERT_LOG_ONLY((slab->counters[free_index] == EMPTY_REFERENCE_COUNT), VDO_ASSERT_LOG_ONLY((slab->counters[free_index] == EMPTY_REFERENCE_COUNT),
"free block must have ref count of zero"); "free block must have ref count of zero");
make_provisional_reference(slab, free_index); make_provisional_reference(slab, free_index);
adjust_free_block_count(slab, false); adjust_free_block_count(slab, false);
...@@ -3850,7 +3850,7 @@ static bool __must_check release_recovery_journal_lock(struct slab_journal *jour ...@@ -3850,7 +3850,7 @@ static bool __must_check release_recovery_journal_lock(struct slab_journal *jour
sequence_number_t recovery_lock) sequence_number_t recovery_lock)
{ {
if (recovery_lock > journal->recovery_lock) { if (recovery_lock > journal->recovery_lock) {
ASSERT_LOG_ONLY((recovery_lock < journal->recovery_lock), VDO_ASSERT_LOG_ONLY((recovery_lock < journal->recovery_lock),
"slab journal recovery lock is not older than the recovery journal head"); "slab journal recovery lock is not older than the recovery journal head");
return false; return false;
} }
...@@ -4665,7 +4665,7 @@ int vdo_prepare_to_grow_slab_depot(struct slab_depot *depot, ...@@ -4665,7 +4665,7 @@ int vdo_prepare_to_grow_slab_depot(struct slab_depot *depot,
return VDO_INCREMENT_TOO_SMALL; return VDO_INCREMENT_TOO_SMALL;
/* Generate the depot configuration for the new block count. */ /* Generate the depot configuration for the new block count. */
ASSERT_LOG_ONLY(depot->first_block == partition->offset, VDO_ASSERT_LOG_ONLY(depot->first_block == partition->offset,
"New slab depot partition doesn't change origin"); "New slab depot partition doesn't change origin");
result = vdo_configure_slab_depot(partition, depot->slab_config, result = vdo_configure_slab_depot(partition, depot->slab_config,
depot->zone_count, &new_state); depot->zone_count, &new_state);
...@@ -4740,7 +4740,7 @@ static void register_new_slabs(void *context, zone_count_t zone_number, ...@@ -4740,7 +4740,7 @@ static void register_new_slabs(void *context, zone_count_t zone_number,
*/ */
void vdo_use_new_slabs(struct slab_depot *depot, struct vdo_completion *parent) void vdo_use_new_slabs(struct slab_depot *depot, struct vdo_completion *parent)
{ {
ASSERT_LOG_ONLY(depot->new_slabs != NULL, "Must have new slabs to use"); VDO_ASSERT_LOG_ONLY(depot->new_slabs != NULL, "Must have new slabs to use");
vdo_schedule_operation(depot->action_manager, vdo_schedule_operation(depot->action_manager,
VDO_ADMIN_STATE_SUSPENDED_OPERATION, VDO_ADMIN_STATE_SUSPENDED_OPERATION,
NULL, register_new_slabs, NULL, register_new_slabs,
...@@ -4796,7 +4796,7 @@ static void do_drain_step(struct vdo_completion *completion) ...@@ -4796,7 +4796,7 @@ static void do_drain_step(struct vdo_completion *completion)
return; return;
case VDO_DRAIN_ALLOCATOR_STEP_FINISHED: case VDO_DRAIN_ALLOCATOR_STEP_FINISHED:
ASSERT_LOG_ONLY(!is_vio_pool_busy(allocator->vio_pool), VDO_ASSERT_LOG_ONLY(!is_vio_pool_busy(allocator->vio_pool),
"vio pool not busy"); "vio pool not busy");
vdo_finish_draining_with_result(&allocator->state, completion->result); vdo_finish_draining_with_result(&allocator->state, completion->result);
return; return;
......
...@@ -44,7 +44,7 @@ void vdo_register_thread(struct thread_registry *registry, ...@@ -44,7 +44,7 @@ void vdo_register_thread(struct thread_registry *registry,
list_add_tail_rcu(&new_thread->links, &registry->links); list_add_tail_rcu(&new_thread->links, &registry->links);
spin_unlock(&registry->lock); spin_unlock(&registry->lock);
ASSERT_LOG_ONLY(!found_it, "new thread not already in registry"); VDO_ASSERT_LOG_ONLY(!found_it, "new thread not already in registry");
if (found_it) { if (found_it) {
/* Ensure no RCU iterators see it before re-initializing. */ /* Ensure no RCU iterators see it before re-initializing. */
synchronize_rcu(); synchronize_rcu();
...@@ -67,7 +67,7 @@ void vdo_unregister_thread(struct thread_registry *registry) ...@@ -67,7 +67,7 @@ void vdo_unregister_thread(struct thread_registry *registry)
} }
spin_unlock(&registry->lock); spin_unlock(&registry->lock);
ASSERT_LOG_ONLY(found_it, "thread found in registry"); VDO_ASSERT_LOG_ONLY(found_it, "thread found in registry");
if (found_it) { if (found_it) {
/* Ensure no RCU iterators see it before re-initializing. */ /* Ensure no RCU iterators see it before re-initializing. */
synchronize_rcu(); synchronize_rcu();
......
...@@ -425,7 +425,7 @@ int vdo_make_thread(struct vdo *vdo, thread_id_t thread_id, ...@@ -425,7 +425,7 @@ int vdo_make_thread(struct vdo *vdo, thread_id_t thread_id,
type = &default_queue_type; type = &default_queue_type;
if (thread->queue != NULL) { if (thread->queue != NULL) {
return ASSERT(vdo_work_queue_type_is(thread->queue, type), return VDO_ASSERT(vdo_work_queue_type_is(thread->queue, type),
"already constructed vdo thread %u is of the correct type", "already constructed vdo thread %u is of the correct type",
thread_id); thread_id);
} }
...@@ -448,7 +448,7 @@ static int register_vdo(struct vdo *vdo) ...@@ -448,7 +448,7 @@ static int register_vdo(struct vdo *vdo)
int result; int result;
write_lock(&registry.lock); write_lock(&registry.lock);
result = ASSERT(filter_vdos_locked(vdo_is_equal, vdo) == NULL, result = VDO_ASSERT(filter_vdos_locked(vdo_is_equal, vdo) == NULL,
"VDO not already registered"); "VDO not already registered");
if (result == VDO_SUCCESS) { if (result == VDO_SUCCESS) {
INIT_LIST_HEAD(&vdo->registration); INIT_LIST_HEAD(&vdo->registration);
...@@ -1050,7 +1050,7 @@ int vdo_register_read_only_listener(struct vdo *vdo, void *listener, ...@@ -1050,7 +1050,7 @@ int vdo_register_read_only_listener(struct vdo *vdo, void *listener,
struct read_only_listener *read_only_listener; struct read_only_listener *read_only_listener;
int result; int result;
result = ASSERT(thread_id != vdo->thread_config.dedupe_thread, result = VDO_ASSERT(thread_id != vdo->thread_config.dedupe_thread,
"read only listener not registered on dedupe thread"); "read only listener not registered on dedupe thread");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -1704,7 +1704,7 @@ void vdo_dump_status(const struct vdo *vdo) ...@@ -1704,7 +1704,7 @@ void vdo_dump_status(const struct vdo *vdo)
*/ */
void vdo_assert_on_admin_thread(const struct vdo *vdo, const char *name) void vdo_assert_on_admin_thread(const struct vdo *vdo, const char *name)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == vdo->thread_config.admin_thread), VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == vdo->thread_config.admin_thread),
"%s called on admin thread", name); "%s called on admin thread", name);
} }
...@@ -1718,7 +1718,7 @@ void vdo_assert_on_admin_thread(const struct vdo *vdo, const char *name) ...@@ -1718,7 +1718,7 @@ void vdo_assert_on_admin_thread(const struct vdo *vdo, const char *name)
void vdo_assert_on_logical_zone_thread(const struct vdo *vdo, zone_count_t logical_zone, void vdo_assert_on_logical_zone_thread(const struct vdo *vdo, zone_count_t logical_zone,
const char *name) const char *name)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() ==
vdo->thread_config.logical_threads[logical_zone]), vdo->thread_config.logical_threads[logical_zone]),
"%s called on logical thread", name); "%s called on logical thread", name);
} }
...@@ -1733,7 +1733,7 @@ void vdo_assert_on_logical_zone_thread(const struct vdo *vdo, zone_count_t logic ...@@ -1733,7 +1733,7 @@ void vdo_assert_on_logical_zone_thread(const struct vdo *vdo, zone_count_t logic
void vdo_assert_on_physical_zone_thread(const struct vdo *vdo, void vdo_assert_on_physical_zone_thread(const struct vdo *vdo,
zone_count_t physical_zone, const char *name) zone_count_t physical_zone, const char *name)
{ {
ASSERT_LOG_ONLY((vdo_get_callback_thread_id() == VDO_ASSERT_LOG_ONLY((vdo_get_callback_thread_id() ==
vdo->thread_config.physical_threads[physical_zone]), vdo->thread_config.physical_threads[physical_zone]),
"%s called on physical thread", name); "%s called on physical thread", name);
} }
...@@ -1773,7 +1773,7 @@ int vdo_get_physical_zone(const struct vdo *vdo, physical_block_number_t pbn, ...@@ -1773,7 +1773,7 @@ int vdo_get_physical_zone(const struct vdo *vdo, physical_block_number_t pbn,
/* With the PBN already checked, we should always succeed in finding a slab. */ /* With the PBN already checked, we should always succeed in finding a slab. */
slab = vdo_get_slab(vdo->depot, pbn); slab = vdo_get_slab(vdo->depot, pbn);
result = ASSERT(slab != NULL, "vdo_get_slab must succeed on all valid PBNs"); result = VDO_ASSERT(slab != NULL, "vdo_get_slab must succeed on all valid PBNs");
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
......
...@@ -82,13 +82,13 @@ int allocate_vio_components(struct vdo *vdo, enum vio_type vio_type, ...@@ -82,13 +82,13 @@ int allocate_vio_components(struct vdo *vdo, enum vio_type vio_type,
struct bio *bio; struct bio *bio;
int result; int result;
result = ASSERT(block_count <= MAX_BLOCKS_PER_VIO, result = VDO_ASSERT(block_count <= MAX_BLOCKS_PER_VIO,
"block count %u does not exceed maximum %u", block_count, "block count %u does not exceed maximum %u", block_count,
MAX_BLOCKS_PER_VIO); MAX_BLOCKS_PER_VIO);
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
result = ASSERT(((vio_type != VIO_TYPE_UNINITIALIZED) && (vio_type != VIO_TYPE_DATA)), result = VDO_ASSERT(((vio_type != VIO_TYPE_UNINITIALIZED) && (vio_type != VIO_TYPE_DATA)),
"%d is a metadata type", vio_type); "%d is a metadata type", vio_type);
if (result != VDO_SUCCESS) if (result != VDO_SUCCESS)
return result; return result;
...@@ -363,12 +363,12 @@ void free_vio_pool(struct vio_pool *pool) ...@@ -363,12 +363,12 @@ void free_vio_pool(struct vio_pool *pool)
return; return;
/* Remove all available vios from the object pool. */ /* Remove all available vios from the object pool. */
ASSERT_LOG_ONLY(!vdo_waitq_has_waiters(&pool->waiting), VDO_ASSERT_LOG_ONLY(!vdo_waitq_has_waiters(&pool->waiting),
"VIO pool must not have any waiters when being freed"); "VIO pool must not have any waiters when being freed");
ASSERT_LOG_ONLY((pool->busy_count == 0), VDO_ASSERT_LOG_ONLY((pool->busy_count == 0),
"VIO pool must not have %zu busy entries when being freed", "VIO pool must not have %zu busy entries when being freed",
pool->busy_count); pool->busy_count);
ASSERT_LOG_ONLY(list_empty(&pool->busy), VDO_ASSERT_LOG_ONLY(list_empty(&pool->busy),
"VIO pool must not have busy entries when being freed"); "VIO pool must not have busy entries when being freed");
list_for_each_entry_safe(pooled, tmp, &pool->available, pool_entry) { list_for_each_entry_safe(pooled, tmp, &pool->available, pool_entry) {
...@@ -377,7 +377,7 @@ void free_vio_pool(struct vio_pool *pool) ...@@ -377,7 +377,7 @@ void free_vio_pool(struct vio_pool *pool)
pool->size--; pool->size--;
} }
ASSERT_LOG_ONLY(pool->size == 0, VDO_ASSERT_LOG_ONLY(pool->size == 0,
"VIO pool must not have missing entries when being freed"); "VIO pool must not have missing entries when being freed");
vdo_free(vdo_forget(pool->buffer)); vdo_free(vdo_forget(pool->buffer));
...@@ -403,7 +403,7 @@ void acquire_vio_from_pool(struct vio_pool *pool, struct vdo_waiter *waiter) ...@@ -403,7 +403,7 @@ void acquire_vio_from_pool(struct vio_pool *pool, struct vdo_waiter *waiter)
{ {
struct pooled_vio *pooled; struct pooled_vio *pooled;
ASSERT_LOG_ONLY((pool->thread_id == vdo_get_callback_thread_id()), VDO_ASSERT_LOG_ONLY((pool->thread_id == vdo_get_callback_thread_id()),
"acquire from active vio_pool called from correct thread"); "acquire from active vio_pool called from correct thread");
if (list_empty(&pool->available)) { if (list_empty(&pool->available)) {
...@@ -424,7 +424,7 @@ void acquire_vio_from_pool(struct vio_pool *pool, struct vdo_waiter *waiter) ...@@ -424,7 +424,7 @@ void acquire_vio_from_pool(struct vio_pool *pool, struct vdo_waiter *waiter)
*/ */
void return_vio_to_pool(struct vio_pool *pool, struct pooled_vio *vio) void return_vio_to_pool(struct vio_pool *pool, struct pooled_vio *vio)
{ {
ASSERT_LOG_ONLY((pool->thread_id == vdo_get_callback_thread_id()), VDO_ASSERT_LOG_ONLY((pool->thread_id == vdo_get_callback_thread_id()),
"vio pool entry returned on same thread as it was acquired"); "vio pool entry returned on same thread as it was acquired");
vio->vio.completion.error_handler = NULL; vio->vio.completion.error_handler = NULL;
...@@ -465,7 +465,7 @@ void vdo_count_bios(struct atomic_bio_stats *bio_stats, struct bio *bio) ...@@ -465,7 +465,7 @@ void vdo_count_bios(struct atomic_bio_stats *bio_stats, struct bio *bio)
* shouldn't exist. * shouldn't exist.
*/ */
default: default:
ASSERT_LOG_ONLY(0, "Bio operation %d not a write, read, discard, or empty flush", VDO_ASSERT_LOG_ONLY(0, "Bio operation %d not a write, read, discard, or empty flush",
bio_op(bio)); bio_op(bio));
} }
......
...@@ -67,7 +67,7 @@ static inline void assert_vio_in_bio_zone(struct vio *vio) ...@@ -67,7 +67,7 @@ static inline void assert_vio_in_bio_zone(struct vio *vio)
thread_id_t expected = get_vio_bio_zone_thread_id(vio); thread_id_t expected = get_vio_bio_zone_thread_id(vio);
thread_id_t thread_id = vdo_get_callback_thread_id(); thread_id_t thread_id = vdo_get_callback_thread_id();
ASSERT_LOG_ONLY((expected == thread_id), VDO_ASSERT_LOG_ONLY((expected == thread_id),
"vio I/O for physical block %llu on thread %u, should be on bio zone thread %u", "vio I/O for physical block %llu on thread %u, should be on bio zone thread %u",
(unsigned long long) pbn_from_vio_bio(vio->bio), thread_id, (unsigned long long) pbn_from_vio_bio(vio->bio), thread_id,
expected); expected);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment