Commit 622c202c authored by Dean Luick's avatar Dean Luick Committed by Doug Ledford

IB/hfi1: Fix TID caching actions

Per file descriptor TID caching actions depend on a global that can
change midway through the lifetime of that file descriptor.

Make the use of caching consistent for the life of the file descriptor
by using the presence of the cache handler to decide when to use the cache
functions.
Reviewed-by: default avatarIra Weiny <ira.weiny@intel.com>
Signed-off-by: default avatarDean Luick <dean.luick@intel.com>
Signed-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent e0b09ac5
...@@ -1132,6 +1132,10 @@ static int get_ctxt_info(struct file *fp, void __user *ubase, __u32 len) ...@@ -1132,6 +1132,10 @@ static int get_ctxt_info(struct file *fp, void __user *ubase, __u32 len)
HFI1_CAP_MISC_MASK) << HFI1_CAP_USER_SHIFT) | HFI1_CAP_MISC_MASK) << HFI1_CAP_USER_SHIFT) |
HFI1_CAP_UGET_MASK(uctxt->flags, MASK) | HFI1_CAP_UGET_MASK(uctxt->flags, MASK) |
HFI1_CAP_KGET_MASK(uctxt->flags, K2U); HFI1_CAP_KGET_MASK(uctxt->flags, K2U);
/* adjust flag if this fd is not able to cache */
if (!fd->handler)
cinfo.runtime_flags |= HFI1_CAP_TID_UNMAP; /* no caching */
cinfo.num_active = hfi1_count_active_units(); cinfo.num_active = hfi1_count_active_units();
cinfo.unit = uctxt->dd->unit; cinfo.unit = uctxt->dd->unit;
cinfo.ctxt = uctxt->ctxt; cinfo.ctxt = uctxt->ctxt;
......
...@@ -196,7 +196,7 @@ int hfi1_user_exp_rcv_init(struct file *fp) ...@@ -196,7 +196,7 @@ int hfi1_user_exp_rcv_init(struct file *fp)
if (!fd->entry_to_rb) if (!fd->entry_to_rb)
return -ENOMEM; return -ENOMEM;
if (!HFI1_CAP_IS_USET(TID_UNMAP)) { if (!HFI1_CAP_UGET_MASK(uctxt->flags, TID_UNMAP)) {
fd->invalid_tid_idx = 0; fd->invalid_tid_idx = 0;
fd->invalid_tids = kzalloc(uctxt->expected_count * fd->invalid_tids = kzalloc(uctxt->expected_count *
sizeof(u32), GFP_KERNEL); sizeof(u32), GFP_KERNEL);
...@@ -207,15 +207,13 @@ int hfi1_user_exp_rcv_init(struct file *fp) ...@@ -207,15 +207,13 @@ int hfi1_user_exp_rcv_init(struct file *fp)
/* /*
* Register MMU notifier callbacks. If the registration * Register MMU notifier callbacks. If the registration
* fails, continue but turn off the TID caching for * fails, continue without TID caching for this context.
* all user contexts.
*/ */
ret = hfi1_mmu_rb_register(fd, fd->mm, &tid_rb_ops, &fd->handler); ret = hfi1_mmu_rb_register(fd, fd->mm, &tid_rb_ops, &fd->handler);
if (ret) { if (ret) {
dd_dev_info(dd, dd_dev_info(dd,
"Failed MMU notifier registration %d\n", "Failed MMU notifier registration %d\n",
ret); ret);
HFI1_CAP_USET(TID_UNMAP);
ret = 0; ret = 0;
} }
} }
...@@ -234,7 +232,7 @@ int hfi1_user_exp_rcv_init(struct file *fp) ...@@ -234,7 +232,7 @@ int hfi1_user_exp_rcv_init(struct file *fp)
* init. * init.
*/ */
spin_lock(&fd->tid_lock); spin_lock(&fd->tid_lock);
if (uctxt->subctxt_cnt && !HFI1_CAP_IS_USET(TID_UNMAP)) { if (uctxt->subctxt_cnt && fd->handler) {
u16 remainder; u16 remainder;
fd->tid_limit = uctxt->expected_count / uctxt->subctxt_cnt; fd->tid_limit = uctxt->expected_count / uctxt->subctxt_cnt;
...@@ -260,7 +258,7 @@ int hfi1_user_exp_rcv_free(struct hfi1_filedata *fd) ...@@ -260,7 +258,7 @@ int hfi1_user_exp_rcv_free(struct hfi1_filedata *fd)
* The notifier would have been removed when the process'es mm * The notifier would have been removed when the process'es mm
* was freed. * was freed.
*/ */
if (!HFI1_CAP_IS_USET(TID_UNMAP)) if (fd->handler)
hfi1_mmu_rb_unregister(fd->handler); hfi1_mmu_rb_unregister(fd->handler);
kfree(fd->invalid_tids); kfree(fd->invalid_tids);
...@@ -857,7 +855,7 @@ static int set_rcvarray_entry(struct file *fp, unsigned long vaddr, ...@@ -857,7 +855,7 @@ static int set_rcvarray_entry(struct file *fp, unsigned long vaddr,
node->freed = false; node->freed = false;
memcpy(node->pages, pages, sizeof(struct page *) * npages); memcpy(node->pages, pages, sizeof(struct page *) * npages);
if (HFI1_CAP_IS_USET(TID_UNMAP)) if (!fd->handler)
ret = tid_rb_insert(fd, &node->mmu); ret = tid_rb_insert(fd, &node->mmu);
else else
ret = hfi1_mmu_rb_insert(fd->handler, &node->mmu); ret = hfi1_mmu_rb_insert(fd->handler, &node->mmu);
...@@ -900,7 +898,7 @@ static int unprogram_rcvarray(struct file *fp, u32 tidinfo, ...@@ -900,7 +898,7 @@ static int unprogram_rcvarray(struct file *fp, u32 tidinfo,
node = fd->entry_to_rb[rcventry]; node = fd->entry_to_rb[rcventry];
if (!node || node->rcventry != (uctxt->expected_base + rcventry)) if (!node || node->rcventry != (uctxt->expected_base + rcventry))
return -EBADF; return -EBADF;
if (HFI1_CAP_IS_USET(TID_UNMAP)) if (!fd->handler)
tid_rb_remove(fd, &node->mmu, fd->mm); tid_rb_remove(fd, &node->mmu, fd->mm);
else else
hfi1_mmu_rb_remove(fd->handler, &node->mmu); hfi1_mmu_rb_remove(fd->handler, &node->mmu);
...@@ -963,7 +961,7 @@ static void unlock_exp_tids(struct hfi1_ctxtdata *uctxt, ...@@ -963,7 +961,7 @@ static void unlock_exp_tids(struct hfi1_ctxtdata *uctxt,
uctxt->expected_base]; uctxt->expected_base];
if (!node || node->rcventry != rcventry) if (!node || node->rcventry != rcventry)
continue; continue;
if (HFI1_CAP_IS_USET(TID_UNMAP)) if (!fd->handler)
tid_rb_remove(fd, &node->mmu, fd->mm); tid_rb_remove(fd, &node->mmu, fd->mm);
else else
hfi1_mmu_rb_remove(fd->handler, hfi1_mmu_rb_remove(fd->handler,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment