Linux Headquarters
[ Register ]
[ About us ] [ Home Page ]

Advertisement
[ Kernel ] [ Documentation ] [ Links ] [ Books ]

Advertisement

Kernel v2.6.24-git16 /kernel/relay.c

Filename:/kernel/relay.c
Lines Added:10
Lines Deleted:15
Also changed in: (Previous) 2.6.24-git15  2.6.24-git14  2.6.24  2.6.24-rc8  2.6.24-rc7  2.6.24-rc6 
(Following) 2.6.24-git17  2.6.24.1-rc1  2.6.24-git18  2.6.24-git19  2.6.24.1  2.6.24-git20 

Location
[  2.6.24-git16
  [  kernel
     o  relay.c

Patch

diff --git a/kernel/relay.c b/kernel/relay.c
index 61134eb..d080b9d 100644
--- a/kernel/relay.c
+++ b/kernel/relay.c
@@ -37,37 +37,31 @@ static void relay_file_mmap_close(struct vm_area_struct *vma)
 }
 
 /*
- * nopage() vm_op implementation for relay file mapping.
+ * fault() vm_op implementation for relay file mapping.
  */
-static struct page *relay_buf_nopage(struct vm_area_struct *vma,
-                 unsigned long address,
-                 int *type)
+static int relay_buf_fault(struct vm_area_struct *vma, struct vm_fault *vmf)
 {
    struct page *page;
    struct rchan_buf *buf = vma->vm_private_data;
-   unsigned long offset = address - vma->vm_start;
+   pgoff_t pgoff = vmf->pgoff;
 
-   if (address > vma->vm_end)
-      return NOPAGE_SIGBUS; /* Disallow mremap */
    if (!buf)
-      return NOPAGE_OOM;
+      return VM_FAULT_OOM;
 
-   page = vmalloc_to_page(buf->start + offset);
+   page = vmalloc_to_page(buf->start + (pgoff << PAGE_SHIFT));
    if (!page)
-      return NOPAGE_OOM;
+      return VM_FAULT_SIGBUS;
    get_page(page);
+   vmf->page = page;
 
-   if (type)
-      *type = VM_FAULT_MINOR;
-
-   return page;
+   return 0;
 }
 
 /*
  * vm_ops for relay file mappings.
  */
 static struct vm_operations_struct relay_file_mmap_ops = {
-   .nopage = relay_buf_nopage,
+   .fault = relay_buf_fault,
    .close = relay_file_mmap_close,
 };
 
@@ -92,6 +86,7 @@ static int relay_mmap_buf(struct rchan_buf *buf, struct vm_area_struct *vma)
       return -EINVAL;
 
    vma->vm_ops = &relay_file_mmap_ops;
+   vma->vm_flags |= VM_DONTEXPAND;
    vma->vm_private_data = buf;
    buf->chan->cb->buf_mapped(buf, filp);
 


Comments: webmaster (at) linuxhq.com.
Advertising: banners (at) linuxhq.com.
Compilation ©1998-2008 Linux Headquarters, Inc.