Commit 43c0ea20 authored by Joerg Roedel's avatar Joerg Roedel

iommu/amd: Correctly set flags for handle_mm_fault call

Instead of just checking for a write access, calculate the
flags that are passed to handle_mm_fault() more precisly and
use the pre-defined macros.
Reviewed-by: default avatarJesse Barnes <jbarnes@virtuousgeek.org>
Acked-By: default avatarDavid Woodhouse <David.Woodhouse@intel.com>
Signed-off-by: default avatarJoerg Roedel <jroedel@suse.de>
parent 7f8312a3
...@@ -513,16 +513,20 @@ static bool access_error(struct vm_area_struct *vma, struct fault *fault) ...@@ -513,16 +513,20 @@ static bool access_error(struct vm_area_struct *vma, struct fault *fault)
static void do_fault(struct work_struct *work) static void do_fault(struct work_struct *work)
{ {
struct fault *fault = container_of(work, struct fault, work); struct fault *fault = container_of(work, struct fault, work);
struct mm_struct *mm;
struct vm_area_struct *vma; struct vm_area_struct *vma;
unsigned int flags = 0;
struct mm_struct *mm;
u64 address; u64 address;
int ret, write; int ret;
write = !!(fault->flags & PPR_FAULT_WRITE);
mm = fault->state->mm; mm = fault->state->mm;
address = fault->address; address = fault->address;
if (fault->flags & PPR_FAULT_USER)
flags |= FAULT_FLAG_USER;
if (fault->flags & PPR_FAULT_WRITE)
flags |= FAULT_FLAG_WRITE;
down_read(&mm->mmap_sem); down_read(&mm->mmap_sem);
vma = find_extend_vma(mm, address); vma = find_extend_vma(mm, address);
if (!vma || address < vma->vm_start) { if (!vma || address < vma->vm_start) {
...@@ -539,7 +543,7 @@ static void do_fault(struct work_struct *work) ...@@ -539,7 +543,7 @@ static void do_fault(struct work_struct *work)
goto out; goto out;
} }
ret = handle_mm_fault(mm, vma, address, write); ret = handle_mm_fault(mm, vma, address, flags);
if (ret & VM_FAULT_ERROR) { if (ret & VM_FAULT_ERROR) {
/* failed to service fault */ /* failed to service fault */
up_read(&mm->mmap_sem); up_read(&mm->mmap_sem);
......
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