summaryrefslogtreecommitdiffstats
path: root/drivers/infiniband/hw/mlx4/main.c
diff options
context:
space:
mode:
authorMaor Gottlieb <maorg@mellanox.com>2017-03-29 06:03:00 +0300
committerDoug Ledford <dledford@redhat.com>2017-04-21 12:26:05 -0400
commit22c3653d04bd0c67b75e99d85e0c0bdf83947df5 (patch)
tree1e7ec4e9a2c72b823d32576a59b4ec1c649807c8 /drivers/infiniband/hw/mlx4/main.c
parentfb7a91746af18b2ebf596778b38a709cdbc488d3 (diff)
downloadlinux-22c3653d04bd0c67b75e99d85e0c0bdf83947df5.tar.gz
linux-22c3653d04bd0c67b75e99d85e0c0bdf83947df5.tar.bz2
linux-22c3653d04bd0c67b75e99d85e0c0bdf83947df5.zip
IB/mlx4: Take write semaphore when changing the vma struct
When the driver disassociate user context, it changes the vma to anonymous by setting the vm_ops to null and zap the vma ptes. In order to avoid race in the kernel, we need to take write lock before we change the vma entries. Fixes: ae184ddeca5db ('IB/mlx4_ib: Disassociate support') Signed-off-by: Maor Gottlieb <maorg@mellanox.com> Signed-off-by: Leon Romanovsky <leon@kernel.org> Signed-off-by: Doug Ledford <dledford@redhat.com>
Diffstat (limited to 'drivers/infiniband/hw/mlx4/main.c')
-rw-r--r--drivers/infiniband/hw/mlx4/main.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/infiniband/hw/mlx4/main.c b/drivers/infiniband/hw/mlx4/main.c
index 7a1b345b6aa9..e2fd6c6fb1b3 100644
--- a/drivers/infiniband/hw/mlx4/main.c
+++ b/drivers/infiniband/hw/mlx4/main.c
@@ -1173,7 +1173,7 @@ static void mlx4_ib_disassociate_ucontext(struct ib_ucontext *ibcontext)
/* need to protect from a race on closing the vma as part of
* mlx4_ib_vma_close().
*/
- down_read(&owning_mm->mmap_sem);
+ down_write(&owning_mm->mmap_sem);
for (i = 0; i < HW_BAR_COUNT; i++) {
vma = context->hw_bar_info[i].vma;
if (!vma)
@@ -1191,7 +1191,7 @@ static void mlx4_ib_disassociate_ucontext(struct ib_ucontext *ibcontext)
context->hw_bar_info[i].vma->vm_ops = NULL;
}
- up_read(&owning_mm->mmap_sem);
+ up_write(&owning_mm->mmap_sem);
mmput(owning_mm);
put_task_struct(owning_process);
}