chiark / gitweb /
missing: use btrfs.h instead of defining our own btrfs structures
[elogind.git] / src / shared / missing.h
1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3 #pragma once
4
5 /***
6   This file is part of systemd.
7
8   Copyright 2010 Lennart Poettering
9
10   systemd is free software; you can redistribute it and/or modify it
11   under the terms of the GNU Lesser General Public License as published by
12   the Free Software Foundation; either version 2.1 of the License, or
13   (at your option) any later version.
14
15   systemd is distributed in the hope that it will be useful, but
16   WITHOUT ANY WARRANTY; without even the implied warranty of
17   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18   Lesser General Public License for more details.
19
20   You should have received a copy of the GNU Lesser General Public License
21   along with systemd; If not, see <http://www.gnu.org/licenses/>.
22 ***/
23
24 /* Missing glibc definitions to access certain kernel APIs */
25
26 #include <sys/resource.h>
27 #include <sys/syscall.h>
28 #include <fcntl.h>
29 #include <stdlib.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 #ifndef IP_TRANSPARENT
84 #define IP_TRANSPARENT 19
85 #endif
86
87 #if !HAVE_DECL_PIVOT_ROOT
88 static inline int pivot_root(const char *new_root, const char *put_old) {
89         return syscall(SYS_pivot_root, new_root, put_old);
90 }
91 #endif
92
93 #ifdef __x86_64__
94 #  ifndef __NR_fanotify_init
95 #    define __NR_fanotify_init 300
96 #  endif
97 #  ifndef __NR_fanotify_mark
98 #    define __NR_fanotify_mark 301
99 #  endif
100 #elif defined _MIPS_SIM
101 #  if _MIPS_SIM == _MIPS_SIM_ABI32
102 #    ifndef __NR_fanotify_init
103 #      define __NR_fanotify_init 4336
104 #    endif
105 #    ifndef __NR_fanotify_mark
106 #      define __NR_fanotify_mark 4337
107 #    endif
108 #  elif _MIPS_SIM == _MIPS_SIM_NABI32
109 #    ifndef __NR_fanotify_init
110 #      define __NR_fanotify_init 6300
111 #    endif
112 #    ifndef __NR_fanotify_mark
113 #      define __NR_fanotify_mark 6301
114 #    endif
115 #  elif _MIPS_SIM == _MIPS_SIM_ABI64
116 #    ifndef __NR_fanotify_init
117 #      define __NR_fanotify_init 5295
118 #    endif
119 #    ifndef __NR_fanotify_mark
120 #      define __NR_fanotify_mark 5296
121 #    endif
122 #  endif
123 #else
124 #  ifndef __NR_fanotify_init
125 #    define __NR_fanotify_init 338
126 #  endif
127 #  ifndef __NR_fanotify_mark
128 #    define __NR_fanotify_mark 339
129 #  endif
130 #endif
131
132 #ifndef HAVE_FANOTIFY_INIT
133 static inline int fanotify_init(unsigned int flags, unsigned int event_f_flags) {
134         return syscall(__NR_fanotify_init, flags, event_f_flags);
135 }
136 #endif
137
138 #ifndef HAVE_FANOTIFY_MARK
139 static inline int fanotify_mark(int fanotify_fd, unsigned int flags, uint64_t mask,
140                                 int dfd, const char *pathname) {
141 #if defined _MIPS_SIM && _MIPS_SIM == _MIPS_SIM_ABI32 || defined __powerpc__ && !defined __powerpc64__ \
142     || defined __arm__ && !defined __aarch64__
143         union {
144                 uint64_t _64;
145                 uint32_t _32[2];
146         } _mask;
147         _mask._64 = mask;
148
149         return syscall(__NR_fanotify_mark, fanotify_fd, flags,
150                        _mask._32[0], _mask._32[1], dfd, pathname);
151 #else
152         return syscall(__NR_fanotify_mark, fanotify_fd, flags, mask, dfd, pathname);
153 #endif
154 }
155 #endif
156
157 #ifndef BTRFS_SUPER_MAGIC
158 #define BTRFS_SUPER_MAGIC 0x9123683E
159 #endif
160
161 #ifndef MS_MOVE
162 #define MS_MOVE 8192
163 #endif
164
165 #ifndef MS_PRIVATE
166 #define MS_PRIVATE  (1 << 18)
167 #endif
168
169 #if !HAVE_DECL_GETTID
170 static inline pid_t gettid(void) {
171         return (pid_t) syscall(SYS_gettid);
172 }
173 #endif
174
175 #ifndef SCM_SECURITY
176 #define SCM_SECURITY 0x03
177 #endif
178
179 #ifndef MS_STRICTATIME
180 #define MS_STRICTATIME (1<<24)
181 #endif
182
183 #ifndef MS_REC
184 #define MS_REC 16384
185 #endif
186
187 #ifndef MS_SHARED
188 #define MS_SHARED (1<<20)
189 #endif
190
191 #ifndef PR_SET_NO_NEW_PRIVS
192 #define PR_SET_NO_NEW_PRIVS 38
193 #endif
194
195 #ifndef PR_SET_CHILD_SUBREAPER
196 #define PR_SET_CHILD_SUBREAPER 36
197 #endif
198
199 #ifndef MAX_HANDLE_SZ
200 #define MAX_HANDLE_SZ 128
201 #endif
202
203 #if defined __x86_64__
204 #  ifndef __NR_name_to_handle_at
205 #    define __NR_name_to_handle_at 303
206 #  endif
207 #elif defined __i386__
208 #  ifndef __NR_name_to_handle_at
209 #    define __NR_name_to_handle_at 341
210 #  endif
211 #elif defined __arm__
212 #  ifndef __NR_name_to_handle_at
213 #    define __NR_name_to_handle_at 370
214 #  endif
215 #elif defined __powerpc__
216 #  ifndef __NR_name_to_handle_at
217 #    define __NR_name_to_handle_at 345
218 #  endif
219 #else
220 #  ifndef __NR_name_to_handle_at
221 #    error __NR_name_to_handle_at is not defined
222 #  endif
223 #endif
224
225 #if !HAVE_DECL_NAME_TO_HANDLE_AT
226 struct file_handle {
227         unsigned int handle_bytes;
228         int handle_type;
229         unsigned char f_handle[0];
230 };
231
232 static inline int name_to_handle_at(int fd, const char *name, struct file_handle *handle, int *mnt_id, int flags) {
233         return syscall(__NR_name_to_handle_at, fd, name, handle, mnt_id, flags);
234 }
235 #endif
236
237 #ifndef HAVE_SECURE_GETENV
238 #  ifdef HAVE___SECURE_GETENV
239 #    define secure_getenv __secure_getenv
240 #  else
241 #    error neither secure_getenv nor __secure_getenv are available
242 #  endif
243 #endif
244
245 #ifndef CIFS_MAGIC_NUMBER
246 #define CIFS_MAGIC_NUMBER 0xFF534D42
247 #endif
248
249 #ifndef TFD_TIMER_CANCEL_ON_SET
250 #define TFD_TIMER_CANCEL_ON_SET (1 << 1)
251 #endif
252
253 #ifndef SO_REUSEPORT
254 #define SO_REUSEPORT 15
255 #endif