mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-12-22 13:45:38 +00:00
libxl: limit support for specifying an interface script
Generally, <interface> ... <script> is only supported for type='ethernet'. Due to the long and pervasive use of <interface type='bridge'> ... <script path='foo'/> </interface> in Xen domain configuration, it was agreed to allow the use of <script> with type='bridge' for backwards compatibility. See the following discussion thread http://www.redhat.com/archives/libvir-list/2013-April/msg00755.html This patch limits the use of <script> to interface types ethernet and bridge, raising an unsupported config error if <script> is specified for all other interface types. While at it, use VIR_ERR_CONFIG_UNSUPPORTED instead of VIR_ERR_INTERNAL_ERROR when reporting unsupported interface types.
This commit is contained in:
parent
bf410bb8eb
commit
2624dfde37
@ -882,6 +882,14 @@ libxlMakeNic(virDomainDefPtr def,
|
||||
* x_nics[i].mtu = 1492;
|
||||
*/
|
||||
|
||||
if (l_nic->script && !(actual_type == VIR_DOMAIN_NET_TYPE_BRIDGE ||
|
||||
actual_type == VIR_DOMAIN_NET_TYPE_ETHERNET)) {
|
||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||
_("specifying a script is only supported with "
|
||||
"interface types bridge and ethernet"));
|
||||
return -1;
|
||||
}
|
||||
|
||||
libxl_device_nic_init(x_nic);
|
||||
|
||||
virMacAddrGetRaw(&l_nic->mac, x_nic->mac);
|
||||
@ -955,8 +963,8 @@ libxlMakeNic(virDomainDefPtr def,
|
||||
case VIR_DOMAIN_NET_TYPE_DIRECT:
|
||||
case VIR_DOMAIN_NET_TYPE_HOSTDEV:
|
||||
case VIR_DOMAIN_NET_TYPE_LAST:
|
||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||
_("libxenlight does not support network device type %s"),
|
||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||
_("unsupported interface type %s"),
|
||||
virDomainNetTypeToString(l_nic->type));
|
||||
return -1;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user