X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=mm%2Fmmap.c;h=f681e1842fadc1ccd8d7188a7ca1688c73548111;hb=9bb5d40cd93c9dd4be74834b1dcb1ba03629716b;hp=da3e9c04bf370fe5d591d72aa6222a8c47ec402c;hpb=c8de2fa4dc2778ae3605925c127b3deac54b2b3a;p=~andy%2Flinux diff --git a/mm/mmap.c b/mm/mmap.c index da3e9c04bf3..f681e1842fa 100644 --- a/mm/mmap.c +++ b/mm/mmap.c @@ -1363,15 +1363,24 @@ SYSCALL_DEFINE6(mmap_pgoff, unsigned long, addr, unsigned long, len, file = fget(fd); if (!file) goto out; + if (is_file_hugepages(file)) + len = ALIGN(len, huge_page_size(hstate_file(file))); } else if (flags & MAP_HUGETLB) { struct user_struct *user = NULL; + struct hstate *hs = hstate_sizelog((flags >> MAP_HUGE_SHIFT) & + SHM_HUGE_MASK); + + if (!hs) + return -EINVAL; + + len = ALIGN(len, huge_page_size(hs)); /* * VM_NORESERVE is used because the reservations will be * taken when vm_ops->mmap() is called * A dummy user value is used because we are not locking * memory so no accounting is necessary */ - file = hugetlb_file_setup(HUGETLB_ANON_FILE, addr, len, + file = hugetlb_file_setup(HUGETLB_ANON_FILE, len, VM_NORESERVE, &user, HUGETLB_ANONHUGE_INODE, (flags >> MAP_HUGE_SHIFT) & MAP_HUGE_MASK);