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

IB/hfi1: Don't remove list entries if they are not in a list

The SDMA cache logic maintains an eviction list which is ordered
by most recently used user buffers. Upon errors or buffer freeing,
the list nodes were unconditionally being deleted. This would lead
to list corruption warnings if the nodes were never inserted in the
eviction list to begin with.

This commit prevents this by checking that the nodes are already
part of the eviction list.
Reviewed-by: NDean Luick <dean.luick@intel.com>
Signed-off-by: NMitko Haralanov <mitko.haralanov@intel.com>
Signed-off-by: NDennis Dalessandro <dennis.dalessandro@intel.com>
Signed-off-by: NDoug Ledford <dledford@redhat.com>
上级 747f4d7a
...@@ -1135,7 +1135,8 @@ static int pin_vector_pages(struct user_sdma_request *req, ...@@ -1135,7 +1135,8 @@ static int pin_vector_pages(struct user_sdma_request *req,
ret = hfi1_mmu_rb_insert(&req->pq->sdma_rb_root, &node->rb); ret = hfi1_mmu_rb_insert(&req->pq->sdma_rb_root, &node->rb);
if (ret) { if (ret) {
spin_lock(&pq->evict_lock); spin_lock(&pq->evict_lock);
list_del(&node->list); if (!list_empty(&node->list))
list_del(&node->list);
pq->n_locked -= node->npages; pq->n_locked -= node->npages;
spin_unlock(&pq->evict_lock); spin_unlock(&pq->evict_lock);
ret = 0; ret = 0;
...@@ -1558,7 +1559,8 @@ static void sdma_rb_remove(struct rb_root *root, struct mmu_rb_node *mnode, ...@@ -1558,7 +1559,8 @@ static void sdma_rb_remove(struct rb_root *root, struct mmu_rb_node *mnode,
container_of(mnode, struct sdma_mmu_node, rb); container_of(mnode, struct sdma_mmu_node, rb);
spin_lock(&node->pq->evict_lock); spin_lock(&node->pq->evict_lock);
list_del(&node->list); if (!list_empty(&node->list))
list_del(&node->list);
node->pq->n_locked -= node->npages; node->pq->n_locked -= node->npages;
spin_unlock(&node->pq->evict_lock); spin_unlock(&node->pq->evict_lock);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册