X-Git-Url: http://git.lttng.org/?a=blobdiff_plain;f=lib%2Fringbuffer%2Fring_buffer_mmap.c;h=2cc0dd24df0aa1749353c125c3a1f213b9cf672b;hb=36561775ae9348c849fe261cabeccd13038e04fd;hp=68221ee9a87030563ed212ac3b32afde26572f92;hpb=f3bc08c50e1b302bceea699027d889fd6d9af525;p=lttng-modules.git diff --git a/lib/ringbuffer/ring_buffer_mmap.c b/lib/ringbuffer/ring_buffer_mmap.c index 68221ee9..2cc0dd24 100644 --- a/lib/ringbuffer/ring_buffer_mmap.c +++ b/lib/ringbuffer/ring_buffer_mmap.c @@ -3,11 +3,23 @@ * * Copyright (C) 2002-2005 - Tom Zanussi , IBM Corp * Copyright (C) 1999-2005 - Karim Yaghmour - * Copyright (C) 2008-2010 - Mathieu Desnoyers + * Copyright (C) 2008-2012 - Mathieu Desnoyers * - * Re-using content from kernel/relay.c. + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; only version 2 of the License. * - * This file is released under the GPL v2. + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Re-using code from kernel/relay.c, hence the GPLv2 license for this + * file. */ #include @@ -24,15 +36,12 @@ static int lib_ring_buffer_fault(struct vm_area_struct *vma, struct vm_fault *vm { struct lib_ring_buffer *buf = vma->vm_private_data; struct channel *chan = buf->backend.chan; - const struct lib_ring_buffer_config *config = chan->backend.config; + const struct lib_ring_buffer_config *config = &chan->backend.config; pgoff_t pgoff = vmf->pgoff; - struct page **page; + unsigned long *pfnp; void **virt; unsigned long offset, sb_bindex; - if (!buf) - return VM_FAULT_OOM; - /* * Verify that faults are only done on the range of pages owned by the * reader. @@ -44,14 +53,14 @@ static int lib_ring_buffer_fault(struct vm_area_struct *vma, struct vm_fault *vm buf->backend.chan->backend.subbuf_size)) return VM_FAULT_SIGBUS; /* - * ring_buffer_read_get_page() gets the page in the current reader's - * pages. + * ring_buffer_read_get_pfn() gets the page frame number for the + * current reader's pages. */ - page = lib_ring_buffer_read_get_page(&buf->backend, offset, &virt); - if (!*page) + pfnp = lib_ring_buffer_read_get_pfn(&buf->backend, offset, &virt); + if (!*pfnp) return VM_FAULT_SIGBUS; - get_page(*page); - vmf->page = *page; + get_page(pfn_to_page(*pfnp)); + vmf->page = pfn_to_page(*pfnp); return 0; } @@ -77,15 +86,12 @@ static int lib_ring_buffer_mmap_buf(struct lib_ring_buffer *buf, { unsigned long length = vma->vm_end - vma->vm_start; struct channel *chan = buf->backend.chan; - const struct lib_ring_buffer_config *config = chan->backend.config; + const struct lib_ring_buffer_config *config = &chan->backend.config; unsigned long mmap_buf_len; if (config->output != RING_BUFFER_MMAP) return -EINVAL; - if (!buf) - return -EBADF; - mmap_buf_len = chan->backend.buf_size; if (chan->backend.extra_reader_sb) mmap_buf_len += chan->backend.subbuf_size; @@ -100,16 +106,23 @@ static int lib_ring_buffer_mmap_buf(struct lib_ring_buffer *buf, return 0; } +int lib_ring_buffer_mmap(struct file *filp, struct vm_area_struct *vma, + struct lib_ring_buffer *buf) +{ + return lib_ring_buffer_mmap_buf(buf, vma); +} +EXPORT_SYMBOL_GPL(lib_ring_buffer_mmap); + /** - * lib_ring_buffer_mmap - mmap file op + * vfs_lib_ring_buffer_mmap - mmap file op * @filp: the file * @vma: the vma describing what to map * * Calls upon lib_ring_buffer_mmap_buf() to map the file into user space. */ -int lib_ring_buffer_mmap(struct file *filp, struct vm_area_struct *vma) +int vfs_lib_ring_buffer_mmap(struct file *filp, struct vm_area_struct *vma) { struct lib_ring_buffer *buf = filp->private_data; - return lib_ring_buffer_mmap_buf(buf, vma); + return lib_ring_buffer_mmap(filp, vma, buf); } -EXPORT_SYMBOL_GPL(lib_ring_buffer_mmap); +EXPORT_SYMBOL_GPL(vfs_lib_ring_buffer_mmap);