#include <stdint.h>
#include <stdlib.h>
#include <stdbool.h>
#include <sys/types.h>
Include dependency graph for vserver.h:
This graph shows which files directly or indirectly include this file:
Go to the source code of this file.
Data Structures | |
struct | vc_ip_mask_pair |
struct | vc_rlimit |
The limits of a resources. More... | |
struct | vc_rlimit_mask |
Masks describing the supported limits. More... | |
struct | vc_nx_info |
struct | vc_net_nx |
struct | vc_net_flags |
struct | vc_net_caps |
struct | vc_vx_info |
struct | vc_ctx_flags |
Flags of process-contexts. More... | |
struct | vc_ctx_caps |
Capabilities of process-contexts. More... | |
struct | vc_err_listparser |
Information about parsing errors. More... | |
struct | vc_set_sched |
struct | vc_ctx_dlimit |
Defines | |
#define | VC_NOCTX ((xid_t)(-1)) |
#define | VC_NOXID ((xid_t)(-1)) |
#define | VC_DYNAMIC_XID ((xid_t)(-1)) |
#define | VC_SAMECTX ((xid_t)(-2)) |
#define | VC_NONID ((nid_t)(-1)) |
#define | VC_DYNAMIC_NID ((nid_t)(-1)) |
#define | VC_LIM_INFINITY (~0ULL) |
#define | VC_LIM_KEEP (~1ULL) |
#define | VC_CDLIM_UNSET (0U) |
#define | VC_CDLIM_INFINITY (~0U) |
#define | VC_CDLIM_KEEP (~1U) |
#define | S_CTX_INFO_LOCK 1 |
#define | S_CTX_INFO_SCHED 2 |
#define | S_CTX_INFO_NPROC 4 |
#define | S_CTX_INFO_PRIVATE 8 |
#define | S_CTX_INFO_INIT 16 |
#define | S_CTX_INFO_HIDEINFO 32 |
#define | S_CTX_INFO_ULIMIT 64 |
#define | S_CTX_INFO_NAMESPACE 128 |
#define | VC_CAP_CHOWN 0 |
#define | VC_CAP_DAC_OVERRIDE 1 |
#define | VC_CAP_DAC_READ_SEARCH 2 |
#define | VC_CAP_FOWNER 3 |
#define | VC_CAP_FSETID 4 |
#define | VC_CAP_KILL 5 |
#define | VC_CAP_SETGID 6 |
#define | VC_CAP_SETUID 7 |
#define | VC_CAP_SETPCAP 8 |
#define | VC_CAP_LINUX_IMMUTABLE 9 |
#define | VC_CAP_NET_BIND_SERVICE 10 |
#define | VC_CAP_NET_BROADCAST 11 |
#define | VC_CAP_NET_ADMIN 12 |
#define | VC_CAP_NET_RAW 13 |
#define | VC_CAP_IPC_LOCK 14 |
#define | VC_CAP_IPC_OWNER 15 |
#define | VC_CAP_SYS_MODULE 16 |
#define | VC_CAP_SYS_RAWIO 17 |
#define | VC_CAP_SYS_CHROOT 18 |
#define | VC_CAP_SYS_PTRACE 19 |
#define | VC_CAP_SYS_PACCT 20 |
#define | VC_CAP_SYS_ADMIN 21 |
#define | VC_CAP_SYS_BOOT 22 |
#define | VC_CAP_SYS_NICE 23 |
#define | VC_CAP_SYS_RESOURCE 24 |
#define | VC_CAP_SYS_TIME 25 |
#define | VC_CAP_SYS_TTY_CONFIG 26 |
#define | VC_CAP_MKNOD 27 |
#define | VC_CAP_LEASE 28 |
#define | VC_CAP_AUDIT_WRITE 29 |
#define | VC_CAP_AUDIT_CONTROL 30 |
#define | VC_IMMUTABLE_FILE_FL 0x0000010lu |
#define | VC_IMMUTABLE_LINK_FL 0x0008000lu |
#define | VC_IMMUTABLE_ALL (VC_IMMUTABLE_LINK_FL|VC_IMMUTABLE_FILE_FL) |
#define | VC_IATTR_XID 0x01000000u |
#define | VC_IATTR_ADMIN 0x00000001u |
#define | VC_IATTR_WATCH 0x00000002u |
#define | VC_IATTR_HIDE 0x00000004u |
#define | VC_IATTR_FLAGS 0x00000007u |
#define | VC_IATTR_BARRIER 0x00010000u |
#define | VC_IATTR_IUNLINK 0x00020000u |
#define | VC_IATTR_IMMUTABLE 0x00040000u |
#define | VC_VXF_INFO_LOCK 0x00000001ull |
#define | VC_VXF_INFO_NPROC 0x00000004ull |
#define | VC_VXF_INFO_PRIVATE 0x00000008ull |
#define | VC_VXF_INFO_INIT 0x00000010ull |
#define | VC_VXF_INFO_HIDEINFO 0x00000020ull |
#define | VC_VXF_INFO_ULIMIT 0x00000040ull |
#define | VC_VXF_INFO_NAMESPACE 0x00000080ull |
#define | VC_VXF_SCHED_HARD 0x00000100ull |
#define | VC_VXF_SCHED_PRIO 0x00000200ull |
#define | VC_VXF_SCHED_PAUSE 0x00000400ull |
#define | VC_VXF_VIRT_MEM 0x00010000ull |
#define | VC_VXF_VIRT_UPTIME 0x00020000ull |
#define | VC_VXF_VIRT_CPU 0x00040000ull |
#define | VC_VXF_VIRT_LOAD 0x00080000ull |
#define | VC_VXF_HIDE_MOUNT 0x01000000ull |
#define | VC_VXF_HIDE_NETIF 0x02000000ull |
#define | VC_VXF_STATE_SETUP (1ULL<<32) |
#define | VC_VXF_STATE_INIT (1ULL<<33) |
#define | VC_VXF_FORK_RSS (1ULL<<48) |
#define | VC_VXF_PROLIFIC (1ULL<<49) |
#define | VC_VXF_IGNEG_NICE (1ULL<<52) |
#define | VC_VXC_SET_UTSNAME 0x00000001ull |
#define | VC_VXC_SET_RLIMIT 0x00000002ull |
#define | VC_VXC_RAW_ICMP 0x00000100ull |
#define | VC_VXC_SYSLOG 0x00001000ull |
#define | VC_VXC_SECURE_MOUNT 0x00010000ull |
#define | VC_VXC_SECURE_REMOUNT 0x00020000ull |
#define | VC_VXC_BINARY_MOUNT 0x00040000ull |
#define | VC_VXC_QUOTA_CTL 0x00100000ull |
#define | VC_VXSM_FILL_RATE 0x0001 |
#define | VC_VXSM_INTERVAL 0x0002 |
#define | VC_VXSM_TOKENS 0x0010 |
#define | VC_VXSM_TOKENS_MIN 0x0020 |
#define | VC_VXSM_TOKENS_MAX 0x0040 |
#define | VC_VXSM_PRIO_BIAS 0x0100 |
#define | VC_BAD_PERSONALITY ((uint_least32_t)(-1)) |
#define | VC_LIMIT_VSERVER_NAME_LEN 1024 |
#define | vcSKEL_INTERFACES 1u |
#define | vcSKEL_PKGMGMT 2u |
#define | vcSKEL_FILESYSTEM 4u |
Typedefs | |
typedef an_unsigned_integer_type | xid_t |
typedef an_unsigned_integer_type | nid_t |
typedef uint_least64_t | vc_limit_t |
The type which is used for a single limit value. | |
Enumerations | |
enum | vc_net_nx_type { vcNET_IPV4 = 1, vcNET_IPV6 = 2, vcNET_IPV4B = 0x101, vcNET_IPV6B = 0x102, vcNET_ANY = ~0 } |
enum | vc_uts_type { vcVHI_CONTEXT, vcVHI_SYSNAME, vcVHI_NODENAME, vcVHI_RELEASE, vcVHI_VERSION, vcVHI_MACHINE, vcVHI_DOMAINNAME } |
enum | vcFeatureSet { vcFEATURE_VKILL, vcFEATURE_IATTR, vcFEATURE_RLIMIT, vcFEATURE_COMPAT, vcFEATURE_MIGRATE, vcFEATURE_NAMESPACE, vcFEATURE_SCHED, vcFEATURE_VINFO, vcFEATURE_VHI, vcFEATURE_VSHELPER0, vcFEATURE_VSHELPER, vcFEATURE_VWAIT, vcFEATURE_VNET } |
enum | vcXidType { vcTYPE_INVALID, vcTYPE_MAIN, vcTYPE_WATCH, vcTYPE_STATIC, vcTYPE_DYNAMIC } |
enum | vcCfgStyle { vcCFG_NONE, vcCFG_AUTO, vcCFG_LEGACY, vcCFG_RECENT_SHORT, vcCFG_RECENT_FULL } |
Functions | |
int | vc_syscall (uint32_t cmd, xid_t xid, void *data) |
The generic vserver syscall
This function executes the generic vserver syscall. It uses the correct syscallnumber (which may differ between the different architectures). | |
int | vc_get_version () |
Returns the version of the current kernel API. | |
xid_t | vc_new_s_context (xid_t ctx, unsigned int remove_cap, unsigned int flags) |
Moves current process into a context
Puts current process into context ctx, removes the capabilities given in remove_cap and sets flags. | |
int | vc_set_ipv4root (uint32_t bcast, size_t nb, struct vc_ip_mask_pair const *ips) |
Sets the ipv4root information. | |
size_t | vc_get_nb_ipv4root () VC_ATTR_CONST |
Returns the value of NB_IPV4ROOT.
This function returns the value of NB_IPV4ROOT which was used when the library was built, but not the value which is used by the currently running kernel. | |
xid_t | vc_ctx_create (xid_t xid) |
Creates a context without starting it.
This functions initializes a new context. When already in a freshly created context, this old context will be discarded. | |
int | vc_ctx_migrate (xid_t xid) |
Moves the current process into the specified context. | |
int | vc_get_rlimit (xid_t xid, int resource, struct vc_rlimit *lim) |
Returns the limits of resource. | |
int | vc_set_rlimit (xid_t xid, int resource, struct vc_rlimit const *lim) |
Sets the limits of resource. | |
int | vc_get_rlimit_mask (xid_t xid, struct vc_rlimit_mask *lim) |
bool | vc_parseLimit (char const *str, vc_limit_t *res) |
Parses a string describing a limit
This function parses str and interprets special words like
| |
int | vc_ctx_kill (xid_t ctx, pid_t pid, int sig) |
Sends a signal to a context/pid Special values for pid are:
| |
nid_t | vc_get_task_nid (pid_t pid) |
int | vc_get_nx_info (nid_t nid, struct vc_nx_info *) |
nid_t | vc_net_create (nid_t nid) |
int | vc_net_migrate (nid_t nid) |
int | vc_net_add (nid_t nid, struct vc_net_nx const *info) |
int | vc_net_remove (nid_t nid, struct vc_net_nx const *info) |
int | vc_get_nflags (nid_t, struct vc_net_flags *) |
int | vc_set_nflags (nid_t, struct vc_net_flags const *) |
int | vc_get_ncaps (nid_t, struct vc_net_caps *) |
int | vc_set_ncaps (nid_t, struct vc_net_caps const *) |
int | vc_set_iattr (char const *filename, xid_t xid, uint_least32_t flags, uint_least32_t mask) |
int | vc_get_iattr (char const *filename, xid_t *xid, uint_least32_t *flags, uint_least32_t *mask) |
Returns information about attributes and assigned context of a file.
This function returns the VC_IATTR_XXX flags and about the assigned context of a file. To request an information, the appropriate bit in | |
xid_t | vc_get_task_xid (pid_t pid) |
Returns the context of the given process. | |
int | vc_get_vx_info (xid_t xid, struct vc_vx_info *info) |
int | vc_set_vhi_name (xid_t xid, vc_uts_type type, char const *val, size_t len) |
int | vc_get_vhi_name (xid_t xid, vc_uts_type type, char *val, size_t len) |
bool | vc_is_dynamic_xid (xid_t xid) |
int | vc_enter_namespace (xid_t xid) |
int | vc_set_namespace () |
int | vc_cleanup_namespace () |
int | vc_get_cflags (xid_t xid, struct vc_ctx_flags *) |
int | vc_set_cflags (xid_t xid, struct vc_ctx_flags const *) |
int | vc_get_ccaps (xid_t xid, struct vc_ctx_caps *) |
int | vc_set_ccaps (xid_t xid, struct vc_ctx_caps const *) |
uint_least64_t | vc_text2bcap (char const *str, size_t len) |
Converts a single string into bcapability. | |
char const * | vc_lobcap2text (uint_least64_t *val) |
Converts the lowest bit of a bcapability or the entire value (when possible) to a textual representation. | |
int | vc_list2bcap (char const *str, size_t len, struct vc_err_listparser *err, struct vc_ctx_caps *cap) |
Converts a string into a bcapability-bitmask | |
uint_least64_t | vc_text2ccap (char const *, size_t len) |
char const * | vc_loccap2text (uint_least64_t *) |
int | vc_list2ccap (char const *, size_t len, struct vc_err_listparser *err, struct vc_ctx_caps *) |
int | vc_list2cflag (char const *, size_t len, struct vc_err_listparser *err, struct vc_ctx_flags *flags) |
uint_least64_t | vc_text2cflag (char const *, size_t len) |
char const * | vc_locflag2text (uint_least64_t *) |
uint_least32_t | vc_list2cflag_compat (char const *, size_t len, struct vc_err_listparser *err) |
uint_least32_t | vc_text2cflag_compat (char const *, size_t len) |
char const * | vc_hicflag2text_compat (uint_least32_t) |
int | vc_text2cap (char const *) |
char const * | vc_cap2text (unsigned int) |
int | vc_list2nflag (char const *, size_t len, struct vc_err_listparser *err, struct vc_net_flags *flags) |
uint_least64_t | vc_text2nflag (char const *, size_t len) |
char const * | vc_lonflag2text (uint_least64_t *) |
uint_least64_t | vc_text2ncap (char const *, size_t len) |
char const * | vc_loncap2text (uint_least64_t *) |
int | vc_list2ncap (char const *, size_t len, struct vc_err_listparser *err, struct vc_net_caps *) |
uint_least64_t | vc_get_insecurebcaps () VC_ATTR_CONST |
uint_least32_t | vc_text2personalityflag (char const *str, size_t len) |
char const * | vc_lopersonality2text (uint_least32_t *) |
int | vc_list2personalityflag (char const *, size_t len, uint_least32_t *personality, struct vc_err_listparser *err) |
uint_least32_t | vc_str2personalitytype (char const *, size_t len) |
xid_t | vc_getfilecontext (char const *filename) |
Returns the context of filename
This function calls vc_get_iattr() with appropriate arguments to determine the context of | |
int | vc_set_sched (xid_t xid, struct vc_set_sched const *) |
int | vc_add_dlimit (char const *filename, xid_t xid, uint_least32_t flags) |
int | vc_rem_dlimit (char const *filename, xid_t xid, uint_least32_t flags) |
int | vc_set_dlimit (char const *filename, xid_t xid, uint_least32_t flags, struct vc_ctx_dlimit const *limits) |
int | vc_get_dlimit (char const *filename, xid_t xid, uint_least32_t flags, struct vc_ctx_dlimit *limits) |
int | vc_wait_exit (xid_t xid) |
Waits for the end of a context. | |
bool | vc_isSupported (vcFeatureSet) VC_ATTR_CONST |
bool | vc_isSupportedString (char const *) |
vcXidType | vc_getXIDType (xid_t xid) VC_ATTR_CONST |
xid_t | vc_xidopt2xid (char const *, bool honor_static, char const **err_info) |
vcCfgStyle | vc_getVserverCfgStyle (char const *id) |
char * | vc_getVserverName (char const *id, vcCfgStyle style) |
char * | vc_getVserverCfgDir (char const *id, vcCfgStyle style) |
char * | vc_getVserverAppDir (char const *id, vcCfgStyle style, char const *app) |
char * | vc_getVserverVdir (char const *id, vcCfgStyle style, bool physical) |
xid_t | vc_getVserverCtx (char const *id, vcCfgStyle style, bool honor_static, bool *is_running) |
char * | vc_getVserverByCtx (xid_t ctx, vcCfgStyle *style, char const *revdir) |
int | vc_compareVserverById (char const *lhs, vcCfgStyle lhs_style, char const *rhs, vcCfgStyle rhs_style) |
int | vc_createSkeleton (char const *id, vcCfgStyle style, int flags) |
Definition in file vserver.h.
|
the value which means a random (the next free) ctx |
|
the value which is returned in error-case (no ctx found) |
|
the value which means the current ctx |
|
The type which is used for a single limit value. Special values are
Else, the interpretation of the value depends on the corresponding resource; it might be bytes, pages, seconds or litres of beer. |
|
The identifier of a context. |
|
Add a disk limit to a file system. |
|
Create a basic configuration skeleton for a vserver plus toplevel directories for pkgmanagemt and filesystem (when requested). |
|
Get a disk limit. |
|
Returns the path of the configuration directory for the given application. The result will be allocated and must be freed by the caller. |
|
Resolves the cfg-path of the vserver owning the given ctx. 'revdir' will be used as the directory holding the mapping-links; when NULL, the default value will be assumed. The result will be allocated and must be freed by the caller. |
|
Returns the path of the vserver configuration directory. When the given vserver does not exist, or when it does not have such a directory, NULL will be returned. Else, the result will be allocated and must be freed by the caller. |
|
Returns the ctx of the given vserver. When vserver is not running and 'honor_static' is false, VC_NOCTX will be returned. Else, when 'honor_static' is true and a static assignment exists, those value will be returned. Else, the result will be VC_NOCTX. When 'is_running' is not null, the status of the vserver will be assigned to this variable. |
|
Resolves the name of the vserver. The result will be allocated and must be freed by the caller. |
|
Returns the path to the vserver root-directory. The result will be allocated and must be freed by the caller. |
|
Returns true iff xid is a dynamic xid |
|
Remove a disk limit from a file system. |
|
Set a disk limit. |
|
Maps an xid given at '--xid' options to an xid_t |