提交 782f6697 编写于 作者: M Mitko Haralanov 提交者: Doug Ledford

IB/hfi1: Protect the interval RB tree when cleaning up

The current implementation of the clean up function for
the interval RB trees has two flaws which may cause
problems in cases of concurrent executing of the function
and MMU notifier.

The flaws were due to the fact that deregistration of the
MMU callbacks was done after the tree was emptied and,
furthermore, the tree was not being locked.

This commit fixes both of these flaws by, first, switch the
order of operations, and, second, locking the tree while
traversing it to prevent any other operations.
Reviewed-by: NDean Luick <dean.luick@intel.com>
Signed-off-by: NMitko Haralanov <mitko.haralanov@intel.com>
Signed-off-by: NDoug Ledford <dledford@redhat.com>
上级 0ad2d3d0
...@@ -126,10 +126,15 @@ void hfi1_mmu_rb_unregister(struct rb_root *root) ...@@ -126,10 +126,15 @@ void hfi1_mmu_rb_unregister(struct rb_root *root)
if (!handler) if (!handler)
return; return;
/* Unregister first so we don't get any more notifications. */
if (current->mm)
mmu_notifier_unregister(&handler->mn, current->mm);
spin_lock_irqsave(&mmu_rb_lock, flags); spin_lock_irqsave(&mmu_rb_lock, flags);
list_del(&handler->list); list_del(&handler->list);
spin_unlock_irqrestore(&mmu_rb_lock, flags); spin_unlock_irqrestore(&mmu_rb_lock, flags);
spin_lock_irqsave(&handler->lock, flags);
if (!RB_EMPTY_ROOT(root)) { if (!RB_EMPTY_ROOT(root)) {
struct rb_node *node; struct rb_node *node;
struct mmu_rb_node *rbnode; struct mmu_rb_node *rbnode;
...@@ -141,9 +146,8 @@ void hfi1_mmu_rb_unregister(struct rb_root *root) ...@@ -141,9 +146,8 @@ void hfi1_mmu_rb_unregister(struct rb_root *root)
handler->ops->remove(root, rbnode, NULL); handler->ops->remove(root, rbnode, NULL);
} }
} }
spin_unlock_irqrestore(&handler->lock, flags);
if (current->mm)
mmu_notifier_unregister(&handler->mn, current->mm);
kfree(handler); kfree(handler);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册