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

IB/hfi1: Correctly compute node interval

The computation of the interval of an interval RB node
was incorrect leading to data corruption due to the RB
search algorithm not properly finding the all RB nodes
in an MMU invalidation interval.

The problem stemmed from the fact that the beginning
address of the node's range was being aligned to a page
boundary. For certain buffer sizes, this would lead to
a end address calculation that was off by 1 page.

An important aspect of keeping the RB same is also
updating the node's range in the case it's being extended.
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>
上级 782f6697
...@@ -91,7 +91,7 @@ static unsigned long mmu_node_start(struct mmu_rb_node *node) ...@@ -91,7 +91,7 @@ static unsigned long mmu_node_start(struct mmu_rb_node *node)
static unsigned long mmu_node_last(struct mmu_rb_node *node) static unsigned long mmu_node_last(struct mmu_rb_node *node)
{ {
return PAGE_ALIGN((node->addr & PAGE_MASK) + node->len) - 1; return PAGE_ALIGN(node->addr + node->len) - 1;
} }
int hfi1_mmu_rb_register(struct rb_root *root, struct mmu_rb_ops *ops) int hfi1_mmu_rb_register(struct rb_root *root, struct mmu_rb_ops *ops)
......
...@@ -1076,7 +1076,6 @@ static int pin_vector_pages(struct user_sdma_request *req, ...@@ -1076,7 +1076,6 @@ static int pin_vector_pages(struct user_sdma_request *req,
return -ENOMEM; return -ENOMEM;
node->rb.addr = (unsigned long)iovec->iov.iov_base; node->rb.addr = (unsigned long)iovec->iov.iov_base;
node->rb.len = iovec->iov.iov_len;
node->pq = pq; node->pq = pq;
atomic_set(&node->refcount, 0); atomic_set(&node->refcount, 0);
INIT_LIST_HEAD(&node->list); INIT_LIST_HEAD(&node->list);
...@@ -1117,6 +1116,7 @@ static int pin_vector_pages(struct user_sdma_request *req, ...@@ -1117,6 +1116,7 @@ static int pin_vector_pages(struct user_sdma_request *req,
goto bail; goto bail;
} }
kfree(node->pages); kfree(node->pages);
node->rb.len = iovec->iov.iov_len;
node->pages = pages; node->pages = pages;
node->npages += pinned; node->npages += pinned;
npages = node->npages; npages = node->npages;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册