diff options
author | Keir Fraser <keir.fraser@citrix.com> | 2010-04-21 12:49:41 +0100 |
---|---|---|
committer | Keir Fraser <keir.fraser@citrix.com> | 2010-04-21 12:49:41 +0100 |
commit | 6e6a088333cdb84dc73ea0cf9639b958b1dd133e (patch) | |
tree | 6ac6a425c7ab8c8fe29f4fdc39c865db47ef0f39 /tools/libxen/src | |
parent | a5f70e8d9271da4675a044954ed2cc82d5a8fcd9 (diff) | |
download | xen-6e6a088333cdb84dc73ea0cf9639b958b1dd133e.tar.gz xen-6e6a088333cdb84dc73ea0cf9639b958b1dd133e.tar.bz2 xen-6e6a088333cdb84dc73ea0cf9639b958b1dd133e.zip |
cpupools [3/6]: libxen changes
Signed-off-by: Juergen Gross <juergen.gross@ts.fujitsu.com>
Diffstat (limited to 'tools/libxen/src')
-rw-r--r-- | tools/libxen/src/xen_cpu_pool.c | 671 | ||||
-rw-r--r-- | tools/libxen/src/xen_host.c | 26 | ||||
-rw-r--r-- | tools/libxen/src/xen_host_cpu.c | 38 | ||||
-rw-r--r-- | tools/libxen/src/xen_vm.c | 78 |
4 files changed, 810 insertions, 3 deletions
diff --git a/tools/libxen/src/xen_cpu_pool.c b/tools/libxen/src/xen_cpu_pool.c new file mode 100644 index 0000000000..5186da85b9 --- /dev/null +++ b/tools/libxen/src/xen_cpu_pool.c @@ -0,0 +1,671 @@ +/* + * 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 + */ + + +#include <stddef.h> +#include <stdlib.h> + +#include "xen_internal.h" +#include <xen/api/xen_common.h> +#include <xen/api/xen_cpu_pool.h> +#include <xen/api/xen_host_cpu.h> + +XEN_FREE(xen_cpu_pool) +XEN_SET_ALLOC_FREE(xen_cpu_pool) +XEN_ALLOC(xen_cpu_pool_record) +XEN_SET_ALLOC_FREE(xen_cpu_pool_record) +XEN_ALLOC(xen_cpu_pool_record_opt) +XEN_RECORD_OPT_FREE(xen_cpu_pool) +XEN_SET_ALLOC_FREE(xen_cpu_pool_record_opt) + + +static const struct_member xen_cpu_pool_record_struct_members[] = + { + { .key = "uuid", + .type = &abstract_type_string, + .offset = offsetof(xen_cpu_pool_record, uuid) }, + { .key = "name_label", + .type = &abstract_type_string, + .offset = offsetof(xen_cpu_pool_record, name_label) }, + { .key = "name_description", + .type = &abstract_type_string, + .offset = offsetof(xen_cpu_pool_record, name_description) }, + { .key = "resident_on", + .type = &abstract_type_ref, + .offset = offsetof(xen_cpu_pool_record, resident_on) }, + { .key = "auto_power_on", + .type = &abstract_type_bool, + .offset = offsetof(xen_cpu_pool_record, auto_power_on) }, + { .key = "started_VMs", + .type = &abstract_type_ref_set, + .offset = offsetof(xen_cpu_pool_record, started_vms) }, + { .key = "ncpu", + .type = &abstract_type_int, + .offset = offsetof(xen_cpu_pool_record, ncpu) }, + { .key = "sched_policy", + .type = &abstract_type_string, + .offset = offsetof(xen_cpu_pool_record, sched_policy) }, + { .key = "proposed_CPUs", + .type = &abstract_type_string_set, + .offset = offsetof(xen_cpu_pool_record, proposed_cpus) }, + { .key = "host_CPUs", + .type = &abstract_type_ref_set, + .offset = offsetof(xen_cpu_pool_record, host_cpus) }, + { .key = "activated", + .type = &abstract_type_bool, + .offset = offsetof(xen_cpu_pool_record, activated) }, + { .key = "other_config", + .type = &abstract_type_string_string_map, + .offset = offsetof(xen_cpu_pool_record, other_config) }, + }; + + +const abstract_type xen_cpu_pool_record_abstract_type_ = + { + .typename = STRUCT, + .struct_size = sizeof(xen_cpu_pool_record), + .member_count = + sizeof(xen_cpu_pool_record_struct_members) / sizeof(struct_member), + .members = xen_cpu_pool_record_struct_members + }; + + +void +xen_cpu_pool_record_free(xen_cpu_pool_record *record) +{ + if (record == NULL) + { + return; + } + free(record->handle); + free(record->uuid); + free(record->name_label); + free(record->name_description); + xen_host_record_opt_free(record->resident_on); + xen_vm_record_opt_set_free(record->started_vms); + free(record->sched_policy); + xen_string_set_free(record->proposed_cpus); + xen_host_cpu_record_opt_set_free(record->host_cpus); + xen_string_string_map_free(record->other_config); + free(record); +} + + +bool +xen_cpu_pool_get_record(xen_session *session, xen_cpu_pool_record **result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = xen_cpu_pool_record_abstract_type_; + + *result = NULL; + XEN_CALL_("cpu_pool.get_record"); + + if (session->ok) + { + (*result)->handle = xen_strdup_((*result)->uuid); + } + + return session->ok; +} + + +bool +xen_cpu_pool_get_by_uuid(xen_session *session, xen_cpu_pool *result, char *uuid) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = uuid } + }; + + abstract_type result_type = abstract_type_string; + + *result = NULL; + XEN_CALL_("cpu_pool.get_by_uuid"); + return session->ok; +} + + +bool +xen_cpu_pool_create(xen_session *session, xen_cpu_pool *result, + xen_cpu_pool_record *record) +{ + abstract_value param_values[] = + { + { .type = &xen_cpu_pool_record_abstract_type_, + .u.struct_val = record } + }; + + abstract_type result_type = abstract_type_string; + + *result = NULL; + XEN_CALL_("cpu_pool.create"); + return session->ok; +} + + +bool +xen_cpu_pool_destroy(xen_session *session, xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + xen_call_(session, "cpu_pool.destroy", param_values, 1, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_get_uuid(xen_session *session, char **result, xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_string; + + *result = NULL; + XEN_CALL_("cpu_pool.get_uuid"); + return session->ok; +} + + +bool +xen_cpu_pool_deactivate(xen_session *session, xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + }; + + xen_call_(session, "cpu_pool.deactivate", param_values, 1, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_activate(xen_session *session, xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + }; + + xen_call_(session, "cpu_pool.activate", param_values, 1, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_add_host_CPU_live(xen_session *session, xen_cpu_pool cpu_pool, + xen_host_cpu host_cpu) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string, + .u.string_val = host_cpu }, + }; + + xen_call_(session, "cpu_pool.add_host_CPU_live", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_remove_host_CPU_live(xen_session *session, xen_cpu_pool cpu_pool, + xen_host_cpu host_cpu) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string, + .u.string_val = host_cpu }, + }; + + xen_call_(session, "cpu_pool.remove_host_CPU_live", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_get_all(xen_session *session, struct xen_cpu_pool_set **result) +{ + abstract_type result_type = abstract_type_string_set; + + *result = NULL; + xen_call_(session, "cpu_pool.get_all", NULL, 0, &result_type, result); + return session->ok; +} + + +bool +xen_cpu_pool_get_by_name_label(xen_session *session, + struct xen_cpu_pool_set **result, char *label) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = label } + }; + + abstract_type result_type = abstract_type_string_set; + + *result = NULL; + XEN_CALL_("cpu_pool.get_by_name_label"); + return session->ok; +} + + +bool +xen_cpu_pool_get_activated(xen_session *session, bool *result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_bool; + + XEN_CALL_("cpu_pool.get_activated"); + return session->ok; +} + + +bool +xen_cpu_pool_get_auto_power_on(xen_session *session, bool *result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_bool; + + XEN_CALL_("cpu_pool.get_auto_power_on"); + return session->ok; +} + + +bool +xen_cpu_pool_get_host_CPUs(xen_session *session, struct xen_host_cpu_set **result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_string_set; + + *result = NULL; + XEN_CALL_("cpu_pool.get_host_CPUs"); + return session->ok; +} + + +bool +xen_cpu_pool_get_name_description(xen_session *session, char **result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_string; + + *result = NULL; + XEN_CALL_("cpu_pool.get_name_description"); + return session->ok; +} + + +bool +xen_cpu_pool_get_name_label(xen_session *session, char **result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_string; + + *result = NULL; + XEN_CALL_("cpu_pool.get_name_label"); + return session->ok; +} + + +bool +xen_cpu_pool_get_ncpu(xen_session *session, int64_t *result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_int; + + XEN_CALL_("cpu_pool.get_ncpu"); + return session->ok; +} + + +bool +xen_cpu_pool_get_proposed_CPUs(xen_session *session, struct xen_string_set **result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_string_set; + + *result = NULL; + XEN_CALL_("cpu_pool.get_proposed_CPUs"); + return session->ok; +} + + +bool +xen_cpu_pool_get_other_config(xen_session *session, xen_string_string_map **result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_string_string_map; + + *result = NULL; + XEN_CALL_("cpu_pool.get_other_config"); + return session->ok; +} + + +bool +xen_cpu_pool_get_resident_on(xen_session *session, xen_host *result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_string; + + *result = NULL; + XEN_CALL_("cpu_pool.get_resident_on"); + return session->ok; +} + + +bool +xen_cpu_pool_get_sched_policy(xen_session *session, char **result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_string; + + *result = NULL; + XEN_CALL_("cpu_pool.get_sched_policy"); + return session->ok; +} + + +bool +xen_cpu_pool_get_started_VMs(xen_session *session, xen_vm_set **result, + xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + abstract_type result_type = abstract_type_string_set; + + *result = NULL; + XEN_CALL_("cpu_pool.get_started_VMs"); + return session->ok; +} + + +bool +xen_cpu_pool_set_auto_power_on(xen_session *session, xen_cpu_pool cpu_pool, + bool auto_power_on) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_bool, + .u.bool_val = auto_power_on } + }; + + xen_call_(session, "cpu_pool.set_auto_power_on", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_set_proposed_CPUs(xen_session *session, xen_cpu_pool cpu_pool, + xen_string_set *proposed_cpus) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string_set, + .u.set_val = (arbitrary_set *)proposed_cpus } + }; + + xen_call_(session, "cpu_pool.set_proposed_CPUs", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_add_to_proposed_CPUs(xen_session *session, xen_cpu_pool cpu_pool, + char* proposed_cpu) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string, + .u.string_val = proposed_cpu } + }; + + xen_call_(session, "cpu_pool.add_to_proposed_CPUs", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_remove_from_proposed_CPUs(xen_session *session, xen_cpu_pool cpu_pool, + char* proposed_cpu) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string, + .u.string_val = proposed_cpu } + }; + + xen_call_(session, "cpu_pool.remove_from_proposed_CPUs", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_set_name_label(xen_session *session, xen_cpu_pool cpu_pool, + char *label) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string, + .u.string_val = label } + }; + + xen_call_(session, "cpu_pool.set_name_label", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_set_name_description(xen_session *session, xen_cpu_pool cpu_pool, + char *descr) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string, + .u.string_val = descr } + }; + + xen_call_(session, "cpu_pool.set_name_description", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_set_ncpu(xen_session *session, xen_cpu_pool cpu_pool, int64_t ncpu) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_int, + .u.int_val = ncpu } + }; + + xen_call_(session, "cpu_pool.set_ncpu", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_set_other_config(xen_session *session, xen_cpu_pool cpu_pool, + xen_string_string_map *other_config) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string_string_map, + .u.set_val = (arbitrary_set *)other_config } + }; + + xen_call_(session, "cpu_pool.set_other_config", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_add_to_other_config(xen_session *session, xen_cpu_pool cpu_pool, + char *key, char *value) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string, + .u.string_val = key }, + { .type = &abstract_type_string, + .u.string_val = value } + }; + + xen_call_(session, "cpu_pool.add_to_other_config", param_values, 3, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_remove_from_other_config(xen_session *session, xen_cpu_pool cpu_pool, + char *key) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string, + .u.string_val = key } + }; + + xen_call_(session, "cpu_pool.remove_from_other_config", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_cpu_pool_set_sched_policy(xen_session *session, xen_cpu_pool cpu_pool, + char *sched_policy) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = cpu_pool }, + { .type = &abstract_type_string, + .u.string_val = sched_policy } + }; + + xen_call_(session, "cpu_pool.set_sched_policy", param_values, 2, NULL, NULL); + return session->ok; +} + diff --git a/tools/libxen/src/xen_host.c b/tools/libxen/src/xen_host.c index 0739c4fe4e..b456f5dab6 100644 --- a/tools/libxen/src/xen_host.c +++ b/tools/libxen/src/xen_host.c @@ -30,6 +30,7 @@ #include <xen/api/xen_sr.h> #include <xen/api/xen_string_string_map.h> #include <xen/api/xen_vm.h> +#include <xen/api/xen_cpu_pool.h> XEN_FREE(xen_host) @@ -108,7 +109,10 @@ static const struct_member xen_host_record_struct_members[] = .offset = offsetof(xen_host_record, host_cpus) }, { .key = "metrics", .type = &abstract_type_ref, - .offset = offsetof(xen_host_record, metrics) } + .offset = offsetof(xen_host_record, metrics) }, + { .key = "resident_cpu_pools", + .type = &abstract_type_ref_set, + .offset = offsetof(xen_host_record, resident_cpu_pools) } }; const abstract_type xen_host_record_abstract_type_ = @@ -148,6 +152,7 @@ xen_host_record_free(xen_host_record *record) xen_pbd_record_opt_set_free(record->pbds); xen_host_cpu_record_opt_set_free(record->host_cpus); xen_host_metrics_record_opt_free(record->metrics); + xen_cpu_pool_record_opt_set_free(record->resident_cpu_pools); free(record); } @@ -889,3 +894,22 @@ xen_host_get_uuid(xen_session *session, char **result, xen_host host) XEN_CALL_("host.get_uuid"); return session->ok; } + + +bool +xen_host_get_resident_cpu_pools(xen_session *session, struct xen_cpu_pool_set **result, + xen_host host) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = host } + }; + + abstract_type result_type = abstract_type_string_set; + + *result = NULL; + XEN_CALL_("host.get_resident_cpu_pools"); + return session->ok; +} + diff --git a/tools/libxen/src/xen_host_cpu.c b/tools/libxen/src/xen_host_cpu.c index 6e84b49f63..85d88f6336 100644 --- a/tools/libxen/src/xen_host_cpu.c +++ b/tools/libxen/src/xen_host_cpu.c @@ -24,6 +24,7 @@ #include <xen/api/xen_common.h> #include <xen/api/xen_host.h> #include <xen/api/xen_host_cpu.h> +#include <xen/api/xen_cpu_pool.h> XEN_FREE(xen_host_cpu) @@ -66,7 +67,10 @@ static const struct_member xen_host_cpu_record_struct_members[] = .offset = offsetof(xen_host_cpu_record, features) }, { .key = "utilisation", .type = &abstract_type_float, - .offset = offsetof(xen_host_cpu_record, utilisation) } + .offset = offsetof(xen_host_cpu_record, utilisation) }, + { .key = "cpu_pool", + .type = &abstract_type_ref_set, + .offset = offsetof(xen_host_cpu_record, cpu_pools) }, }; const abstract_type xen_host_cpu_record_abstract_type_ = @@ -94,6 +98,7 @@ xen_host_cpu_record_free(xen_host_cpu_record *record) free(record->stepping); free(record->flags); free(record->features); + xen_cpu_pool_record_opt_set_free(record->cpu_pools); free(record); } @@ -315,3 +320,34 @@ xen_host_cpu_get_uuid(xen_session *session, char **result, xen_host_cpu host_cpu XEN_CALL_("host_cpu.get_uuid"); return session->ok; } + + +bool +xen_host_cpu_get_cpu_pool(xen_session *session, struct xen_cpu_pool_set **result, xen_host_cpu host_cpu) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = host_cpu } + }; + + abstract_type result_type = abstract_type_string_set; + + *result = NULL; + XEN_CALL_("host_cpu.get_cpu_pool"); + return session->ok; +} + + +bool +xen_host_cpu_get_unassigned_cpus(xen_session *session, struct xen_host_cpu_set **result) +{ + abstract_type result_type = abstract_type_string_set; + + *result = NULL; + xen_call_(session, "host_cpu.get_unassigned_cpus", NULL, 0, &result_type, result); + return session->ok; +} + + + diff --git a/tools/libxen/src/xen_vm.c b/tools/libxen/src/xen_vm.c index 2b501e56e3..b762fbea29 100644 --- a/tools/libxen/src/xen_vm.c +++ b/tools/libxen/src/xen_vm.c @@ -36,6 +36,7 @@ #include <xen/api/xen_vm_guest_metrics.h> #include <xen/api/xen_vm_metrics.h> #include <xen/api/xen_vtpm.h> +#include <xen/api/xen_cpu_pool.h> XEN_FREE(xen_vm) @@ -165,7 +166,13 @@ static const struct_member xen_vm_record_struct_members[] = .offset = offsetof(xen_vm_record, guest_metrics) }, { .key = "security_label", .type = &abstract_type_string, - .offset = offsetof(xen_vm_record, security_label) } + .offset = offsetof(xen_vm_record, security_label) }, + { .key = "pool_name", + .type = &abstract_type_string, + .offset = offsetof(xen_vm_record, pool_name) }, + { .key = "cpu_pool", + .type = &abstract_type_ref_set, + .offset = offsetof(xen_vm_record, cpu_pool) }, }; const abstract_type xen_vm_record_abstract_type_ = @@ -209,6 +216,7 @@ xen_vm_record_free(xen_vm_record *record) xen_string_string_map_free(record->other_config); xen_vm_metrics_record_opt_free(record->metrics); xen_vm_guest_metrics_record_opt_free(record->guest_metrics); + xen_cpu_pool_record_opt_set_free(record->cpu_pool); free(record->security_label); free(record); } @@ -1781,3 +1789,71 @@ xen_vm_get_security_label(xen_session *session, char **result, xen_vm vm) XEN_CALL_("VM.get_security_label"); return session->ok; } + + +bool +xen_vm_get_cpu_pool(xen_session *session, struct xen_cpu_pool_set **result, xen_vm vm) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = vm }, + }; + + abstract_type result_type = abstract_type_string_set; + + *result = NULL; + XEN_CALL_("VM.get_cpu_pool"); + return session->ok; +} + + +bool +xen_vm_get_pool_name(xen_session *session, char **result, xen_vm vm) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = vm }, + }; + + abstract_type result_type = abstract_type_string; + + *result = NULL; + XEN_CALL_("VM.get_pool_name"); + return session->ok; +} + + +bool +xen_vm_set_pool_name(xen_session *session, xen_vm vm, char *pool_name) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = vm }, + { .type = &abstract_type_string, + .u.string_val = pool_name } + }; + + xen_call_(session, "VM.set_pool_name", param_values, 2, NULL, NULL); + return session->ok; +} + + +bool +xen_vm_cpu_pool_migrate(xen_session *session, xen_vm vm, xen_cpu_pool cpu_pool) +{ + abstract_value param_values[] = + { + { .type = &abstract_type_string, + .u.string_val = vm }, + { .type = &abstract_type_string, + .u.string_val = cpu_pool } + }; + + xen_call_(session, "VM.cpu_pool_migrate", param_values, 2, NULL, NULL); + return session->ok; +} + + |