diff options
-rw-r--r-- | driver/compat.h | 9 | ||||
-rw-r--r-- | driver/kmem.c | 4 | ||||
-rw-r--r-- | driver/umem.c | 22 |
3 files changed, 19 insertions, 16 deletions
diff --git a/driver/compat.h b/driver/compat.h index 24cc5a9..ba9d15a 100644 --- a/driver/compat.h +++ b/driver/compat.h @@ -37,4 +37,13 @@ # define __devinitdata #endif +#if LINUX_VERSION_CODE >= KERNEL_VERSION(4,9,0) +# define get_user_pages_compat(vma, nr, pages) get_user_pages(vma, nr, FOLL_WRITE, pages, NULL) +#elif LINUX_VERSION_CODE >= KERNEL_VERSION(4,6,0) +# define get_user_pages_compat(vma, nr, pages) get_user_pages(vma, nr, 1, 0, pages, NULL) +#else +# define get_user_pages_compat(vma, nr, pages) get_user_pages(current, current->mm, vma, nr, 1, 0, pages, NULL) +#endif + + #endif diff --git a/driver/kmem.c b/driver/kmem.c index 522f3bc..c1282be 100644 --- a/driver/kmem.c +++ b/driver/kmem.c @@ -616,8 +616,10 @@ int pcidriver_mmap_kmem(pcidriver_privdata_t *privdata, struct vm_area_struct *v vma->vm_flags |= (VM_RESERVED); + if ((kmem_entry->type&&PCILIB_KMEM_TYPE_MASK) == PCILIB_KMEM_TYPE_CONSISTENT) { // This is coherent memory, so it must not be cached. - vma->vm_page_prot = pgprot_noncached(vma->vm_page_prot); + vma->vm_page_prot = pgprot_noncached(vma->vm_page_prot); + } mod_info_dbg("Mapping address %08lx / PFN %08lx\n", virt_to_phys((void*)kmem_entry->cpua), diff --git a/driver/umem.c b/driver/umem.c index 8d73207..e643102 100644 --- a/driver/umem.c +++ b/driver/umem.c @@ -81,15 +81,7 @@ int pcidriver_umem_sgmap(pcidriver_privdata_t *privdata, umem_handle_t *umem_han /* Get the page information */ down_read(¤t->mm->mmap_sem); - res = get_user_pages( - current, - current->mm, - umem_handle->vma, - nr_pages, - 1, - 0, /* do not force, FIXME: shall I? */ - pages, - NULL ); + res = get_user_pages_compat(umem_handle->vma, nr_pages, pages); up_read(¤t->mm->mmap_sem); /* Error, not all pages mapped */ @@ -106,7 +98,7 @@ int pcidriver_umem_sgmap(pcidriver_privdata_t *privdata, umem_handle_t *umem_han /* Lock the pages, then populate the SG list with the pages */ /* page0 is different */ if ( !PageReserved(pages[0]) ) - __set_page_locked(pages[0]); + lock_page(pages[0]); offset = (umem_handle->vma & ~PAGE_MASK); length = (umem_handle->size > (PAGE_SIZE-offset) ? (PAGE_SIZE-offset) : umem_handle->size); @@ -117,7 +109,7 @@ int pcidriver_umem_sgmap(pcidriver_privdata_t *privdata, umem_handle_t *umem_han for(i=1; i<nr_pages; i++) { /* Lock page first */ if ( !PageReserved(pages[i]) ) - __set_page_locked(pages[i]); + lock_page(pages[i]); /* Populate the list */ sg_set_page(&sg[i], pages[i], ((count > PAGE_SIZE) ? PAGE_SIZE : count), 0); @@ -166,10 +158,10 @@ umem_sgmap_unmap: if (nr_pages > 0) { for(i=0; i<nr_pages; i++) { if (PageLocked(pages[i])) - __clear_page_locked(pages[i]); + unlock_page(pages[i]); if (!PageReserved(pages[i])) set_page_dirty(pages[i]); - page_cache_release(pages[i]); + put_page(pages[i]); } } vfree(sg); @@ -198,10 +190,10 @@ int pcidriver_umem_sgunmap(pcidriver_privdata_t *privdata, pcidriver_umem_entry_ /* Mark pages as Dirty and unlock it */ if ( !PageReserved( umem_entry->pages[i] )) { SetPageDirty( umem_entry->pages[i] ); - __clear_page_locked(umem_entry->pages[i]); + unlock_page(umem_entry->pages[i]); } /* and release it from the cache */ - page_cache_release( umem_entry->pages[i] ); + put_page( umem_entry->pages[i] ); } } |