From 57a05004a81e40f0dfc9fbfbefb4919e4010e16f Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Sat, 13 Aug 2005 14:22:59 -0700 Subject: [PATCH] --- yaml --- r: 5787 b: refs/heads/master c: 4bb82551e165f887448f6f61055d7bcd90aefa2a h: refs/heads/master i: 5785: 552536a0d39a6da76378c78381c816f0550cc02b 5783: cb0f1846b6ff8820b0fc9f606640bb916d6b1d82 v: v3 --- [refs] | 2 +- trunk/drivers/char/mem.c | 12 ++++++++---- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index 867f5f209bf0..313ec5c2ff74 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 2da5bf80f754e28cc153362e5ed1edaa9740897a +refs/heads/master: 4bb82551e165f887448f6f61055d7bcd90aefa2a diff --git a/trunk/drivers/char/mem.c b/trunk/drivers/char/mem.c index 42187381506b..850a78c9c4bc 100644 --- a/trunk/drivers/char/mem.c +++ b/trunk/drivers/char/mem.c @@ -261,7 +261,11 @@ static int mmap_mem(struct file * file, struct vm_area_struct * vma) static int mmap_kmem(struct file * file, struct vm_area_struct * vma) { - unsigned long long val; + unsigned long pfn; + + /* Turn a kernel-virtual address into a physical page frame */ + pfn = __pa((u64)vma->vm_pgoff << PAGE_SHIFT) >> PAGE_SHIFT; + /* * RED-PEN: on some architectures there is more mapped memory * than available in mem_map which pfn_valid checks @@ -269,10 +273,10 @@ static int mmap_kmem(struct file * file, struct vm_area_struct * vma) * * RED-PEN: vmalloc is not supported right now. */ - if (!pfn_valid(vma->vm_pgoff)) + if (!pfn_valid(pfn)) return -EIO; - val = (u64)vma->vm_pgoff << PAGE_SHIFT; - vma->vm_pgoff = __pa(val) >> PAGE_SHIFT; + + vma->vm_pgoff = pfn; return mmap_mem(file, vma); }