--- a/net/9p/trans_fd.c +++ b/net/9p/trans_fd.c @@ -207,8 +207,6 @@ static void p9_conn_cancel(struct p9_con list_move(&req->req_list, &cancel_list); } - spin_unlock(&m->req_lock); - list_for_each_entry_safe(req, rtmp, &cancel_list, req_list) { p9_debug(P9_DEBUG_ERROR, "call back req %p\n", req); list_del(&req->req_list); @@ -216,6 +214,7 @@ static void p9_conn_cancel(struct p9_con req->t_err = err; p9_client_cb(m->client, req, REQ_STATUS_ERROR); } + spin_unlock(&m->req_lock); } static __poll_t