conf: move virNWFilterBindingDefPtr into its own files

There's no code sharing between virNWFilterDef and
virNWFilterBindingDefPtr types, so it is clearer if they live in
separate source files and headers.

Reviewed-by: John Ferlan <jferlan@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
Daniel P. Berrangé 2018-05-10 14:30:42 +01:00
parent ce376228e9
commit 7c7880dd98
6 changed files with 137 additions and 73 deletions

View File

@ -85,6 +85,8 @@ NWFILTER_CONF_SOURCES = \
conf/nwfilter_conf.h \
conf/virnwfilterobj.c \
conf/virnwfilterobj.h \
conf/virnwfilterbindingdef.c \
conf/virnwfilterbindingdef.h \
$(NULL)
STORAGE_CONF_SOURCES = \

View File

@ -3265,57 +3265,3 @@ virNWFilterRuleIsProtocolEthernet(virNWFilterRuleDefPtr rule)
return true;
return false;
}
void
virNWFilterBindingDefFree(virNWFilterBindingDefPtr def)
{
if (!def)
return;
VIR_FREE(def->ownername);
VIR_FREE(def->portdevname);
VIR_FREE(def->linkdevname);
VIR_FREE(def->filter);
virHashFree(def->filterparams);
VIR_FREE(def);
}
virNWFilterBindingDefPtr
virNWFilterBindingDefCopy(virNWFilterBindingDefPtr src)
{
virNWFilterBindingDefPtr ret;
if (VIR_ALLOC(ret) < 0)
return NULL;
if (VIR_STRDUP(ret->ownername, src->ownername) < 0)
goto error;
memcpy(ret->owneruuid, src->owneruuid, sizeof(ret->owneruuid));
if (VIR_STRDUP(ret->portdevname, src->portdevname) < 0)
goto error;
if (VIR_STRDUP(ret->linkdevname, src->linkdevname) < 0)
goto error;
ret->mac = src->mac;
if (VIR_STRDUP(ret->filter, src->filter) < 0)
goto error;
if (!(ret->filterparams = virNWFilterHashTableCreate(0)))
goto error;
if (virNWFilterHashTablePutAll(src->filterparams, ret->filterparams) < 0)
goto error;
return ret;
error:
virNWFilterBindingDefFree(ret);
return NULL;
}

View File

@ -545,19 +545,6 @@ struct _virNWFilterDef {
virNWFilterEntryPtr *filterEntries;
};
typedef struct _virNWFilterBindingDef virNWFilterBindingDef;
typedef virNWFilterBindingDef *virNWFilterBindingDefPtr;
struct _virNWFilterBindingDef {
char *ownername;
unsigned char owneruuid[VIR_UUID_BUFLEN];
char *portdevname;
char *linkdevname;
virMacAddr mac;
char *filter;
virHashTablePtr filterparams;
};
typedef enum {
STEP_APPLY_NEW,
@ -663,10 +650,6 @@ virNWFilterRuleIsProtocolIPv6(virNWFilterRuleDefPtr rule);
bool
virNWFilterRuleIsProtocolEthernet(virNWFilterRuleDefPtr rule);
void
virNWFilterBindingDefFree(virNWFilterBindingDefPtr binding);
virNWFilterBindingDefPtr
virNWFilterBindingDefCopy(virNWFilterBindingDefPtr src);
VIR_ENUM_DECL(virNWFilterRuleAction);
VIR_ENUM_DECL(virNWFilterRuleDirection);

View File

@ -0,0 +1,83 @@
/*
* virnwfilterbindingdef.c: network filter binding XML processing
*
* Copyright (C) 2018 Red Hat, 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, see
* <http://www.gnu.org/licenses/>.
*/
#include <config.h>
#include "viralloc.h"
#include "virerror.h"
#include "virstring.h"
#include "nwfilter_params.h"
#include "virnwfilterbindingdef.h"
#define VIR_FROM_THIS VIR_FROM_NWFILTER
void
virNWFilterBindingDefFree(virNWFilterBindingDefPtr def)
{
if (!def)
return;
VIR_FREE(def->ownername);
VIR_FREE(def->portdevname);
VIR_FREE(def->linkdevname);
VIR_FREE(def->filter);
virHashFree(def->filterparams);
VIR_FREE(def);
}
virNWFilterBindingDefPtr
virNWFilterBindingDefCopy(virNWFilterBindingDefPtr src)
{
virNWFilterBindingDefPtr ret;
if (VIR_ALLOC(ret) < 0)
return NULL;
if (VIR_STRDUP(ret->ownername, src->ownername) < 0)
goto error;
memcpy(ret->owneruuid, src->owneruuid, sizeof(ret->owneruuid));
if (VIR_STRDUP(ret->portdevname, src->portdevname) < 0)
goto error;
if (VIR_STRDUP(ret->linkdevname, src->linkdevname) < 0)
goto error;
ret->mac = src->mac;
if (VIR_STRDUP(ret->filter, src->filter) < 0)
goto error;
if (!(ret->filterparams = virNWFilterHashTableCreate(0)))
goto error;
if (virNWFilterHashTablePutAll(src->filterparams, ret->filterparams) < 0)
goto error;
return ret;
error:
virNWFilterBindingDefFree(ret);
return NULL;
}

View File

@ -0,0 +1,47 @@
/*
* virnwfilterbindingdef.h: network filter binding XML processing
*
* Copyright (C) 2018 Red Hat, 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, see
* <http://www.gnu.org/licenses/>.
*
*/
#ifndef VIR_NWFILTER_BINDING_DEF_H
# define VIR_NWFILTER_BINDING_DEF_H
# include "internal.h"
# include "virmacaddr.h"
# include "virhash.h"
typedef struct _virNWFilterBindingDef virNWFilterBindingDef;
typedef virNWFilterBindingDef *virNWFilterBindingDefPtr;
struct _virNWFilterBindingDef {
char *ownername;
unsigned char owneruuid[VIR_UUID_BUFLEN];
char *portdevname;
char *linkdevname;
virMacAddr mac;
char *filter;
virHashTablePtr filterparams;
};
void
virNWFilterBindingDefFree(virNWFilterBindingDefPtr binding);
virNWFilterBindingDefPtr
virNWFilterBindingDefCopy(virNWFilterBindingDefPtr src);
#endif /* VIR_NWFILTER_BINDING_DEF_H */

View File

@ -787,8 +787,6 @@ virDomainNumatuneSpecifiedMaxNode;
# conf/nwfilter_conf.h
virNWFilterBindingDefCopy;
virNWFilterBindingDefFree;
virNWFilterCallbackDriversLock;
virNWFilterCallbackDriversUnlock;
virNWFilterChainSuffixTypeToString;
@ -1049,6 +1047,11 @@ virNodeDeviceObjListNumOfDevices;
virNodeDeviceObjListRemove;
# conf/virnwfilterbindingdef.h
virNWFilterBindingDefCopy;
virNWFilterBindingDefFree;
# conf/virnwfilterobj.h
virNWFilterObjGetDef;
virNWFilterObjGetNewDef;