blob: 89958985e42f1726950b7d9f4d2ceb7dc639fa8e [file] [log] [blame]
yuezonghe824eb0c2024-06-27 02:32:26 -07001/* vi: set sw=4 ts=4: */
2/*
3 * mmap() for uClibc
4 *
5 * Copyright (C) 2000-2006 Erik Andersen <andersen@uclibc.org>
6 *
7 * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball.
8 */
9
10#include <sys/syscall.h>
11#include <unistd.h>
12#include <sys/mman.h>
13#include <bits/uClibc_page.h>
14
15#ifdef __NR_mmap
16
17
18#ifdef __UCLIBC_MMAP_HAS_6_ARGS__
19
20_syscall6(void *, mmap, void *, start, size_t, length,
21 int, prot, int, flags, int, fd, off_t, offset)
22
23#else
24
25# define __NR__mmap __NR_mmap
26static __inline__ _syscall1(__ptr_t, _mmap, unsigned long *, buffer)
27__ptr_t mmap(__ptr_t addr, size_t len, int prot,
28 int flags, int fd, __off_t offset)
29{
30 unsigned long buffer[6];
31
32 buffer[0] = (unsigned long) addr;
33 buffer[1] = (unsigned long) len;
34 buffer[2] = (unsigned long) prot;
35 buffer[3] = (unsigned long) flags;
36 buffer[4] = (unsigned long) fd;
37 buffer[5] = (unsigned long) offset;
38 return (__ptr_t) _mmap(buffer);
39}
40
41#endif
42
43libc_hidden_def(mmap)
44
45#elif defined(__NR_mmap2)
46
47
48#define __NR___syscall_mmap2 __NR_mmap2
49static __inline__ _syscall6(__ptr_t, __syscall_mmap2, __ptr_t, addr,
50 size_t, len, int, prot, int, flags, int, fd, off_t, offset)
51
52/* Some architectures always use 12 as page shift for mmap2() eventhough the
53 * real PAGE_SHIFT != 12. Other architectures use the same value as
54 * PAGE_SHIFT...
55 */
56# ifndef MMAP2_PAGE_SHIFT
57# define MMAP2_PAGE_SHIFT 12
58# endif
59
60__ptr_t mmap(__ptr_t addr, size_t len, int prot, int flags, int fd, __off_t offset)
61{
62 if (offset & ((1 << MMAP2_PAGE_SHIFT) - 1)) {
63 __set_errno(EINVAL);
64 return MAP_FAILED;
65 }
66 return __syscall_mmap2(addr, len, prot, flags, fd, offset >> MMAP2_PAGE_SHIFT);
67}
68
69libc_hidden_def(mmap)
70
71#endif