This commit was generated by cvs2svn to compensate for changes in r120,
[util-vserver.git] / lib / vserver.h
1 /* $Id: vserver.h,v 1.1.4.11 2004/01/26 18:19:41 ensc Exp $
2
3 *  Copyright (C) 2003 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de>
4 *   
5 *  This program is free software; you can redistribute it and/or modify
6 *  it under the terms of the GNU General Public License as published by
7 *  the Free Software Foundation; either version 2, or (at your option)
8 *  any later version.
9 *   
10 *  This program is distributed in the hope that it will be useful,
11 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 *  GNU General Public License for more details.
14 *   
15 *  You should have received a copy of the GNU General Public License
16 *  along with this program; if not, write to the Free Software
17 *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18 */
19
20 #ifndef H_VSERVER_SYSCALL_H
21 #define H_VSERVER_SYSCALL_H
22
23 #include <stdint.h>
24 #include <stdlib.h>
25 #include <sys/types.h>
26
27 /** the value which is returned in error-case (no ctx found) */
28 #define VC_NOCTX                ((xid_t)(-1))
29 /** the value which means a random (the next free) ctx */
30 #define VC_RANDCTX              ((xid_t)(-1))
31 /** the value which means the current ctx */
32 #define VC_SAMECTX              ((xid_t)(-2))
33
34 #define VC_LIM_INFINITY         (~0ULL)
35 #define VC_LIM_KEEP             (~1ULL)
36
37 #ifdef __cplusplus
38 extern "C" {
39 #endif
40
41   struct vc_ip_mask_pair {
42     uint32_t    ip;
43     uint32_t    mask;
44   };
45
46     /** Returns version of the current kernel API */
47   int   vc_get_version();
48   
49     /** Puts current process into context <ctx>, removes the given caps and
50      *  sets flags.
51      *  Special values for ctx are
52      *  - VC_SAMECTX  which means the current context (just for changing caps and flags)
53      *  - VC_RANDCTX  which means the next free context; this value can be used by
54      *                ordinary users also */
55   int   vc_new_s_context(xid_t ctx, unsigned int remove_cap, unsigned int flags);
56
57     /** Sets the ipv4root information.
58      *  \precondition: nb<16 */
59   int   vc_set_ipv4root(uint32_t  bcast, size_t nb, struct vc_ip_mask_pair const *ips);
60   
61
62   /* rlimit related functions */
63   typedef uint64_t      vc_limit_t;
64   
65   
66   struct vc_rlimit
67   {
68       vc_limit_t min;
69       vc_limit_t soft;
70       vc_limit_t hard;      
71   };
72
73   struct  vc_rlimit_mask {
74       uint32_t min;
75       uint32_t soft;
76       uint32_t hard;
77   };
78
79   int   vc_get_rlimit(xid_t ctx, int resource, struct vc_rlimit *lim);
80   int   vc_set_rlimit(xid_t ctx, int resource, struct vc_rlimit const *lim);
81   int   vc_get_rlimit_mask(xid_t ctx, struct vc_rlimit_mask *lim);
82
83
84   /** sends a signal to a context/pid
85       Special values for pid are:
86       * -1   which means every process in ctx except the init-process
87       *  0   which means every process in ctx inclusive the init-process */
88   int   vc_ctx_kill(xid_t ctx, pid_t pid, int sig);
89   
90     /** Returns the context of the given process. pid==0 means the current process. */
91   xid_t vc_X_getctx(pid_t pid);
92     
93 #ifdef __cplusplus
94 }
95 #endif
96
97 #endif