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

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

Advertisement

Kernel v2.6.25-rc7 /kernel/relay.c

Filename:/kernel/relay.c
Lines Added:13
Lines Deleted:17
Also changed in: (Previous) 2.6.25-rc6-git8  2.6.25-rc6-git7  2.6.25-rc6-git6  2.6.25-rc6-git5  2.6.25-rc6-git4  2.6.25-rc6-git3 
(Following) 2.6.25-rc7-git1  2.6.25-rc7-git2  2.6.25-rc7-git3  2.6.25-rc7-git4  2.6.25-rc7-git5  2.6.25-rc7-git6 

Location
[  2.6.25-rc7
  [  kernel
     o  relay.c

Patch

diff --git a/kernel/relay.c b/kernel/relay.c
index 61134eb..4c035a8 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);
 
@@ -1071,7 +1066,7 @@ static int subbuf_splice_actor(struct file *in,
                 unsigned int flags,
                 int *nonpad_ret)
 {
-   unsigned int pidx, poff, total_len, subbuf_pages, ret;
+   unsigned int pidx, poff, total_len, subbuf_pages, nr_pages, ret;
    struct rchan_buf *rbuf = in->private_data;
    unsigned int subbuf_size = rbuf->chan->subbuf_size;
    uint64_t pos = (uint64_t) *ppos;
@@ -1102,8 +1097,9 @@ static int subbuf_splice_actor(struct file *in,
    subbuf_pages = rbuf->chan->alloc_size >> PAGE_SHIFT;
    pidx = (read_start / PAGE_SIZE) % subbuf_pages;
    poff = read_start & ~PAGE_MASK;
+   nr_pages = min_t(unsigned int, subbuf_pages, PIPE_BUFFERS);
 
-   for (total_len = 0; spd.nr_pages < subbuf_pages; spd.nr_pages++) {
+   for (total_len = 0; spd.nr_pages < nr_pages; spd.nr_pages++) {
       unsigned int this_len, this_end, private;
       unsigned int cur_pos = read_start + total_len;
 


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