2011-07-13 15:05:19 +00:00
|
|
|
/*
|
|
|
|
* hyperv_wmi_classes.h: WMI classes for managing Microsoft Hyper-V hosts
|
|
|
|
*
|
2017-06-27 19:13:24 +00:00
|
|
|
* Copyright (C) 2017 Datto Inc
|
2011-07-13 15:05:19 +00:00
|
|
|
* Copyright (C) 2011 Matthias Bolte <matthias.bolte@googlemail.com>
|
|
|
|
* Copyright (C) 2009 Michael Sievers <msievers83@googlemail.com>
|
|
|
|
*
|
|
|
|
* 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
|
2012-09-20 22:30:55 +00:00
|
|
|
* License along with this library. If not, see
|
2012-07-21 10:06:23 +00:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
2011-07-13 15:05:19 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#pragma once
|
2011-07-13 15:05:19 +00:00
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#include "internal.h"
|
|
|
|
#include "openwsman.h"
|
2011-07-13 15:05:19 +00:00
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#include "hyperv_wmi_classes.generated.typedef"
|
2011-07-13 15:05:19 +00:00
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#define ROOT_CIMV2 \
|
hyperv: add support for Hyper-V 2012 and newer
This patch reworks the Hyper-V driver structs and the code generator
to provide seamless support for both Hyper-V 2008 and 2012 or newer.
This does not implement any new libvirt APIs, it just adapts existing
2008-only driver to also handle 2012 and newer by sharing as much
driver code as possible (currently it's all of it :-)). This is needed
to set the foundation before we can move forward with implementing the
rest of the driver APIs.
With the 2012 release, Microsoft introduced "v2" version of Msvm_* WMI
classes. Those are largely the same as "v1" (used in 2008) but have some
new properties as well as need different wsman request URIs. To
accomodate those differences, most of work went into the code generator
so that it's "aware" of possibility of multiple versions of the same WMI
class and produce C code accordingly.
To accomplish this the following changes were made:
* the abstract hypervObject struct's data member was changed to a union
that has "common", "v1" and "v2" members. Those are structs that
represent WMI classes that we get back from wsman response. The
"common" struct has members that are present in both "v1" and "v2"
which the driver API callbacks can use to read the data from in
version-independent manner (if version-specific member needs to be
accessed the driver can check priv->wmiVersion and read from "v1" or
"v2" as needed). Those structs are guaranteed to be memory aligned
by the code generator (see the align_property_members implementation
that takes care of that)
* the generator produces *_WmiInfo for each WMI class "family" that
holds an array of hypervWmiClassInfoPtr each providing information
as to which request URI to use for each "version" of given WMI class
as well as XmlSerializerInfo struct needed to unserilize WS-MAN
responsed into the data structs. The driver uses those to make proper
WS-MAN request depending on which version it's connected to.
* the generator no longer produces "helper" functions such as
hypervGetMsvmComputerSystemList as those were originally just simple
wrappers around hypervEnumAndPull, instead those were hand-written
now (to keep driver changes minimal). The reason is that we'll have
more code coming implementing missing libvirt APIs and surely code
patterns will emerge that would warrant more useful "utility" functions
like that.
* a hypervInitConnection was added to the driver which "detects"
Hyper-V version by testing simple wsman request using v2 then falling
back to v1, obviously if both fail, the we're erroring out.
To express how the above translates in code:
void
hypervImplementSomeLibvirtApi(virConnectPtr conn, ...)
{
hypervPrivate *priv = conn->privateData;
virBuffer query = VIR_BUFFER_INITIALIZER;
hypervWqlQuery wqlQuery = HYPERV_WQL_QUERY_INITIALIZER;
Msvm_ComputerSystem *list = NULL; /* typed hypervObject instance */
/* the WmiInfo struct has the data needed for wsman request and
* response handling for both v1 and v2 */
wqlQuery.info = Msvm_ComputerSystem_WmiInfo;
wqlQuery.query = &query;
virBufferAddLit(&query, "select * from Msvm_ComputerSystem");
if (hypervEnumAndPull(priv, &wqlQuery, (hypervObject **) &list) < 0) {
goto cleanup;
}
if (list == NULL) {
/* none found */
goto cleanup;
}
/* works with v1 and v2 */
char *vmName = list->data.common->Name;
/* access property that is in v2 only */
if (priv->wmiVersion == HYPERV_WMI_VERSION_V2)
char *foo = list->data.v2->V2Property;
else
char *foo = list->data.v1->V1Property;
cleanup:
hypervFreeObject(priv, (hypervObject *)list);
}
2017-04-04 22:26:08 +00:00
|
|
|
"http://schemas.microsoft.com/wbem/wsman/1/wmi/root/cimv2/*"
|
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#define ROOT_VIRTUALIZATION \
|
hyperv: add support for Hyper-V 2012 and newer
This patch reworks the Hyper-V driver structs and the code generator
to provide seamless support for both Hyper-V 2008 and 2012 or newer.
This does not implement any new libvirt APIs, it just adapts existing
2008-only driver to also handle 2012 and newer by sharing as much
driver code as possible (currently it's all of it :-)). This is needed
to set the foundation before we can move forward with implementing the
rest of the driver APIs.
With the 2012 release, Microsoft introduced "v2" version of Msvm_* WMI
classes. Those are largely the same as "v1" (used in 2008) but have some
new properties as well as need different wsman request URIs. To
accomodate those differences, most of work went into the code generator
so that it's "aware" of possibility of multiple versions of the same WMI
class and produce C code accordingly.
To accomplish this the following changes were made:
* the abstract hypervObject struct's data member was changed to a union
that has "common", "v1" and "v2" members. Those are structs that
represent WMI classes that we get back from wsman response. The
"common" struct has members that are present in both "v1" and "v2"
which the driver API callbacks can use to read the data from in
version-independent manner (if version-specific member needs to be
accessed the driver can check priv->wmiVersion and read from "v1" or
"v2" as needed). Those structs are guaranteed to be memory aligned
by the code generator (see the align_property_members implementation
that takes care of that)
* the generator produces *_WmiInfo for each WMI class "family" that
holds an array of hypervWmiClassInfoPtr each providing information
as to which request URI to use for each "version" of given WMI class
as well as XmlSerializerInfo struct needed to unserilize WS-MAN
responsed into the data structs. The driver uses those to make proper
WS-MAN request depending on which version it's connected to.
* the generator no longer produces "helper" functions such as
hypervGetMsvmComputerSystemList as those were originally just simple
wrappers around hypervEnumAndPull, instead those were hand-written
now (to keep driver changes minimal). The reason is that we'll have
more code coming implementing missing libvirt APIs and surely code
patterns will emerge that would warrant more useful "utility" functions
like that.
* a hypervInitConnection was added to the driver which "detects"
Hyper-V version by testing simple wsman request using v2 then falling
back to v1, obviously if both fail, the we're erroring out.
To express how the above translates in code:
void
hypervImplementSomeLibvirtApi(virConnectPtr conn, ...)
{
hypervPrivate *priv = conn->privateData;
virBuffer query = VIR_BUFFER_INITIALIZER;
hypervWqlQuery wqlQuery = HYPERV_WQL_QUERY_INITIALIZER;
Msvm_ComputerSystem *list = NULL; /* typed hypervObject instance */
/* the WmiInfo struct has the data needed for wsman request and
* response handling for both v1 and v2 */
wqlQuery.info = Msvm_ComputerSystem_WmiInfo;
wqlQuery.query = &query;
virBufferAddLit(&query, "select * from Msvm_ComputerSystem");
if (hypervEnumAndPull(priv, &wqlQuery, (hypervObject **) &list) < 0) {
goto cleanup;
}
if (list == NULL) {
/* none found */
goto cleanup;
}
/* works with v1 and v2 */
char *vmName = list->data.common->Name;
/* access property that is in v2 only */
if (priv->wmiVersion == HYPERV_WMI_VERSION_V2)
char *foo = list->data.v2->V2Property;
else
char *foo = list->data.v1->V1Property;
cleanup:
hypervFreeObject(priv, (hypervObject *)list);
}
2017-04-04 22:26:08 +00:00
|
|
|
"http://schemas.microsoft.com/wbem/wsman/1/wmi/root/virtualization/*"
|
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#define ROOT_VIRTUALIZATION_V2 \
|
hyperv: add support for Hyper-V 2012 and newer
This patch reworks the Hyper-V driver structs and the code generator
to provide seamless support for both Hyper-V 2008 and 2012 or newer.
This does not implement any new libvirt APIs, it just adapts existing
2008-only driver to also handle 2012 and newer by sharing as much
driver code as possible (currently it's all of it :-)). This is needed
to set the foundation before we can move forward with implementing the
rest of the driver APIs.
With the 2012 release, Microsoft introduced "v2" version of Msvm_* WMI
classes. Those are largely the same as "v1" (used in 2008) but have some
new properties as well as need different wsman request URIs. To
accomodate those differences, most of work went into the code generator
so that it's "aware" of possibility of multiple versions of the same WMI
class and produce C code accordingly.
To accomplish this the following changes were made:
* the abstract hypervObject struct's data member was changed to a union
that has "common", "v1" and "v2" members. Those are structs that
represent WMI classes that we get back from wsman response. The
"common" struct has members that are present in both "v1" and "v2"
which the driver API callbacks can use to read the data from in
version-independent manner (if version-specific member needs to be
accessed the driver can check priv->wmiVersion and read from "v1" or
"v2" as needed). Those structs are guaranteed to be memory aligned
by the code generator (see the align_property_members implementation
that takes care of that)
* the generator produces *_WmiInfo for each WMI class "family" that
holds an array of hypervWmiClassInfoPtr each providing information
as to which request URI to use for each "version" of given WMI class
as well as XmlSerializerInfo struct needed to unserilize WS-MAN
responsed into the data structs. The driver uses those to make proper
WS-MAN request depending on which version it's connected to.
* the generator no longer produces "helper" functions such as
hypervGetMsvmComputerSystemList as those were originally just simple
wrappers around hypervEnumAndPull, instead those were hand-written
now (to keep driver changes minimal). The reason is that we'll have
more code coming implementing missing libvirt APIs and surely code
patterns will emerge that would warrant more useful "utility" functions
like that.
* a hypervInitConnection was added to the driver which "detects"
Hyper-V version by testing simple wsman request using v2 then falling
back to v1, obviously if both fail, the we're erroring out.
To express how the above translates in code:
void
hypervImplementSomeLibvirtApi(virConnectPtr conn, ...)
{
hypervPrivate *priv = conn->privateData;
virBuffer query = VIR_BUFFER_INITIALIZER;
hypervWqlQuery wqlQuery = HYPERV_WQL_QUERY_INITIALIZER;
Msvm_ComputerSystem *list = NULL; /* typed hypervObject instance */
/* the WmiInfo struct has the data needed for wsman request and
* response handling for both v1 and v2 */
wqlQuery.info = Msvm_ComputerSystem_WmiInfo;
wqlQuery.query = &query;
virBufferAddLit(&query, "select * from Msvm_ComputerSystem");
if (hypervEnumAndPull(priv, &wqlQuery, (hypervObject **) &list) < 0) {
goto cleanup;
}
if (list == NULL) {
/* none found */
goto cleanup;
}
/* works with v1 and v2 */
char *vmName = list->data.common->Name;
/* access property that is in v2 only */
if (priv->wmiVersion == HYPERV_WMI_VERSION_V2)
char *foo = list->data.v2->V2Property;
else
char *foo = list->data.v1->V1Property;
cleanup:
hypervFreeObject(priv, (hypervObject *)list);
}
2017-04-04 22:26:08 +00:00
|
|
|
"http://schemas.microsoft.com/wbem/wsman/1/wmi/root/virtualization/v2/*"
|
|
|
|
|
2011-07-13 15:05:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
|
|
* Msvm_ComputerSystem
|
|
|
|
*/
|
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#define MSVM_COMPUTERSYSTEM_WQL_VIRTUAL \
|
2011-07-13 15:05:19 +00:00
|
|
|
"Description = \"Microsoft Virtual Machine\" "
|
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#define MSVM_COMPUTERSYSTEM_WQL_PHYSICAL \
|
2011-07-13 15:05:19 +00:00
|
|
|
"Description = \"Microsoft Hosting Computer System\" "
|
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#define MSVM_COMPUTERSYSTEM_WQL_ACTIVE \
|
2011-07-13 15:05:19 +00:00
|
|
|
"(EnabledState != 0 and EnabledState != 3 and EnabledState != 32769) "
|
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#define MSVM_COMPUTERSYSTEM_WQL_INACTIVE \
|
2011-07-13 15:05:19 +00:00
|
|
|
"(EnabledState = 0 or EnabledState = 3 or EnabledState = 32769) "
|
|
|
|
|
|
|
|
enum _Msvm_ComputerSystem_EnabledState {
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_UNKNOWN = 0, /* inactive */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_ENABLED = 2, /* active */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_DISABLED = 3, /* inactive */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_PAUSED = 32768, /* active */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_SUSPENDED = 32769, /* inactive */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_STARTING = 32770, /* active */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_SNAPSHOTTING = 32771, /* active */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_SAVING = 32773, /* active */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_STOPPING = 32774, /* active */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_PAUSING = 32776, /* active */
|
|
|
|
MSVM_COMPUTERSYSTEM_ENABLEDSTATE_RESUMING = 32777 /* active */
|
|
|
|
};
|
|
|
|
|
|
|
|
enum _Msvm_ComputerSystem_RequestedState {
|
|
|
|
MSVM_COMPUTERSYSTEM_REQUESTEDSTATE_ENABLED = 2,
|
|
|
|
MSVM_COMPUTERSYSTEM_REQUESTEDSTATE_DISABLED = 3,
|
|
|
|
MSVM_COMPUTERSYSTEM_REQUESTEDSTATE_REBOOT = 10,
|
|
|
|
MSVM_COMPUTERSYSTEM_REQUESTEDSTATE_PAUSED = 32768,
|
|
|
|
MSVM_COMPUTERSYSTEM_REQUESTEDSTATE_SUSPENDED = 32769,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
|
|
* Msvm_ConcreteJob
|
|
|
|
*/
|
|
|
|
|
|
|
|
enum _Msvm_ConcreteJob_JobState {
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_NEW = 2,
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_STARTING = 3,
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_RUNNING = 4,
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_SUSPENDED = 5,
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_SHUTTING_DOWN = 6,
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_COMPLETED = 7,
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_TERMINATED = 8,
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_KILLED = 9,
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_EXCEPTION = 10,
|
|
|
|
MSVM_CONCRETEJOB_JOBSTATE_SERVICE = 11,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-06-27 19:13:24 +00:00
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
|
|
* WMI
|
|
|
|
*/
|
|
|
|
|
|
|
|
typedef struct _hypervCimType hypervCimType;
|
|
|
|
typedef hypervCimType *hypervCimTypePtr;
|
|
|
|
struct _hypervCimType {
|
|
|
|
/* Parameter name */
|
|
|
|
const char *name;
|
|
|
|
/* Parameter type */
|
|
|
|
const char *type;
|
|
|
|
/* whether parameter is an array type */
|
|
|
|
bool isArray;
|
|
|
|
};
|
|
|
|
|
2017-04-04 22:26:06 +00:00
|
|
|
typedef struct _hypervWmiClassInfo hypervWmiClassInfo;
|
|
|
|
typedef hypervWmiClassInfo *hypervWmiClassInfoPtr;
|
|
|
|
struct _hypervWmiClassInfo {
|
|
|
|
/* The WMI class name */
|
|
|
|
const char *name;
|
|
|
|
/* The version of the WMI class as in "v1" or "v2" */
|
|
|
|
const char *version;
|
|
|
|
/* The URI for wsman enumerate request */
|
|
|
|
const char *rootUri;
|
|
|
|
/* The namespace URI for XML serialization */
|
|
|
|
const char *resourceUri;
|
|
|
|
/* The wsman serializer info - one of the *_TypeInfo structs */
|
|
|
|
XmlSerializerInfo *serializerInfo;
|
2017-06-27 19:13:24 +00:00
|
|
|
/* Property type information */
|
|
|
|
hypervCimTypePtr propertyInfo;
|
2017-04-04 22:26:06 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct _hypervWmiClassInfoList hypervWmiClassInfoList;
|
|
|
|
typedef hypervWmiClassInfoList *hypervWmiClassInfoListPtr;
|
|
|
|
struct _hypervWmiClassInfoList {
|
|
|
|
size_t count;
|
|
|
|
hypervWmiClassInfoPtr *objs;
|
|
|
|
};
|
2011-07-13 15:05:19 +00:00
|
|
|
|
2019-06-07 20:20:25 +00:00
|
|
|
#include "hyperv_wmi_classes.generated.h"
|