]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/missing.h
exec: hangup/reset/deallocate VTs in gettys
[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
dd6c17b1
LP
83static inline int pivot_root(const char *new_root, const char *put_old) {
84 return syscall(SYS_pivot_root, new_root, put_old);
85}
86
22be093f 87#ifdef __x86_64__
d59d0a2b 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
22be093f 117#else
d59d0a2b 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
22be093f
LP
124#endif
125
126static inline int fanotify_init(unsigned int flags, unsigned int event_f_flags) {
05115020 127 return syscall(__NR_fanotify_init, flags, event_f_flags);
22be093f
LP
128}
129
05115020 130static inline int fanotify_mark(int fanotify_fd, unsigned int flags, uint64_t mask,
22be093f 131 int dfd, const char *pathname) {
373c23b2 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
05115020 142 return syscall(__NR_fanotify_mark, fanotify_fd, flags, mask, dfd, pathname);
373c23b2 143#endif
22be093f
LP
144}
145
746f8906
LP
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
154struct 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
94d82985
LP
167#ifndef MS_MOVE
168#define MS_MOVE 8192
169#endif
170
b9f880f4 171#endif