]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/shared/missing.h
units: make fsck units remain after exit
[thirdparty/systemd.git] / src / shared / missing.h
CommitLineData
03467c88 1/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
15ae422b 2
c2f1db8f 3#pragma once
b9f880f4 4
15ae422b
LP
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
5430f7f2
LP
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
15ae422b
LP
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
5430f7f2 18 Lesser General Public License for more details.
15ae422b 19
5430f7f2 20 You should have received a copy of the GNU Lesser General Public License
15ae422b
LP
21 along with systemd; If not, see <http://www.gnu.org/licenses/>.
22***/
23
b9f880f4
LP
24/* Missing glibc definitions to access certain kernel APIs */
25
26#include <sys/resource.h>
15ae422b 27#include <sys/syscall.h>
16c42ce1 28#include <fcntl.h>
4db17f29 29#include <stdlib.h>
82c121a4 30#include <unistd.h>
dd6c17b1
LP
31#include <linux/oom.h>
32
33#ifdef HAVE_AUDIT
34#include <libaudit.h>
35#endif
b9f880f4 36
ad780f19
LP
37#include "macro.h"
38
d59d0a2b 39#ifdef ARCH_MIPS
40#include <asm/sgidefs.h>
41#endif
42
b9f880f4
LP
43#ifndef RLIMIT_RTTIME
44#define RLIMIT_RTTIME 15
45#endif
46
4fd5948e
LP
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
16c42ce1
KS
59#ifndef IP_FREEBIND
60#define IP_FREEBIND 15
61#endif
62
dd6c17b1
LP
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
15ae422b 70
4927fcae 71#ifndef AUDIT_SERVICE_START
dd6c17b1 72#define AUDIT_SERVICE_START 1130 /* Service (daemon) start */
4927fcae
LP
73#endif
74
75#ifndef AUDIT_SERVICE_STOP
dd6c17b1 76#define AUDIT_SERVICE_STOP 1131 /* Service (daemon) stop */
4927fcae
LP
77#endif
78
6ea832a2
LP
79#ifndef TIOCVHANGUP
80#define TIOCVHANGUP 0x5437
81#endif
82
b90865ba
KS
83#ifndef IP_TRANSPARENT
84#define IP_TRANSPARENT 19
85#endif
86
a8348796 87#if !HAVE_DECL_PIVOT_ROOT
dd6c17b1
LP
88static inline int pivot_root(const char *new_root, const char *put_old) {
89 return syscall(SYS_pivot_root, new_root, put_old);
90}
a8348796 91#endif
dd6c17b1 92
22be093f 93#ifdef __x86_64__
d59d0a2b 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
22be093f 123#else
d59d0a2b 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
22be093f
LP
130#endif
131
a8348796 132#ifndef HAVE_FANOTIFY_INIT
22be093f 133static inline int fanotify_init(unsigned int flags, unsigned int event_f_flags) {
05115020 134 return syscall(__NR_fanotify_init, flags, event_f_flags);
22be093f 135}
a8348796 136#endif
22be093f 137
a8348796 138#ifndef HAVE_FANOTIFY_MARK
05115020 139static inline int fanotify_mark(int fanotify_fd, unsigned int flags, uint64_t mask,
22be093f 140 int dfd, const char *pathname) {
28f30cf2 141#if defined _MIPS_SIM && _MIPS_SIM == _MIPS_SIM_ABI32 || defined __powerpc__ && !defined __powerpc64__ \
e9c1ea9d 142 || defined __arm__ && !defined __aarch64__
373c23b2 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
05115020 152 return syscall(__NR_fanotify_mark, fanotify_fd, flags, mask, dfd, pathname);
373c23b2 153#endif
22be093f 154}
a8348796 155#endif
22be093f 156
746f8906
LP
157#ifndef BTRFS_SUPER_MAGIC
158#define BTRFS_SUPER_MAGIC 0x9123683E
159#endif
160
94d82985
LP
161#ifndef MS_MOVE
162#define MS_MOVE 8192
163#endif
164
7cb1094a
HH
165#ifndef MS_PRIVATE
166#define MS_PRIVATE (1 << 18)
167#endif
168
a8348796 169#if !HAVE_DECL_GETTID
4d14be09
LP
170static inline pid_t gettid(void) {
171 return (pid_t) syscall(SYS_gettid);
172}
a8348796 173#endif
4d14be09 174
54ecda32
LP
175#ifndef SCM_SECURITY
176#define SCM_SECURITY 0x03
177#endif
178
48ac500b
LP
179#ifndef MS_STRICTATIME
180#define MS_STRICTATIME (1<<24)
181#endif
182
a9621528
AM
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
8351ceae
LP
191#ifndef PR_SET_NO_NEW_PRIVS
192#define PR_SET_NO_NEW_PRIVS 38
193#endif
d4447f4d
AK
194
195#ifndef PR_SET_CHILD_SUBREAPER
196#define PR_SET_CHILD_SUBREAPER 36
197#endif
a8348796
LP
198
199#ifndef MAX_HANDLE_SZ
200#define MAX_HANDLE_SZ 128
201#endif
202
f527b6b8 203#if defined __x86_64__
848af055
ED
204# ifndef __NR_name_to_handle_at
205# define __NR_name_to_handle_at 303
a8348796 206# endif
f527b6b8 207#elif defined __i386__
848af055
ED
208# ifndef __NR_name_to_handle_at
209# define __NR_name_to_handle_at 341
a8348796 210# endif
f527b6b8
MO
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
a8348796
LP
223#endif
224
9388e99e 225#if !HAVE_DECL_NAME_TO_HANDLE_AT
a8348796
LP
226struct file_handle {
227 unsigned int handle_bytes;
228 int handle_type;
229 unsigned char f_handle[0];
230};
231
232static 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
4db17f29
ZJS
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
85210bff
LP
244
245#ifndef CIFS_MAGIC_NUMBER
246#define CIFS_MAGIC_NUMBER 0xFF534D42
247#endif
8742514c
LP
248
249#ifndef TFD_TIMER_CANCEL_ON_SET
250#define TFD_TIMER_CANCEL_ON_SET (1 << 1)
251#endif
f7db7a69
SL
252
253#ifndef SO_REUSEPORT
254#define SO_REUSEPORT 15
255#endif