Permalink
Switch branches/tags
vzctl.open-3.0.0-4 vzctl.open-3.0.0-3 vzctl.open-3.0.0-2 vzctl.open-3.0.0-1 vzctl.open-2.7.0-28 vzctl.open-2.7.0-27 vzctl.open-2.7.0-26 vzctl.open-2.7.0-25 vzctl.open-2.7.0-24 vzctl.open-2.7.0-23 vzctl-4.5.1 vzctl-4.5.1-20130928-funtoo vzctl-4.5.1-20130923-funtoo vzctl-4.5 vzctl-4.4 vzctl-4.3.1 vzctl-4.3.1-funtoo vzctl-4.3 vzctl-4.2 vzctl-4.1.2 vzctl-4.1.1 vzctl-4.1 vzctl-4.0 vzctl-3.3 vzctl-3.3-r3-funtoo vzctl-3.3-r2-funtoo vzctl-3.3-r1-funtoo vzctl-3.2.1 vzctl-3.2 vzctl-3.1 vzctl-3.0.30.2 vzctl-3.0.30.2-funtoo vzctl-3.0.30.1 vzctl-3.0.30 vzctl-3.0.29.3 vzctl-3.0.29.2 vzctl-3.0.29.1 vzctl-3.0.29 vzctl-3.0.28.3-funtoo vzctl-3.0.28.2 vzctl-3.0.28.1 vzctl-3.0.28 vzctl-3.0.27 vzctl-3.0.27-r1-funtoo vzctl-3.0.27-funtoo vzctl-3.0.26.3 vzctl-3.0.26.3-funtoo vzctl-3.0.26.2 vzctl-3.0.26.1 vzctl-3.0.26 vzctl-3.0.25.2 vzctl-3.0.25.1 vzctl-3.0.25.1-funtoo vzctl-3.0.25 vzctl-3.0.25-r3-funtoo vzctl-3.0.25-r2-funtoo vzctl-3.0.25-r1-funtoo vzctl-3.0.25-funtoo vzctl-3.0.24.2 vzctl-3.0.24.1 vzctl-3.0.24 vzctl-3.0.24-r4-funtoo vzctl-3.0.23.2 vzctl-3.0.23.1 vzctl-3.0.23 vzctl-3.0.22 vzctl-3.0.21 vzctl-3.0.20 vzctl-3.0.19 vzctl-3.0.19-1 vzctl-3.0.18 vzctl-3.0.17 vzctl-3.0.17-1 vzctl-3.0.16 vzctl-3.0.15 vzctl-3.0.14 vzctl-3.0.13-1 vzctl-3.0.12-1 vzctl-3.0.11 vzctl-3.0.11-3 vzctl-3.0.11-2 vzctl-3.0.10 vzctl-3.0.9-1 vzctl-3.0.0-8 vzctl-3.0.0-7 vzctl-3.0.0-6 vzctl-3.0.0-5 master-4.5.1 master-4.1.2 master-4.1.1 master-3.0.30.2 master-3.0.30.1 master-3.0.29.3 master-3.0.29.2 master-3.0.29.1 master-3.0.28.3 master-3.0.28.2 master-3.0.28.1 3.0.25.1-funtoo 3.0.25-r2-funtoo
Nothing to show
Find file
Fetching contributors…
Cannot retrieve contributors at this time
150 lines (135 sloc) 3.55 KB
/*
* Copyright (C) 2000-2009, Parallels, Inc. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef _RES_H_
#define _RES_H_
#include "types.h"
#include "net.h"
#include "cpu.h"
#include "dev.h"
#include "ub.h"
#include "cap.h"
#include "quota.h"
#include "fs.h"
#include "dist.h"
#include "cpt.h"
#include "meminfo.h"
#include "veth.h"
struct env_param {
envid_t veid;
unsigned long long ipt_mask;
/*
* features_known is the set of features that are present
* in config file. this make vzctl work with new kernel
* that supports features vzctl still doesn't know yet.
* features that kernel support and that are not present
* in this mask kernel sets to default values.
*/
unsigned long long features_mask;
unsigned long long features_known;
char *osrelease;
};
typedef struct env_param env_param_t;
typedef struct {
list_head_t userpw;
list_head_t nameserver;
list_head_t searchdomain;
char *hostname;
char *description;
int onboot;
unsigned long *bootorder;
int wait;
} misc_param;
struct mod_action;
typedef struct {
int ioprio;
} io_param;
typedef struct name_param {
int veid;
char *name;
} name_param;
/** Data structure for CT resources.
*/
typedef struct vps_res {
fs_param fs; /**< file system parameters. */
tmpl_param tmpl; /**< template parameters. */
env_param_t env; /**< environment parameters. */
net_param net; /**< network parameters. */
cpu_param cpu; /**< cpu parameters. */
dev_param dev; /**< device parameters. */
ub_param ub; /**< UBC aprameters. */
cap_param cap; /**< capability parameters. */
dq_param dq; /**< disk quota parameters. */
cpt_param cpt; /**< chekpointing parameters */
meminfo_param meminfo;
veth_param veth; /**< veth parameters */
misc_param misc;
name_param name;
io_param io;
pci_param pci;
} vps_res;
enum {
APPCONF_MAP_NAME = 0x01,
};
typedef struct {
int save;
int save_force;
int fast_kill;
int skip_lock;
int skip_setup;
int start_disabled;
int start_force;
int setmode;
char *config;
char *origin_sample;
char *lockdir;
char *apply_cfg;
int apply_cfg_map;
int reset_ub;
} vps_opt;
struct log_s {
char *log_file;
int level;
int enable;
int *verbose;
};
struct vps_param {
struct log_s log;
vps_res res;
vps_res del_res;
vps_opt opt;
struct mod_action *mod;
struct vps_param *g_param;
};
typedef struct vps_param vps_param;
/** Setting CT resources.
*
* @param h CT handler.
* @param veid CT ID.
* @param actions distribution action scripts.
* @param fs CT FS parameters
* @param param CT parameters.
* @param vps_state CT state.
* @param action external modules.
* @return 0 on success.
*/
int vps_setup_res(vps_handler *h, envid_t veid, dist_actions *actions,
fs_param *fs, vps_param *param, int vps_state, skipFlags skip,
struct mod_action *action);
int setup_resource_management(vps_handler *h, envid_t veid, vps_res *res);
int need_configure(vps_res *res);
#endif