⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 xen_xspolicy.h

📁 xen虚拟机源代码安装包
💻 H
字号:
/* * Copyright (c) 2007, IBM Corp. * Copyright (c) 2007, XenSource Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  USA */#ifndef XEN_XSPOLICY_H#define XEN_XSPOLICY_H#include "xen_common.h"#include "xen_xspolicy_decl.h"#include "xen_string_string_map.h"/* * The XSPolicy and associated data structures. * */typedef int64_t xs_type;typedef int64_t xs_instantiationflags;enum xs_type {    XS_POLICY_ACM = (1 << 0),};enum xs_instantiationflags {    XS_INST_NONE = 0,    XS_INST_BOOT = (1 << 0),    XS_INST_LOAD = (1 << 1),};/* Error codes returned by xend following XSPolicy operations */#define XSERR_BASE                       0x1000#define XSERR_SUCCESS                    0#define XSERR_GENERAL_FAILURE            1 + XSERR_BASE#define XSERR_BAD_XML                    2 + XSERR_BASE#define XSERR_XML_PROCESSING             3 + XSERR_BASE#define XSERR_POLICY_INCONSISTENT        4 + XSERR_BASE#define XSERR_FILE_ERROR                 5 + XSERR_BASE#define XSERR_BAD_RESOURCE_FORMAT        6 + XSERR_BASE#define XSERR_BAD_LABEL_FORMAT           7 + XSERR_BASE#define XSERR_RESOURCE_NOT_LABELED       8 + XSERR_BASE#define XSERR_RESOURCE_ALREADY_LABELED   9 + XSERR_BASE#define XSERR_WRONG_POLICY_TYPE         10 + XSERR_BASE#define XSERR_BOOTPOLICY_INSTALLED      11 + XSERR_BASE#define XSERR_NO_DEFAULT_BOOT_TITLE     12 + XSERR_BASE#define XSERR_POLICY_LOAD_FAILED        13 + XSERR_BASE#define XSERR_POLICY_LOADED             14 + XSERR_BASE#define XSERR_POLICY_TYPE_UNSUPPORTED   15 + XSERR_BASE#define XSERR_BAD_CONFLICTSET           20 + XSERR_BASE#define XSERR_RESOURCE_IN_USE           21 + XSERR_BASE#define XSERR_BAD_POLICY_NAME           22 + XSERR_BASE#define XSERR_RESOURCE_ACCESS           23 + XSERR_BASE#define XSERR_HV_OP_FAILED              24 + XSERR_BASE#define XSERR_BOOTPOLICY_INSTALL_ERROR  25 + XSERR_BASE#define XSERR_VM_NOT_AUTHORIZED         26 + XSERR_BASE#define XSERR_VM_IN_CONFLICT            27 + XSERR_BASE/** * Free the given xen_xspolicy.  The given handle must have been allocated * by this library. */extern voidxen_xspolicy_free(xen_xspolicy xspolicy);typedef struct xen_xspolicy_set{    size_t size;    xen_xspolicy *contents[];} xen_xspolicy_set;/** * Allocate a xen_xspolicy_set of the given size. */extern xen_xspolicy_set *xen_xspolicy_set_alloc(size_t size);/** * Free the given xen_xspolicy_set.  The given set must have been allocated * by this library. */extern voidxen_xspolicy_set_free(xen_xspolicy_set *set);typedef struct xen_xspolicy_record{    xen_xspolicy handle;    char *uuid;    char *repr;    xs_instantiationflags flags;    xs_type type;} xen_xspolicy_record;/** * Allocate a xen_xspolicy_record. */extern xen_xspolicy_record *xen_xspolicy_record_alloc(void);/** * Free the given xen_xspolicy_record, and all referenced values.  The * given record must have been allocated by this library. */extern voidxen_xspolicy_record_free(xen_xspolicy_record *record);typedef struct xen_xspolicy_record_opt{    bool is_record;    union    {        xen_xspolicy handle;        xen_xspolicy_record *record;    } u;} xen_xspolicy_record_opt;/** * Allocate a xen_xspolicy_record_opt. */extern xen_xspolicy_record_opt *xen_xspolicy_record_opt_alloc(void);/** * Free the given xen_xspolicy_record_opt, and all referenced values.  The * given record_opt must have been allocated by this library. */extern voidxen_xspolicy_record_opt_free(xen_xspolicy_record_opt *record_opt);typedef struct xen_xspolicy_record_set{    size_t size;    xen_xspolicy_record *contents[];} xen_xspolicy_record_set;/** * Allocate a xen_xspolicy_record_set of the given size. */extern xen_xspolicy_record_set *xen_xspolicy_record_set_alloc(size_t size);/** * Free the given xen_xspolicy_record_set, and all referenced values.  The * given set must have been allocated by this library. */extern voidxen_xspolicy_record_set_free(xen_xspolicy_record_set *set);/** * Data structures and function declarations for an XS Policy's state * information. */typedef struct xen_xs_policystate{    xen_xspolicy_record_opt *xs_ref;    int64_t xserr;    char *repr;    xs_type type;    xs_instantiationflags flags;    char *version;    char *errors;} xen_xs_policystate;extern voidxen_xs_policystate_free(xen_xs_policystate *state);/** * Get the referenced policy's record. */extern boolxen_xspolicy_get_record(xen_session *session, xen_xspolicy_record **result,                        xen_xspolicy xspolicy);/** * Get the UUID field of the given policy. */extern boolxen_xspolicy_get_uuid(xen_session *session, char **result,                      xen_xspolicy xspolicy);/** * Get a policy given it's UUID */extern boolxen_xspolicy_get_by_uuid(xen_session *session, xen_xspolicy *result,                         char *uuid);/** * Get the types of policies supported by the system. */extern boolxen_xspolicy_get_xstype(xen_session *session, xs_type *result);/** * Get information about the currently managed policy. * (The API allows only one policy to be on the system.) */extern boolxen_xspolicy_get_xspolicy(xen_session *session, xen_xs_policystate **result);/** * Activate the referenced policy by loading it into the hypervisor. */extern boolxen_xspolicy_activate_xspolicy(xen_session *session, int64_t *result,                               xen_xspolicy xspolicy,                               xs_instantiationflags flags);/** * Set the system's policy to the given information comprising * type of policy, the xml representation of the policy, some flags * on whether to load the policy immediately and whether to overwrite * an existing policy on the system. */extern boolxen_xspolicy_set_xspolicy(xen_session *session, xen_xs_policystate **result,                          xs_type type, char *repr, int64_t flags,                          bool overwrite);/** * Attempt to reset the system's policy to the DEFAULT policy for the * respective policy type. This is done by updating the system and therefore * underlies the same restrictions of a policy update. This operation may * for example fail if other domains than Domain-0 are running and have * different labels than Domain-0. */extern boolxen_xspolicy_reset_xspolicy(xen_session *session, xen_xs_policystate **result,                            xs_type type);/** * Remove any policy from having the system booted with. */extern boolxen_xspolicy_rm_xsbootpolicy(xen_session *session);/** * Retrieve all labeled resources. */extern boolxen_xspolicy_get_labeled_resources(xen_session *session,                                   xen_string_string_map **resources);/** * Label a resource such as for example a hard drive partition or file */extern boolxen_xspolicy_set_resource_label(xen_session *session,                                char *resource, char *label,                                char *oldlabel);/** * Get the label of a resource. */extern boolxen_xspolicy_get_resource_label(xen_session *session, char **label,                                char *resource);/** * Check whether a VM with the given VM-label could run. */extern boolxen_xspolicy_can_run(xen_session *session, int64_t *result,                     char *security_label);#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -