2022-06-21 13:45:21 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
2022-11-01 20:26:26 +00:00
|
|
|
* Copyright (C) 2022 Intel Corporation.
|
2022-06-21 13:45:21 +00:00
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "ftl_core.h"
|
|
|
|
#include "ftl_mngt.h"
|
|
|
|
#include "ftl_mngt_steps.h"
|
|
|
|
|
2022-06-20 09:50:06 +00:00
|
|
|
/*
|
|
|
|
* Steps executed during clean shutdown - includes persisting metadata and rolling
|
|
|
|
* back any setup steps executed during startup (closing bdevs, io channels, etc)
|
|
|
|
*/
|
2022-06-21 13:45:21 +00:00
|
|
|
static const struct ftl_mngt_process_desc desc_shutdown = {
|
|
|
|
.name = "FTL shutdown",
|
|
|
|
.error_handler = ftl_mngt_rollback_device,
|
|
|
|
.steps = {
|
2022-06-21 11:03:31 +00:00
|
|
|
{
|
|
|
|
.name = "Deinit core IO channel",
|
|
|
|
.action = ftl_mngt_deinit_io_channel
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "Unregister IO device",
|
|
|
|
.action = ftl_mngt_unregister_io_device
|
|
|
|
},
|
2022-06-21 11:04:41 +00:00
|
|
|
{
|
|
|
|
.name = "Stop core poller",
|
|
|
|
.action = ftl_mngt_stop_core_poller
|
|
|
|
},
|
2022-06-01 09:19:04 +00:00
|
|
|
{
|
|
|
|
.name = "Persist L2P",
|
|
|
|
.action = ftl_mngt_persist_l2p
|
|
|
|
},
|
2022-05-27 11:46:59 +00:00
|
|
|
{
|
|
|
|
.name = "Finish L2P unmaps",
|
|
|
|
.action = ftl_mngt_unmap_l2p,
|
|
|
|
},
|
2022-06-01 09:19:04 +00:00
|
|
|
{
|
|
|
|
.name = "Persist metadata",
|
|
|
|
.action = ftl_mngt_persist_md
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "Set FTL clean state",
|
|
|
|
.action = ftl_mngt_set_clean
|
|
|
|
},
|
2022-06-20 09:44:35 +00:00
|
|
|
{
|
|
|
|
.name = "Dump statistics",
|
|
|
|
.action = ftl_mngt_dump_stats
|
|
|
|
},
|
2022-07-07 17:53:08 +00:00
|
|
|
{
|
|
|
|
.name = "Deinitialize L2P",
|
|
|
|
.action = ftl_mngt_deinit_l2p
|
|
|
|
},
|
2022-07-07 17:32:30 +00:00
|
|
|
{
|
|
|
|
.name = "Deinitialize P2L checkpointing",
|
|
|
|
.action = ftl_mngt_p2l_deinit_ckpt
|
|
|
|
},
|
2022-06-21 13:45:21 +00:00
|
|
|
{
|
|
|
|
.name = "Rollback FTL device",
|
|
|
|
.action = ftl_mngt_rollback_device
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-06-01 09:03:05 +00:00
|
|
|
/*
|
|
|
|
* Steps executed during fast clean shutdown (shutting down to shared memory). Utilizes
|
|
|
|
* minimum amount of metadata persistence and rolls back any setup steps executed during
|
|
|
|
* startup (closing bdevs, io channels, etc)
|
|
|
|
*/
|
|
|
|
static const struct ftl_mngt_process_desc desc_fast_shutdown = {
|
|
|
|
.name = "FTL fast shutdown",
|
|
|
|
.steps = {
|
|
|
|
{
|
|
|
|
.name = "Deinit core IO channel",
|
|
|
|
.action = ftl_mngt_deinit_io_channel
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "Unregister IO device",
|
|
|
|
.action = ftl_mngt_unregister_io_device
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "Stop core poller",
|
|
|
|
.action = ftl_mngt_stop_core_poller
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "Fast persist metadata",
|
|
|
|
.action = ftl_mngt_fast_persist_md
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "Set FTL SHM clean state",
|
|
|
|
.action = ftl_mngt_set_shm_clean
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "Dump statistics",
|
|
|
|
.action = ftl_mngt_dump_stats
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.name = "Deinitialize L2P",
|
|
|
|
.action = ftl_mngt_deinit_l2p
|
|
|
|
},
|
2022-07-07 17:32:30 +00:00
|
|
|
{
|
|
|
|
.name = "Deinitialize P2L checkpointing",
|
|
|
|
.action = ftl_mngt_p2l_deinit_ckpt
|
|
|
|
},
|
2022-06-01 09:03:05 +00:00
|
|
|
{
|
|
|
|
.name = "Rollback FTL device",
|
|
|
|
.action = ftl_mngt_rollback_device
|
|
|
|
},
|
|
|
|
{}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-06-21 13:45:21 +00:00
|
|
|
int
|
|
|
|
ftl_mngt_call_dev_shutdown(struct spdk_ftl_dev *dev, ftl_mngt_completion cb, void *cb_cntx)
|
|
|
|
{
|
2022-06-01 09:03:05 +00:00
|
|
|
const struct ftl_mngt_process_desc *pdesc;
|
|
|
|
|
|
|
|
if (dev->conf.fast_shutdown) {
|
|
|
|
pdesc = &desc_fast_shutdown;
|
|
|
|
} else {
|
|
|
|
pdesc = &desc_shutdown;
|
|
|
|
}
|
|
|
|
return ftl_mngt_process_execute(dev, pdesc, cb, cb_cntx);
|
2022-06-21 13:45:21 +00:00
|
|
|
}
|