summaryrefslogtreecommitdiffstats
path: root/drivers/s390/net/lcs.c
diff options
context:
space:
mode:
authorVlad Yasevich <vladislav.yasevich@hp.com>2009-01-22 14:53:23 -0800
committerDavid S. Miller <davem@davemloft.net>2009-01-22 14:53:23 -0800
commitae53b5bd77719fed58086c5be60ce4f22bffe1c6 (patch)
treeb48da8033f59117512a5486a779b0853a255dc7b /drivers/s390/net/lcs.c
parent759af00ebef858015eb68876ac1f383bcb6a1774 (diff)
downloadkernel-crypto-ae53b5bd77719fed58086c5be60ce4f22bffe1c6.tar.gz
kernel-crypto-ae53b5bd77719fed58086c5be60ce4f22bffe1c6.tar.xz
kernel-crypto-ae53b5bd77719fed58086c5be60ce4f22bffe1c6.zip
sctp: Fix another socket race during accept/peeloff
There is a race between sctp_rcv() and sctp_accept() where we have moved the association from the listening socket to the accepted socket, but sctp_rcv() processing cached the old socket and continues to use it. The easy solution is to check for the socket mismatch once we've grabed the socket lock. If we hit a mis-match, that means that were are currently holding the lock on the listening socket, but the association is refrencing a newly accepted socket. We need to drop the lock on the old socket and grab the lock on the new one. A more proper solution might be to create accepted sockets when the new association is established, similar to TCP. That would eliminate the race for 1-to-1 style sockets, but it would still existing for 1-to-many sockets where a user wished to peeloff an association. For now, we'll live with this easy solution as it addresses the problem. Reported-by: Michal Hocko <mhocko@suse.cz> Reported-by: Karsten Keil <kkeil@suse.de> Signed-off-by: Vlad Yasevich <vladislav.yasevich@hp.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/s390/net/lcs.c')
0 files changed, 0 insertions, 0 deletions