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:
parent
0540e9667e
commit
8467241e6a
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user