X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=mm%2Fmadvise.c;h=c8c01a12fea43719b034e6f394d8d72faa1aea16;hb=4d7670e0f649f9e6e6ea6c8bb9f52441fa00f92b;hp=54a5d3bc55d501caa3d2da3f3a9ef265ca584f2a;hpb=3bc1ee3e8f1c05c0f64a479c6d56eb34a6190599;p=linux-2.6 diff --git a/mm/madvise.c b/mm/madvise.c index 54a5d3bc55..c8c01a12fe 100644 --- a/mm/madvise.c +++ b/mm/madvise.c @@ -83,8 +83,10 @@ static long madvise_willneed(struct vm_area_struct * vma, { struct file *file = vma->vm_file; - if (!file) - return -EBADF; + if (file->f_mapping->a_ops->get_xip_page) { + /* no bad return value, but ignore advice */ + return 0; + } *prev = vma; start = ((start - vma->vm_start) >> PAGE_SHIFT) + vma->vm_pgoff; @@ -135,11 +137,16 @@ static long madvise_dontneed(struct vm_area_struct * vma, return 0; } -static long madvise_vma(struct vm_area_struct *vma, struct vm_area_struct **prev, - unsigned long start, unsigned long end, int behavior) +static long +madvise_vma(struct vm_area_struct *vma, struct vm_area_struct **prev, + unsigned long start, unsigned long end, int behavior) { + struct file *filp = vma->vm_file; long error = -EBADF; + if (!filp) + goto out; + switch (behavior) { case MADV_NORMAL: case MADV_SEQUENTIAL: @@ -160,6 +167,7 @@ static long madvise_vma(struct vm_area_struct *vma, struct vm_area_struct **prev break; } +out: return error; }