When a CMRC connection is closed, the deferred shutdown process calls ib_destroy_qp(). This will cause the receive work queue entries to complete in error (since they are being cancelled), which will in turn reschedule the deferred shutdown process. This eventually leads to ib_destroy_conn() being called on a connection that has already been freed. Fix by explicitly cancelling any pending shutdown process after the shutdown process has completed. Ironically, this almost exactly reverts commit 019d4c1 ("[infiniband] Use a one-shot process for CMRC shutdown"); prior to the introduction of one-shot processes the only way to achieve a one-shot process was for the process to cancel itself. Signed-off-by: Michael Brown <mcb30@ipxe.org>tags/v1.20.1
|
|
||
117 |
|
117 |
|
118 |
|
118 |
|
119 |
|
119 |
|
|
120 |
|
|
|
121 |
|
|
|
122 |
|
|
120 |
|
123 |
|
121 |
|
124 |
|
122 |
|
125 |
|