Introduce nat/linux-namespaces.[ch]
[external/binutils.git] / gdb / nat / linux-namespaces.h
1 /* Linux namespaces(7) support.
2
3    Copyright (C) 2015 Free Software Foundation, Inc.
4
5    This file is part of GDB.
6
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 3 of the License, or
10    (at your option) any later version.
11
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16
17    You should have received a copy of the GNU General Public License
18    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
19
20 #ifndef LINUX_NAMESPACES_H
21 #define LINUX_NAMESPACES_H
22
23 /* Set to nonzero to enable debugging of Linux namespaces code.  */
24
25 extern int debug_linux_namespaces;
26
27 /* Enumeration of Linux namespace types.  */
28
29 enum linux_ns_type
30   {
31     /* IPC namespace: System V IPC, POSIX message queues.  */
32     LINUX_NS_IPC,
33
34     /* Mount namespace: mount points.  */
35     LINUX_NS_MNT,
36
37     /* Network namespace: network devices, stacks, ports, etc.  */
38     LINUX_NS_NET,
39
40     /* PID namespace: process IDs.  */
41     LINUX_NS_PID,
42
43     /* User namespace: user and group IDs.  */
44     LINUX_NS_USER,
45
46     /* UTS namespace: hostname and NIS domain name.  */
47     LINUX_NS_UTS,
48
49     /* Number of Linux namespaces.  */
50     NUM_LINUX_NS_TYPES
51   };
52
53 /* Return nonzero if process PID has the same TYPE namespace as the
54    calling process, or if the kernel does not support TYPE namespaces
55    (in which case there is only one TYPE namespace).  Return zero if
56    the kernel supports TYPE namespaces and the two processes have
57    different TYPE namespaces.  */
58
59 extern int linux_ns_same (pid_t pid, enum linux_ns_type type);
60
61 /* Like gdb_open_cloexec, but in the mount namespace of process
62    PID.  */
63
64 extern int linux_mntns_open_cloexec (pid_t pid, const char *filename,
65                                      int flags, mode_t mode);
66
67 /* Like unlink(2), but in the mount namespace of process PID.  */
68
69 extern int linux_mntns_unlink (pid_t pid, const char *filename);
70
71 /* Like readlink(2), but in the mount namespace of process PID.  */
72
73 extern ssize_t linux_mntns_readlink (pid_t pid, const char *filename,
74                                      char *buf, size_t bufsiz);
75
76 #endif /* LINUX_NAMESPACES_H */