Page MenuHomeFreeBSD

Fix LOR
ClosedPublic

Authored by tuexen on Sep 12 2021, 5:37 PM.
Tags
None
Referenced Files
Unknown Object (File)
Nov 22 2024, 9:58 AM
Unknown Object (File)
Nov 12 2024, 8:28 PM
Unknown Object (File)
Oct 19 2024, 3:58 PM
Unknown Object (File)
Oct 19 2024, 3:19 AM
Unknown Object (File)
Oct 9 2024, 8:36 AM
Unknown Object (File)
Sep 30 2024, 1:14 PM
Unknown Object (File)
Sep 30 2024, 3:16 AM
Unknown Object (File)
Sep 28 2024, 6:33 AM

Details

Summary

Don't try to lock the inp-info lock while holding an stcb lock (and don't lock twice...)

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

How was it getting locked twice?

How was it getting locked twice?

Because

SCTP_INP_INFO_RLOCK();
new_vtag = sctp_select_a_tag(stcb->sctp_ep, stcb->sctp_ep->sctp_lport, stcb->rport, 1);
SCTP_INP_INFO_RLOCK();

should have been

SCTP_INP_INFO_RLOCK();
new_vtag = sctp_select_a_tag(stcb->sctp_ep, stcb->sctp_ep->sctp_lport, stcb->rport, 1);
SCTP_INP_INFO_RUNLOCK();

(the difference is in the last line).

This revision is now accepted and ready to land.Sep 12 2021, 7:10 PM
This revision was automatically updated to reflect the committed changes.

How was it getting locked twice?

Because

SCTP_INP_INFO_RLOCK();
new_vtag = sctp_select_a_tag(stcb->sctp_ep, stcb->sctp_ep->sctp_lport, stcb->rport, 1);
SCTP_INP_INFO_RLOCK();

should have been

SCTP_INP_INFO_RLOCK();
new_vtag = sctp_select_a_tag(stcb->sctp_ep, stcb->sctp_ep->sctp_lport, stcb->rport, 1);
SCTP_INP_INFO_RUNLOCK();

(the difference is in the last line).

Oops, thanks.