diff --git a/lib/nvmf/session.c b/lib/nvmf/session.c index 2673a1f47b..6dd0bae0d0 100644 --- a/lib/nvmf/session.c +++ b/lib/nvmf/session.c @@ -638,13 +638,6 @@ spdk_nvmf_session_poll(struct spdk_nvmf_session *session) SPDK_ERRLOG("Transport poll failed for conn %p; closing connection\n", conn); spdk_nvmf_session_disconnect(conn); } - if (subsys->subtype == SPDK_NVMF_SUBTYPE_NVME) { - if (subsys->is_removed && conn->transport->conn_is_idle(conn)) { - if (subsys->ops->detach) { - subsys->ops->detach(subsys); - } - } - } } return 0; diff --git a/lib/nvmf/subsystem.c b/lib/nvmf/subsystem.c index 2c843fb1d1..1ba5157878 100644 --- a/lib/nvmf/subsystem.c +++ b/lib/nvmf/subsystem.c @@ -128,6 +128,25 @@ spdk_nvmf_subsystem_start(struct spdk_nvmf_subsystem *subsystem) return subsystem->ops->attach(subsystem); } +static bool +nvmf_subsystem_removable(struct spdk_nvmf_subsystem *subsystem) +{ + struct spdk_nvmf_session *session; + struct spdk_nvmf_conn *conn; + + if (subsystem->is_removed) { + TAILQ_FOREACH(session, &subsystem->sessions, link) { + TAILQ_FOREACH(conn, &session->connections, link) { + if (!conn->transport->conn_is_idle(conn)) { + return false; + } + } + } + return true; + } + return false; +} + void spdk_nvmf_subsystem_poll(struct spdk_nvmf_subsystem *subsystem) { @@ -142,6 +161,12 @@ spdk_nvmf_subsystem_poll(struct spdk_nvmf_subsystem *subsystem) /* For each connection in the session, check for completions */ spdk_nvmf_session_poll(session); } + + if (nvmf_subsystem_removable(subsystem)) { + if (subsystem->ops->detach) { + subsystem->ops->detach(subsystem); + } + } } static bool