]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/missing.h
umount: log failed umounts only once at the end
[thirdparty/systemd.git] / src / missing.h
CommitLineData
03467c88 1/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
15ae422b 2
b9f880f4
LP
3#ifndef foomissinghfoo
4#define foomissinghfoo
5
15ae422b
LP
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
b9f880f4
LP
25/* Missing glibc definitions to access certain kernel APIs */
26
27#include <sys/resource.h>
15ae422b 28#include <sys/syscall.h>
16c42ce1 29#include <fcntl.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
dd6c17b1
LP
87static inline int pivot_root(const char *new_root, const char *put_old) {
88 return syscall(SYS_pivot_root, new_root, put_old);
89}
90
22be093f 91#ifdef __x86_64__
d59d0a2b 92# ifndef __NR_fanotify_init
93# define __NR_fanotify_init 300
94# endif
95# ifndef __NR_fanotify_mark
96# define __NR_fanotify_mark 301
97# endif
98#elif defined _MIPS_SIM
99# if _MIPS_SIM == _MIPS_SIM_ABI32
100# ifndef __NR_fanotify_init
101# define __NR_fanotify_init 4336
102# endif
103# ifndef __NR_fanotify_mark
104# define __NR_fanotify_mark 4337
105# endif
106# elif _MIPS_SIM == _MIPS_SIM_NABI32
107# ifndef __NR_fanotify_init
108# define __NR_fanotify_init 6300
109# endif
110# ifndef __NR_fanotify_mark
111# define __NR_fanotify_mark 6301
112# endif
113# elif _MIPS_SIM == _MIPS_SIM_ABI64
114# ifndef __NR_fanotify_init
115# define __NR_fanotify_init 5295
116# endif
117# ifndef __NR_fanotify_mark
118# define __NR_fanotify_mark 5296
119# endif
120# endif
22be093f 121#else
d59d0a2b 122# ifndef __NR_fanotify_init
123# define __NR_fanotify_init 338
124# endif
125# ifndef __NR_fanotify_mark
126# define __NR_fanotify_mark 339
127# endif
22be093f
LP
128#endif
129
130static inline int fanotify_init(unsigned int flags, unsigned int event_f_flags) {
05115020 131 return syscall(__NR_fanotify_init, flags, event_f_flags);
22be093f
LP
132}
133
05115020 134static inline int fanotify_mark(int fanotify_fd, unsigned int flags, uint64_t mask,
22be093f 135 int dfd, const char *pathname) {
373c23b2 136#if defined _MIPS_SIM && _MIPS_SIM == _MIPS_SIM_ABI32
137 union {
138 uint64_t _64;
139 uint32_t _32[2];
140 } _mask;
141 _mask._64 = mask;
142
143 return syscall(__NR_fanotify_mark, fanotify_fd, flags,
144 _mask._32[0], _mask._32[1], dfd, pathname);
145#else
05115020 146 return syscall(__NR_fanotify_mark, fanotify_fd, flags, mask, dfd, pathname);
373c23b2 147#endif
22be093f
LP
148}
149
746f8906
LP
150#ifndef BTRFS_IOCTL_MAGIC
151#define BTRFS_IOCTL_MAGIC 0x94
152#endif
153
154#ifndef BTRFS_PATH_NAME_MAX
155#define BTRFS_PATH_NAME_MAX 4087
156#endif
157
158struct btrfs_ioctl_vol_args {
159 int64_t fd;
160 char name[BTRFS_PATH_NAME_MAX + 1];
161};
162
163#ifndef BTRFS_IOC_DEFRAG
164#define BTRFS_IOC_DEFRAG _IOW(BTRFS_IOCTL_MAGIC, 2, struct btrfs_ioctl_vol_args)
165#endif
166
167#ifndef BTRFS_SUPER_MAGIC
168#define BTRFS_SUPER_MAGIC 0x9123683E
169#endif
170
94d82985
LP
171#ifndef MS_MOVE
172#define MS_MOVE 8192
173#endif
174
b9f880f4 175#endif