提交 c0946642 编写于 作者: D Dean Luick 提交者: Doug Ledford

IB/hfi1: Always expect ops functions

Remove, insert, and invalidate are always provided.  No
need to test.
Reviewed-by: NIra Weiny <ira.weiny@intel.com>
Signed-off-by: NDean Luick <dean.luick@intel.com>
Signed-off-by: NDoug Ledford <dledford@redhat.com>
上级 862548da
...@@ -99,9 +99,6 @@ int hfi1_mmu_rb_register(struct rb_root *root, struct mmu_rb_ops *ops) ...@@ -99,9 +99,6 @@ int hfi1_mmu_rb_register(struct rb_root *root, struct mmu_rb_ops *ops)
{ {
struct mmu_rb_handler *handlr; struct mmu_rb_handler *handlr;
if (!ops->invalidate)
return -EINVAL;
handlr = kmalloc(sizeof(*handlr), GFP_KERNEL); handlr = kmalloc(sizeof(*handlr), GFP_KERNEL);
if (!handlr) if (!handlr)
return -ENOMEM; return -ENOMEM;
...@@ -143,8 +140,7 @@ void hfi1_mmu_rb_unregister(struct rb_root *root) ...@@ -143,8 +140,7 @@ void hfi1_mmu_rb_unregister(struct rb_root *root)
while ((node = rb_first(root))) { while ((node = rb_first(root))) {
rbnode = rb_entry(node, struct mmu_rb_node, node); rbnode = rb_entry(node, struct mmu_rb_node, node);
rb_erase(node, root); rb_erase(node, root);
if (handler->ops->remove) handler->ops->remove(root, rbnode, NULL);
handler->ops->remove(root, rbnode, NULL);
} }
} }
spin_unlock_irqrestore(&handler->lock, flags); spin_unlock_irqrestore(&handler->lock, flags);
...@@ -172,11 +168,9 @@ int hfi1_mmu_rb_insert(struct rb_root *root, struct mmu_rb_node *mnode) ...@@ -172,11 +168,9 @@ int hfi1_mmu_rb_insert(struct rb_root *root, struct mmu_rb_node *mnode)
} }
__mmu_int_rb_insert(mnode, root); __mmu_int_rb_insert(mnode, root);
if (handler->ops->insert) { ret = handler->ops->insert(root, mnode);
ret = handler->ops->insert(root, mnode); if (ret)
if (ret) __mmu_int_rb_remove(mnode, root);
__mmu_int_rb_remove(mnode, root);
}
unlock: unlock:
spin_unlock_irqrestore(&handler->lock, flags); spin_unlock_irqrestore(&handler->lock, flags);
return ret; return ret;
...@@ -219,8 +213,7 @@ static void __mmu_rb_remove(struct mmu_rb_handler *handler, ...@@ -219,8 +213,7 @@ static void __mmu_rb_remove(struct mmu_rb_handler *handler,
__mmu_int_rb_remove(node, handler->root); __mmu_int_rb_remove(node, handler->root);
spin_unlock_irqrestore(&handler->lock, flags); spin_unlock_irqrestore(&handler->lock, flags);
if (handler->ops->remove) handler->ops->remove(handler->root, node, mm);
handler->ops->remove(handler->root, node, mm);
} }
struct mmu_rb_node *hfi1_mmu_rb_extract(struct rb_root *root, struct mmu_rb_node *hfi1_mmu_rb_extract(struct rb_root *root,
...@@ -300,8 +293,7 @@ static void mmu_notifier_mem_invalidate(struct mmu_notifier *mn, ...@@ -300,8 +293,7 @@ static void mmu_notifier_mem_invalidate(struct mmu_notifier *mn,
node->addr, node->len); node->addr, node->len);
if (handler->ops->invalidate(root, node)) { if (handler->ops->invalidate(root, node)) {
__mmu_int_rb_remove(node, root); __mmu_int_rb_remove(node, root);
if (handler->ops->remove) handler->ops->remove(root, node, mm);
handler->ops->remove(root, node, mm);
} }
} }
spin_unlock_irqrestore(&handler->lock, flags); spin_unlock_irqrestore(&handler->lock, flags);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册