2012-08-12 03:51:30 -04:00
|
|
|
/*
|
2014-02-20 13:59:55 +02:00
|
|
|
* Copyright (C) 2009-2014 Red Hat, Inc.
|
2012-08-12 03:51:30 -04:00
|
|
|
*
|
|
|
|
* 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 16:30:55 -06:00
|
|
|
* License along with this library. If not, see
|
2012-08-12 03:51:30 -04:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Laine Stump <laine@redhat.com>
|
2013-05-23 18:12:10 +01:00
|
|
|
* James Robson <jrobson@websense.com>
|
2012-08-12 03:51:30 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#include "netdev_vlan_conf.h"
|
2012-12-13 18:21:53 +00:00
|
|
|
#include "virerror.h"
|
2012-12-12 18:06:53 +00:00
|
|
|
#include "viralloc.h"
|
2012-08-12 03:51:30 -04:00
|
|
|
|
|
|
|
#define VIR_FROM_THIS VIR_FROM_NONE
|
|
|
|
|
2013-05-23 18:12:10 +01:00
|
|
|
VIR_ENUM_IMPL(virNativeVlanMode, VIR_NATIVE_VLAN_MODE_LAST,
|
|
|
|
"default", "tagged", "untagged")
|
|
|
|
|
2012-08-12 03:51:30 -04:00
|
|
|
int
|
|
|
|
virNetDevVlanParse(xmlNodePtr node, xmlXPathContextPtr ctxt, virNetDevVlanPtr def)
|
|
|
|
{
|
|
|
|
int ret = -1;
|
|
|
|
xmlNodePtr save = ctxt->node;
|
2013-09-03 12:36:22 +01:00
|
|
|
char *trunk = NULL;
|
|
|
|
char *nativeMode = NULL;
|
2012-08-12 03:51:30 -04:00
|
|
|
xmlNodePtr *tagNodes = NULL;
|
Convert 'int i' to 'size_t i' in src/conf/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
int nTags;
|
|
|
|
size_t i;
|
2012-08-12 03:51:30 -04:00
|
|
|
|
|
|
|
ctxt->node = node;
|
|
|
|
|
|
|
|
nTags = virXPathNodeSet("./tag", ctxt, &tagNodes);
|
|
|
|
if (nTags < 0)
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2012-08-12 03:51:30 -04:00
|
|
|
|
|
|
|
if (nTags == 0) {
|
|
|
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
|
|
|
_("missing tag id - each <vlan> must have "
|
|
|
|
"at least one <tag id='n'/> subelement"));
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2012-08-12 03:51:30 -04:00
|
|
|
}
|
|
|
|
|
2013-07-04 12:02:00 +02:00
|
|
|
if (VIR_ALLOC_N(def->tag, nTags) < 0)
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2012-08-12 03:51:30 -04:00
|
|
|
|
2013-05-23 18:12:10 +01:00
|
|
|
def->nativeMode = 0;
|
|
|
|
def->nativeTag = 0;
|
Convert 'int i' to 'size_t i' in src/conf/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
for (i = 0; i < nTags; i++) {
|
2012-08-12 03:51:30 -04:00
|
|
|
unsigned long id;
|
|
|
|
|
Convert 'int i' to 'size_t i' in src/conf/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
ctxt->node = tagNodes[i];
|
2012-08-12 03:51:30 -04:00
|
|
|
if (virXPathULong("string(./@id)", ctxt, &id) < 0) {
|
|
|
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
|
|
|
_("missing or invalid vlan tag id attribute"));
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2012-08-12 03:51:30 -04:00
|
|
|
}
|
|
|
|
if (id > 4095) {
|
|
|
|
virReportError(VIR_ERR_XML_ERROR,
|
|
|
|
_("vlan tag id %lu too large (maximum 4095)"), id);
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2012-08-12 03:51:30 -04:00
|
|
|
}
|
2013-05-23 18:12:10 +01:00
|
|
|
if ((nativeMode = virXPathString("string(./@nativeMode)", ctxt))) {
|
|
|
|
if (def->nativeMode != 0) {
|
|
|
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
|
|
|
_("duplicate native vlan setting"));
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2013-05-23 18:12:10 +01:00
|
|
|
}
|
|
|
|
if ((def->nativeMode
|
|
|
|
= virNativeVlanModeTypeFromString(nativeMode)) <= 0) {
|
2014-01-10 17:41:33 +01:00
|
|
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
2013-05-23 18:12:10 +01:00
|
|
|
_("Invalid \"nativeMode='%s'\" "
|
|
|
|
"in vlan <tag> element"),
|
|
|
|
nativeMode);
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2013-05-23 18:12:10 +01:00
|
|
|
}
|
2013-06-28 12:04:37 -04:00
|
|
|
VIR_FREE(nativeMode);
|
2013-05-23 18:12:10 +01:00
|
|
|
def->nativeTag = id;
|
|
|
|
}
|
Convert 'int i' to 'size_t i' in src/conf/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
def->tag[i] = id;
|
2012-08-12 03:51:30 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
def->nTags = nTags;
|
|
|
|
|
|
|
|
/* now that we know how many tags there are, look for an explicit
|
|
|
|
* trunk setting.
|
|
|
|
*/
|
|
|
|
if (nTags > 1)
|
|
|
|
def->trunk = true;
|
|
|
|
|
|
|
|
ctxt->node = node;
|
|
|
|
if ((trunk = virXPathString("string(./@trunk)", ctxt)) != NULL) {
|
|
|
|
def->trunk = STRCASEEQ(trunk, "yes");
|
|
|
|
if (!def->trunk) {
|
|
|
|
if (nTags > 1) {
|
|
|
|
virReportError(VIR_ERR_XML_ERROR,
|
|
|
|
_("invalid \"trunk='%s'\" in <vlan> - trunk='yes' "
|
|
|
|
"is required for more than one vlan tag"), trunk);
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2012-08-12 03:51:30 -04:00
|
|
|
}
|
2013-05-23 18:12:10 +01:00
|
|
|
if (def->nativeMode != 0) {
|
|
|
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
|
|
|
_("invalid configuration in <vlan> - \"trunk='no'\" is "
|
|
|
|
"not allowed with a native vlan id"));
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2013-05-23 18:12:10 +01:00
|
|
|
}
|
2012-08-12 03:51:30 -04:00
|
|
|
/* allow (but discard) "trunk='no' if there is a single tag */
|
|
|
|
if (STRCASENEQ(trunk, "no")) {
|
|
|
|
virReportError(VIR_ERR_XML_ERROR,
|
|
|
|
_("invalid \"trunk='%s'\" in <vlan> "
|
|
|
|
"- must be yes or no"), trunk);
|
2013-06-28 12:04:37 -04:00
|
|
|
goto cleanup;
|
2012-08-12 03:51:30 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ret = 0;
|
2014-03-25 07:48:31 +01:00
|
|
|
cleanup:
|
2012-08-12 03:51:30 -04:00
|
|
|
ctxt->node = save;
|
|
|
|
VIR_FREE(tagNodes);
|
2013-02-04 09:57:00 -05:00
|
|
|
VIR_FREE(trunk);
|
2013-06-28 12:04:37 -04:00
|
|
|
VIR_FREE(nativeMode);
|
2012-08-12 03:51:30 -04:00
|
|
|
if (ret < 0)
|
|
|
|
virNetDevVlanClear(def);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
maint: avoid 'const fooPtr' in conf
'const fooPtr' is the same as 'foo * const' (the pointer won't
change, but it's contents can). But in general, if an interface
is trying to be const-correct, it should be using 'const foo *'
(the pointer is to data that can't be changed).
Fix up remaining offenders in src/conf, and their fallout.
* src/conf/snapshot_conf.h (virDomainSnapshotAssignDef)
(virDomainSnapshotFindByName): Drop attempt at const.
* src/conf/interface_conf.h (virInterfaceObjIsActive)
(virInterfaceDefFormat): Use intended type.
(virInterfaceFindByMACString, virInterfaceFindByName)
(virInterfaceAssignDef, virInterfaceRemove): Drop attempt at
const.
* src/conf/network_conf.h (virNetworkObjIsActive)
(virNetworkDefFormat, virNetworkDefForwardIf)
(virNetworkDefGetIpByIndex, virNetworkIpDefPrefix)
(virNetworkIpDefNetmask): Use intended type.
(virNetworkFindByUUID, virNetworkFindByName, virNetworkAssignDef)
(virNetworkObjAssignDef, virNetworkRemoveInactive)
(virNetworkBridgeInUse, virNetworkSetBridgeName)
(virNetworkAllocateBridge): Drop attempt at const.
* src/conf/netdev_vlan_conf.h (virNetDevVlanFormat): Make
const-correct.
* src/conf/node_device_conf.h (virNodeDeviceHasCap)
(virNodeDeviceDefFormat): Use intended type.
(virNodeDeviceFindByName, virNodeDeviceFindBySysfsPath)
(virNodeDeviceAssignDef, virNodeDeviceObjRemove)
(virNodeDeviceGetParentHost): Drop attempt at const.
* src/conf/secret_conf.h (virSecretDefFormat): Use intended type.
* src/conf/snapshot_conf.c (virDomainSnapshotAssignDef)
(virDomainSnapshotFindByName): Fix fallout.
* src/conf/interface_conf.c (virInterfaceBridgeDefFormat)
(virInterfaceBondDefFormat, virInterfaceVlanDefFormat)
(virInterfaceProtocolDefFormat, virInterfaceDefDevFormat)
(virInterfaceDefFormat, virInterfaceFindByMACString)
(virInterfaceFindByName, virInterfaceAssignDef)
(virInterfaceRemove): Likewise.
* src/conf/network_conf.c
(VIR_ENUM_IMPL, virNetworkFindByName, virNetworkObjAssignDef)
(virNetworkAssignDef, virNetworkRemoveInactive)
(virNetworkDefGetIpByIndex, virNetworkIpDefPrefix)
(virNetworkIpDefNetmask, virNetworkDHCPHostDefParseXML)
(virNetworkIpDefFormat, virNetworkRouteDefFormat)
(virPortGroupDefFormat, virNetworkForwardNatDefFormat)
(virNetworkDefFormatInternal, virNetworkBridgeInUse)
(virNetworkAllocateBridge, virNetworkSetBridgeName)
(virNetworkDNSDefFormat, virNetworkDefFormat): Likewise.
* src/conf/netdev_vlan_conf.c (virNetDevVlanFormat): Likewise.
* src/conf/node_device_conf.c (virNodeDeviceHasCap)
(virNodeDeviceFindBySysfsPath, virNodeDeviceFindByName)
(virNodeDeviceAssignDef, virNodeDeviceObjRemove)
(virNodeDeviceDefFormat, virNodeDeviceGetParentHost): Likewise.
* src/conf/secret_conf.c (virSecretDefFormatUsage)
(virSecretDefFormat): Likewise.
Signed-off-by: Eric Blake <eblake@redhat.com>
2013-10-08 10:36:37 -06:00
|
|
|
virNetDevVlanFormat(const virNetDevVlan *def, virBufferPtr buf)
|
2012-08-12 03:51:30 -04:00
|
|
|
{
|
Convert 'int i' to 'size_t i' in src/conf/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
size_t i;
|
2012-08-12 03:51:30 -04:00
|
|
|
|
2014-02-20 13:59:55 +02:00
|
|
|
if (!(def && def->nTags))
|
2012-08-12 03:51:30 -04:00
|
|
|
return 0;
|
|
|
|
|
|
|
|
if (!def->tag) {
|
|
|
|
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
|
|
|
_("missing vlan tag data"));
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
virBufferAsprintf(buf, "<vlan%s>\n", def->trunk ? " trunk='yes'" : "");
|
2014-03-06 16:58:56 +02:00
|
|
|
virBufferAdjustIndent(buf, 2);
|
Convert 'int i' to 'size_t i' in src/conf/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
for (i = 0; i < def->nTags; i++) {
|
2013-05-23 18:12:10 +01:00
|
|
|
if (def->nativeMode != VIR_NATIVE_VLAN_MODE_DEFAULT &&
|
Convert 'int i' to 'size_t i' in src/conf/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
def->nativeTag == def->tag[i]) {
|
2013-05-23 18:12:10 +01:00
|
|
|
/* check the nativeMode in case we get <tag id='0'/>*/
|
|
|
|
const char *mode = virNativeVlanModeTypeToString(def->nativeMode);
|
|
|
|
if (!mode) {
|
|
|
|
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
|
|
|
_("Bad value for nativeMode"));
|
|
|
|
}
|
2014-03-06 16:58:56 +02:00
|
|
|
virBufferAsprintf(buf, "<tag id='%u' nativeMode='%s'/>\n",
|
Convert 'int i' to 'size_t i' in src/conf/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
def->tag[i], mode);
|
2013-05-23 18:12:10 +01:00
|
|
|
} else {
|
2014-03-06 16:58:56 +02:00
|
|
|
virBufferAsprintf(buf, "<tag id='%u'/>\n", def->tag[i]);
|
2013-05-23 18:12:10 +01:00
|
|
|
}
|
2012-08-12 03:51:30 -04:00
|
|
|
}
|
2014-03-06 16:58:56 +02:00
|
|
|
virBufferAdjustIndent(buf, -2);
|
2012-08-12 03:51:30 -04:00
|
|
|
virBufferAddLit(buf, "</vlan>\n");
|
|
|
|
return 0;
|
|
|
|
}
|