Fix iSCSI target panics on concurrent session teardown and display

(eg removing a target and doing "ctladm islist -v" at the same time).

Reviewed by:	manu
Tested by:	manu
MFC after:	2 weeks
Sponsored by:	DARPA, AFRL
This commit is contained in:
trasz 2017-10-04 11:35:04 +00:00
parent 0540e9667e
commit 8467241e6a

View File

@ -1308,18 +1308,17 @@ cfiscsi_session_delete(struct cfiscsi_session *cs)
KASSERT(TAILQ_EMPTY(&cs->cs_waiting_for_data_out), KASSERT(TAILQ_EMPTY(&cs->cs_waiting_for_data_out),
("destroying session with non-empty queue")); ("destroying session with non-empty queue"));
mtx_lock(&softc->lock);
TAILQ_REMOVE(&softc->sessions, cs, cs_next);
mtx_unlock(&softc->lock);
cfiscsi_session_unregister_initiator(cs); cfiscsi_session_unregister_initiator(cs);
if (cs->cs_target != NULL) if (cs->cs_target != NULL)
cfiscsi_target_release(cs->cs_target); cfiscsi_target_release(cs->cs_target);
icl_conn_close(cs->cs_conn); icl_conn_close(cs->cs_conn);
icl_conn_free(cs->cs_conn); icl_conn_free(cs->cs_conn);
mtx_lock(&softc->lock);
TAILQ_REMOVE(&softc->sessions, cs, cs_next);
cv_signal(&softc->sessions_cv);
mtx_unlock(&softc->lock);
free(cs, M_CFISCSI); free(cs, M_CFISCSI);
cv_signal(&softc->sessions_cv);
} }
static int static int