dm vdo io-submitter: rename to vdo_submit_metadata_vio

Rename submit_metadata_vio() to vdo_submit_metadata_vio().

Reviewed-by: Susan LeGendre-McGhee <slegendr@redhat.com>
Signed-off-by: Mike Snitzer <snitzer@kernel.org>
Signed-off-by: Matthew Sakai <msakai@redhat.com>
This commit is contained in:
Mike Snitzer 2023-08-25 14:36:46 -04:00
parent 0dc2009d97
commit f7f46761cc
7 changed files with 68 additions and 69 deletions

View File

@ -786,8 +786,8 @@ static int __must_check launch_page_load(struct page_info *info,
cache->outstanding_reads++; cache->outstanding_reads++;
ADD_ONCE(cache->stats.pages_loaded, 1); ADD_ONCE(cache->stats.pages_loaded, 1);
callback = (cache->rebuilding ? handle_rebuild_read_error : handle_load_error); callback = (cache->rebuilding ? handle_rebuild_read_error : handle_load_error);
submit_metadata_vio(info->vio, pbn, load_cache_page_endio, vdo_submit_metadata_vio(info->vio, pbn, load_cache_page_endio,
callback, REQ_OP_READ | REQ_PRIO); callback, REQ_OP_READ | REQ_PRIO);
return VDO_SUCCESS; return VDO_SUCCESS;
} }
@ -1055,10 +1055,10 @@ static void page_is_written_out(struct vdo_completion *completion)
if (!page->header.initialized) { if (!page->header.initialized) {
page->header.initialized = true; page->header.initialized = true;
submit_metadata_vio(info->vio, info->pbn, vdo_submit_metadata_vio(info->vio, info->pbn,
write_cache_page_endio, write_cache_page_endio,
handle_page_write_error, handle_page_write_error,
(REQ_OP_WRITE | REQ_PRIO | REQ_PREFLUSH)); REQ_OP_WRITE | REQ_PRIO | REQ_PREFLUSH);
return; return;
} }
@ -1123,8 +1123,8 @@ static void write_pages(struct vdo_completion *flush_completion)
continue; continue;
} }
ADD_ONCE(info->cache->stats.pages_saved, 1); ADD_ONCE(info->cache->stats.pages_saved, 1);
submit_metadata_vio(info->vio, info->pbn, write_cache_page_endio, vdo_submit_metadata_vio(info->vio, info->pbn, write_cache_page_endio,
handle_page_write_error, REQ_OP_WRITE | REQ_PRIO); handle_page_write_error, REQ_OP_WRITE | REQ_PRIO);
} }
if (has_unflushed_pages) { if (has_unflushed_pages) {
@ -1632,9 +1632,9 @@ static void write_initialized_page(struct vdo_completion *completion)
if (zone->flusher == tree_page) if (zone->flusher == tree_page)
operation |= REQ_PREFLUSH; operation |= REQ_PREFLUSH;
submit_metadata_vio(vio, vdo_get_block_map_page_pbn(page), vdo_submit_metadata_vio(vio, vdo_get_block_map_page_pbn(page),
write_page_endio, handle_write_error, write_page_endio, handle_write_error,
operation); operation);
} }
static void write_page_endio(struct bio *bio) static void write_page_endio(struct bio *bio)
@ -1689,9 +1689,9 @@ static void write_page(struct tree_page *tree_page, struct pooled_vio *vio)
} }
page->header.initialized = true; page->header.initialized = true;
submit_metadata_vio(&vio->vio, vdo_get_block_map_page_pbn(page), vdo_submit_metadata_vio(&vio->vio, vdo_get_block_map_page_pbn(page),
write_page_endio, handle_write_error, write_page_endio, handle_write_error,
REQ_OP_WRITE | REQ_PRIO); REQ_OP_WRITE | REQ_PRIO);
} }
/* Release a lock on a page which was being loaded or allocated. */ /* Release a lock on a page which was being loaded or allocated. */
@ -1879,8 +1879,8 @@ static void load_page(struct waiter *waiter, void *context)
physical_block_number_t pbn = lock->tree_slots[lock->height - 1].block_map_slot.pbn; physical_block_number_t pbn = lock->tree_slots[lock->height - 1].block_map_slot.pbn;
pooled->vio.completion.parent = data_vio; pooled->vio.completion.parent = data_vio;
submit_metadata_vio(&pooled->vio, pbn, load_page_endio, vdo_submit_metadata_vio(&pooled->vio, pbn, load_page_endio,
handle_io_error, REQ_OP_READ | REQ_PRIO); handle_io_error, REQ_OP_READ | REQ_PRIO);
} }
/* /*
@ -2613,9 +2613,9 @@ static void traverse(struct cursor *cursor)
next_level->page_index = entry_index; next_level->page_index = entry_index;
next_level->slot = 0; next_level->slot = 0;
level->slot++; level->slot++;
submit_metadata_vio(&cursor->vio->vio, location.pbn, vdo_submit_metadata_vio(&cursor->vio->vio, location.pbn,
traversal_endio, continue_traversal, traversal_endio, continue_traversal,
REQ_OP_READ | REQ_PRIO); REQ_OP_READ | REQ_PRIO);
return; return;
} }
} }

View File

@ -320,7 +320,7 @@ void submit_data_vio_io(struct data_vio *data_vio)
} }
/** /**
* vdo_submit_metadata_io() - Submit I/O for a metadata vio. * __submit_metadata_vio() - Submit I/O for a metadata vio.
* @vio: the vio for which to issue I/O * @vio: the vio for which to issue I/O
* @physical: the physical block number to read or write * @physical: the physical block number to read or write
* @callback: the bio endio function which will be called after the I/O completes * @callback: the bio endio function which will be called after the I/O completes
@ -336,12 +336,12 @@ void submit_data_vio_io(struct data_vio *data_vio)
* no error can occur on the bio queue. Currently this is true for all callers, but additional care * no error can occur on the bio queue. Currently this is true for all callers, but additional care
* will be needed if this ever changes. * will be needed if this ever changes.
*/ */
void vdo_submit_metadata_io(struct vio *vio, physical_block_number_t physical, void __submit_metadata_vio(struct vio *vio, physical_block_number_t physical,
bio_end_io_t callback, vdo_action_fn error_handler, bio_end_io_t callback, vdo_action_fn error_handler,
unsigned int operation, char *data) unsigned int operation, char *data)
{ {
struct vdo_completion *completion = &vio->completion;
int result; int result;
struct vdo_completion *completion = &vio->completion;
const struct admin_state_code *code = vdo_get_admin_state(completion->vdo); const struct admin_state_code *code = vdo_get_admin_state(completion->vdo);

View File

@ -24,24 +24,24 @@ void process_vio_io(struct vdo_completion *completion);
void submit_data_vio_io(struct data_vio *data_vio); void submit_data_vio_io(struct data_vio *data_vio);
void vdo_submit_metadata_io(struct vio *vio, physical_block_number_t physical, void __submit_metadata_vio(struct vio *vio, physical_block_number_t physical,
bio_end_io_t callback, vdo_action_fn error_handler, bio_end_io_t callback, vdo_action_fn error_handler,
unsigned int operation, char *data); unsigned int operation, char *data);
static inline void submit_metadata_vio(struct vio *vio, physical_block_number_t physical, static inline void vdo_submit_metadata_vio(struct vio *vio, physical_block_number_t physical,
bio_end_io_t callback, vdo_action_fn error_handler, bio_end_io_t callback, vdo_action_fn error_handler,
unsigned int operation) unsigned int operation)
{ {
vdo_submit_metadata_io(vio, physical, callback, error_handler, __submit_metadata_vio(vio, physical, callback, error_handler,
operation, vio->data); operation, vio->data);
} }
static inline void submit_flush_vio(struct vio *vio, bio_end_io_t callback, static inline void submit_flush_vio(struct vio *vio, bio_end_io_t callback,
vdo_action_fn error_handler) vdo_action_fn error_handler)
{ {
/* FIXME: Can we just use REQ_OP_FLUSH? */ /* FIXME: Can we just use REQ_OP_FLUSH? */
vdo_submit_metadata_io(vio, 0, callback, error_handler, __submit_metadata_vio(vio, 0, callback, error_handler,
REQ_OP_WRITE | REQ_PREFLUSH, NULL); REQ_OP_WRITE | REQ_PREFLUSH, NULL);
} }
#endif /* VDO_IO_SUBMITTER_H */ #endif /* VDO_IO_SUBMITTER_H */

View File

@ -1394,8 +1394,8 @@ static void write_block(struct waiter *waiter, void *context __always_unused)
* the data being referenced is stable. The FUA is necessary to ensure that the journal * the data being referenced is stable. The FUA is necessary to ensure that the journal
* block itself is stable before allowing overwrites of the lbn's previous data. * block itself is stable before allowing overwrites of the lbn's previous data.
*/ */
submit_metadata_vio(&block->vio, journal->origin + block->block_number, vdo_submit_metadata_vio(&block->vio, journal->origin + block->block_number,
complete_write_endio, handle_write_error, WRITE_FLAGS); complete_write_endio, handle_write_error, WRITE_FLAGS);
} }

View File

@ -1748,10 +1748,9 @@ void vdo_repair(struct vdo_completion *parent)
remaining -= blocks; remaining -= blocks;
} }
for (vio_count = 0; for (vio_count = 0; vio_count < repair->vio_count;
vio_count < repair->vio_count;
vio_count++, pbn += MAX_BLOCKS_PER_VIO) { vio_count++, pbn += MAX_BLOCKS_PER_VIO) {
submit_metadata_vio(&repair->vios[vio_count], pbn, read_journal_endio, vdo_submit_metadata_vio(&repair->vios[vio_count], pbn, read_journal_endio,
handle_journal_load_error, REQ_OP_READ); handle_journal_load_error, REQ_OP_READ);
} }
} }

View File

@ -338,8 +338,8 @@ static void launch_write(struct slab_summary_block *block)
pbn = (depot->summary_origin + pbn = (depot->summary_origin +
(VDO_SLAB_SUMMARY_BLOCKS_PER_ZONE * allocator->zone_number) + (VDO_SLAB_SUMMARY_BLOCKS_PER_ZONE * allocator->zone_number) +
block->index); block->index);
submit_metadata_vio(&block->vio, pbn, write_slab_summary_endio, vdo_submit_metadata_vio(&block->vio, pbn, write_slab_summary_endio,
handle_write_error, REQ_OP_WRITE | REQ_PREFLUSH); handle_write_error, REQ_OP_WRITE | REQ_PREFLUSH);
} }
/** /**
@ -771,8 +771,8 @@ static void write_slab_journal_block(struct waiter *waiter, void *context)
* This block won't be read in recovery until the slab summary is updated to refer to it. * This block won't be read in recovery until the slab summary is updated to refer to it.
* The slab summary update does a flush which is sufficient to protect us from VDO-2331. * The slab summary update does a flush which is sufficient to protect us from VDO-2331.
*/ */
submit_metadata_vio(uds_forget(vio), block_number, write_slab_journal_endio, vdo_submit_metadata_vio(uds_forget(vio), block_number, write_slab_journal_endio,
complete_write, REQ_OP_WRITE); complete_write, REQ_OP_WRITE);
/* Since the write is submitted, the tail block structure can be reused. */ /* Since the write is submitted, the tail block structure can be reused. */
journal->tail++; journal->tail++;
@ -1205,8 +1205,8 @@ static void write_reference_block(struct waiter *waiter, void *context)
block->slab->allocator->ref_counts_statistics.blocks_written + 1); block->slab->allocator->ref_counts_statistics.blocks_written + 1);
completion->callback_thread_id = ((struct block_allocator *) pooled->context)->thread_id; completion->callback_thread_id = ((struct block_allocator *) pooled->context)->thread_id;
submit_metadata_vio(&pooled->vio, pbn, write_reference_block_endio, vdo_submit_metadata_vio(&pooled->vio, pbn, write_reference_block_endio,
handle_io_error, REQ_OP_WRITE | REQ_PREFLUSH); handle_io_error, REQ_OP_WRITE | REQ_PREFLUSH);
} }
static void reclaim_journal_space(struct slab_journal *journal) static void reclaim_journal_space(struct slab_journal *journal)
@ -2268,9 +2268,9 @@ static void load_reference_block(struct waiter *waiter, void *context)
size_t block_offset = (block - block->slab->reference_blocks); size_t block_offset = (block - block->slab->reference_blocks);
vio->completion.parent = block; vio->completion.parent = block;
submit_metadata_vio(vio, block->slab->ref_counts_origin + block_offset, vdo_submit_metadata_vio(vio, block->slab->ref_counts_origin + block_offset,
load_reference_block_endio, handle_io_error, load_reference_block_endio, handle_io_error,
REQ_OP_READ); REQ_OP_READ);
} }
/** /**
@ -2475,9 +2475,9 @@ static void read_slab_journal_tail(struct waiter *waiter, void *context)
vio->completion.parent = journal; vio->completion.parent = journal;
vio->completion.callback_thread_id = slab->allocator->thread_id; vio->completion.callback_thread_id = slab->allocator->thread_id;
submit_metadata_vio(vio, slab->journal_origin + tail_block, vdo_submit_metadata_vio(vio, slab->journal_origin + tail_block,
read_slab_journal_tail_endio, handle_load_error, read_slab_journal_tail_endio, handle_load_error,
REQ_OP_READ); REQ_OP_READ);
} }
/** /**
@ -2915,9 +2915,9 @@ static void start_scrubbing(struct vdo_completion *completion)
return; return;
} }
submit_metadata_vio(&scrubber->vio, slab->journal_origin, vdo_submit_metadata_vio(&scrubber->vio, slab->journal_origin,
read_slab_journal_endio, handle_scrubber_error, read_slab_journal_endio, handle_scrubber_error,
REQ_OP_READ); REQ_OP_READ);
} }
/** /**
@ -4513,9 +4513,9 @@ static void finish_loading_summary(struct vdo_completion *completion)
combine_summaries(depot); combine_summaries(depot);
/* Write the combined summary back out. */ /* Write the combined summary back out. */
submit_metadata_vio(as_vio(completion), depot->summary_origin, vdo_submit_metadata_vio(as_vio(completion), depot->summary_origin,
write_summary_endio, handle_combining_error, write_summary_endio, handle_combining_error,
REQ_OP_WRITE); REQ_OP_WRITE);
} }
static void load_summary_endio(struct bio *bio) static void load_summary_endio(struct bio *bio)
@ -4555,8 +4555,8 @@ static void load_slab_summary(void *context, struct vdo_completion *parent)
return; return;
} }
submit_metadata_vio(vio, depot->summary_origin, load_summary_endio, vdo_submit_metadata_vio(vio, depot->summary_origin, load_summary_endio,
handle_combining_error, REQ_OP_READ); handle_combining_error, REQ_OP_READ);
} }
/* Implements vdo_zone_action_fn. */ /* Implements vdo_zone_action_fn. */

View File

@ -813,11 +813,11 @@ void vdo_load_super_block(struct vdo *vdo, struct vdo_completion *parent)
} }
vdo->super_block.vio.completion.parent = parent; vdo->super_block.vio.completion.parent = parent;
submit_metadata_vio(&vdo->super_block.vio, vdo_submit_metadata_vio(&vdo->super_block.vio,
vdo_get_data_region_start(vdo->geometry), vdo_get_data_region_start(vdo->geometry),
read_super_block_endio, read_super_block_endio,
handle_super_block_read_error, handle_super_block_read_error,
REQ_OP_READ); REQ_OP_READ);
} }
/** /**
@ -1028,10 +1028,10 @@ void vdo_save_components(struct vdo *vdo, struct vdo_completion *parent)
vdo_encode_super_block(super_block->buffer, &vdo->states); vdo_encode_super_block(super_block->buffer, &vdo->states);
super_block->vio.completion.parent = parent; super_block->vio.completion.parent = parent;
super_block->vio.completion.callback_thread_id = parent->callback_thread_id; super_block->vio.completion.callback_thread_id = parent->callback_thread_id;
submit_metadata_vio(&super_block->vio, vdo_submit_metadata_vio(&super_block->vio,
vdo_get_data_region_start(vdo->geometry), vdo_get_data_region_start(vdo->geometry),
super_block_write_endio, handle_save_error, super_block_write_endio, handle_save_error,
REQ_OP_WRITE | REQ_PREFLUSH | REQ_FUA); REQ_OP_WRITE | REQ_PREFLUSH | REQ_FUA);
} }
/** /**