|
@@ -38,6 +38,7 @@
|
|
|
#include <linux/slab.h>
|
|
|
#include <linux/export.h>
|
|
|
#include <linux/vmalloc.h>
|
|
|
+#include <linux/hugetlb.h>
|
|
|
|
|
|
#include <rdma/ib_verbs.h>
|
|
|
#include <rdma/ib_umem.h>
|
|
@@ -306,7 +307,8 @@ out_umem:
|
|
|
}
|
|
|
EXPORT_SYMBOL(ib_alloc_odp_umem);
|
|
|
|
|
|
-int ib_umem_odp_get(struct ib_ucontext *context, struct ib_umem *umem)
|
|
|
+int ib_umem_odp_get(struct ib_ucontext *context, struct ib_umem *umem,
|
|
|
+ int access)
|
|
|
{
|
|
|
int ret_val;
|
|
|
struct pid *our_pid;
|
|
@@ -315,6 +317,20 @@ int ib_umem_odp_get(struct ib_ucontext *context, struct ib_umem *umem)
|
|
|
if (!mm)
|
|
|
return -EINVAL;
|
|
|
|
|
|
+ if (access & IB_ACCESS_HUGETLB) {
|
|
|
+ struct vm_area_struct *vma;
|
|
|
+ struct hstate *h;
|
|
|
+
|
|
|
+ vma = find_vma(mm, ib_umem_start(umem));
|
|
|
+ if (!vma || !is_vm_hugetlb_page(vma))
|
|
|
+ return -EINVAL;
|
|
|
+ h = hstate_vma(vma);
|
|
|
+ umem->page_shift = huge_page_shift(h);
|
|
|
+ umem->hugetlb = 1;
|
|
|
+ } else {
|
|
|
+ umem->hugetlb = 0;
|
|
|
+ }
|
|
|
+
|
|
|
/* Prevent creating ODP MRs in child processes */
|
|
|
rcu_read_lock();
|
|
|
our_pid = get_task_pid(current->group_leader, PIDTYPE_PID);
|
|
@@ -325,7 +341,6 @@ int ib_umem_odp_get(struct ib_ucontext *context, struct ib_umem *umem)
|
|
|
goto out_mm;
|
|
|
}
|
|
|
|
|
|
- umem->hugetlb = 0;
|
|
|
umem->odp_data = kzalloc(sizeof(*umem->odp_data), GFP_KERNEL);
|
|
|
if (!umem->odp_data) {
|
|
|
ret_val = -ENOMEM;
|