/* * Copyright (c) Citrix Systems, Inc. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1) Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2) Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials * provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED * OF THE POSSIBILITY OF SUCH DAMAGE. */ using System; using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Globalization; using Newtonsoft.Json; namespace XenAPI { /// /// A virtual GPU (vGPU) /// First published in XenServer 6.0. /// public partial class VGPU : XenObject { #region Constructors public VGPU() { } public VGPU(string uuid, XenRef VM, XenRef GPU_group, string device, bool currently_attached, Dictionary other_config, XenRef type, XenRef resident_on, XenRef scheduled_to_be_resident_on, Dictionary compatibility_metadata, string extra_args, XenRef PCI) { this.uuid = uuid; this.VM = VM; this.GPU_group = GPU_group; this.device = device; this.currently_attached = currently_attached; this.other_config = other_config; this.type = type; this.resident_on = resident_on; this.scheduled_to_be_resident_on = scheduled_to_be_resident_on; this.compatibility_metadata = compatibility_metadata; this.extra_args = extra_args; this.PCI = PCI; } /// /// Creates a new VGPU from a Hashtable. /// Note that the fields not contained in the Hashtable /// will be created with their default values. /// /// public VGPU(Hashtable table) : this() { UpdateFrom(table); } /// /// Creates a new VGPU from a Proxy_VGPU. /// /// public VGPU(Proxy_VGPU proxy) { UpdateFrom(proxy); } #endregion /// /// Updates each field of this instance with the value of /// the corresponding field of a given VGPU. /// public override void UpdateFrom(VGPU update) { uuid = update.uuid; VM = update.VM; GPU_group = update.GPU_group; device = update.device; currently_attached = update.currently_attached; other_config = update.other_config; type = update.type; resident_on = update.resident_on; scheduled_to_be_resident_on = update.scheduled_to_be_resident_on; compatibility_metadata = update.compatibility_metadata; extra_args = update.extra_args; PCI = update.PCI; } internal void UpdateFrom(Proxy_VGPU proxy) { uuid = proxy.uuid == null ? null : proxy.uuid; VM = proxy.VM == null ? null : XenRef.Create(proxy.VM); GPU_group = proxy.GPU_group == null ? null : XenRef.Create(proxy.GPU_group); device = proxy.device == null ? null : proxy.device; currently_attached = (bool)proxy.currently_attached; other_config = proxy.other_config == null ? null : Maps.convert_from_proxy_string_string(proxy.other_config); type = proxy.type == null ? null : XenRef.Create(proxy.type); resident_on = proxy.resident_on == null ? null : XenRef.Create(proxy.resident_on); scheduled_to_be_resident_on = proxy.scheduled_to_be_resident_on == null ? null : XenRef.Create(proxy.scheduled_to_be_resident_on); compatibility_metadata = proxy.compatibility_metadata == null ? null : Maps.convert_from_proxy_string_string(proxy.compatibility_metadata); extra_args = proxy.extra_args == null ? null : proxy.extra_args; PCI = proxy.PCI == null ? null : XenRef.Create(proxy.PCI); } public Proxy_VGPU ToProxy() { Proxy_VGPU result_ = new Proxy_VGPU(); result_.uuid = uuid ?? ""; result_.VM = VM ?? ""; result_.GPU_group = GPU_group ?? ""; result_.device = device ?? ""; result_.currently_attached = currently_attached; result_.other_config = Maps.convert_to_proxy_string_string(other_config); result_.type = type ?? ""; result_.resident_on = resident_on ?? ""; result_.scheduled_to_be_resident_on = scheduled_to_be_resident_on ?? ""; result_.compatibility_metadata = Maps.convert_to_proxy_string_string(compatibility_metadata); result_.extra_args = extra_args ?? ""; result_.PCI = PCI ?? ""; return result_; } /// /// Given a Hashtable with field-value pairs, it updates the fields of this VGPU /// with the values listed in the Hashtable. Note that only the fields contained /// in the Hashtable will be updated and the rest will remain the same. /// /// public void UpdateFrom(Hashtable table) { if (table.ContainsKey("uuid")) uuid = Marshalling.ParseString(table, "uuid"); if (table.ContainsKey("VM")) VM = Marshalling.ParseRef(table, "VM"); if (table.ContainsKey("GPU_group")) GPU_group = Marshalling.ParseRef(table, "GPU_group"); if (table.ContainsKey("device")) device = Marshalling.ParseString(table, "device"); if (table.ContainsKey("currently_attached")) currently_attached = Marshalling.ParseBool(table, "currently_attached"); if (table.ContainsKey("other_config")) other_config = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "other_config")); if (table.ContainsKey("type")) type = Marshalling.ParseRef(table, "type"); if (table.ContainsKey("resident_on")) resident_on = Marshalling.ParseRef(table, "resident_on"); if (table.ContainsKey("scheduled_to_be_resident_on")) scheduled_to_be_resident_on = Marshalling.ParseRef(table, "scheduled_to_be_resident_on"); if (table.ContainsKey("compatibility_metadata")) compatibility_metadata = Maps.convert_from_proxy_string_string(Marshalling.ParseHashTable(table, "compatibility_metadata")); if (table.ContainsKey("extra_args")) extra_args = Marshalling.ParseString(table, "extra_args"); if (table.ContainsKey("PCI")) PCI = Marshalling.ParseRef(table, "PCI"); } public bool DeepEquals(VGPU other) { if (ReferenceEquals(null, other)) return false; if (ReferenceEquals(this, other)) return true; return Helper.AreEqual2(this._uuid, other._uuid) && Helper.AreEqual2(this._VM, other._VM) && Helper.AreEqual2(this._GPU_group, other._GPU_group) && Helper.AreEqual2(this._device, other._device) && Helper.AreEqual2(this._currently_attached, other._currently_attached) && Helper.AreEqual2(this._other_config, other._other_config) && Helper.AreEqual2(this._type, other._type) && Helper.AreEqual2(this._resident_on, other._resident_on) && Helper.AreEqual2(this._scheduled_to_be_resident_on, other._scheduled_to_be_resident_on) && Helper.AreEqual2(this._compatibility_metadata, other._compatibility_metadata) && Helper.AreEqual2(this._extra_args, other._extra_args) && Helper.AreEqual2(this._PCI, other._PCI); } internal static List ProxyArrayToObjectList(Proxy_VGPU[] input) { var result = new List(); foreach (var item in input) result.Add(new VGPU(item)); return result; } public override string SaveChanges(Session session, string opaqueRef, VGPU server) { if (opaqueRef == null) { System.Diagnostics.Debug.Assert(false, "Cannot create instances of this type on the server"); return ""; } else { if (!Helper.AreEqual2(_other_config, server._other_config)) { VGPU.set_other_config(session, opaqueRef, _other_config); } if (!Helper.AreEqual2(_extra_args, server._extra_args)) { VGPU.set_extra_args(session, opaqueRef, _extra_args); } return null; } } /// /// Get a record containing the current state of the given VGPU. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu public static VGPU get_record(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_record(session.opaque_ref, _vgpu); else return new VGPU(session.XmlRpcProxy.vgpu_get_record(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Get a reference to the VGPU instance with the specified UUID. /// First published in XenServer 6.0. /// /// The session /// UUID of object to return public static XenRef get_by_uuid(Session session, string _uuid) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_by_uuid(session.opaque_ref, _uuid); else return XenRef.Create(session.XmlRpcProxy.vgpu_get_by_uuid(session.opaque_ref, _uuid ?? "").parse()); } /// /// Get the uuid field of the given VGPU. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu public static string get_uuid(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_uuid(session.opaque_ref, _vgpu); else return session.XmlRpcProxy.vgpu_get_uuid(session.opaque_ref, _vgpu ?? "").parse(); } /// /// Get the VM field of the given VGPU. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu public static XenRef get_VM(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_vm(session.opaque_ref, _vgpu); else return XenRef.Create(session.XmlRpcProxy.vgpu_get_vm(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Get the GPU_group field of the given VGPU. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu public static XenRef get_GPU_group(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_gpu_group(session.opaque_ref, _vgpu); else return XenRef.Create(session.XmlRpcProxy.vgpu_get_gpu_group(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Get the device field of the given VGPU. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu public static string get_device(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_device(session.opaque_ref, _vgpu); else return session.XmlRpcProxy.vgpu_get_device(session.opaque_ref, _vgpu ?? "").parse(); } /// /// Get the currently_attached field of the given VGPU. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu public static bool get_currently_attached(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_currently_attached(session.opaque_ref, _vgpu); else return (bool)session.XmlRpcProxy.vgpu_get_currently_attached(session.opaque_ref, _vgpu ?? "").parse(); } /// /// Get the other_config field of the given VGPU. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu public static Dictionary get_other_config(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_other_config(session.opaque_ref, _vgpu); else return Maps.convert_from_proxy_string_string(session.XmlRpcProxy.vgpu_get_other_config(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Get the type field of the given VGPU. /// First published in XenServer 6.2 SP1 Tech-Preview. /// /// The session /// The opaque_ref of the given vgpu public static XenRef get_type(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_type(session.opaque_ref, _vgpu); else return XenRef.Create(session.XmlRpcProxy.vgpu_get_type(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Get the resident_on field of the given VGPU. /// First published in XenServer 6.2 SP1 Tech-Preview. /// /// The session /// The opaque_ref of the given vgpu public static XenRef get_resident_on(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_resident_on(session.opaque_ref, _vgpu); else return XenRef.Create(session.XmlRpcProxy.vgpu_get_resident_on(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Get the scheduled_to_be_resident_on field of the given VGPU. /// First published in XenServer 7.0. /// /// The session /// The opaque_ref of the given vgpu public static XenRef get_scheduled_to_be_resident_on(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_scheduled_to_be_resident_on(session.opaque_ref, _vgpu); else return XenRef.Create(session.XmlRpcProxy.vgpu_get_scheduled_to_be_resident_on(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Get the compatibility_metadata field of the given VGPU. /// First published in XenServer 7.3. /// /// The session /// The opaque_ref of the given vgpu public static Dictionary get_compatibility_metadata(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_compatibility_metadata(session.opaque_ref, _vgpu); else return Maps.convert_from_proxy_string_string(session.XmlRpcProxy.vgpu_get_compatibility_metadata(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Get the extra_args field of the given VGPU. /// First published in Citrix Hypervisor 8.1. /// /// The session /// The opaque_ref of the given vgpu public static string get_extra_args(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_extra_args(session.opaque_ref, _vgpu); else return session.XmlRpcProxy.vgpu_get_extra_args(session.opaque_ref, _vgpu ?? "").parse(); } /// /// Get the PCI field of the given VGPU. /// First published in Citrix Hypervisor 8.1. /// /// The session /// The opaque_ref of the given vgpu public static XenRef get_PCI(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_pci(session.opaque_ref, _vgpu); else return XenRef.Create(session.XmlRpcProxy.vgpu_get_pci(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Set the other_config field of the given VGPU. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu /// New value to set public static void set_other_config(Session session, string _vgpu, Dictionary _other_config) { if (session.JsonRpcClient != null) session.JsonRpcClient.vgpu_set_other_config(session.opaque_ref, _vgpu, _other_config); else session.XmlRpcProxy.vgpu_set_other_config(session.opaque_ref, _vgpu ?? "", Maps.convert_to_proxy_string_string(_other_config)).parse(); } /// /// Add the given key-value pair to the other_config field of the given VGPU. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu /// Key to add /// Value to add public static void add_to_other_config(Session session, string _vgpu, string _key, string _value) { if (session.JsonRpcClient != null) session.JsonRpcClient.vgpu_add_to_other_config(session.opaque_ref, _vgpu, _key, _value); else session.XmlRpcProxy.vgpu_add_to_other_config(session.opaque_ref, _vgpu ?? "", _key ?? "", _value ?? "").parse(); } /// /// Remove the given key and its corresponding value from the other_config field of the given VGPU. If the key is not in that Map, then do nothing. /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu /// Key to remove public static void remove_from_other_config(Session session, string _vgpu, string _key) { if (session.JsonRpcClient != null) session.JsonRpcClient.vgpu_remove_from_other_config(session.opaque_ref, _vgpu, _key); else session.XmlRpcProxy.vgpu_remove_from_other_config(session.opaque_ref, _vgpu ?? "", _key ?? "").parse(); } /// /// Set the extra_args field of the given VGPU. /// First published in Citrix Hypervisor 8.1. /// /// The session /// The opaque_ref of the given vgpu /// New value to set public static void set_extra_args(Session session, string _vgpu, string _extra_args) { if (session.JsonRpcClient != null) session.JsonRpcClient.vgpu_set_extra_args(session.opaque_ref, _vgpu, _extra_args); else session.XmlRpcProxy.vgpu_set_extra_args(session.opaque_ref, _vgpu ?? "", _extra_args ?? "").parse(); } /// /// /// First published in XenServer 6.0. /// /// The session /// /// /// /// public static XenRef create(Session session, string _vm, string _gpu_group, string _device, Dictionary _other_config) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_create(session.opaque_ref, _vm, _gpu_group, _device, _other_config); else return XenRef.Create(session.XmlRpcProxy.vgpu_create(session.opaque_ref, _vm ?? "", _gpu_group ?? "", _device ?? "", Maps.convert_to_proxy_string_string(_other_config)).parse()); } /// /// /// First published in XenServer 6.0. /// /// The session /// /// /// /// public static XenRef async_create(Session session, string _vm, string _gpu_group, string _device, Dictionary _other_config) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_vgpu_create(session.opaque_ref, _vm, _gpu_group, _device, _other_config); else return XenRef.Create(session.XmlRpcProxy.async_vgpu_create(session.opaque_ref, _vm ?? "", _gpu_group ?? "", _device ?? "", Maps.convert_to_proxy_string_string(_other_config)).parse()); } /// /// /// First published in XenServer 6.0. /// /// The session /// /// /// /// /// First published in XenServer 6.2 SP1 Tech-Preview. public static XenRef create(Session session, string _vm, string _gpu_group, string _device, Dictionary _other_config, string _type) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_create(session.opaque_ref, _vm, _gpu_group, _device, _other_config, _type); else return XenRef.Create(session.XmlRpcProxy.vgpu_create(session.opaque_ref, _vm ?? "", _gpu_group ?? "", _device ?? "", Maps.convert_to_proxy_string_string(_other_config), _type ?? "").parse()); } /// /// /// First published in XenServer 6.0. /// /// The session /// /// /// /// /// First published in XenServer 6.2 SP1 Tech-Preview. public static XenRef async_create(Session session, string _vm, string _gpu_group, string _device, Dictionary _other_config, string _type) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_vgpu_create(session.opaque_ref, _vm, _gpu_group, _device, _other_config, _type); else return XenRef.Create(session.XmlRpcProxy.async_vgpu_create(session.opaque_ref, _vm ?? "", _gpu_group ?? "", _device ?? "", Maps.convert_to_proxy_string_string(_other_config), _type ?? "").parse()); } /// /// /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu public static void destroy(Session session, string _vgpu) { if (session.JsonRpcClient != null) session.JsonRpcClient.vgpu_destroy(session.opaque_ref, _vgpu); else session.XmlRpcProxy.vgpu_destroy(session.opaque_ref, _vgpu ?? "").parse(); } /// /// /// First published in XenServer 6.0. /// /// The session /// The opaque_ref of the given vgpu public static XenRef async_destroy(Session session, string _vgpu) { if (session.JsonRpcClient != null) return session.JsonRpcClient.async_vgpu_destroy(session.opaque_ref, _vgpu); else return XenRef.Create(session.XmlRpcProxy.async_vgpu_destroy(session.opaque_ref, _vgpu ?? "").parse()); } /// /// Return a list of all the VGPUs known to the system. /// First published in XenServer 6.0. /// /// The session public static List> get_all(Session session) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_all(session.opaque_ref); else return XenRef.Create(session.XmlRpcProxy.vgpu_get_all(session.opaque_ref).parse()); } /// /// Get all the VGPU Records at once, in a single XML RPC call /// First published in XenServer 6.0. /// /// The session public static Dictionary, VGPU> get_all_records(Session session) { if (session.JsonRpcClient != null) return session.JsonRpcClient.vgpu_get_all_records(session.opaque_ref); else return XenRef.Create(session.XmlRpcProxy.vgpu_get_all_records(session.opaque_ref).parse()); } /// /// Unique identifier/object reference /// public virtual string uuid { get { return _uuid; } set { if (!Helper.AreEqual(value, _uuid)) { _uuid = value; NotifyPropertyChanged("uuid"); } } } private string _uuid = ""; /// /// VM that owns the vGPU /// [JsonConverter(typeof(XenRefConverter))] public virtual XenRef VM { get { return _VM; } set { if (!Helper.AreEqual(value, _VM)) { _VM = value; NotifyPropertyChanged("VM"); } } } private XenRef _VM = new XenRef(Helper.NullOpaqueRef); /// /// GPU group used by the vGPU /// [JsonConverter(typeof(XenRefConverter))] public virtual XenRef GPU_group { get { return _GPU_group; } set { if (!Helper.AreEqual(value, _GPU_group)) { _GPU_group = value; NotifyPropertyChanged("GPU_group"); } } } private XenRef _GPU_group = new XenRef(Helper.NullOpaqueRef); /// /// Order in which the devices are plugged into the VM /// public virtual string device { get { return _device; } set { if (!Helper.AreEqual(value, _device)) { _device = value; NotifyPropertyChanged("device"); } } } private string _device = "0"; /// /// Reflects whether the virtual device is currently connected to a physical device /// public virtual bool currently_attached { get { return _currently_attached; } set { if (!Helper.AreEqual(value, _currently_attached)) { _currently_attached = value; NotifyPropertyChanged("currently_attached"); } } } private bool _currently_attached = false; /// /// Additional configuration /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary other_config { get { return _other_config; } set { if (!Helper.AreEqual(value, _other_config)) { _other_config = value; NotifyPropertyChanged("other_config"); } } } private Dictionary _other_config = new Dictionary() {}; /// /// Preset type for this VGPU /// First published in XenServer 6.2 SP1 Tech-Preview. /// [JsonConverter(typeof(XenRefConverter))] public virtual XenRef type { get { return _type; } set { if (!Helper.AreEqual(value, _type)) { _type = value; NotifyPropertyChanged("type"); } } } private XenRef _type = new XenRef("OpaqueRef:NULL"); /// /// The PGPU on which this VGPU is running /// First published in XenServer 6.2 SP1 Tech-Preview. /// [JsonConverter(typeof(XenRefConverter))] public virtual XenRef resident_on { get { return _resident_on; } set { if (!Helper.AreEqual(value, _resident_on)) { _resident_on = value; NotifyPropertyChanged("resident_on"); } } } private XenRef _resident_on = new XenRef("OpaqueRef:NULL"); /// /// The PGPU on which this VGPU is scheduled to run /// First published in XenServer 7.0. /// [JsonConverter(typeof(XenRefConverter))] public virtual XenRef scheduled_to_be_resident_on { get { return _scheduled_to_be_resident_on; } set { if (!Helper.AreEqual(value, _scheduled_to_be_resident_on)) { _scheduled_to_be_resident_on = value; NotifyPropertyChanged("scheduled_to_be_resident_on"); } } } private XenRef _scheduled_to_be_resident_on = new XenRef("OpaqueRef:NULL"); /// /// VGPU metadata to determine whether a VGPU can migrate between two PGPUs /// First published in XenServer 7.3. /// [JsonConverter(typeof(StringStringMapConverter))] public virtual Dictionary compatibility_metadata { get { return _compatibility_metadata; } set { if (!Helper.AreEqual(value, _compatibility_metadata)) { _compatibility_metadata = value; NotifyPropertyChanged("compatibility_metadata"); } } } private Dictionary _compatibility_metadata = new Dictionary() {}; /// /// Extra arguments for vGPU and passed to demu /// First published in Citrix Hypervisor 8.1. /// public virtual string extra_args { get { return _extra_args; } set { if (!Helper.AreEqual(value, _extra_args)) { _extra_args = value; NotifyPropertyChanged("extra_args"); } } } private string _extra_args = ""; /// /// Device passed trough to VM, either as full device or SR-IOV virtual function /// First published in Citrix Hypervisor 8.1. /// [JsonConverter(typeof(XenRefConverter))] public virtual XenRef PCI { get { return _PCI; } set { if (!Helper.AreEqual(value, _PCI)) { _PCI = value; NotifyPropertyChanged("PCI"); } } } private XenRef _PCI = new XenRef("OpaqueRef:NULL"); } }