From 6e04492ec6ff80036535d684018b5268c16e70c7 Mon Sep 17 00:00:00 2001 From: Javier Martinez Canillas Date: Mon, 3 Jan 2011 20:24:22 +0100 Subject: scullp: Change to new page fault API --- scullp/mmap.c | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) (limited to 'scullp/mmap.c') diff --git a/scullp/mmap.c b/scullp/mmap.c index c84f0e8..0616dcb 100644 --- a/scullp/mmap.c +++ b/scullp/mmap.c @@ -57,16 +57,16 @@ void scullp_vma_close(struct vm_area_struct *vma) * is individually decreased, and would drop to 0. */ -struct page *scullp_vma_nopage(struct vm_area_struct *vma, - unsigned long address, int *type) +static int scullp_vma_nopage(struct vm_area_struct *vma, struct vm_fault *vmf) { unsigned long offset; struct scullp_dev *ptr, *dev = vma->vm_private_data; - struct page *page = VM_FAULT_SIGBUS; + struct page *page = NULL; void *pageptr = NULL; /* default to "missing" */ + int retval = VM_FAULT_NOPAGE; down(&dev->sem); - offset = (address - vma->vm_start) + (vma->vm_pgoff << PAGE_SHIFT); + offset = (unsigned long)(vmf->virtual_address - vma->vm_start) + (vma->vm_pgoff << PAGE_SHIFT); if (offset >= dev->size) goto out; /* out of range */ /* @@ -85,11 +85,12 @@ struct page *scullp_vma_nopage(struct vm_area_struct *vma, /* got it, now increment the count */ get_page(page); - if (type) - *type = VM_FAULT_MINOR; + vmf->page = page; + retval = 0; + out: up(&dev->sem); - return page; + return retval; } -- cgit v1.2.1-18-gbd029