|
|
@@ -152,9 +152,6 @@ static void xdp_umem_unaccount_pages(struct xdp_umem *umem)
|
|
|
|
|
|
static void xdp_umem_release(struct xdp_umem *umem)
|
|
|
{
|
|
|
- struct task_struct *task;
|
|
|
- struct mm_struct *mm;
|
|
|
-
|
|
|
xdp_umem_clear_dev(umem);
|
|
|
|
|
|
if (umem->fq) {
|
|
|
@@ -169,21 +166,10 @@ static void xdp_umem_release(struct xdp_umem *umem)
|
|
|
|
|
|
xdp_umem_unpin_pages(umem);
|
|
|
|
|
|
- task = get_pid_task(umem->pid, PIDTYPE_PID);
|
|
|
- put_pid(umem->pid);
|
|
|
- if (!task)
|
|
|
- goto out;
|
|
|
- mm = get_task_mm(task);
|
|
|
- put_task_struct(task);
|
|
|
- if (!mm)
|
|
|
- goto out;
|
|
|
-
|
|
|
- mmput(mm);
|
|
|
kfree(umem->pages);
|
|
|
umem->pages = NULL;
|
|
|
|
|
|
xdp_umem_unaccount_pages(umem);
|
|
|
-out:
|
|
|
kfree(umem);
|
|
|
}
|
|
|
|
|
|
@@ -312,7 +298,6 @@ static int xdp_umem_reg(struct xdp_umem *umem, struct xdp_umem_reg *mr)
|
|
|
if (size_chk < 0)
|
|
|
return -EINVAL;
|
|
|
|
|
|
- umem->pid = get_task_pid(current, PIDTYPE_PID);
|
|
|
umem->address = (unsigned long)addr;
|
|
|
umem->props.chunk_mask = ~((u64)chunk_size - 1);
|
|
|
umem->props.size = size;
|
|
|
@@ -328,7 +313,7 @@ static int xdp_umem_reg(struct xdp_umem *umem, struct xdp_umem_reg *mr)
|
|
|
|
|
|
err = xdp_umem_account_pages(umem);
|
|
|
if (err)
|
|
|
- goto out;
|
|
|
+ return err;
|
|
|
|
|
|
err = xdp_umem_pin_pages(umem);
|
|
|
if (err)
|
|
|
@@ -347,8 +332,6 @@ static int xdp_umem_reg(struct xdp_umem *umem, struct xdp_umem_reg *mr)
|
|
|
|
|
|
out_account:
|
|
|
xdp_umem_unaccount_pages(umem);
|
|
|
-out:
|
|
|
- put_pid(umem->pid);
|
|
|
return err;
|
|
|
}
|
|
|
|