17dcbbb2bSMichal Simek /*
27dcbbb2bSMichal Simek  * Copyright (C) 2007-2009 Michal Simek <monstr@monstr.eu>
37dcbbb2bSMichal Simek  * Copyright (C) 2007-2009 PetaLogix
47dcbbb2bSMichal Simek  * Copyright (C) 2007 John Williams <john.williams@petalogix.com>
57dcbbb2bSMichal Simek  *
67dcbbb2bSMichal Simek  * Copyright (C) 2006 Atmark Techno, Inc.
77dcbbb2bSMichal Simek  *	Yasushi SHOJI <yashi@atmark-techno.com>
87dcbbb2bSMichal Simek  *	Tetsuya OHKAWA <tetsuya@atmark-techno.com>
97dcbbb2bSMichal Simek  *
107dcbbb2bSMichal Simek  * This file is subject to the terms and conditions of the GNU General Public
117dcbbb2bSMichal Simek  * License. See the file "COPYING" in the main directory of this archive
127dcbbb2bSMichal Simek  * for more details.
137dcbbb2bSMichal Simek  */
147dcbbb2bSMichal Simek 
157dcbbb2bSMichal Simek #include <linux/errno.h>
16d64af918SMichal Simek #include <linux/export.h>
177dcbbb2bSMichal Simek #include <linux/mm.h>
187dcbbb2bSMichal Simek #include <linux/smp.h>
197dcbbb2bSMichal Simek #include <linux/syscalls.h>
207dcbbb2bSMichal Simek #include <linux/sem.h>
217dcbbb2bSMichal Simek #include <linux/msg.h>
227dcbbb2bSMichal Simek #include <linux/shm.h>
237dcbbb2bSMichal Simek #include <linux/stat.h>
247dcbbb2bSMichal Simek #include <linux/mman.h>
257dcbbb2bSMichal Simek #include <linux/sys.h>
267dcbbb2bSMichal Simek #include <linux/ipc.h>
277dcbbb2bSMichal Simek #include <linux/file.h>
287dcbbb2bSMichal Simek #include <linux/err.h>
297dcbbb2bSMichal Simek #include <linux/fs.h>
307dcbbb2bSMichal Simek #include <linux/semaphore.h>
317dcbbb2bSMichal Simek #include <linux/uaccess.h>
327dcbbb2bSMichal Simek #include <linux/unistd.h>
335a0e3ad6STejun Heo #include <linux/slab.h>
347dcbbb2bSMichal Simek #include <asm/syscalls.h>
357dcbbb2bSMichal Simek 
SYSCALL_DEFINE6(mmap,unsigned long,addr,unsigned long,len,unsigned long,prot,unsigned long,flags,unsigned long,fd,off_t,pgoff)36176195e7SMichal Simek SYSCALL_DEFINE6(mmap, unsigned long, addr, unsigned long, len,
37176195e7SMichal Simek 		unsigned long, prot, unsigned long, flags, unsigned long, fd,
38176195e7SMichal Simek 		off_t, pgoff)
397dcbbb2bSMichal Simek {
40f8b72560SAl Viro 	if (pgoff & ~PAGE_MASK)
41f8b72560SAl Viro 		return -EINVAL;
427dcbbb2bSMichal Simek 
43a90f590aSDominik Brodowski 	return ksys_mmap_pgoff(addr, len, prot, flags, fd, pgoff >> PAGE_SHIFT);
447dcbbb2bSMichal Simek }
4599399545SMichal Simek 
SYSCALL_DEFINE6(mmap2,unsigned long,addr,unsigned long,len,unsigned long,prot,unsigned long,flags,unsigned long,fd,unsigned long,pgoff)4699399545SMichal Simek SYSCALL_DEFINE6(mmap2, unsigned long, addr, unsigned long, len,
4799399545SMichal Simek 		unsigned long, prot, unsigned long, flags, unsigned long, fd,
4899399545SMichal Simek 		unsigned long, pgoff)
4999399545SMichal Simek {
5099399545SMichal Simek 	if (pgoff & (~PAGE_MASK >> 12))
5199399545SMichal Simek 		return -EINVAL;
5299399545SMichal Simek 
53a90f590aSDominik Brodowski 	return ksys_mmap_pgoff(addr, len, prot, flags, fd,
5499399545SMichal Simek 			       pgoff >> (PAGE_SHIFT - 12));
5599399545SMichal Simek }
56