diff options
-rw-r--r-- | libc/sysdeps/linux/bfin/Makefile.arch | 2 | ||||
-rw-r--r-- | libc/sysdeps/linux/bfin/mmap.c | 24 | ||||
-rw-r--r-- | libc/sysdeps/linux/common/mmap.c | 29 |
3 files changed, 30 insertions, 25 deletions
diff --git a/libc/sysdeps/linux/bfin/Makefile.arch b/libc/sysdeps/linux/bfin/Makefile.arch index fa62cc610..7a428b380 100644 --- a/libc/sysdeps/linux/bfin/Makefile.arch +++ b/libc/sysdeps/linux/bfin/Makefile.arch @@ -5,7 +5,7 @@ # Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball. # -CSRC := brk.c bsdsetjmp.c clone.c syscall.c mmap.c +CSRC := brk.c bsdsetjmp.c clone.c syscall.c SSRC := __longjmp.S setjmp.S bsd-_setjmp.S vfork.S diff --git a/libc/sysdeps/linux/bfin/mmap.c b/libc/sysdeps/linux/bfin/mmap.c deleted file mode 100644 index 41140df0e..000000000 --- a/libc/sysdeps/linux/bfin/mmap.c +++ /dev/null @@ -1,24 +0,0 @@ -/* Use new style mmap for bfin */ - -#include <unistd.h> -#include <errno.h> -#include <sys/mman.h> -#include <sys/syscall.h> -#include <asm/page.h> - -#define __NR___syscall_mmap2 __NR_mmap2 -inline _syscall6(__ptr_t, __syscall_mmap2, __ptr_t, addr, - size_t, len, int, prot, int, flags, int, fd, off_t, offset); - -libc_hidden_proto(mmap) - -__ptr_t mmap(__ptr_t addr, size_t len, int prot, - int flags, int fd, __off_t offset) -{ - if (offset & ~PAGE_MASK) { - return NULL; - } - return __syscall_mmap2(addr, len, prot, flags, fd, offset >> PAGE_SHIFT); -} - -libc_hidden_def(mmap) diff --git a/libc/sysdeps/linux/common/mmap.c b/libc/sysdeps/linux/common/mmap.c index 91fc0beb1..f40554ebb 100644 --- a/libc/sysdeps/linux/common/mmap.c +++ b/libc/sysdeps/linux/common/mmap.c @@ -10,6 +10,7 @@ #include <sys/syscall.h> #include <unistd.h> #include <sys/mman.h> +#include <bits/uClibc_page.h> #ifdef __NR_mmap @@ -41,4 +42,32 @@ __ptr_t mmap(__ptr_t addr, size_t len, int prot, #endif libc_hidden_def(mmap) + +#elif defined(__NR_mmap2) + +libc_hidden_proto(mmap) + +#define __NR___syscall_mmap2 __NR_mmap2 +static inline _syscall6(__ptr_t, __syscall_mmap2, __ptr_t, addr, + size_t, len, int, prot, int, flags, int, fd, off_t, offset); + +/* Some architectures always use 12 as page shift for mmap2() eventhough the + * real PAGE_SHIFT != 12. Other architectures use the same value as + * PAGE_SHIFT... + */ +# ifndef MMAP2_PAGE_SHIFT +# define MMAP2_PAGE_SHIFT 12 +# endif + +__ptr_t mmap(__ptr_t addr, size_t len, int prot, int flags, int fd, __off_t offset) +{ + if (offset & ((1 << MMAP2_PAGE_SHIFT) - 1)) { + __set_errno(EINVAL); + return MAP_FAILED; + } + return __syscall_mmap2(addr, len, prot, flags, fd, offset >> MMAP2_PAGE_SHIFT); +} + +libc_hidden_def(mmap) + #endif |