📄 xen_host.h
字号:
/* * Copyright (c) 2006-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_HOST_H#define XEN_HOST_H#include <xen/api/xen_common.h>#include <xen/api/xen_host_cpu_decl.h>#include <xen/api/xen_host_decl.h>#include <xen/api/xen_host_metrics_decl.h>#include <xen/api/xen_pbd_decl.h>#include <xen/api/xen_pif_decl.h>#include <xen/api/xen_sr_decl.h>#include <xen/api/xen_string_set.h>#include <xen/api/xen_string_string_map.h>#include <xen/api/xen_vm_decl.h>/* * The host class. * * A physical host. *//** * Free the given xen_host. The given handle must have been allocated * by this library. */extern voidxen_host_free(xen_host host);typedef struct xen_host_set{ size_t size; xen_host *contents[];} xen_host_set;/** * Allocate a xen_host_set of the given size. */extern xen_host_set *xen_host_set_alloc(size_t size);/** * Free the given xen_host_set. The given set must have been allocated * by this library. */extern voidxen_host_set_free(xen_host_set *set);typedef struct xen_host_record{ xen_host handle; char *uuid; char *name_label; char *name_description; int64_t api_version_major; int64_t api_version_minor; char *api_version_vendor; xen_string_string_map *api_version_vendor_implementation; bool enabled; xen_string_string_map *software_version; xen_string_string_map *other_config; struct xen_string_set *capabilities; xen_string_string_map *cpu_configuration; char *sched_policy; struct xen_string_set *supported_bootloaders; struct xen_vm_record_opt_set *resident_vms; xen_string_string_map *logging; struct xen_pif_record_opt_set *pifs; struct xen_sr_record_opt *suspend_image_sr; struct xen_sr_record_opt *crash_dump_sr; struct xen_pbd_record_opt_set *pbds; struct xen_host_cpu_record_opt_set *host_cpus; struct xen_host_metrics_record_opt *metrics;} xen_host_record;/** * Allocate a xen_host_record. */extern xen_host_record *xen_host_record_alloc(void);/** * Free the given xen_host_record, and all referenced values. The * given record must have been allocated by this library. */extern voidxen_host_record_free(xen_host_record *record);typedef struct xen_host_record_opt{ bool is_record; union { xen_host handle; xen_host_record *record; } u;} xen_host_record_opt;/** * Allocate a xen_host_record_opt. */extern xen_host_record_opt *xen_host_record_opt_alloc(void);/** * Free the given xen_host_record_opt, and all referenced values. The * given record_opt must have been allocated by this library. */extern voidxen_host_record_opt_free(xen_host_record_opt *record_opt);typedef struct xen_host_record_set{ size_t size; xen_host_record *contents[];} xen_host_record_set;/** * Allocate a xen_host_record_set of the given size. */extern xen_host_record_set *xen_host_record_set_alloc(size_t size);/** * Free the given xen_host_record_set, and all referenced values. The * given set must have been allocated by this library. */extern voidxen_host_record_set_free(xen_host_record_set *set);typedef struct xen_host_record_opt_set{ size_t size; xen_host_record_opt *contents[];} xen_host_record_opt_set;/** * Allocate a xen_host_record_opt_set of the given size. */extern xen_host_record_opt_set *xen_host_record_opt_set_alloc(size_t size);/** * Free the given xen_host_record_opt_set, and all referenced values. * The given set must have been allocated by this library. */extern voidxen_host_record_opt_set_free(xen_host_record_opt_set *set);/** * Get a record containing the current state of the given host. */extern boolxen_host_get_record(xen_session *session, xen_host_record **result, xen_host host);/** * Get a reference to the host instance with the specified UUID. */extern boolxen_host_get_by_uuid(xen_session *session, xen_host *result, char *uuid);/** * Get all the host instances with the given label. */extern boolxen_host_get_by_name_label(xen_session *session, struct xen_host_set **result, char *label);/** * Get the uuid field of the given host. */extern boolxen_host_get_uuid(xen_session *session, char **result, xen_host host);/** * Get the name/label field of the given host. */extern boolxen_host_get_name_label(xen_session *session, char **result, xen_host host);/** * Get the name/description field of the given host. */extern boolxen_host_get_name_description(xen_session *session, char **result, xen_host host);/** * Get the API_version/major field of the given host. */extern boolxen_host_get_api_version_major(xen_session *session, int64_t *result, xen_host host);/** * Get the API_version/minor field of the given host. */extern boolxen_host_get_api_version_minor(xen_session *session, int64_t *result, xen_host host);/** * Get the API_version/vendor field of the given host. */extern boolxen_host_get_api_version_vendor(xen_session *session, char **result, xen_host host);/** * Get the API_version/vendor_implementation field of the given host. */extern boolxen_host_get_api_version_vendor_implementation(xen_session *session, xen_string_string_map **result, xen_host host);/** * Get the enabled field of the given host. */extern boolxen_host_get_enabled(xen_session *session, bool *result, xen_host host);/** * Get the software_version field of the given host. */extern boolxen_host_get_software_version(xen_session *session, xen_string_string_map **result, xen_host host);/** * Get the other_config field of the given host. */extern boolxen_host_get_other_config(xen_session *session, xen_string_string_map **result, xen_host host);/** * Get the capabilities field of the given host. */extern boolxen_host_get_capabilities(xen_session *session, struct xen_string_set **result, xen_host host);/** * Get the cpu_configuration field of the given host. */extern boolxen_host_get_cpu_configuration(xen_session *session, xen_string_string_map **result, xen_host host);/** * Get the sched_policy field of the given host. */extern boolxen_host_get_sched_policy(xen_session *session, char **result, xen_host host);/** * Get the supported_bootloaders field of the given host. */extern boolxen_host_get_supported_bootloaders(xen_session *session, struct xen_string_set **result, xen_host host);/** * Get the resident_VMs field of the given host. */extern boolxen_host_get_resident_vms(xen_session *session, struct xen_vm_set **result, xen_host host);/** * Get the logging field of the given host. */extern boolxen_host_get_logging(xen_session *session, xen_string_string_map **result, xen_host host);/** * Get the PIFs field of the given host. */extern boolxen_host_get_pifs(xen_session *session, struct xen_pif_set **result, xen_host host);/** * Get the suspend_image_sr field of the given host. */extern boolxen_host_get_suspend_image_sr(xen_session *session, xen_sr *result, xen_host host);/** * Get the crash_dump_sr field of the given host. */extern boolxen_host_get_crash_dump_sr(xen_session *session, xen_sr *result, xen_host host);/** * Get the PBDs field of the given host. */extern boolxen_host_get_pbds(xen_session *session, struct xen_pbd_set **result, xen_host host);/** * Get the host_CPUs field of the given host. */extern boolxen_host_get_host_cpus(xen_session *session, struct xen_host_cpu_set **result, xen_host host);/** * Get the metrics field of the given host. */extern boolxen_host_get_metrics(xen_session *session, xen_host_metrics *result, xen_host host);/** * Set the name/label field of the given host. */extern boolxen_host_set_name_label(xen_session *session, xen_host host, char *label);/** * Set the name/description field of the given host. */extern boolxen_host_set_name_description(xen_session *session, xen_host host, char *description);/** * Set the other_config field of the given host. */extern boolxen_host_set_other_config(xen_session *session, xen_host host, xen_string_string_map *other_config);/** * Add the given key-value pair to the other_config field of the given * host. */extern boolxen_host_add_to_other_config(xen_session *session, xen_host host, char *key, char *value);/** * Remove the given key and its corresponding value from the * other_config field of the given host. If the key is not in that Map, then * do nothing. */extern boolxen_host_remove_from_other_config(xen_session *session, xen_host host, char *key);/** * Set the logging field of the given host. */extern boolxen_host_set_logging(xen_session *session, xen_host host, xen_string_string_map *logging);/** * Add the given key-value pair to the logging field of the given host. */extern boolxen_host_add_to_logging(xen_session *session, xen_host host, char *key, char *value);/** * Remove the given key and its corresponding value from the logging * field of the given host. If the key is not in that Map, then do nothing. */extern boolxen_host_remove_from_logging(xen_session *session, xen_host host, char *key);/** * Set the suspend_image_sr field of the given host. */extern boolxen_host_set_suspend_image_sr(xen_session *session, xen_host host, xen_sr suspend_image_sr);/** * Set the crash_dump_sr field of the given host. */extern boolxen_host_set_crash_dump_sr(xen_session *session, xen_host host, xen_sr crash_dump_sr);/** * Puts the host into a state in which no new VMs can be started. * Currently active VMs on the host continue to execute. */extern boolxen_host_disable(xen_session *session, xen_host host);/** * Puts the host into a state in which new VMs can be started. */extern boolxen_host_enable(xen_session *session, xen_host host);/** * Shutdown the host. (This function can only be called if there are no * currently running VMs on the host and it is disabled.). */extern boolxen_host_shutdown(xen_session *session, xen_host host);/** * Reboot the host. (This function can only be called if there are no * currently running VMs on the host and it is disabled.). */extern boolxen_host_reboot(xen_session *session, xen_host host);/** * Get the host xen dmesg. */extern boolxen_host_dmesg(xen_session *session, char **result, xen_host host);/** * Get the host xen dmesg, and clear the buffer. */extern boolxen_host_dmesg_clear(xen_session *session, char **result, xen_host host);/** * Get the host's log file. */extern boolxen_host_get_log(xen_session *session, char **result, xen_host host);/** * Inject the given string as debugging keys into Xen. */extern boolxen_host_send_debug_keys(xen_session *session, xen_host host, char *keys);/** * List all supported methods. */extern boolxen_host_list_methods(xen_session *session, struct xen_string_set **result);/** * Return a list of all the hosts known to the system. */extern boolxen_host_get_all(xen_session *session, struct xen_host_set **result);#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -