chiark / gitweb /
exec: hangup/reset/deallocate VTs in gettys
[elogind.git] / src / missing.h
1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3 #ifndef foomissinghfoo
4 #define foomissinghfoo
5
6 /***
7   This file is part of systemd.
8
9   Copyright 2010 Lennart Poettering
10
11   systemd is free software; you can redistribute it and/or modify it
12   under the terms of the GNU General Public License as published by
13   the Free Software Foundation; either version 2 of the License, or
14   (at your option) any later version.
15
16   systemd is distributed in the hope that it will be useful, but
17   WITHOUT ANY WARRANTY; without even the implied warranty of
18   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19   General Public License for more details.
20
21   You should have received a copy of the GNU General Public License
22   along with systemd; If not, see <http://www.gnu.org/licenses/>.
23 ***/
24
25 /* Missing glibc definitions to access certain kernel APIs */
26
27 #include <sys/resource.h>
28 #include <sys/syscall.h>
29 #include <fcntl.h>
30 #include <unistd.h>
31 #include <linux/oom.h>
32
33 #ifdef HAVE_AUDIT
34 #include <libaudit.h>
35 #endif
36
37 #include "macro.h"
38
39 #ifdef ARCH_MIPS
40 #include <asm/sgidefs.h>
41 #endif
42
43 #ifndef RLIMIT_RTTIME
44 #define RLIMIT_RTTIME 15
45 #endif
46
47 #ifndef F_LINUX_SPECIFIC_BASE
48 #define F_LINUX_SPECIFIC_BASE 1024
49 #endif
50
51 #ifndef F_SETPIPE_SZ
52 #define F_SETPIPE_SZ (F_LINUX_SPECIFIC_BASE + 7)
53 #endif
54
55 #ifndef F_GETPIPE_SZ
56 #define F_GETPIPE_SZ (F_LINUX_SPECIFIC_BASE + 8)
57 #endif
58
59 #ifndef IP_FREEBIND
60 #define IP_FREEBIND 15
61 #endif
62
63 #ifndef OOM_SCORE_ADJ_MIN
64 #define OOM_SCORE_ADJ_MIN (-1000)
65 #endif
66
67 #ifndef OOM_SCORE_ADJ_MAX
68 #define OOM_SCORE_ADJ_MAX 1000
69 #endif
70
71 #ifndef AUDIT_SERVICE_START
72 #define AUDIT_SERVICE_START 1130 /* Service (daemon) start */
73 #endif
74
75 #ifndef AUDIT_SERVICE_STOP
76 #define AUDIT_SERVICE_STOP 1131 /* Service (daemon) stop */
77 #endif
78
79 #ifndef TIOCVHANGUP
80 #define TIOCVHANGUP 0x5437
81 #endif
82
83 static inline int pivot_root(const char *new_root, const char *put_old) {
84         return syscall(SYS_pivot_root, new_root, put_old);
85 }
86
87 #ifdef __x86_64__
88 #  ifndef __NR_fanotify_init
89 #    define __NR_fanotify_init 300
90 #  endif
91 #  ifndef __NR_fanotify_mark
92 #    define __NR_fanotify_mark 301
93 #  endif
94 #elif defined _MIPS_SIM
95 #  if _MIPS_SIM == _MIPS_SIM_ABI32
96 #    ifndef __NR_fanotify_init
97 #      define __NR_fanotify_init 4336
98 #    endif
99 #    ifndef __NR_fanotify_mark
100 #      define __NR_fanotify_mark 4337
101 #    endif
102 #  elif _MIPS_SIM == _MIPS_SIM_NABI32
103 #    ifndef __NR_fanotify_init
104 #      define __NR_fanotify_init 6300
105 #    endif
106 #    ifndef __NR_fanotify_mark
107 #      define __NR_fanotify_mark 6301
108 #    endif
109 #  elif _MIPS_SIM == _MIPS_SIM_ABI64
110 #    ifndef __NR_fanotify_init
111 #      define __NR_fanotify_init 5295
112 #    endif
113 #    ifndef __NR_fanotify_mark
114 #      define __NR_fanotify_mark 5296
115 #    endif
116 #  endif
117 #else
118 #  ifndef __NR_fanotify_init
119 #    define __NR_fanotify_init 338
120 #  endif
121 #  ifndef __NR_fanotify_mark
122 #    define __NR_fanotify_mark 339
123 #  endif
124 #endif
125
126 static inline int fanotify_init(unsigned int flags, unsigned int event_f_flags) {
127         return syscall(__NR_fanotify_init, flags, event_f_flags);
128 }
129
130 static inline int fanotify_mark(int fanotify_fd, unsigned int flags, uint64_t mask,
131                                 int dfd, const char *pathname) {
132 #if defined _MIPS_SIM && _MIPS_SIM == _MIPS_SIM_ABI32
133         union {
134                 uint64_t _64;
135                 uint32_t _32[2];
136         } _mask;
137         _mask._64 = mask;
138
139         return syscall(__NR_fanotify_mark, fanotify_fd, flags,
140                        _mask._32[0], _mask._32[1], dfd, pathname);
141 #else
142         return syscall(__NR_fanotify_mark, fanotify_fd, flags, mask, dfd, pathname);
143 #endif
144 }
145
146 #ifndef BTRFS_IOCTL_MAGIC
147 #define BTRFS_IOCTL_MAGIC 0x94
148 #endif
149
150 #ifndef BTRFS_PATH_NAME_MAX
151 #define BTRFS_PATH_NAME_MAX 4087
152 #endif
153
154 struct btrfs_ioctl_vol_args {
155         int64_t fd;
156         char name[BTRFS_PATH_NAME_MAX + 1];
157 };
158
159 #ifndef BTRFS_IOC_DEFRAG
160 #define BTRFS_IOC_DEFRAG _IOW(BTRFS_IOCTL_MAGIC, 2, struct btrfs_ioctl_vol_args)
161 #endif
162
163 #ifndef BTRFS_SUPER_MAGIC
164 #define BTRFS_SUPER_MAGIC 0x9123683E
165 #endif
166
167 #ifndef MS_MOVE
168 #define MS_MOVE 8192
169 #endif
170
171 #endif