summaryrefslogtreecommitdiff
path: root/net/tipc/handler.c
diff options
context:
space:
mode:
authorEli Cohen <eli@dev.mellanox.co.il>2012-01-03 20:36:48 -0800
committerRoland Dreier <roland@purestorage.com>2012-01-03 20:36:48 -0800
commite214a0fe2b382fa302c036ecd6e6ffe99e3b9875 (patch)
tree6cfd92715630e3406521f700a3df3cf3295e7770 /net/tipc/handler.c
parent5f0a6e2d503896062f641639dacfe5055c2f593b (diff)
IB/uverbs: Protect QP multicast list
Userspace verbs multicast attach/detach operations on a QP are done while holding the rwsem of the QP for reading. That's not sufficient since a reader lock allows more than one reader to acquire the lock. However, multicast attach/detach does list manipulation that can corrupt the list if multiple threads run in parallel. Fix this by acquiring the rwsem as a writer to serialize attach/detach operations. Add idr_write_qp() and put_qp_write() to encapsulate this. This fixes oops seen when running applications that perform multicast joins/leaves. Reported by: Mike Dubman <miked@mellanox.com> Signed-off-by: Eli Cohen <eli@mellanox.com> Cc: <stable@kernel.org> Signed-off-by: Roland Dreier <roland@purestorage.com>
Diffstat (limited to 'net/tipc/handler.c')
0 files changed, 0 insertions, 0 deletions