diff options
| author | Eli Cohen <eli@dev.mellanox.co.il> | 2012-01-04 08:36:48 +0400 | 
|---|---|---|
| committer | Roland Dreier <roland@purestorage.com> | 2012-01-04 08:36:48 +0400 | 
| commit | e214a0fe2b382fa302c036ecd6e6ffe99e3b9875 (patch) | |
| tree | 6cfd92715630e3406521f700a3df3cf3295e7770 /tools/perf/scripts/python/syscall-counts-by-pid.py | |
| parent | 5f0a6e2d503896062f641639dacfe5055c2f593b (diff) | |
| download | linux-e214a0fe2b382fa302c036ecd6e6ffe99e3b9875.tar.xz | |
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 'tools/perf/scripts/python/syscall-counts-by-pid.py')
0 files changed, 0 insertions, 0 deletions
